|
|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:. b5 Q. Y8 i% m0 Z
PCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。, V J9 D) g- O7 D6 n1 e% G
如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。' b0 H9 i( I1 \* j7 q4 i" G( F
1 L" G( A2 x2 |) D
bini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。
/ j5 p1 E5 l- o8 m& t4 ^1 a) @; ?& Q* X) b0 p1 E( Q' @
REFF:[我所知道的BIOS->PCISCAN]
. d* Y0 j: E( M8 @# b, m7 A1 t5 d[Practice]
, k5 ?$ U p3 F9 U; f假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read). " M: U6 w6 x) z8 r8 X) \! p7 {" T& c2 j
& A9 W# l# a6 a. A# q/ c
但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?& U8 |0 H% @& H1 P2 j+ J% e
-----------------9 g- z' X7 D- R* |# Y0 D5 n
Ans:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...1 `3 H4 d/ o- ~( n! z4 f
7 G, `0 G! @. W2 H在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !
, M' q/ [; L& |
& N$ W9 P0 @3 k6 P1 z所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|