|
|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
Linux 2.6.11版本的内核软中断线程ksoftirqd代码如下,下面框架可以看出对于,吞吐量与处理延迟两者之间的权衡。' O( f6 h' i$ p) C6 r; {/ c1 ]
7 w& J# ]) C7 E% f5 J" ]
软中断线程处理概括:
$ H) T& c( } V- m7 D, Z, _) ^
5 x3 B1 O: |$ m6 `; J+ Y1、如果没有活干(没有软中断等待处理)就 schedule()切出,并从运行队列里面删除(由于任务状态已经变成TASK_INTERRUPTIBLE)
% q4 s, x* ?) I( a4 r* f+ B4 R( D. I5 d
2、如果有活儿干,就把当前pending的软中断处理完,处理过程中检查如果本线程运行时间过长,则 schedule()切出(cond_resched()完成这一切),避免其他线程饿死。但切出时任务状态是TASK_RUNNING,不会移出运行队列(线程还有活儿没干完,得赶紧回来),由于移出前,关闭了内核抢占,很快就会重新调度到本线程的。
8 e% _/ I9 z+ ^/ S# a) z/ j2 q1 S+ x0 x' i9 p4 R2 V0 R
6 k" `- L3 p1 ^2 |, g
+ a# n& _) n) s/ C9 G7 C |
|