|
|
理论上在扫描PCI 设备的时候我们大可用 3个loops来做就可以了。但是这里有很大的弊端!1 I: G# b6 }2 o9 d" @
( H: f* A0 E! o4 O. k# i1 ^
有优化的方案:1 J. V6 L, J1 R8 Q8 h
. R1 i" ]- _4 Y2 I' W0 M$ i 第一,扫描每个PCI设备的 第00 function,如果这里返回的是 00 or FFH。那么,说明它的
, a+ W. L& `0 E1 Z
5 N- P; P$ j4 @其他function设备也肯定没有!所以这里就可以直接挑到下一个device的扫描了。5 R/ b6 G9 s. n+ {- s
+ V. I/ M* ^9 y* \& _. \! \: u 第二,假如第00 function是有设备的。那么也大可不必一下把后面的 01--07 function都扫描 U A: S& s! y- ~' M2 A+ ?
0 L5 v8 L( [$ A' k2 N7 N$ c5 d一遍。因为spec中有个位是专门来说明是否是multi 设备的。若这里被置1,才说明01--07有设备。
7 |/ `8 }0 T& N% R! F" T& U: A
/ @, R! t8 g2 k/ ?5 k4 P否则该pci设备是single function的。6 }, _5 W" A) @- I1 D
; F% g) {3 I/ {
基于上面两点,可以优化很不少的时间。 W% S0 T u7 v, j2 h& X
, }( x3 l: A7 F1 D7 o8 J$ k( R 以上仅仅是我作为一个初学者的经验,希望对后辈有用。少走点弯路。2 W" M0 f I: A9 o% b0 T
* R. W& Y9 }) F7 ~6 R. Y: a
以后有时间我会继续,发表我的心得。也许比较简单。不知道版主支持不? |
|