免费注册 查看新帖 |

Chinaunix

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

[内核同步] 关于自旋锁中的忙等的疑问 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-12-09 12:58 |只看该作者 |倒序浏览
我们知道内核中,如果某个自旋锁暂时获取不到,就进入一个忙等阶段,大概的代码归纳为:

while (lock != 1) {
    __asm__ __volatile__("rep;nop": : :"memory");
}

查了一些资料也不太清楚rep;nop的作用,我想问的是,如果这里就是简单的写一个死循环会怎样,即:
while (lock != 1);

请大牛指点!谢谢

论坛徽章:
0
2 [报告]
发表于 2012-12-09 13:06 |只看该作者
“如果用一段死循环来代替这个循环是不行的,那样会锁住总线,unlock想设置值都不能了。rep;nop就是要让CPU休息一下,把总线暂时让出来。”,看到别人有这种解释,对吗?

论坛徽章:
1
双鱼座
日期:2013-08-28 13:47:26
3 [报告]
发表于 2012-12-09 13:43 |只看该作者

论坛徽章:
0
4 [报告]
发表于 2012-12-09 15:27 |只看该作者
本帖最后由 dingyujie 于 2012-12-09 15:28 编辑

谢谢了,文章讲的很好!不过我的疑问是,如果不加这个指令,直接使用一个while循环会怎样呢?会像我在2楼上说的那样吗回复 3# firkraag


   

论坛徽章:
0
5 [报告]
发表于 2012-12-09 15:51 |只看该作者
3楼给的链接中说到了. nop 是编译为 pause, 也就是让CPU以极低的速率和功耗在运行. 如果不加 rep;nop, cpu是以极高的速率运行的,也就耗电.

而且,好像还有其他的目的, 是为了规避性能损失吧.

链接中有提到如下:
提升 spin-wait loops(自旋锁循环等待)的性能。在执行一个 spin-wait loop 时,Pentium4 处理器会
遇到严重的性能损失.PAUSE 指令会向处理器提供一种提示:告诉处理器所执行的代码序列是一个 spin-wait loop。
处理器会根据这个提示而避开内存序列冲突(memory order violation),也就是说对 spin-wait loop 不做缓存,不做指令
重新排序等动作。这样就可以大大的提高了处理器的性能。正是基于此,才建议在 spin-wait loops 中使用 pasuse 指令。

PAUSE指令的另外一个功能是让 Pentium4 处理器在执行 spin-wait loop 时可以减少电源的消耗。
在等待资源而执行自旋锁等待时,Pentium4 处理器以极快的速度执行自旋等待时,将会消耗很多电能,
但使用 pause 指令则可以极大的减少处理器的电能消耗。  

论坛徽章:
0
6 [报告]
发表于 2012-12-09 15:51 |只看该作者
@firkraag 学习了,谢谢你的链接.

论坛徽章:
0
7 [报告]
发表于 2012-12-09 20:20 来自手机 |只看该作者
一个忙等,有功耗考虑,有优化,不简单

论坛徽章:
4
天秤座
日期:2013-10-18 13:58:33金牛座
日期:2013-11-28 16:17:01辰龙
日期:2014-01-14 09:54:32戌狗
日期:2014-01-24 09:23:27
8 [报告]
发表于 2012-12-09 20:52 |只看该作者
pasuse 另外一个作用是,超线程一个线程pasuse 会将处理器让给另外一个线程,避免持有锁的线程挨饿。

论坛徽章:
0
9 [报告]
发表于 2012-12-10 08:51 |只看该作者
我觉得这句话还有这样的作用,让寄存器的值都失效,而要cpu重新从memory加载变量(lock)的值。否则如果一直从寄存器读取lock的值,那这就是个死循环了。

论坛徽章:
0
10 [报告]
发表于 2012-12-10 10:37 |只看该作者
有道理!  回复 9# leslielg


   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP