1 Star 0 Fork 0

BSCRL/log

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
atomicops_internals_arm64_gcc.h 1.85 KB
一键复制 编辑 原始数据 按行查看 历史
Wangtao 提交于 2024-09-12 09:54 . 新增arm的内存屏障
#ifndef BUTIL_ATOMICOPS_INTERNALS_ARM64_GCC_H_
#define BUTIL_ATOMICOPS_INTERNALS_ARM64_GCC_H_
#if defined(OS_QNX)
#include <sys/cpuinline.h>
#endif
namespace butil {
namespace subtle {
// NOLINT:这通常是一个注释,用于指示某些代码分析工具(如静态代码分析器)忽略这一行。
// 在这个上下文中,它可能是为了告诉代码检查工具不要对这条内联汇编指令进行特定的检查或警告。
// inline 关键字:这告诉编译器尝试将这个函数体直接插入到每个调用点,而不是像通常那样进行函数调用。
// 这可以减少函数调用的开销,但也可能导致代码膨胀。
// 然而,对于像内存屏障这样的简单函数,内联通常是有益的。
inline void MemoryBarrier()
{
// __asm__ __volatile__: 这是 GCC 的内联汇编语法。
// __asm__ 用于插入汇编代码,而 __volatile__ 告诉编译器不要优化或删除这段汇编代码,即使它看起来没有副作用。
// 这对于内存屏障等指令至关重要,因为它们的“副作用”是确保内存访问的顺序和可见性。
// "dmb ish":这是要执行的汇编指令。
// dmb 是 ARM 架构中的一个指令,用于在内存访问之间提供屏障,以确保指令的执行顺序。
// ish 指定了同步的域是 Inner Shareable domain,这意味着同步影响的是当前处理器的内部缓存以及与之共享缓存的其他处理器(在支持这种共享性的多核处理器系统中)。
// ::: 这是 GCC 内联汇编的 clobber 列表部分。
// 在这里,它被用来指定这条指令可能会影响“memory”,即整个内存空间。
// 这告诉编译器不要对这条指令周围的内存访问进行重排序。
__asm__ __volatile__ ("dmb ish" ::: "memory"); // NOLINT
}
}
}
#endif // BUTIL_ATOMICOPS_INTERNALS_ARM64_GCC_H_
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
C++
1
https://gitee.com/bscrl/log.git
[email protected]:bscrl/log.git
bscrl
log
log
master

搜索帮助