免费注册 查看新帖 |

Chinaunix

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

[内核同步] 请问up模式下是否还需要mb(memory barrier)? [复制链接]

论坛徽章:
20
程序设计版块每日发帖之星
日期:2015-08-17 06:20:00程序设计版块每日发帖之星
日期:2016-07-16 06:20:00程序设计版块每日发帖之星
日期:2016-07-18 06:20:00每日论坛发贴之星
日期:2016-07-18 06:20:00黑曼巴
日期:2016-12-26 16:00:3215-16赛季CBA联赛之江苏
日期:2017-06-26 11:05:5615-16赛季CBA联赛之上海
日期:2017-07-21 18:12:5015-16赛季CBA联赛之青岛
日期:2017-09-04 17:32:0515-16赛季CBA联赛之吉林
日期:2018-03-26 10:02:16程序设计版块每日发帖之星
日期:2016-07-15 06:20:0015-16赛季CBA联赛之江苏
日期:2016-07-07 18:37:512015亚冠之萨济拖拉机
日期:2015-08-17 12:21:08
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-03-12 12:06 |只看该作者 |倒序浏览
最近正在学习@何登成的《CPU Cache and Memory Ordering(并发程序设计入门)》(不能发链接,可以在百度文库搜索 )
里面谈到了(page#50),Intel的CPU存在StoreLoad类型的乱序,在SMP场景下,需要使用mb来保证某些程序语义的正确性。
比如,X和Y初始值为0,cpu1执行thread1{ X = 1; r1 = Y; },cpu2执行thread2{ Y = 1; r2 = X; }
假设编译器不修改指令顺序,如果不使用mb,就会出现r1=r2=0的情况(两个CPU的load先于store完成)。(文档中有示例代码,并且实际测试会出现这种情况)

【问题】
我的问题是,如果thread1和thread2绑定到同一个cpu执行,还会出现r1=r2=0的结果吗?
我在没有mb的情况下测试了一下,结果没有出现。但我不知道理论上是不是存在可能性?总感觉极端任务切换造成的结果(指观察到的memory行为)跟SMP下应该是一样的?

PS:关于乱序执行,有几点没太想明白:
比如指令序列 { store X;inc rax;inc rbx;} 很有可能两条inc指令在store完成前执行完毕,如果此时发生了中断(意味着可能产生context switch),请问CPU在什么时候响应中断,应该不会等到X被写到内存吧?

论坛徽章:
0
2 [报告]
发表于 2015-03-20 12:02 |只看该作者
本帖最后由 l4rmbr 于 2015-03-20 12:02 编辑

回复 1# nswcfd


不会。

两个线程在一个CPU上切换,要依赖进程调度, 这个调度的实现隐含着MB。
   

论坛徽章:
0
3 [报告]
发表于 2015-03-21 14:55 |只看该作者
回复 1# nswcfd

需要的,SMP的情况下需要smp_mb之类的barrier。
然后up下面使用mb主要原因是,当读写外设地址空间的时候,要确保指令顺序以及指令能够及时刷到外设去,这个时候需要使用mb, 它的使用场景和smp完全不同。
这个虽然与具体的处理器有关系,但任何时候都要考虑到平台移植性而加上mb

Thanks



   

论坛徽章:
20
程序设计版块每日发帖之星
日期:2015-08-17 06:20:00程序设计版块每日发帖之星
日期:2016-07-16 06:20:00程序设计版块每日发帖之星
日期:2016-07-18 06:20:00每日论坛发贴之星
日期:2016-07-18 06:20:00黑曼巴
日期:2016-12-26 16:00:3215-16赛季CBA联赛之江苏
日期:2017-06-26 11:05:5615-16赛季CBA联赛之上海
日期:2017-07-21 18:12:5015-16赛季CBA联赛之青岛
日期:2017-09-04 17:32:0515-16赛季CBA联赛之吉林
日期:2018-03-26 10:02:16程序设计版块每日发帖之星
日期:2016-07-15 06:20:0015-16赛季CBA联赛之江苏
日期:2016-07-07 18:37:512015亚冠之萨济拖拉机
日期:2015-08-17 12:21:08
4 [报告]
发表于 2015-03-23 11:19 |只看该作者
感谢各位的答复,同时提供了一条信息量非常大的老帖子。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP