LinuxSir.cn,穿越时空的Linuxsir!

 找回密码
 注册
搜索
热搜: shell linux mysql
查看: 1779|回复: 1

__asm__ __volatile__("": : :"memory");啥意

[复制链接]
发表于 2009-5-21 17:07:02 | 显示全部楼层 |阅读模式
在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手册中怎么没找到呢?
请大侠告诉我是哪一个手册,并且最好能把上面那段对阐述对应的英文原文贴出来!十分感谢!
发表于 2009-5-22 00:48:06 | 显示全部楼层
情景分析里有些介绍
回复 支持 反对

使用道具 举报

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

本版积分规则

快速回复 返回顶部 返回列表