|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:
# z$ l! V$ U& L/ V! ?% I/ @PCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。7 Z# v- m; w) { }5 {
如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。
9 a3 }/ x# L# I2 E+ n- |/ f; \8 [! a$ d9 \' Y6 J& q6 Y" J/ M; H# s
bini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。: K. x- {' z& e- p
0 E; J2 ^* l$ W. G x
REFF:[我所知道的BIOS->PCISCAN]
1 l1 T- h! o* [ |: f% Z* r[Practice]
$ ~2 X& F* q7 ]$ f( N! V假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read).
$ h/ e! J3 a/ e! }- R7 B( X) n7 j0 k; k; E( p: {
但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?
( ~7 R3 s/ ^* d! `5 _! ~4 |-----------------3 r I5 d1 E2 x: d: }. I/ A7 Q- [* r y
Ans:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...$ X1 k5 j; D- W% a7 ^+ x9 \3 H5 X
0 y& G7 p( ^* ]3 u, Q在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !3 P: r% Q8 ~' C3 q$ C
7 O4 `' j3 P8 N/ V所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|