|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:
4 [9 i9 T. \" ?# t0 U5 gPCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。5 n+ `( Q- K$ w+ V8 p, [- D [
如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。
8 _2 J& T" b1 B# |+ U1 s6 @) y
) r( J3 M+ J. d+ [/ cbini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。
# e' a7 F" B2 M- L" W3 v3 b5 p- `, {, v. s* p1 h
REFF:[我所知道的BIOS->PCISCAN]9 P. R# R l$ c$ \$ H
[Practice] 4 V% x# g6 o! S: L; e7 T- g/ u
假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read). . d; f1 \+ T# k+ w. g- e
: Z& x. }; F+ x( d& V1 {
但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?
+ s7 E5 ` h0 G: k-----------------
% c# s6 |0 n& }5 r/ u, U1 ~Ans:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...
# n. b& c" |% d& ~2 X& Y9 r/ K/ W4 _! G
在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !
) S& D1 ~% U* H5 C! I) i x q
% a! j( K; J6 `& l$ R" A所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|