提交 210d3a90 编写于 作者: H Heiko Carstens 提交者: Martin Schwidefsky

[S390] Force link error if xchg/cmpxchg gets called with unsupported size.

Signed-off-by: NMartin Schwidefsky <schwidefsky@de.ibm.com>
Signed-off-by: NHeiko Carstens <heiko.carstens@de.ibm.com>
上级 c622498e
...@@ -130,6 +130,8 @@ extern void pfault_fini(void); ...@@ -130,6 +130,8 @@ extern void pfault_fini(void);
__ret; \ __ret; \
}) })
extern void __xchg_called_with_bad_pointer(void);
static inline unsigned long __xchg(unsigned long x, void * ptr, int size) static inline unsigned long __xchg(unsigned long x, void * ptr, int size)
{ {
unsigned long addr, old; unsigned long addr, old;
...@@ -150,8 +152,7 @@ static inline unsigned long __xchg(unsigned long x, void * ptr, int size) ...@@ -150,8 +152,7 @@ static inline unsigned long __xchg(unsigned long x, void * ptr, int size)
: "=&d" (old), "=m" (*(int *) addr) : "=&d" (old), "=m" (*(int *) addr)
: "d" (x << shift), "d" (~(255 << shift)), "a" (addr), : "d" (x << shift), "d" (~(255 << shift)), "a" (addr),
"m" (*(int *) addr) : "memory", "cc", "0"); "m" (*(int *) addr) : "memory", "cc", "0");
x = old >> shift; return old >> shift;
break;
case 2: case 2:
addr = (unsigned long) ptr; addr = (unsigned long) ptr;
shift = (2 ^ (addr & 2)) << 3; shift = (2 ^ (addr & 2)) << 3;
...@@ -166,8 +167,7 @@ static inline unsigned long __xchg(unsigned long x, void * ptr, int size) ...@@ -166,8 +167,7 @@ static inline unsigned long __xchg(unsigned long x, void * ptr, int size)
: "=&d" (old), "=m" (*(int *) addr) : "=&d" (old), "=m" (*(int *) addr)
: "d" (x << shift), "d" (~(65535 << shift)), "a" (addr), : "d" (x << shift), "d" (~(65535 << shift)), "a" (addr),
"m" (*(int *) addr) : "memory", "cc", "0"); "m" (*(int *) addr) : "memory", "cc", "0");
x = old >> shift; return old >> shift;
break;
case 4: case 4:
asm volatile( asm volatile(
" l %0,0(%3)\n" " l %0,0(%3)\n"
...@@ -176,8 +176,7 @@ static inline unsigned long __xchg(unsigned long x, void * ptr, int size) ...@@ -176,8 +176,7 @@ static inline unsigned long __xchg(unsigned long x, void * ptr, int size)
: "=&d" (old), "=m" (*(int *) ptr) : "=&d" (old), "=m" (*(int *) ptr)
: "d" (x), "a" (ptr), "m" (*(int *) ptr) : "d" (x), "a" (ptr), "m" (*(int *) ptr)
: "memory", "cc"); : "memory", "cc");
x = old; return old;
break;
#ifdef __s390x__ #ifdef __s390x__
case 8: case 8:
asm volatile( asm volatile(
...@@ -187,10 +186,10 @@ static inline unsigned long __xchg(unsigned long x, void * ptr, int size) ...@@ -187,10 +186,10 @@ static inline unsigned long __xchg(unsigned long x, void * ptr, int size)
: "=&d" (old), "=m" (*(long *) ptr) : "=&d" (old), "=m" (*(long *) ptr)
: "d" (x), "a" (ptr), "m" (*(long *) ptr) : "d" (x), "a" (ptr), "m" (*(long *) ptr)
: "memory", "cc"); : "memory", "cc");
x = old; return old;
break;
#endif /* __s390x__ */ #endif /* __s390x__ */
} }
__xchg_called_with_bad_pointer();
return x; return x;
} }
...@@ -206,6 +205,8 @@ static inline unsigned long __xchg(unsigned long x, void * ptr, int size) ...@@ -206,6 +205,8 @@ static inline unsigned long __xchg(unsigned long x, void * ptr, int size)
((__typeof__(*(ptr)))__cmpxchg((ptr),(unsigned long)(o),\ ((__typeof__(*(ptr)))__cmpxchg((ptr),(unsigned long)(o),\
(unsigned long)(n),sizeof(*(ptr)))) (unsigned long)(n),sizeof(*(ptr))))
extern void __cmpxchg_called_with_bad_pointer(void);
static inline unsigned long static inline unsigned long
__cmpxchg(volatile void *ptr, unsigned long old, unsigned long new, int size) __cmpxchg(volatile void *ptr, unsigned long old, unsigned long new, int size)
{ {
...@@ -270,6 +271,7 @@ __cmpxchg(volatile void *ptr, unsigned long old, unsigned long new, int size) ...@@ -270,6 +271,7 @@ __cmpxchg(volatile void *ptr, unsigned long old, unsigned long new, int size)
return prev; return prev;
#endif /* __s390x__ */ #endif /* __s390x__ */
} }
__cmpxchg_called_with_bad_pointer();
return old; return old;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册