|
|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:
& r: X) p# H/ ^4 sPCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。
# s- d5 L7 P* a. K如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。, X5 ]) I3 [; J! }/ y2 ?
1 E. T4 ]0 R; p5 y$ x
bini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。8 g! ]! M3 G$ Q' [3 w
6 I, D. ?+ b3 ?" {- e
REFF:[我所知道的BIOS->PCISCAN]
) b# L7 ~% M, V% D[Practice] 0 N2 }5 o8 d* S" I6 A( F; l! M
假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read). & U) [- `" J) ]! M4 H, i1 j/ q
9 E L ~3 L4 E. v4 j7 ^) I但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?
# C2 I1 G7 G! m/ w$ E$ b: s-----------------
. @, p, t+ m3 R+ y ~6 M/ KAns:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...6 r& B+ o, ^3 x& q
& f2 z G; k. E
在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !
4 ^$ V% B% A& L) N0 F9 s4 J# ~1 y! ]3 F8 ]$ v' |
所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|