免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12
最近访问板块 发新帖
楼主: rockcanon
打印 上一主题 下一主题

[进程管理] schedule() 会被中断和return吗? [复制链接]

论坛徽章:
1
拜羊年徽章
日期:2015-03-03 16:15:43
11 [报告]
发表于 2014-02-06 10:22 |只看该作者
调度schedule()是不允许被抢占的

论坛徽章:
3
射手座
日期:2014-08-18 12:15:53戌狗
日期:2014-08-22 09:53:36寅虎
日期:2014-08-22 14:15:29
12 [报告]
发表于 2014-02-06 13:11 |只看该作者
你看看schedule函数的实现, 他一开始执行就会关中断同时禁止内核抢占

论坛徽章:
0
13 [报告]
发表于 2014-02-09 20:27 |只看该作者
本帖最后由 omycle 于 2014-02-09 22:27 编辑

1. 是否可以中断的问题 ,在schedule()函数刚开始的时候,就有preempt_disable()和spin_lock_irq。即,禁止抢占并关闭中断。其实,对于schedule本身,只要禁止抢占就没问题了。这里的spin_lock_irq主要是为了锁住runqueue。(2.6.10的版本)
2. 任何一个进程(刚被fork出来的除外)在拿住cpu开始运行的时候,都是从context_switch->__switch_to()中,上次被切换出去的地方继续执行的。
3. (接上)所以finsh_task_switch(prev)是由新进程执行的,处理之前的进程(prev)遗留的东西(在v2.4中,是__schedule_tail()把prev 的task_struct结构中policy字段里的SCHED_YIELD位清掉(可参见Linux内核情景分析))

论坛徽章:
9
程序设计版块每日发帖之星
日期:2016-02-13 06:20:00数据库技术版块每日发帖之星
日期:2016-06-15 06:20:00数据库技术版块每日发帖之星
日期:2016-06-16 06:20:00数据库技术版块每日发帖之星
日期:2016-06-18 06:20:00程序设计版块每日发帖之星
日期:2016-06-27 06:20:00程序设计版块每日发帖之星
日期:2016-07-09 06:20:00IT运维版块每日发帖之星
日期:2016-07-15 06:20:00IT运维版块每日发帖之星
日期:2016-07-27 06:20:00程序设计版块每日发帖之星
日期:2016-08-18 06:20:00
14 [报告]
发表于 2014-02-10 08:56 |只看该作者
wenkai169 发表于 2014-01-28 17:38
那个叫scheduler_tick(),如果当前进程是实时进程,这个函数什么都不做,否则就进行调度和平衡,和你说 ...



scheduler_tick到底做不做调度

论坛徽章:
0
15 [报告]
发表于 2014-02-11 09:36 |只看该作者
本帖最后由 wenkai169 于 2014-02-11 09:47 编辑
mordorwww 发表于 2014-02-10 08:56
scheduler_tick到底做不做调度


弄错了,他只触发了调度,自己没有去操作。

