|
|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:
2 c4 {3 @7 C! S* d" [2 J* SPCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。
1 x8 V; y' s5 ~! F! G如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。" R# U/ |- Z& z
9 `) n, j* P- Z- b3 w3 Ybini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。
* K8 T( T* G- @! \+ d/ W
/ _ r" z" i( l# t. K- o* c! ^REFF:[我所知道的BIOS->PCISCAN]
8 o Q/ H1 C1 ~+ z9 _' z0 |# A[Practice]
1 d0 w, V; F' Y: Z6 ^' H4 U) H假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read). ) W7 D: z5 b& Z" g" X+ Q/ j, W1 S
/ c+ g0 N! [, }$ J
但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?
6 y2 f3 I; C# c& U% Q3 k-----------------
. s% Y8 q6 M6 C! B0 | TAns:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed.... S2 j0 t4 E! C8 E
. L8 J! L- H. g) Q, M% z) W! s在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !
6 l1 Y4 p0 x; H, s! a6 Y+ O" p. F) z
所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|