|
|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:9 w- N: y& j V$ I6 [' ^% G
PCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。+ D% H) g& ^4 Y
如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。 s% [# C( b) x( |) Y3 Q
0 E4 B7 X+ z+ W& F
bini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。
8 `' H( z- U3 H. [/ E8 u, d# u5 [ d; s$ T; o
REFF:[我所知道的BIOS->PCISCAN]
: ^+ E, q" q7 J9 R5 z$ e/ e/ O[Practice]
! F. w1 j6 M3 Q0 X* d- g$ E! K. `假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read). - ?; n+ u3 Y$ V6 f2 ]
% b. e; R- @* i; e* |9 c2 N! e3 i
但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?
$ ]2 O+ s. @7 {5 S- D' ]' d" x-----------------, l( o( s5 \8 K/ n# |0 V
Ans:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...4 V& w3 j3 H) x; e% `- ^
2 q* R1 j, j9 e+ ^
在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !! F5 v4 z6 l7 V" a1 s9 Z# _
e3 W A- L" Q( y5 J T4 [2 q# V1 k
所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|