源码里面
  1. void scheduler_tick(void) {
  2. ...
  3. #ifdef CONFIG_SMP
  4.         rq->idle_balance = idle_cpu(cpu);
  5.         trigger_load_balance(rq, cpu);
  6. #endif


  7. /*
  8. * Trigger the SCHED_SOFTIRQ if it is time to do periodic load balancing.
  9. */
  10. void trigger_load_balance(struct rq *rq, int cpu)
  11. {
  12.         /* Don't need to rebalance while attached to NULL domain */
  13.         if (time_after_eq(jiffies, rq->next_balance) &&
  14.             likely(!on_null_domain(cpu)))
  15.                 raise_softirq(SCHED_SOFTIRQ);
  16. #ifdef CONFIG_NO_HZ_COMMON
  17.         if (nohz_kick_needed(rq, cpu) && likely(!on_null_domain(cpu)))
  18.                 nohz_balancer_kick(cpu);
  19. #endif
  20. }
复制代码

论坛徽章:
9
程序设计版块每日发帖之星
日期:2016-02-13 06:20:00数据库技术版块每日发帖之星
日期:2016-06-15 06:20:00数据库技术版块每日发帖之星
日期:2016-06-16 06:20:00数据库技术版块每日发帖之星
日期:2016-06-18 06:20:00程序设计版块每日发帖之星
日期:2016-06-27 06:20:00程序设计版块每日发帖之星
日期:2016-07-09 06:20:00IT运维版块每日发帖之星
日期:2016-07-15 06:20:00IT运维版块每日发帖之星
日期:2016-07-27 06:20:00程序设计版块每日发帖之星
日期:2016-08-18 06:20:00
16 [报告]
发表于 2014-02-11 10:04 |只看该作者
wenkai169 发表于 2014-02-11 09:36
弄错了,他只触发了调度,自己没有去操作。

源码里面


时钟中断里必须要做schedule的啊,这是最基本的分时调度

论坛徽章:
15
射手座
日期:2014-02-26 13:45:082015年迎新春徽章
日期:2015-03-04 09:54:452015年辞旧岁徽章
日期:2015-03-03 16:54:15羊年新春福章
日期:2015-02-26 08:47:552015年亚洲杯之卡塔尔
日期:2015-02-03 08:33:45射手座
日期:2014-12-31 08:36:51水瓶座
日期:2014-06-04 08:33:52天蝎座
日期:2014-05-14 14:30:41天秤座
日期:2014-04-21 08:37:08处女座
日期:2014-04-18 16:57:05戌狗
日期:2014-04-04 12:21:33技术图书徽章
日期:2014-03-25 09:00:29
17 [报告]
发表于 2014-02-11 10:12 |只看该作者
时钟中断真正的调度点在“中断返回”的时候。

论坛徽章:
9
程序设计版块每日发帖之星
日期:2016-02-13 06:20:00数据库技术版块每日发帖之星
日期:2016-06-15 06:20:00数据库技术版块每日发帖之星
日期:2016-06-16 06:20:00数据库技术版块每日发帖之星
日期:2016-06-18 06:20:00程序设计版块每日发帖之星
日期:2016-06-27 06:20:00程序设计版块每日发帖之星
日期:2016-07-09 06:20:00IT运维版块每日发帖之星
日期:2016-07-15 06:20:00IT运维版块每日发帖之星
日期:2016-07-27 06:20:00程序设计版块每日发帖之星
日期:2016-08-18 06:20:00
18 [报告]
发表于 2014-02-11 10:19 |只看该作者
humjb_1983 发表于 2014-02-11 10:12
时钟中断真正的调度点在“中断返回”的时候。


这个没错啊,中断结束了才能做switch
前面 wenkai169 同学的意思貌似是中断不会触发调度

论坛徽章:
15
射手座
日期:2014-02-26 13:45:082015年迎新春徽章
日期:2015-03-04 09:54:452015年辞旧岁徽章
日期:2015-03-03 16:54:15羊年新春福章
日期:2015-02-26 08:47:552015年亚洲杯之卡塔尔
日期:2015-02-03 08:33:45射手座
日期:2014-12-31 08:36:51水瓶座
日期:2014-06-04 08:33:52天蝎座
日期:2014-05-14 14:30:41天秤座
日期:2014-04-21 08:37:08处女座
日期:2014-04-18 16:57:05戌狗
日期:2014-04-04 12:21:33技术图书徽章
日期:2014-03-25 09:00:29
19 [报告]
发表于 2014-02-11 10:24 |只看该作者
mordorwww 发表于 2014-02-11 10:19
这个没错啊,中断结束了才能做switch
前面 wenkai169 同学的意思貌似是中断不会触发调度

呵呵,他说的也没错,scheduler_tick()函数中只是根据情况设置TIF_NEED_RESCHED标记,并不直接触发调度,真正调度发生在中断返回时,会检查是否有该标记,有的话就会产生switch了,所以,scheduler_tick()是间接触发了调度。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP