|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:5 ]( o P) _- u# O6 {
PCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。- l! X* ~, [: s5 V- P, E, ?
如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。/ ?( ~; h6 {0 T! F$ {% Z4 m% J" ?
: S" x! K% N# q( e/ g
bini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。
# X- V+ E: O6 F! U5 Y( {! a( a. h+ M3 D6 l1 x. |% f
REFF:[我所知道的BIOS->PCISCAN]& X- n K! @% p1 `
[Practice]
9 Y) s! H- x3 Q% a9 q' D4 j7 j$ ?假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read). 0 m& V/ V2 A4 V5 P
* c! S$ [' z% E但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?
2 i6 P7 u3 z/ S-----------------
) M6 P$ ?+ X& n9 C# g3 eAns:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...
+ | s$ p4 Q+ Q- o1 s% l5 |/ q! x0 u c
在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !8 [# X+ k, p7 x- l! L; B' H+ }
4 W- K( m2 A% y" ?" a所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|