|
|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:
$ v/ a5 i3 N: ` O+ e3 S8 kPCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。
9 L2 T6 |$ J: D' y' S8 P如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。
* U: m. @- M- L
p+ g3 o/ k9 ]) e! ]- I9 P) p7 d1 gbini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。
) c9 ~ V$ C6 h7 Q; z8 F- h7 T" m" A3 u- H) Q, R6 g
REFF:[我所知道的BIOS->PCISCAN]
# f( m* V% ^! [$ w s. y; ]+ V& L! b[Practice]
7 z* \* C" y: u/ N假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read).
5 k, O) `& W4 y% Q- p& m7 P* F2 t/ s9 P4 F& _/ o: R
但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?% d) \9 C4 L! _6 i( Y
-----------------
3 ]5 r0 f6 Q" S" K( x( wAns:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...1 p( ~0 f. ?& r& H" w
2 l6 P& m0 w( r2 r: L q在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 ! n) X; l9 Y9 f$ C6 A
$ a v( D2 e" r D
所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|