x86和arm对于锁实现的差异

最近把一个分布式存储的application从x86移植到aarch64上,经过一大坨编译问题的改动,及一些汇编指令的修改,已经能够正常跑job了(这里已经解决syscall number不一致, page size64k等问题)。但是在测试terasort的时候,跑100G任务没问题,跑1T的任务会出现进程coredump的问题, gdb的发现a=b->c 类似这句话出错,出错的原因是b的不对,要么是0要么是一个非常大的值。


分析代码发现,这个b是从一个list里面取出来的。然后list add是在另外一个线程中操作的,所以直觉是锁不对。然后查看application代码,发现自己实现了一个所谓spinlock的东西,就是类似cmpxchg的东西,循环判断是否执行成功。这里我们已经把cmpxchg替换成gcc builtin的函数,通过汇编看到是ldaxr xx, stlxr。ldaxr 就是Load-acquire exclusive register,stlxr是store-release, 查看arm手册,理解这个是可以对应到x86的spin lock实现


开始怀疑是因为x86里面的store buffer刷新机制跟arm不一样,因为

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值