|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:, |2 u( x1 o- f2 `! _
PCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。
" h8 z8 n! c8 b9 ^0 d6 Y如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。1 Q* r9 I/ }( o7 R% u
5 k e# s" r: V+ m7 D
bini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。
5 m& n, v0 C7 x. Y8 f& n& u& Q4 g5 g b$ a# J+ u9 K
REFF:[我所知道的BIOS->PCISCAN]) m/ l3 u; z! ~. F
[Practice] , N! s! @; z0 E6 M# A3 \- D- {
假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read). 9 P( H4 n ^& R+ u, P
; A/ Z. E0 V$ n9 u+ E
但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?
# u- l, l; D% Q* ^" N3 ?-----------------9 a# X L) ~; E1 f0 T4 V) x; g
Ans:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...
4 ]" y" \- Z6 ~% \: F: ^! u( ?( n$ O) M
在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !$ p8 R. E- v2 v0 d
4 q Q- F7 g2 q5 z8 S
所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|