__asm__ __volatile__("": : :"memory");啥意思啊?

发布于 2022-09-18 17:43:36 字数 529 浏览 11 评论 0

在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手册中怎么没找到呢?
请大侠告诉我是哪一个手册,并且最好能把上面那段对阐述对应的英文原文贴出来!十分感谢!

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(4

护你周全 2022-09-25 17:43:36

告诉gcc,我对内存做了改动

死开点丶别碍眼 2022-09-25 17:43:36

告诉gcc,我对内存做了改动
flystar707 发表于 2010-09-19 14:32

    简洁通俗!

骄傲 2022-09-25 17:43:36

回复 1# 巨人史玉柱

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

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文