免费注册 查看新帖 |

Chinaunix

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

请内核中关于信号量的函数__down的一些问题? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-07-01 17:39 |只看该作者 |倒序浏览
内核中信号量(semaphore)中的__down函数,对这段函数感觉比较迷惑,有几个不太理解的地方:
1,for循环到底干什么啊? add_wait_queue_exclusive_locked 函数已经把当前的任务给suspend,并且插入了wait队列中了。
     那么直接把sleepers设置为1,应该就可以了吧?
2,for循环中的schedule() 函数,会不会引起进程切换啊?也就是说,当调用schedule() 函数后,其后的代码要等到重新调度后,才会被执行?


  1.     __attribute__((regparm(3))) void _ _down(struct semaphore * sem)
  2.     {
  3.         DECLARE_WAITQUEUE(wait, current);
  4.         unsigned long flags;
  5.         current->state = TASK_UNINTERRUPTIBLE;
  6.         spin_lock_irqsave(&sem->wait.lock, flags);
  7.         add_wait_queue_exclusive_locked(&sem->wait, &wait);
  8.         sem->sleepers++;
  9.         for (;;) {
  10.             if (!atomic_add_negative(sem->sleepers-1, &sem->count)) {
  11.                 sem->sleepers = 0;
  12.                 break;
  13.             }
  14.             sem->sleepers = 1;
  15.             spin_unlock_irqrestore(&sem->wait.lock, flags);
  16.             schedule( );
  17.             spin_lock_irqsave(&sem->wait.lock, flags);
  18.             current->state = TASK_UNINTERRUPTIBLE;
  19.         }
  20.         remove_wait_queue_locked(&sem->wait, &wait);
  21.         wake_up_locked(&sem->wait);
  22.         spin_unlock_irqrestore(&sem->wait.lock, flags);
  23.         current->state = TASK_RUNNING;
  24.     }
复制代码

论坛徽章:
0
2 [报告]
发表于 2009-07-02 14:23 |只看该作者

回复 #1 goooogo 的帖子

自己顶一下,请大侠们指点。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP