|
发表于 2009-7-8 09:06:27
|
显示全部楼层
to dangdangtop:1 w* A* ` o6 W0 Y1 R R8 k6 h7 v( [. M
PCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。
. d: u9 n# G, @- l如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。6 s8 Y' v5 g( \% G2 X: V
9 E G8 d- y) hbini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。# D( V! I5 |) ` b; R+ ?; I
6 s! ]- m2 A+ d* b( A
REFF:[我所知道的BIOS->PCISCAN]! z0 I+ g1 k- }- l3 s
[Practice] : _( S* j9 u: O) O" L( x
假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read).
9 T/ f& L7 x# A
5 y$ D6 i+ d& G( J但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?
" R; q( P0 E# k-----------------
, K/ ^3 e. [% ~9 J7 }8 T: HAns:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...* u* i' s% @5 l2 `+ L7 w0 O7 m
0 I# j& V% {: q' e0 M在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !5 z& |" f. z8 {& _
; N2 W7 n4 i3 M# x3 D所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices... |
|