|
|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:
X1 A b$ B W8 E. y2 Q+ ?1 pPCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。
$ s6 @$ W% D' O6 q( Z如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。0 j# ~" _4 k# K; }5 I+ V& J5 ]
% q' j( M- O' _% U! J! g. ~( N
bini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。 V2 }( \) l, |" ^) R
k- n& q2 f; U; O0 CREFF:[我所知道的BIOS->PCISCAN]
& H; P2 j# Y! m/ b& a" ?+ t; P2 b[Practice]
- A k' D$ }4 c/ P4 P. m) |假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read). " E; D2 \* [( {7 m* U
3 H! N/ S1 N {2 g
但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?. k8 g# l, k6 z4 h" V
-----------------: x9 d2 h6 E- X7 b
Ans:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...
% a; ^ F0 U5 V+ B; X3 o/ ^: R
: M! i! N/ O/ Q! |3 E3 Q; B3 p在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !
8 N; o- g5 [% Y- D( h2 H, W+ v" m) {/ x, A! }& P- d8 Y9 s
所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|