|
|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:9 r7 V- z C2 @4 j, i T; J6 c
PCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。
$ }6 [, O& H2 E$ F- K) m9 A如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。
) L* y- h( s& \7 v6 p, r& p. k1 o) h' |6 p
bini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。
" {4 g9 m. Z2 {7 w/ L) k; e( ]+ \4 c) w" h9 L! Y
REFF:[我所知道的BIOS->PCISCAN]6 t6 W$ M3 h4 d- E. g" Z1 k
[Practice]
7 p% u4 Q, T& M9 a. Z4 X假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read). 2 d; r6 S. k q( K
7 ]9 x& `1 E" u但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?# O8 \ }7 O+ i' F' B
-----------------# e- S+ T, H# K1 x; L/ K% ]
Ans:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...
1 o5 u. B [# a+ t3 g5 e6 Z: k/ E% U, Y+ E: r( p
在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !) u7 c6 m) w5 \! o9 h ]+ N
6 g, m4 C( E6 ~9 }
所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|