|
|
理论上在扫描PCI 设备的时候我们大可用 3个loops来做就可以了。但是这里有很大的弊端!
. m9 z6 w0 ^3 ]7 W l. l- \- d5 `8 d8 V2 e( n
有优化的方案:
) `8 S2 x, {5 x8 k# d1 H# f) h8 W+ v. e" v
第一,扫描每个PCI设备的 第00 function,如果这里返回的是 00 or FFH。那么,说明它的
" g& Y' [" I! y( v- O/ s' o! Y
, f# q2 P0 O' a: C( e其他function设备也肯定没有!所以这里就可以直接挑到下一个device的扫描了。1 q9 I# C; S0 V V# b% o# k' E
- [4 Y& D/ D& M3 k 第二,假如第00 function是有设备的。那么也大可不必一下把后面的 01--07 function都扫描' T2 p- G, r V9 n. Z6 a
( {* I* E) E4 t& n/ z
一遍。因为spec中有个位是专门来说明是否是multi 设备的。若这里被置1,才说明01--07有设备。
0 {" ]# w: Q! ~$ Y4 V, {5 E8 o. S7 X5 T# f2 e1 ]
否则该pci设备是single function的。
2 ]$ x& q W o- {3 a. r e* S: Q$ i( y! v) a- H
基于上面两点,可以优化很不少的时间。
* p, \3 m; C! j7 s6 n! f. R1 t0 ?+ w$ C& }! O
以上仅仅是我作为一个初学者的经验,希望对后辈有用。少走点弯路。7 W0 t8 V# S: y- S& D6 F
0 K: ]7 H) R8 n* | 以后有时间我会继续,发表我的心得。也许比较简单。不知道版主支持不? |
|