summaryrefslogtreecommitdiffstats
path: root/qemu/roms/SLOF/slof/fs/pci-scan.fs
diff options
context:
space:
mode:
Diffstat (limited to 'qemu/roms/SLOF/slof/fs/pci-scan.fs')
-rw-r--r--qemu/roms/SLOF/slof/fs/pci-scan.fs351
1 files changed, 0 insertions, 351 deletions
diff --git a/qemu/roms/SLOF/slof/fs/pci-scan.fs b/qemu/roms/SLOF/slof/fs/pci-scan.fs
deleted file mode 100644
index 2fdf0e8f5..000000000
--- a/qemu/roms/SLOF/slof/fs/pci-scan.fs
+++ /dev/null
@@ -1,351 +0,0 @@
-\ *****************************************************************************
-\ * Copyright (c) 2004, 2008 IBM Corporation
-\ * All rights reserved.
-\ * This program and the accompanying materials
-\ * are made available under the terms of the BSD License
-\ * which accompanies this distribution, and is available at
-\ * http://www.opensource.org/licenses/bsd-license.php
-\ *
-\ * Contributors:
-\ * IBM Corporation - initial implementation
-\ ****************************************************************************/
-
-\ ----------------------------------------------------------
-\ ********** Variables to be set by host bridge **********
-\ ----------------------------------------------------------
-
-\ Values of the next free memory area
-VARIABLE pci-next-mem \ prefetchable memory mapped
-VARIABLE pci-max-mem
-VARIABLE pci-next-mmio \ non-prefetchable memory
-VARIABLE pci-max-mmio
-VARIABLE pci-next-io \ I/O space
-VARIABLE pci-max-io
-VARIABLE pci-next-mem64 \ prefetchable 64-bit memory mapped
-VARIABLE pci-max-mem64
-
-\ Counter of busses found
-0 VALUE pci-bus-number
-\ Counter of devices found
-0 VALUE pci-device-number
-\ bit field of devices plugged into this bridge
-0 VALUE pci-device-slots
-\ byte field holding the device-slot number vector of the current device
-\ the vector can be as deep as the max depth of bridges possible
-\ 3,4,5 means
-\ the 5th slot on the bus of the bridge in
-\ the 4th slot on the bus of the bridge in
-\ the 3rd slot on the HostBridge bus
-here 100 allot CONSTANT pci-device-vec
-0 VALUE pci-device-vec-len
-\ enable/disable creation of hotplug-specific properties
-0 VALUE pci-hotplug-enabled
-
-
-\ Fixme Glue to the pci-devices ... remove this later
-: next-pci-mem ( addr -- addr ) pci-next-mem ;
-: next-pci-mmio ( addr -- addr ) pci-next-mmio ;
-: next-pci-io ( addr -- addr ) pci-next-io ;
-
-
-#include "pci-helper.fs"
-
-\ Dump out the pci device-slot vector
-: pci-vec ( -- )
- cr s" device-vec(" type
- pci-device-vec-len dup 2 0.r s" ):" type
- 1+ 0 DO
- pci-device-vec i + c@
- space 2 0.r
- LOOP
- cr
-;
-
-\ prints out all relevant pci variables
-: pci-var-out ( -- )
- s" mem:" type pci-next-mem @ 16 0.r cr
- s" mmio:" type pci-next-mmio @ 16 0.r cr
- s" io:" type pci-next-io @ 16 0.r cr
-;
-
-
-\ Update the device-slot number vector
-\ Set the bit of the DeviceSlot in the Slot array
-: pci-set-slot ( addr -- )
- pci-addr2dev dup \ calc slot number
- pci-device-vec-len \ the end of the vector
- pci-device-vec + c! \ and update the vector
- 80000000 swap rshift \ calc bit position of the device slot
- pci-device-slots or \ set this bit
- TO pci-device-slots \ and write it back
-;
-
-\ Update pci-next-mmio to be 1MB aligned and set the mmio-base register
-\ and set the Limit register to the maximum available address space
-\ needed for scanning possible devices behind the bridge
-: pci-bridge-set-mmio-base ( addr -- )
- pci-next-mmio @ 100000 #aligned \ read the current Value and align to 1MB boundary
- dup 100000 + pci-next-mmio ! \ and write back with 1MB for bridge
- 10 rshift \ mmio-base reg is only the upper 16 bits
- pci-max-mmio @ 1- FFFF0000 and or \ and Insert mmio Limit (set it to max)
- swap 20 + rtas-config-l! \ and write it into the bridge
-;
-
-\ Update pci-next-mmio to be 1MB aligned and set the mmio-limit register
-\ The Limit Value is one less then the upper boundary
-\ If the limit is less than the base the mmio is disabled
-: pci-bridge-set-mmio-limit ( addr -- )
- pci-next-mmio @ 100000 #aligned \ fetch current value and align to 1MB
- dup pci-next-mmio ! \ and write it back
- 1- FFFF0000 and \ make it one less and keep upper 16 bits
- over 20 + rtas-config-l@ 0000FFFF and \ fetch original value
- or swap 20 + rtas-config-l! \ and write it into the Reg
-;
-
-\ Update pci-next-mem to be 1MB aligned and set the mem-base and mem-base-upper register
-\ and set the Limit register to the maximum available address space
-\ needed for scanning possible devices behind the bridge
-: pci-bridge-set-mem-base ( addr -- )
- pci-next-mem @ 100000 #aligned \ read the current Value and align to 1MB boundary
- 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
- pci-next-mem64 @ 100000000 #aligned \ | read the current Value of 64-bit and align to 4GB boundary
- 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)
- swap 24 + rtas-config-l! \ and write it into the bridge
-;
-
-\ Update pci-next-mem to be 1MB aligned and set the mem-limit register
-\ The Limit Value is one less then the upper boundary
-\ If the limit is less than the base the mem is disabled
-: pci-bridge-set-mem-limit ( addr -- )
- pci-next-mem @ 100000 #aligned \ read the current Value and align to 1MB boundary
- dup pci-next-mem ! \ and write it back
- 1- \ make limit one less than boundary
- over 24 + rtas-config-w@ \ check if 64bit support
- 1 and IF \ IF 64 bit support
- pci-next-mem64 @ 100000000 #aligned \ | Reat current value of 64-bar and align at 4GB
- 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
- or swap 24 + rtas-config-l! \ and write it into the bridge
-;
-
-\ Update pci-next-io to be 4KB aligned and set the io-base and io-base-upper register
-\ and set the Limit register to the maximum available address space
-\ needed for scanning possible devices behind the bridge
-: pci-bridge-set-io-base ( addr -- )
- pci-next-io @ 1000 #aligned \ read the current Value and align to 4KB boundary
- dup 1000 + pci-next-io ! \ and write back with 4K for bridge
- over 1C + rtas-config-l@ \ check if 32bit support
- 1 and IF \ IF 32 bit support
- 2dup 10 rshift \ | keep upper 16 bits
- pci-max-io @ FFFF0000 and or \ | insert upper 16 bits of Max-Limit
- swap 30 + rtas-config-l! \ | and write it into the Base-Upper16-bits
- THEN \ FI
- 8 rshift 000000FF and \ keep upper 8 bits
- pci-max-io @ 1- 0000FF00 and or \ insert upper 8 bits of Max-Limit
- over rtas-config-l@ FFFF0000 and \ fetch original Value
- or swap 1C + rtas-config-l! \ and write it into the bridge
-;
-
-\ Update pci-next-io to be 4KB aligned and set the io-limit register
-\ The Limit Value is one less then the upper boundary
-\ If the limit is less than the base the io is disabled
-: pci-bridge-set-io-limit ( addr -- )
- pci-next-io @ 1000 #aligned \ read the current Value and align to 4KB boundary
- dup pci-next-io ! \ and write it back
- 1- \ make limit one less than boundary
- over 1D + rtas-config-b@ \ check if 32bit support
- 1 and IF \ IF 32 bit support
- 2dup FFFF0000 and \ | keep upper 16 bits
- over 30 + rtas-config-l@ \ | fetch original Value
- or swap 30 + rtas-config-l! \ | and write it into the Limit-Upper16-bits
- THEN \ FI
- 0000FF00 and \ keep upper 8 bits
- over 1C + rtas-config-l@ FFFF00FF and \ fetch original Value
- or swap 1C + rtas-config-l! \ and write it into the bridge
-;
-
-\ set up all base registers to the current variable Values
-: pci-bridge-set-bases ( addr -- )
- dup pci-bridge-set-mmio-base
- dup pci-bridge-set-mem-base
- pci-bridge-set-io-base
-;
-
-\ set up all limit registers to the current variable Values
-: pci-bridge-set-limits ( addr -- )
- dup pci-bridge-set-mmio-limit
- dup pci-bridge-set-mem-limit
- pci-bridge-set-io-limit
-;
-
-\ ----------------------------------------------------------
-\ ****************** PCI Scan functions ******************
-\ ----------------------------------------------------------
-
-\ define function pointer as forward declaration of pci-probe-bus
-DEFER func-pci-probe-bus
-DEFER func-pci-bridge-range-props
-
-\ Setup the Base and Limits in the Bridge
-\ and scan the bus(es) beyond that Bridge
-: pci-bridge-probe ( addr -- )
- dup pci-bridge-set-bases \ SetUp all Base Registers
- dup func-pci-bridge-range-props \ Setup temporary "range
- pci-bus-number 1+ TO pci-bus-number \ increase number of busses found
- pci-device-vec-len 1+ TO pci-device-vec-len \ increase the device-slot vector depth
- dup \ stack config-addr for pci-bus!
- FF swap \ Subordinate Bus Number ( for now to max to open all subbusses )
- pci-bus-number swap \ Secondary Bus Number ( the new busnumber )
- dup pci-addr2bus swap \ Primary Bus Number ( the current bus )
- pci-bus! \ and set them into the bridge
- pci-enable \ enable mem/IO transactions
- dup pci-bus-scnd@ func-pci-probe-bus \ and probe the secondary bus
- dup pci-bus-number swap pci-bus-subo! \ set SubOrdinate Bus Number to current number of busses
- pci-device-vec-len 1- TO pci-device-vec-len \ decrease the device-slot vector depth
- dup pci-bridge-set-limits \ SetUp all Limit Registers
- drop \ forget the config-addr
-;
-
-\ set up the pci-device
-: pci-device-setup ( addr -- )
- drop \ since the config-addr is coded in my-space, drop it here
- s" pci-device.fs" included \ and setup the device as node in the device tree
-;
-
-\ set up the pci bridge
-: pci-bridge-setup ( addr -- )
- drop \ since the config-addr is coded in my-space, drop it here
- s" pci-bridge.fs" included \ and setup the bridge as node in the device tree
-;
-
-\ add the new found device/bridge to the device tree and set it up
-: pci-add-device ( addr -- )
- new-device \ create a new device-tree node
- dup set-space \ set the config addr for this device tree entry
- dup pci-set-slot \ set the slot bit
- dup pci-htype@ \ read HEADER-Type
- 7f and \ Mask bit 7 - multifunction device
- CASE
- 0 OF pci-device-setup ENDOF \ | set up the device
- 1 OF pci-bridge-setup ENDOF \ | set up the bridge
- dup OF dup pci-htype@ pci-out ENDOF
- ENDCASE
- finish-device \ and close the device-tree node
-;
-
-\ check for multifunction and for each function
-\ (dependig from header type) call device or bridge setup
-: pci-setup-device ( addr -- )
- dup pci-htype@ \ read HEADER-Type
- 80 and IF 8 ELSE 1 THEN \ check for multifunction
- 0 DO \ LOOP over all possible functions (either 8 or only 1)
- dup
- i 8 lshift + \ calc device-function-config-addr
- dup pci-vendor@ \ check if valid function
- FFFF = IF
- drop \ non-valid so forget the address
- ELSE
- pci-device-number 1+ \ increase the number of devices
- TO pci-device-number \ and store it
- pci-add-device \ and add the device to the device tree and set it up
- THEN
- LOOP \ next function
- drop \ forget the device-addr
-;
-
-\ check if a device is plugged into this bus at this device number
-: pci-probe-device ( busnr devicenr -- )
- pci-bus2addr \ calc pci-address
- dup pci-vendor@ \ fetch Vendor-ID
- FFFF = IF \ check if valid
- drop \ if not forget it
- ELSE
- pci-setup-device \ if valid setup the device
- THEN
-;
-
-\ walk through all 32 possible pci devices on this bus and probe them
-: pci-probe-bus ( busnr -- )
- 0 TO pci-device-slots \ reset slot array to unpoppulated
- 20 0 DO
- dup
- i pci-probe-device
- LOOP
- drop
-;
-
-\ setup the function pointer used in pci-bridge-setup
-' pci-probe-bus TO func-pci-probe-bus
-
-\ ----------------------------------------------------------
-\ ****************** System functions ********************
-\ ----------------------------------------------------------
-\ Setup the whole system for pci devices
-\ start with the bus-min and try all busses
-\ until at least 1 device was found
-\ ( needed for HostBridges that don't start with Bus 0 )
-: pci-probe-all ( bus-max bus-min -- ) \ Check all busses from bus-min up to bus-max if needed
- 0 TO pci-device-vec-len \ reset the device-slot vector
- DO
- i TO pci-bus-number \ set current Busnumber
- 0 TO pci-device-number \ reset Device Number
- pci-bus-number pci-probe-bus \ and probe this bus
- pci-device-number 0 > IF LEAVE THEN \ if we found a device we're done
- LOOP \ else next bus
-;
-
-: (probe-pci-host-bridge) ( bus-max bus-min -- )
- 0d emit ." Adapters on " puid 10 0.r cr \ print the puid we're looking at
- ( bus-max bus-min ) pci-probe-all \ and walk the bus
- pci-device-number 0= IF \ IF no devices found
- 15 spaces \ | indent the output
- ." None" cr \ | tell the world our result
- THEN \ FI
-;
-
-\ probe the hostbridge that is specified in my-puid
-\ for the mmio mem and io addresses:
-\ base is the least available address
-\ max is the highest available address
-: probe-pci-host-bridge ( bus-max bus-min mmio-max mmio-base mem-max mem-base io-max io-base my-puid -- )
- puid >r TO puid \ save puid and set the new
- pci-next-io ! \ save the next io-base address
- pci-max-io ! \ save the max io-space address
- pci-next-mem ! \ save the next mem-base address
- pci-max-mem ! \ save the max mem-space address
- pci-next-mmio ! \ save the next mmio-base address
- pci-max-mmio ! \ save the max mmio-space address
- (probe-pci-host-bridge)
- r> TO puid \ restore puid
-;
-
-\ provide the device-alias definition words
-#include <pci-aliases.fs>
-
-\ provide all words for the interrupts settings
-#include <pci-interrupts.fs>
-
-\ provide all words for the pci capabilities init
-#include <pci-capabilities.fs>
-
-\ provide all words needed to generate the properties and/or assign BAR values
-#include "pci-properties.fs"
-
-\ setup the function pointer for bridge ranges
-' pci-bridge-range-props TO func-pci-bridge-range-props