|
|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:
o) g/ d2 E; f# q& ~1 s; mPCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。
# i0 a& E( U: |如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。( i" n( V, N4 V
$ G2 t \6 A9 t% \/ k# d/ n) N5 i
bini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。8 }3 y0 T9 b2 V1 G) d1 D& G$ G" r/ ?
0 Q# [8 y/ }. l
REFF:[我所知道的BIOS->PCISCAN]) R3 V# C2 R8 r6 o/ f
[Practice]
. X2 \- Q9 R5 T% E7 ^8 n假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read).
9 R1 L0 S" w% P, z8 b L1 C2 a: p% N; `3 ~3 n; h, M# C9 l
但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?
( y5 b- v; F$ \( k# N-----------------& q3 n" c: X9 ^9 [
Ans:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...7 W$ z$ ?! r9 K1 X
u3 w5 C w. b: m( n% F
在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !$ G& G1 N6 i: J$ j/ H- N
5 N6 t/ }& o( r: Y% j; R所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|