|
|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:- `- r4 Y+ [1 I* X# h7 H5 i$ Q) }0 p
PCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。& L: q7 n2 m( ~* R) I N/ l q
如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。! s2 D* n) A( w1 G5 D
6 p1 d3 U; [: V4 e- ~5 m
bini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。; n" w$ ~ Z7 R0 b, z
' h" K. `/ d* X/ }% _$ d3 KREFF:[我所知道的BIOS->PCISCAN]
! b" j/ f5 S' u$ }) e. o9 }2 V/ z7 f[Practice]
( X6 m5 m0 x7 L4 J0 e7 d; w2 \假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read). 3 j$ z2 F, U' ?) t
3 i. @& r/ z( {4 U# Q
但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?3 t) V; p1 F; R! q9 e; s
-----------------5 A Q) C. P* R+ d! b/ v# d; D! k
Ans:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed..., i! H1 T7 x. ]% |
# S3 _1 Z- C4 u* s6 Z( }在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !- M0 U' @7 M$ } V1 p% F4 ^6 Z
( u; h$ k" K# ^0 J* Q/ p
所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|