关于schedule_timeout

http://blog.chinaunix.net/uid-10221131-id-357017.html

schedule_timeout这个函数除了对当前进程调用schedule之外,还有一个功能,如同其名字中暗示的,在指定的时间到期后(timeout了)将进程唤醒。我们知道,进程一旦进入睡

眠状态,就会从cpu的run queue中移走,直觉是系统将不会维护散落到系统各处(等待队列等)的这些睡眠进程的时间信息,那么如何在指定的时间到期时唤醒这些进程呢?Linux内核使用了timer机制来完成,timer不依赖于进程,依赖于处理器的中断,当然关于timer的内部实现的机制可以成为另一个帖子了,这里就不多说。看看schedule_timeout的源码:

  1. signed long __sched schedule_timeout(signed long timeout)
  2. {
  3.         struct timer_list timer;
  4.         unsigned long expire;

  5.         switch (timeout)
  6.         {
  7.         case MAX_SCHEDULE_TIMEOUT:
  8.                 schedule();
  9.                 goto out;
  10.         default:
  11.                 if (timeout < 0) {
  12.                         printk(KERN_ERR "schedule_timeout: wrong timeout "
  13.                                 "value %lx\n", timeout);
  14.                         dump_stack();
  15.                         current->state = TASK_RUNNING;
  16.                         goto out;
  17.                 }
  18.         }

  19.         expire = timeout + jiffies;

  20.         setup_timer_on_stack(&timer, process_timeout, (unsigned long)current);
  21.         __mod_timer(&timer, expire, false, TIMER_NOT_PINNED);
  22.         schedule();
  23.         del_singleshot_timer_sync(&timer);

  24.         /* Remove the timer from the object tracker */
  25.         destroy_timer_on_stack(&timer);

  26.         timeout = expire - jiffies;

  27. out:
  28.         return timeout < 0 ? 0 : timeout;
  29. }
复制代码
我们关注的主要是defaul t 那块,因为前一个case指定的时间太漫长,不知道猴年马月才到期呢吧?!defal t  case其实 蛮简单,expire =  timeout  + jiffies;
用当前jiffies加上函数调用时的 timeout 值构成到期时间点,然后se t up_ time r_on_s t ack创建了一个 time r,这个 time r到期后将调用process_ timeout ,传入的参数是当前进程的指针curren t ,然后调用schedule,函数将停留在schedule上(当前进程被调度出处理器,同时从cpu的run queue中移走,一个新的进程被调度运行起来)。但是不管进程怎么切换,游离于进程世界之外的 time r在每次时钟中断都有相应,当这个 time r的时间到期后,将调用 time r上的 回调函数。

schedule_ timeout time r安装的回调是process_ timeout ,核心代码就是wake_up(curren t )类似的样子,这样因为schedule_ timeout 而睡眠的进程将进入到cpu的run queue,当它被调度时,schedule函数返回,除了删除已经不再使用的 time r之外,一个比较重要的步骤是 timeout  = expire - jiffies,这个主要是用来判断进程被唤醒的原因,因为有可能在 time r没到期时,其他 进程唤醒了该进程,这种情况下 timeout  = expire - jiffies算出的 timeout 是>0的,所以反映到函数的返回值上就是,0意味着进程因为时间 timeout 而被唤醒,一个正数意味着进程在时间尚没有 timeout 的情况下被唤醒。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值