|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:
/ ^* c4 y- c+ e e) i/ sPCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。. K i7 ^8 r a6 n4 k. ]2 Z7 ]6 k4 ]# e
如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。
+ ]' G& v" E0 h- A8 G% h$ F- n' D. k3 ?% C3 r# Y) V0 m
bini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。& u% V5 h- L* G) e* a
6 Q T# Y* |2 P8 T& Y6 X7 _
REFF:[我所知道的BIOS->PCISCAN]1 j( J. O) @; F& u9 `1 W
[Practice]
0 n6 Q6 v8 p$ z3 d8 B, ~5 |, w假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read).
5 K: W- x7 d) p& m- C2 p6 G, H$ P. ?1 b* B) Y2 s0 y
但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?
8 S: b/ R/ ^ D8 v-----------------+ a8 L% m* O9 Q$ k7 b
Ans:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...
* N/ I% R9 n2 M
; F% v: o: q3 f( e在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !
* ~( [8 |* n' p( `$ o6 |0 J! k, `& J$ a& T: k
所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|