|
|
理论上在扫描PCI 设备的时候我们大可用 3个loops来做就可以了。但是这里有很大的弊端!
4 @8 e, d6 W& W* x( r5 Z' ~: k" @) U& s2 L8 A6 x s
有优化的方案:
v, s+ p. ?2 ^6 j; D* P: j% i+ B& V# h$ M$ d }
第一,扫描每个PCI设备的 第00 function,如果这里返回的是 00 or FFH。那么,说明它的 u, R; p4 J' w6 r% d
' J$ X( I. g5 O其他function设备也肯定没有!所以这里就可以直接挑到下一个device的扫描了。
3 g/ `5 b2 w1 r% \
3 h: U: `2 b. B. k3 a. ?8 |$ ~3 p! e 第二,假如第00 function是有设备的。那么也大可不必一下把后面的 01--07 function都扫描
' M& i$ Q+ R( z! Q, o# c b
+ ?0 i f) W) Q7 J: |/ i一遍。因为spec中有个位是专门来说明是否是multi 设备的。若这里被置1,才说明01--07有设备。
2 f! |) Q0 V: S7 s
0 j. i' _+ o; Y0 j; K- w/ x否则该pci设备是single function的。* c1 T- P4 A4 R4 X, ^1 V1 e9 }# E; L
* |* g( X4 M* Z( m; S4 C- E" M ^
基于上面两点,可以优化很不少的时间。% m! c! n) l4 T; R
- U0 n& j' [; e 以上仅仅是我作为一个初学者的经验,希望对后辈有用。少走点弯路。5 X7 ^( w( Y; R5 V' P: _8 z
) J0 o: W5 n: G/ j
以后有时间我会继续,发表我的心得。也许比较简单。不知道版主支持不? |
|