|
|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:) Q- {# p. ?5 Q# R' g
PCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。) V3 F r/ I9 L5 w5 X3 G) u7 d7 v
如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。% H( t' Y0 h6 T+ O4 r& h" h
' c. ?5 P8 W& Q/ `( Z7 @
bini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。
# n. h) L2 {3 W" ]0 z. t
/ ~1 y; D4 O' g1 H3 uREFF:[我所知道的BIOS->PCISCAN]
/ I0 \9 ]7 u% v1 a" N[Practice]
9 D6 K/ C" F. \: h. a假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read).
1 r8 U8 E7 V1 k* X! J0 o5 E' c B9 p7 e: J+ h5 H
但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?4 B4 H( Z! z8 O T+ w" G3 l
-----------------8 d" k5 B( U5 Y7 v2 h4 t+ O7 A2 F4 t
Ans:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...0 Z# e8 L/ A, Z5 C8 r' Y
& M8 S' i) B; h9 w1 o
在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !( W: D9 A* `, k) w" P* A: V
7 Q* O% e% N- c# v5 C所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|