|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:
2 J6 e4 G8 K' f1 C8 ^: W1 VPCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。
9 ?* I+ f0 _) ^/ u* Q S0 {# A* A如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。 h/ h9 _7 g8 A6 [- U
6 {, A% ]2 E" Nbini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。* y" w6 x& X+ \ f
. ?- D$ k' D" x$ x9 pREFF:[我所知道的BIOS->PCISCAN], J% ?+ Z8 d4 D0 e. C( i! d
[Practice]
/ t9 G( J) e/ F1 y7 {# c: B6 a假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read). * ^4 O1 f1 Z3 I$ Z8 n6 g
+ _0 M) |# ?6 _% h1 F
但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?
+ g* q6 m: Y! S- l0 ]-----------------% j' m$ J1 x: C/ F7 g8 q2 `# z* i5 S
Ans:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...2 ]$ C; Y/ P) y# J
( Q7 `. q1 J) {
在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !# r+ N* `* Z' M8 }9 A% K8 q* E- Y* k
6 E4 L, u3 q& B$ Q( @/ a# |所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|