|
|
理论上在扫描PCI 设备的时候我们大可用 3个loops来做就可以了。但是这里有很大的弊端!" K6 V, O' V! e
( P! F, a T0 x3 C
有优化的方案:1 F0 y* w& P$ W; T2 W; Y
2 ?4 W) ]0 s5 w 第一,扫描每个PCI设备的 第00 function,如果这里返回的是 00 or FFH。那么,说明它的; a" \+ U! z& f/ ~" \0 \
% S4 l+ G: `, D! m- r4 T其他function设备也肯定没有!所以这里就可以直接挑到下一个device的扫描了。
! S9 S0 j: |- S$ D; ` j" Z& Q; g! ]9 `
. H5 \/ _1 K# E" j1 C; i 第二,假如第00 function是有设备的。那么也大可不必一下把后面的 01--07 function都扫描1 d; s5 ~; T& O: K2 E
9 u* I3 L( q, K* F
一遍。因为spec中有个位是专门来说明是否是multi 设备的。若这里被置1,才说明01--07有设备。
! X6 P# w, A+ q. G; G/ r" |' ?! |2 R) S4 w: y
否则该pci设备是single function的。
' Q+ O: a4 `" g* H4 N
/ }4 H( {/ ^ E' ^ 基于上面两点,可以优化很不少的时间。
I1 F9 L$ y; O. I+ l4 K& X" ^ n" A' Q5 l8 R" u+ B5 H
以上仅仅是我作为一个初学者的经验,希望对后辈有用。少走点弯路。
0 Q$ K# U- Y/ s; ^8 |$ x' y0 ]/ t( e H. h( Q; d
以后有时间我会继续,发表我的心得。也许比较简单。不知道版主支持不? |
|