|
|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:
0 J: z2 J& Q6 S# e- h" X( mPCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。
, J6 Z* a9 {6 J1 \2 s6 D6 s如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。
# J$ x9 ?% M8 S/ {$ v% ^- D
! x4 d( F) r# E3 C3 \# I5 S; ]" Rbini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。
& a* G0 M- G2 o; P! X0 G1 U& \; W" o& `; X5 X' H6 ?8 q7 l
REFF:[我所知道的BIOS->PCISCAN]
' j! x2 m' [9 _3 _8 m1 }9 W[Practice]
, n) A5 R! L- {) W( W假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read). _: f; j _: ?; j& W: D
' L+ [3 i, g3 }8 P3 m7 W, K/ H( [& _ ]但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?* L$ U8 }( k% y1 C$ G9 L, B; q
-----------------8 ^( B# W( n" y( u
Ans:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...
$ R7 ?+ ~" f# x4 I% [0 i
# ]9 d! H9 O& J+ D! \( S在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !
0 L* ~5 k+ z& q+ o9 W
# q- V% {, d) G) T6 |9 w: g所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|