|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:' v' O4 C' n( B% ]# G' B
PCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。& L5 K, H) ` Q4 J7 ]3 K& p
如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。) n0 \5 T# w1 p r6 [
r+ G* I: X; f; t9 k1 V
bini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。
; S) `3 W$ X d O4 A# d4 `0 P( U+ c% \0 x# t6 g
REFF:[我所知道的BIOS->PCISCAN]9 I9 S9 M# E. C% Y% ]' Q, ]% ] P/ x* ~
[Practice]
2 |4 D6 s' O5 n2 F- ~& q+ r假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read).
6 F7 K0 T) k* Z5 x% r* _& Q9 a; ^- |
但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?7 S0 m' p# G; K3 `* h) M% t
-----------------
/ k* p2 x- h! fAns:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...; S, A# D# l, T, v( o5 T
9 j; a; ^9 V4 _7 m7 ]2 b在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !, E' o& ]; L1 _, t+ h, n2 u' n o$ Y
3 Z0 a* R# S: y所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|