[SLOF] [PATCH v3] pci: force minimum mem bar alignment of 64K for board-qemu

Michael Roth mdroth at linux.vnet.ibm.com
Wed Mar 8 18:53:36 AEDT 2017


This is needed to ensure VFIO passthrough devices are able to
offload MMIO accesses to KVM.

Cc: Segher Boessenkool <segher at kernel.crashing.org>
Cc: Nikunj A Dadhania <nikunj at linux.vnet.ibm.com>
Cc: David Gibson <david at gibson.dropbear.id.au>
Signed-off-by: Michael Roth <mdroth at linux.vnet.ibm.com>
---
v3:
  * default to 64K, and plan to move BAR assignment to QEMU to avoid
    needing to use property to maintain older behavior (Alexey)
v2:
  * default to 0 min-align instead of 64K (David)
---
 board-qemu/slof/pci-phb.fs |  6 ++++++
 slof/engine.in             |  1 +
 slof/fs/pci-properties.fs  | 38 ++++++++++++++++++++++++++++++--------
 slof/fs/pci-scan.fs        |  3 +++
 4 files changed, 40 insertions(+), 8 deletions(-)

diff --git a/board-qemu/slof/pci-phb.fs b/board-qemu/slof/pci-phb.fs
index 667514e..fc2341c 100644
--- a/board-qemu/slof/pci-phb.fs
+++ b/board-qemu/slof/pci-phb.fs
@@ -331,6 +331,12 @@ setup-puid
    my-puid TO puid                  \ Set current puid
    phb-parse-ranges
    1 TO pci-hotplug-enabled
+   s" qemu,mem-bar-min-align" get-node get-property 0= IF
+       decode-int TO pci-mem-bar-min-align
+       2drop
+   ELSE
+       10000 TO pci-mem-bar-min-align
+   THEN
    s" qemu,phb-enumerated" get-node get-property 0<> IF
        1 0 (probe-pci-host-bridge)
    ELSE
diff --git a/slof/engine.in b/slof/engine.in
index 0344a38..549e409 100644
--- a/slof/engine.in
+++ b/slof/engine.in
@@ -145,6 +145,7 @@ col(D2/ >R U2/ R@ LIT(8*CELLSIZE-1) LSHIFT OR R> 2/)
 col(NEGATE 0 SWAP -)
 col(ABS DUP 0< 0BRANCH(1) NEGATE)
 col(MAX 2DUP < 0BRANCH(1) SWAP DROP)
+col(UMAX 2DUP U< 0BRANCH(1) SWAP DROP)
 col(MIN 2DUP > 0BRANCH(1) SWAP DROP)
 col(U* *)
 col(1+ 1 +)
diff --git a/slof/fs/pci-properties.fs b/slof/fs/pci-properties.fs
index 7faa714..e6fd843 100644
--- a/slof/fs/pci-properties.fs
+++ b/slof/fs/pci-properties.fs
@@ -91,17 +91,37 @@
 \ ***************************************************************************************
 \ align the current mem and set var to next mem
 \ align with a size of 0 returns 0 !!!
-: assign-var ( size var -- al-mem )
-        2dup @                          \ ( size var size cur-mem ) read current free mem
-        swap #aligned                   \ ( size var al-mem )       align the mem to the size
-        dup 2swap -rot +                \ ( al-mem var new-mem )    add size to aligned mem
-        swap !                          \ ( al-mem )                set variable to new mem
+: assign-var-align ( size align var -- al-mem )
+        dup >r @                        \ ( size align cur-mem )
+        swap #aligned                   \ ( size al-mem )
+        tuck +                          \ ( al-mem new-mem )
+        r> !                            \ ( al-mem )
+;
+
+: assign-var-min-align ( size min-align var -- al-mem )
+        >r over umax                    \ ( size align )
+        r> assign-var-align             \ ( al-mem )
 ;
 
 \ set bar to current free mem ( in variable ) and set variable to next free mem
 : assign-bar-value32 ( bar size var -- 4 )
         over IF                         \ IF size > 0
-                assign-var              \ | ( bar al-mem ) set variable to next mem
+                >r                      \ | ( bar size )
+                pci-mem-bar-min-align   \ | ( bar size min-align )
+                r> assign-var-min-align \ | ( bar al-mem ) set variable to next mem
+                swap rtas-config-l!     \ | ( -- )         set the bar to al-mem
+        ELSE                            \ ELSE
+                2drop drop              \ | clear stack
+        THEN                            \ FI
+        4                               \ size of the base-address-register
+;
+
+\ set bar to current free mem ( in variable ) and set variable to next free mem
+: assign-io-bar-value32 ( bar size var -- 4 )
+        over IF                         \ IF size > 0
+                >r                      \ | ( bar size )
+                dup                     \ | ( bar size size-align )
+                r> assign-var-align     \ | ( bar al-mem ) set variable to next mem
                 swap rtas-config-l!     \ | ( -- )         set the bar to al-mem
         ELSE                            \ ELSE
                 2drop drop              \ | clear stack
@@ -112,7 +132,9 @@
 \ set bar to current free mem ( in variable ) and set variable to next free mem
 : assign-bar-value64 ( bar size var -- 8 )
         over IF                         \ IF size > 0
-                assign-var              \ | ( bar al-mem ) set variable to next mem
+                >r                      \ | ( bar size )
+                pci-mem-bar-min-align   \ | ( bar size min-align )
+                r> assign-var-min-align \ | ( bar al-mem ) set variable to next mem
                 swap                    \ | ( al-mem addr ) calc config-addr of this bar
                 2dup rtas-config-l!     \ | ( al-mem addr ) set the Lower part of the bar to al-mem
                 4 + swap 20 rshift      \ | ( al-mem>>32 addr ) prepare the upper part of the al-mem
@@ -163,7 +185,7 @@
 : assign-io-bar ( bar-addr -- 4 )
         dup pci-bar-size-io             \ fetch size
         pci-next-io                     \ var to change
-        assign-bar-value32              \ and set it all
+        assign-io-bar-value32           \ and set it all
 ;
 
 \ Setup an Expansion ROM bar
diff --git a/slof/fs/pci-scan.fs b/slof/fs/pci-scan.fs
index a528c8e..bd8cc0d 100644
--- a/slof/fs/pci-scan.fs
+++ b/slof/fs/pci-scan.fs
@@ -24,6 +24,9 @@ VARIABLE pci-max-io
 VARIABLE pci-next-mem64           \ prefetchable 64-bit memory mapped
 VARIABLE pci-max-mem64
 
+\ 0 to default to natural alignment
+0 VALUE pci-mem-bar-min-align
+
 \ Counter of busses found
 0 VALUE pci-bus-number
 \ Counter of devices found
-- 
2.7.4



More information about the SLOF mailing list