|
|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:; O! {, p0 O! q0 c9 b# x
PCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。3 S- ?" O" s2 e& k
如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。
5 M" T' B* P/ H! d
; V5 u4 ~, W( s6 C5 j+ obini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。) N/ _! F. R6 W
$ S/ S, V9 f/ E/ L% MREFF:[我所知道的BIOS->PCISCAN]
2 F B% \2 `5 B1 t6 m6 Q[Practice]
# G6 C/ q$ N5 `$ P) C( _假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read).
1 y9 a- v1 {# s' P- V5 D4 H* S& \! w, ]
但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?0 E2 A+ h7 H( Z& l; K
-----------------3 x* t# x7 j" Y/ ?
Ans:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...7 S) G3 C" N' y* r
6 j: i2 y* d. F3 Z- C- L8 h. P
在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !! C S7 v t+ b! g0 B/ {3 t6 Y
0 p# G/ L% k0 {* _8 V所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|