|
|
理论上在扫描PCI 设备的时候我们大可用 3个loops来做就可以了。但是这里有很大的弊端!; I/ c# W& W; ~# O
3 l! s4 e0 ^- T/ I" F/ P 有优化的方案:
# T, ?2 o6 u4 X
: @7 j, k+ F& j( x8 _3 O$ l" ? 第一,扫描每个PCI设备的 第00 function,如果这里返回的是 00 or FFH。那么,说明它的
; a* q3 @$ U4 e8 Q
1 z8 l7 `/ j+ \其他function设备也肯定没有!所以这里就可以直接挑到下一个device的扫描了。5 L$ f" S* B# b3 K- R+ t
[6 @/ ?$ u& p5 V 第二,假如第00 function是有设备的。那么也大可不必一下把后面的 01--07 function都扫描
7 y* D" a) {4 W/ x
- O% c9 q7 P- [一遍。因为spec中有个位是专门来说明是否是multi 设备的。若这里被置1,才说明01--07有设备。
# N; X$ ~! W& l/ O: o" A$ b# T9 z3 [
否则该pci设备是single function的。
, H, q4 p( d" \1 d4 f Z! f: c/ ^' Z' \7 f
基于上面两点,可以优化很不少的时间。
9 n, ~% T3 n( k6 V, c @
/ x% N; n) _* g, Z, r# |$ E! b 以上仅仅是我作为一个初学者的经验,希望对后辈有用。少走点弯路。
) F% \% e+ Z& ^+ N% q' J: F: R
) o5 B3 t3 Q% L- A! o. J$ s7 s9 f8 l 以后有时间我会继续,发表我的心得。也许比较简单。不知道版主支持不? |
|