|
|
理论上在扫描PCI 设备的时候我们大可用 3个loops来做就可以了。但是这里有很大的弊端!
4 s! l }9 G; ?& L
; M$ k* P. K. W }, F0 r 有优化的方案:
b8 s1 M/ Y% {1 d
2 K& Y, S* e3 B& x4 c7 Q 第一,扫描每个PCI设备的 第00 function,如果这里返回的是 00 or FFH。那么,说明它的
; R4 |% {5 `+ l- ]$ j/ v& }- v9 M0 L3 z2 q6 V, E6 z2 F
其他function设备也肯定没有!所以这里就可以直接挑到下一个device的扫描了。
" P2 X! G# p, [5 G& \& l) l; v$ [; G* T3 t" L& N, }6 `
第二,假如第00 function是有设备的。那么也大可不必一下把后面的 01--07 function都扫描
9 r$ \3 X6 W; }" f5 B* v
2 J4 b( q! J9 F" x2 C一遍。因为spec中有个位是专门来说明是否是multi 设备的。若这里被置1,才说明01--07有设备。2 o# v* z8 U7 S5 L- p9 L& t
. @ d, ], r+ o, i; V
否则该pci设备是single function的。: t9 ~* d$ u7 g# L. C1 q: @; Z
; i- w/ h" q4 \1 h+ C( l2 M 基于上面两点,可以优化很不少的时间。
& i" \+ x: ]+ V/ s0 g/ }& r+ ]' y( g u8 Q- Z# N
以上仅仅是我作为一个初学者的经验,希望对后辈有用。少走点弯路。0 q6 R: p8 ]* D8 l4 e' f
k4 R: v! R: {2 X, F' `
以后有时间我会继续,发表我的心得。也许比较简单。不知道版主支持不? |
|