|
|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:
J% z% ^" Z9 I" P, DPCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。" i8 \% H" M' x& a
如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。
& |5 b$ ]& x% l k( k0 }* d( y* i9 s, W2 G
bini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。$ N+ m- T r ~3 ~; }
& {, {7 C! ^3 Z2 K+ @# QREFF:[我所知道的BIOS->PCISCAN]
9 P7 Z; ^3 l2 B; [# m[Practice]
, U9 k- A* ~) d2 ]1 K1 ]* t8 W假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read).
: @) X7 |. {2 N) b; Q# U
9 V# u/ r7 J( u5 n- S但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?
9 k& c' H) p) G-----------------7 r8 P$ B, |7 l; W, I
Ans:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...
- ?/ C1 x) n" R
5 N) i# K) @6 y. A8 A" K) G7 M在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !7 t/ o0 p" s5 `, R1 s% N
4 g4 H% d" `$ \6 ?- d
所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|