|
|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:
+ D* s& I8 s) A% V& e# rPCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。
9 b3 m# x( h# ?6 @& N1 n如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。3 \* J5 i; T6 G
- l$ P- l/ u, c. |% J4 {
bini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。
4 }& y0 H2 W/ X) P, `5 x( J5 x; g
REFF:[我所知道的BIOS->PCISCAN]
+ Q9 w9 `" S# [8 R a0 D[Practice]
+ w; l9 Z$ H! b7 O1 {假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read). 2 z% b2 _+ r# S
9 I2 ^$ j4 |+ i# R; k9 D1 }# |
但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?
1 K2 A: I# e" m% a6 d% t-----------------4 U( a' z2 H1 I1 N
Ans:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...+ o F8 n8 K' q( `6 r% N
5 Y! r/ }, m+ @1 ]& N在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !
! y9 I/ F: r' [" C( K4 [
7 w5 N$ V7 z" u3 i+ @* E所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|