|
|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:
) u$ `4 P( M: N8 O: F0 ePCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。" Y _7 K" n0 f# c. @
如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。1 o/ r( M% D5 l R- a
0 z3 C ~0 m6 q5 h+ a
bini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。4 e7 t5 K; }) i8 u3 J# x4 K0 M
9 r8 n% H& ` ~! I
REFF:[我所知道的BIOS->PCISCAN]
# o* z5 D, j9 @( x! i7 w: [$ d4 {; j. Z' L[Practice]
+ R" @% U6 ^" f. t假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read). 4 d+ z x j) ^0 f; F3 Z4 D
* d: x! a; p- p: l; |
但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?
& p& z: ?6 @2 Z$ [& z# |, J-----------------
2 E7 |. k1 ~3 ~" V. oAns:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...
+ X* _" S, t$ G1 J- L3 i: Z
" K3 V6 Q8 m% t) G% V o/ }/ }在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !; }+ s8 P5 u! p. v5 {! `
2 N' P5 B/ u g5 J
所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|