|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:' a" v9 i& D# a- b: \0 k
PCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。
7 `* \4 i+ Q0 X4 `如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。% t/ ~2 r4 G, z2 a: y1 o% X, e
' B. y% u0 h" u; c _bini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。
9 L& D% S% E6 m7 @ {5 M
' E8 T" ?6 N+ ?" s3 I$ ~REFF:[我所知道的BIOS->PCISCAN]
/ c+ n" `/ P# r, t% b! @+ k' D& F[Practice] 7 ?3 h" y4 J9 }' f: B
假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read). # r& K) `' O/ G' d4 s% Q
9 L# w6 l+ g' Z. {
但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?( _( N M- Z) C* I
-----------------
! y6 k0 b: _) F9 N' b9 F% G- m. Y9 s/ NAns:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...& l' i) U' g' m) ?
- [/ d3 } _8 }6 `- M- U, A8 I9 R0 X
在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !' E1 P2 H) f5 A. A6 [ [; @
n& a0 x0 L; T- k
所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|