免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2762 | 回复: 3
打印 上一主题 下一主题

内核调度策略的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-09-18 14:58 |只看该作者 |倒序浏览
被这些问题困扰很久了,我也看了一些源代码,似乎有些懂了,呵呵,想听听各位达人高见, 谢谢 :)

1.  用kernel_thread创建若干内核进程, 这些进程应该如何调度?

2.  ksoftirq如何调度多个软中断?

3. 实时linux (2.6.20),中的实时高优先级进程是否能抢占内核?

论坛徽章:
0
2 [报告]
发表于 2007-09-18 21:18 |只看该作者

回复 #1 lsddx110 的帖子

>>1.  用kernel_thread创建若干内核进程, 这些进程应该如何调度?
内核线程和进程同样调度。只是内核线程使用前一个活动进程(在它之前运行的进程)的地址空间

>>2.  ksoftirq如何调度多个软中断?
不太明白什么是调度多个软中断。能解释一下吗

>>3. 实时linux (2.6.20),中的实时高优先级进程是否能抢占内核?
可以的。前提是当前进程是可抢占的

[ 本帖最后由 zx_wing 于 2007-9-19 17:59 编辑 ]

论坛徽章:
0
3 [报告]
发表于 2007-09-18 22:15 |只看该作者
原帖由 zx_wing 于 2007-9-18 21:18 发表
>>1.  用kernel_thread创建若干内核进程, 这些进程应该如何调度?
内核线程和进程同样调度。只是内核线程使用前一个活动进程(在它之前运行的进程)的上下文

>>2.  ksoftirq如何调度多个软中断?
不太明白 ...

惭愧,以前对ksoftirq不是特别了解,刚才没敢乱说。去看了看资料和源码,我想lz问的是ksoftirq的功用。它主要是解决软中断的一个平衡问题。举个例子,如果我们向下面这样处理软中断:

  1. while(1)
  2. {
  3. go_on:  
  4.       do_softirq();
  5.       if ( local_softirq_pending() )
  6.             goto go_on;
  7.       schdule();
  8. }
复制代码

这样如果当软中断过多,例如网络遭受flood攻击了,包过多。 用户程序就会饿死,迟迟得不到响应。

又例如这样处理:

  1. while(1)
  2. {
  3.       if ( local_softirq_pending() )
  4.            do_softirq();
  5.       schdule();
  6. }
复制代码

当系统进程较少,idle时候较多的时候,软中断又得不到及时的处理。

为了平衡,在__do_softirq()函数会进行检测,如果如果刚处理完软中断,还没返回的时候又有软中断pending了,那么就说明软中断过多,于是调用wakeup_softirqd()唤醒ksoftirqd这个低优先级内核进程来处理。这样就可以保证用户进程不会饿死,而软中断在系统空闲的时候又能及时的到处理,取得一个平衡。

[ 本帖最后由 zx_wing 于 2007-9-18 22:16 编辑 ]

论坛徽章:
0
4 [报告]
发表于 2007-09-19 17:01 |只看该作者
非常感谢zx_wing的回答,受益匪浅 :)
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP