|
|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:9 M6 _, R6 }7 F, B$ J8 Z; q6 X
PCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。' H) r+ [+ l, s8 T0 R2 V
如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。2 n2 O) ^- z ^4 e
% a ?/ T' t% ?
bini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。
5 @- M _3 @% i+ C% T1 S: D: J# p N o6 s4 ~: w
REFF:[我所知道的BIOS->PCISCAN]
+ I9 ^! t( P! \. a4 x[Practice] % j* t! e6 r, u* j4 y( u* p
假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read). 6 x: o6 g8 t% z d% v4 s
4 X' `/ R$ r5 e" h% \0 D
但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?% d1 t+ w6 ~+ r' D W& g X! [
-----------------, y# v' A" d, F. ]; G
Ans:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...
/ A; Z& q; L% C1 b5 C) @7 }+ W' q6 w! h& H* F
在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !
8 ~, a. b9 |8 S( ~+ m1 p0 ^9 r! D1 c+ O4 l
所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|