[SLOF] [PATCH] pci-scan: program 64-bit mem bar range in pci-bridge bar

Alexey Kardashevskiy aik at ozlabs.ru
Fri Oct 9 16:50:56 AEDT 2015


On 10/08/2015 10:01 PM, Nikunj A Dadhania wrote:
> If the devices beyond the bridge requests 64-bit mem
> current code does not correctly program the bridge range properties.
>
> 64-bit prefetchable memory region is tracked by
> pci-[next,max]-mem64. Use these to program the
> pci bridge range registers.
>
> Signed-off-by: Nikunj A Dadhania <nikunj at linux.vnet.ibm.com>
> ---
>   slof/fs/pci-scan.fs | 19 +++++++++++++------
>   1 file changed, 13 insertions(+), 6 deletions(-)
>
> diff --git a/slof/fs/pci-scan.fs b/slof/fs/pci-scan.fs
> index b8b9fe6..0b221b6 100644
> --- a/slof/fs/pci-scan.fs
> +++ b/slof/fs/pci-scan.fs
> @@ -110,10 +110,13 @@ here 100 allot CONSTANT pci-device-vec
>           dup 100000 + pci-next-mem !             \ and write back with 1MB for bridge
>           over 24 + rtas-config-w@                \ check if 64bit support
>           1 and IF                                \ IF 64 bit support
> -                2dup 20 rshift                  \ | keep upper 32 bits
> -                swap 28 + rtas-config-l!        \ | and write it into the Base-Upper32-bits
> -                pci-max-mem @ 20 rshift         \ | fetch max Limit address and keep upper 32 bits
> -                2 pick 2C + rtas-config-l!      \ | and set the Limit
> +                pci-next-mem64 @ 100000000 #aligned \ | read the current Value of 64-bit and align to 1GB boundary


100000000 != 1GB, it is 4GB. Or you want it to be 1GB, if so, then why?


> +                dup 100000000 + pci-next-mem64 x!   \ | and write back with 1GB for bridge
> +                2 pick swap                         \ |
> +                20 rshift                           \ | keep upper 32 bits
> +                swap 28 + rtas-config-l!            \ | and write it into the Base-Upper32-bits
> +                pci-max-mem64 @ 20 rshift           \ | fetch max Limit address and keep upper 32 bits
> +                2 pick 2C + rtas-config-l!          \ | and set the Limit
>           THEN                                    \ FI
>           10 rshift                               \ keep upper 16 bits
>           pci-max-mem @ 1- FFFF0000 and or        \ and Insert mmem Limit (set it to max)
> @@ -129,8 +132,12 @@ here 100 allot CONSTANT pci-device-vec
>           1-                                      \ make limit one less than boundary
>           over 24 + rtas-config-w@                \ check if 64bit support
>           1 and IF                                \ IF 64 bit support
> -                2dup 20 rshift                  \ | keep upper 32 bits
> -                swap 2C + rtas-config-l!        \ | and write it into the Limit-Upper32-bits
> +                pci-next-mem64 @ 100000000 #aligned \ | Reat current value of 64-bar and align at 1GB
> +                dup pci-next-mem64 x!               \ | and write it back
> +                1-                                  \ | make limite one less than boundary
> +                2 pick swap                         \ |
> +                20 rshift                           \ | keep upper 32 bits
> +                swap 2C + rtas-config-l!            \ | and write it into the Limit-Upper32-bits
>           THEN                                    \ FI
>           FFFF0000 and                            \ keep upper 16 bits
>           over 24 + rtas-config-l@ 0000FFFF and   \ fetch original Value
>


-- 
Alexey


More information about the SLOF mailing list