|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:0 Q% h* m5 ]5 b9 k6 W, l! R& \
PCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。
8 t9 P, d4 S: V* b1 O如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。+ C$ x9 A' a; o6 i2 l$ o
7 p% u1 V f+ _- ` t
bini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。
Q4 ] m; [* S% x
( V* I7 w2 l* l4 H$ W7 v' CREFF:[我所知道的BIOS->PCISCAN]
) o2 c) W) R) Y# q( Z[Practice]
' w9 a$ m, E& E$ ~3 n+ v0 M9 G假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read).
f( Y/ _0 W1 o, P& s1 j( D, g) K
但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?
" g$ s' t3 [4 }( l-----------------
( n! R1 Y% N- X7 [6 c9 w, BAns:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...
) ]: W! }# b- H( l" q. r6 X+ K) W- z5 g {' u! x! s, }7 S7 Z8 Q5 w
在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 ! B" i7 c* X: V8 I
$ F$ W2 ?, }) x, R7 ~. i5 e1 I5 V所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|