|
|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:& g2 J+ P& X& M4 Y# o g
PCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。: ?( b7 v) ~! b0 |/ j
如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。
1 [6 _" ^/ u" C: @ w2 s( S
: ^. d! p6 W6 Q: ^" }" Ibini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。
" {# i4 q( d+ a( q5 B- P* Q- t$ c* a. E" c" N( k" W- S
REFF:[我所知道的BIOS->PCISCAN]6 x* p G9 ^( I8 |0 V
[Practice] 3 K! m! u$ t. B" H- ?) Y
假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read). f8 j1 _% r9 ?: K
1 o; ?% j$ b; B但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?
0 F3 Z4 F4 `& N, T-----------------
/ G( U) ^/ O# G: o/ F; O/ XAns:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed..." I: \3 o9 B/ j( l% q
& P3 |' T0 u: R( j5 X在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !
{) v4 B! {* v* b [0 ]2 P
( N, |1 B- r# p5 K所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|