|
|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:+ _/ Q) G3 @7 j; h5 Z9 i% p1 z9 j" s
PCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。
, [8 C; B+ d v _" n1 p如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。
2 h5 f g' L% I6 e; K( b- X8 w
) H! W1 G8 w, L9 V/ \/ t u( _bini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。/ x. L/ a) M3 H. q) F$ C, {: t7 d2 t
) T- a3 v; E. }/ T E% y0 o# gREFF:[我所知道的BIOS->PCISCAN]
' l3 T4 U2 f% _" a% k* r[Practice] ! D0 v& g' C5 I# `) y0 m, P
假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read). 4 _# y) L) Z, B, _' A# G7 ]
+ G+ L9 [4 q3 e E2 W但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?
+ A* X" L9 |2 q: k7 v; M-----------------
- t3 n0 o I. QAns:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...
) H" p' d! B# I# t* U- ?9 s
& n: p) c0 f3 |( r+ z在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !
& v( G8 s' X( D
0 c" Q- M2 V& r: \4 d所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|