|
|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:
2 e* }( L4 K& a4 E s" y7 LPCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。
% p8 _3 p. e* u Y& f如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。
- c1 f$ J$ h, Y) Y2 o8 {
9 f9 [# o/ V" N3 f* m1 i% Wbini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。
5 p3 B8 P+ h( H
y' a- N7 C/ |0 Z0 U' d$ |3 ?REFF:[我所知道的BIOS->PCISCAN]4 X* ~8 i; A6 k2 _. E1 a
[Practice]
5 C: k$ V: A- p, P假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read).
4 T# J1 B+ P1 d6 I% k
& T, }- i" a& r L- N5 j但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?: g! c# x. m( a' O' C6 ?" M
-----------------
1 ~/ u2 H+ J% G2 hAns:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...
' q1 M8 \0 b. d2 k) t* L F' G* w% r+ \ [
在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !( E$ Y& X; u" j) X" c" _
! y9 s* }" H' |
所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|