GCC 之 cas和cas2

cas.h

#if defined(__GNUC__)

#if defined(__GCC_HAVE_SYNC_COMPARE_AND_SWAP)
#define CAS  __sync_bool_compare_and_swap
#endif

//CAS2
#if defined(__x86_64__)

#if  defined(__GCC_HAVE_SYNC_COMPARE_AND_SWAP_16)
#define CAS2(p,o,n)  __sync_bool_compare_and_swap_16((long long *)(p), *(long long *)(&o), *(long long *)(&n))
#else
#define CAS2(p,o,n)  CAS2_IMPL((long long *)(p), (long *)(&o), (long *)(&n))
inline
bool CAS2_IMPL(long *addr,
        long * old_value,
        long * new_value)
{
    bool  ret;
    __asm__ __volatile__(
            "lock cmpxchg16b %1;\n"
            "sete %0;\n"
            :"=m"(ret),"+m" (*(volatile long long *) (addr))
            :"a" (old_value[0]), "d" (old_value[1]), "b" (new_value[0]), "c" (new_value[1]));
    return ret;
}
#endif

#else
#if !defined(__GCC_HAVE_SYNC_COMPARE_AND_SWAP_8)
#define CAS2(p,o,n)  __sync_bool_compare_and_swap_8((long long *)(p), *(long long *)(&o), *(long long *)(&n))
#else
#define CAS2(p,o,n)  CAS2_IMPL((long long *)(p), (long *)(&o), (long *)(&n))
inline
bool CAS2_IMPL(long long *addr,
        long * old_value,
        long * new_value)
{
    bool  ret;
    __asm__ __volatile__(
            "lock cmpxchg8b %1;\n"
            "sete %0;\n"
            :"=m"(ret),"+m" (*(volatile long long *) (addr))
            :"a" (old_value[0]), "d" (old_value[1]), "b" (new_value[0]), "c" (new_value[1]));
    return ret;
}

#endif

#endif //CAS2

#endif //__GNUC__

posted @   napoleon_liu  阅读(2876)  评论(0编辑  收藏  举报
编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 使用C#创建一个MCP客户端
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示