|
|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:9 M1 x( b$ U8 G9 f0 B
PCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。9 H, f. l! b; f$ X% J; _6 p
如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。& d" c! ^* X m" ?4 p* O
4 @& R% V. a2 n0 T m- q# \
bini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。: r* c( Q$ H0 l, `% i0 b" n
8 r, x M0 d6 \4 c5 ]6 OREFF:[我所知道的BIOS->PCISCAN]
2 D- i" w9 p/ }" H; X3 Z+ Q. l; M[Practice]
# c' R% r }+ I假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read).
9 p: x0 Q& ]8 q# b) k- _; z3 _. I( e+ \$ w
但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?* b9 H5 U$ O C- \( n$ m+ }* h
-----------------
: K+ [' G: P/ { k. NAns:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...
' V4 ^/ @) b x/ k8 v8 ?" \3 B+ J, ~( {7 K6 }
在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !
) U- u; r4 q3 N
4 l6 y+ `- G7 P所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|