|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:: z1 B. G: }$ G4 C
PCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。
: o) a: H4 V7 U0 t+ H. E如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。; O0 T' J% X% _4 Z) q8 I
5 r* M0 F6 k1 N6 ebini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。
, {* z% n# Q8 W! c+ I% F" ^* _
REFF:[我所知道的BIOS->PCISCAN]
9 c; p, H6 W+ ^5 ][Practice]
2 X. B5 i1 o1 v9 m( [# W+ {5 b( l假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read). 4 H& Y) {3 A* E5 C) b; H2 |3 }
+ {# B) m: U& }0 U* z, D但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?
/ \8 _# I6 U# O! S-----------------( g3 e" }3 H; ]( E0 ?& N( a- A
Ans:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...- Y( R5 x1 ~5 c ]) @+ G
% p+ d/ r" U7 c+ @5 k. b
在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !
+ \8 F9 m( E, p: M' F4 J$ x8 H3 y. ^" p8 [4 q p$ q+ S' b' K
所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|