|
|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:( |& m$ n8 L: G" W
PCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。- ]8 w0 H8 g2 _. F
如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。7 E1 Z- S& Z- B% E
# _ j# M y9 P, P f( Hbini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。
& v7 O) f0 g& k; x! w0 N+ N0 s4 K# f' H$ ~) P" }1 G" n
REFF:[我所知道的BIOS->PCISCAN]
+ L+ a1 x1 j. x& K0 x u' z+ a[Practice] / ?3 e# P Q/ ?, B8 K# `8 P
假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read). 0 t/ o8 F% g* S( N
" k) D" U) ?* @5 }" P/ m8 r" U但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?
0 l- D" G: P$ Q3 j9 X-----------------
. ?. m. O3 M8 ?3 g( iAns:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...
' L- J! @8 D; c
; c# e( i: V1 P; o& l在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !# h% S4 h* N# z$ p5 e) u
' S1 c, V7 G( F+ z( d: M" h- f所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|