|
|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:
: e. a7 U: C' l" @$ sPCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。( R: b9 n& u3 B& Y& B
如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。
; c/ A# f4 z6 V u" Q$ o9 j w4 Z- t, J0 U' ]6 n5 z Q! Q* f; ?/ w
bini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。
t! N) T! ?2 H# f' T. }$ b$ |" E2 Q. I7 C9 z4 N; Q
REFF:[我所知道的BIOS->PCISCAN]) _' C, {- ?8 o% j2 N' n
[Practice] 1 |0 {6 _, G! {$ H3 }
假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read). 6 j+ ]1 s/ {% ? p$ g7 r2 z9 u/ h
% A; h3 j4 b2 w9 R u
但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?
. \4 y( I1 X1 L-----------------. R- f1 m6 [% r T" Z% x w5 l
Ans:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...
0 O; e# X0 O0 r9 Q2 e6 J% t
$ t& s4 C9 h- S _/ l* k在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !
8 j& y& z7 ]: R% r+ x$ z8 r! |
2 p, G$ j4 f9 h& R6 Y; P0 B& {所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|