|
|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:1 |5 i4 h) K$ ?* v2 ^0 C! c
PCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。
" e7 X7 r- m/ P8 a& o: v" s如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。' O- ^9 d _. P- w: J
# Y* R! H, `% E8 C, D; q" P6 u! {3 nbini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。
- h2 ~+ X, {+ O! x/ |! f
! W# t" |0 E- ?% J1 k; G8 MREFF:[我所知道的BIOS->PCISCAN]. P- u: Q9 Y) v* q
[Practice]
) [& a$ e! Z# Y: H3 D4 {假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read).
$ w% R" x' @4 u5 g* ?% n5 I
w- c0 R1 N* ~1 D' O6 J# @但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?, r5 c) p; c" I+ j$ {5 S7 v
-----------------, ^9 G, }: w# n* w6 }
Ans:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...
9 w5 u7 z& g% Y2 @9 Q: e& k' Q
: u/ z5 m6 |. P在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !
3 h& _; G/ i$ F7 {% A/ _9 S
+ ]3 k# ^1 J5 l; s所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|