|
|
理论上在扫描PCI 设备的时候我们大可用 3个loops来做就可以了。但是这里有很大的弊端!
: t6 g* f# X9 X6 r
) p" t/ D! X$ ~/ H# S5 ?" c 有优化的方案:
5 V. i$ {2 y% |2 o9 f L+ x: ~
7 H1 w1 L( ~! ]( t$ A 第一,扫描每个PCI设备的 第00 function,如果这里返回的是 00 or FFH。那么,说明它的/ J0 x- ^' E$ H- W. N
! N- r4 U$ [5 V) u其他function设备也肯定没有!所以这里就可以直接挑到下一个device的扫描了。, u& {* C1 G7 d0 h% D1 A
7 H8 [& \$ l7 E 第二,假如第00 function是有设备的。那么也大可不必一下把后面的 01--07 function都扫描4 |& h/ o N6 X- m9 F* X; E6 B
0 G, r& o# Q2 e9 t1 I |9 q0 y一遍。因为spec中有个位是专门来说明是否是multi 设备的。若这里被置1,才说明01--07有设备。
& r9 R3 b2 G& W- W( k/ e$ D! {' e' M- L' s8 g. g& {7 T. C
否则该pci设备是single function的。
4 v1 x8 f0 f' C i( \
* \9 b, K: \9 C& s4 | 基于上面两点,可以优化很不少的时间。
, {8 s0 Q7 `+ L9 }# K+ C( t [! t( y! l
以上仅仅是我作为一个初学者的经验,希望对后辈有用。少走点弯路。; H% O1 ]- k6 d- |- w2 T
7 m. ~5 K5 z" a; _9 T% S9 b6 U
以后有时间我会继续,发表我的心得。也许比较简单。不知道版主支持不? |
|