|
|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:
5 v, I; D* U* S% [4 xPCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。
' s# ]( ?/ h m( h9 e: w如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。
( n- E) `6 @7 y' ]1 j
/ W' [# e1 K2 @7 p I5 q; k% sbini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。
# T' ~! O0 Z( p; b A/ h
& S) |7 K- i8 f* p# \4 [4 |4 F; aREFF:[我所知道的BIOS->PCISCAN]
' J: u9 A, c' t+ D- S[Practice]
' n! l. l( t* e& h5 V/ l1 t( f2 R" N: M假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read). 9 [& u& S6 l6 v& m% g, R9 r, a0 w
" Y; N* A3 d# v0 [& q* ]( I
但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?
6 S3 w$ m7 T( f-----------------6 L& R8 {2 m; r9 a, R
Ans:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...
. _6 f* k6 u+ k* M G5 _" o8 r# h( {6 Y
在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !
; _* }, I; N% X7 V2 h; e. n0 p" ~4 x5 A1 h0 w5 h4 b
所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|