免费注册 查看新帖 |

Chinaunix

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

自旋锁引发的疑问 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-10-23 16:22 |只看该作者 |倒序浏览
书上讲自旋锁保护的临界区不能包含可能引起阻塞的代码,是因为阻塞会引起进程切换,切换出去后,另外进程企图获取自旋锁时,就会发生阻塞

问题是在执行自旋锁保护的代码时 不是不能发生抢占吗?为什么会发生进程切换呢

论坛徽章:
0
2 [报告]
发表于 2011-10-23 17:10 |只看该作者
阻塞是主动让出
抢占是被动的抢走
不同的情况

论坛徽章:
0
3 [报告]
发表于 2011-10-24 09:18 |只看该作者
回复 2# osant


    是的

论坛徽章:
0
4 [报告]
发表于 2011-10-24 12:28 |只看该作者
阻塞是主动让出
抢占是被动的抢走
不同的情况
osant 发表于 2011-10-23 17:10


可是《linux内核设计与实现》提到内核调用schedule()也属于内核抢占呢 应该怎么理解呢

论坛徽章:
0
5 [报告]
发表于 2011-10-29 16:30 |只看该作者
能否提供原文。
schedule()只是一个切换进程的函数。

论坛徽章:
0
6 [报告]
发表于 2011-10-30 02:25 |只看该作者
本帖最后由 251316192 于 2011-10-30 02:31 编辑

进程上下文自旋锁里不能有阻塞是因为阻塞是用等待队列实现的,挂队列,移出就绪队列,设置进程状态,执行调度函数让出cpu,此时新task,有可能执行同样的锁,就杯具了。
非进程上下文,不能执行睡眠有关的函数,因为不属于任何task。
补充下:
     内核抢占是中断,高优先级抢占。这里和抢占没关系,是自己切出cpu的。和内核抢占机制搭不上。

论坛徽章:
0
7 [报告]
发表于 2011-10-30 12:57 |只看该作者
进程上下文自旋锁里不能有阻塞是因为阻塞是用等待队列实现的,挂队列,移出就绪队列,设置进程状态,执行调度函数让出cpu,此时新task,有可能执行同样的锁,就杯具了。
251316192 发表于 2011-10-30 02:25


新的task,有可能执行同样的锁,就杯具了。这句话怎么理解呢
此时新的task,得不到锁时,大不了就自旋在那里,等待持有锁的进程唤醒后,不就可以结束自旋 得到锁了吗

论坛徽章:
0
8 [报告]
发表于 2011-10-30 15:13 |只看该作者
持有锁就禁止抢占了,一直在自旋,忙等待,什么都不能做,而锁的释放要原来的进程来释放,但内核抢占禁止,内核就down了。

论坛徽章:
0
9 [报告]
发表于 2011-10-31 10:42 |只看该作者
持有锁就禁止抢占了,一直在自旋,忙等待,什么都不能做,而锁的释放要原来的进程来释放,但内核抢占禁止, ...
251316192 发表于 2011-10-30 15:13

哦! 也就是说 锁在自旋的时候也是不可抢占的喽?

论坛徽章:
0
10 [报告]
发表于 2011-10-31 11:52 |只看该作者
回复 9# madope
是这样的,除非你自己放弃,就像你在获得锁的时候调用睡眠函数一样。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP