免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 5464 | 回复: 4

__asm__ __volatile__("": : :"memory");啥意思啊? [复制链接]

论坛徽章:
0
发表于 2009-05-21 17:01 |显示全部楼层
在u-boot1.1.6 的lib_arm/board.c  的void start_armboot (void)函数中,有这样一行内嵌汇编:__asm__ __volatile__("": : :"memory");

我一开始不理解其中的"memory"是什么意思,
后来在网上看到说是设置“内存屏障”的,并找到了关于"memory"的一段阐述:
“memory强制gcc编译器假设RAM所有内存单元均被汇编指令修改,这样cpu中的registers和cache中已缓存的内存单元中的数据将作废。cpu将不得不在需要的时候重新读取内存中的数据。这就阻止了cpu又将registers,cache中的数据用于去优化指令,而避免去访问内存。”


我的问题是,这段关于"memory"的阐述,来自于哪一个权威文件或者英文手册?我在gcc手册中怎么没找到呢?
请大侠告诉我是哪一个手册,并且最好能把上面那段对阐述对应的英文原文贴出来!十分感谢!

论坛徽章:
3
2015年迎新春徽章
日期:2015-03-04 09:56:11数据库技术版块每日发帖之星
日期:2016-08-03 06:20:00数据库技术版块每日发帖之星
日期:2016-08-04 06:20:00
发表于 2009-05-22 10:15 |显示全部楼层

论坛徽章:
0
发表于 2010-09-19 14:32 |显示全部楼层
告诉gcc,我对内存做了改动

论坛徽章:
0
发表于 2010-09-20 00:30 |显示全部楼层
告诉gcc,我对内存做了改动
flystar707 发表于 2010-09-19 14:32



    简洁通俗!

论坛徽章:
14
水瓶座
日期:2014-06-10 09:51:0215-16赛季CBA联赛之江苏
日期:2017-11-27 11:42:3515-16赛季CBA联赛之八一
日期:2017-04-12 14:26:2815-16赛季CBA联赛之吉林
日期:2016-08-20 10:43:1215-16赛季CBA联赛之广夏
日期:2016-06-23 09:53:58程序设计版块每日发帖之星
日期:2016-02-11 06:20:00程序设计版块每日发帖之星
日期:2016-02-09 06:20:0015-16赛季CBA联赛之上海
日期:2015-12-25 16:40:3515-16赛季CBA联赛之广夏
日期:2015-12-22 09:39:36程序设计版块每日发帖之星
日期:2015-08-24 06:20:002015亚冠之德黑兰石油
日期:2015-08-07 09:57:302015年辞旧岁徽章
日期:2015-03-03 16:54:15
发表于 2016-04-09 21:34 |显示全部楼层
回复 1# 巨人史玉柱


    两个作用(均为编译器级别):1,告诉编译器内存变了,不要再使用cache或者register中的信息;2,告诉编译器不要做乱序优化,代码是什么顺序,生成代码就是什么顺序。
    asm volatile("":::"memory")不会插入任何指令。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP