|
|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:
& W: J2 F- |# |, F# FPCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。6 Q1 T2 E0 d( q( _
如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。 p9 t( _% {+ W8 T# |
. a7 Q/ a3 k8 ]6 J! j
bini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。
1 \3 A8 d+ P$ m Y r1 G$ \. F2 Q7 e" J# h& O3 ? B' J6 @
REFF:[我所知道的BIOS->PCISCAN]
4 [5 c. L ?: q, o+ v( t3 `4 _[Practice] - v& O& u5 M. J+ q- K! j" G
假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read). p; m0 H- n4 a- ~, U& A2 j0 w
! C# X: N; V: ?' @
但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?6 o# l3 M- |+ N3 I1 }0 a
-----------------
. z1 U6 K! T4 P; C# b) RAns:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...) }# Y+ J( m) m3 p
& h6 s5 u# _$ e( s6 a/ f. M/ |
在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !: z" A8 D+ r0 |' I
: R, q6 Q* a' `% X& y所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|