提交 2d14fa39 编写于 作者: S Szabolcs Nagy 提交者: Rich Felker

fix aarch64 atomics to load/store 32bit only

a_ll/a_sc inline asm used 64bit register operands (%0) instead of 32bit
ones (%w0), this at least broke a_and_64 (which always cleared the top
32bit, leaking memory in malloc).
上级 b17fbd35
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
static inline int a_ll(volatile int *p) static inline int a_ll(volatile int *p)
{ {
int v; int v;
__asm__ __volatile__ ("ldaxr %0, %1" : "=r"(v) : "Q"(*p)); __asm__ __volatile__ ("ldaxr %w0,%1" : "=r"(v) : "Q"(*p));
return v; return v;
} }
...@@ -10,7 +10,7 @@ static inline int a_ll(volatile int *p) ...@@ -10,7 +10,7 @@ static inline int a_ll(volatile int *p)
static inline int a_sc(volatile int *p, int v) static inline int a_sc(volatile int *p, int v)
{ {
int r; int r;
__asm__ __volatile__ ("stlxr %w0,%1,%2" : "=&r"(r) : "r"(v), "Q"(*p) : "memory"); __asm__ __volatile__ ("stlxr %w0,%w1,%2" : "=&r"(r) : "r"(v), "Q"(*p) : "memory");
return !r; return !r;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册