|
|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:/ u" I7 I5 ^# A6 r# k5 R
PCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。; u0 X$ G7 _( Z, K7 n6 m/ c' M* Z
如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。
+ V6 F) ?7 d4 j# x3 M& P) r+ t/ ?- B( p; [! T. L: b, D9 _2 g
bini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。
# B4 b, b# d( n3 F! C9 W' o- l. ]. J
REFF:[我所知道的BIOS->PCISCAN]( \% U5 Y+ n# G0 e; K1 X3 m/ ?, K. n
[Practice] ! ~ v }- J8 j$ V+ C" K! [
假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read).
- I, K5 K8 v" a3 ]3 L. X7 t( k
& D5 f& t3 G v/ W9 a5 c3 {但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?
0 K* x, g& O9 |9 R2 C/ P h! o1 k-----------------
P x9 i! i( IAns:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...& l9 i% Q7 w9 a2 {: J
; s' j% u3 `9 Z$ \9 K# K$ N9 j$ V
在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !
: D2 f8 i7 x( C1 V6 P
- I8 Z3 b) x9 ?7 q所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|