mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson
synced 2025-09-04 02:25:58 +00:00
x86/futex: Remove .fixup usage
Use the new EX_TYPE_IMM_REG to store -EFAULT into the designated 'ret' register, this removes the need for anonymous .fixup code. Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org> Reviewed-by: Josh Poimboeuf <jpoimboe@redhat.com> Link: https://lore.kernel.org/r/20211110101325.426016322@infradead.org
This commit is contained in:
parent
d52a7344bd
commit
4c132d1d84
@ -42,6 +42,8 @@
|
|||||||
#define EX_TYPE_DEFAULT_MCE_SAFE 14
|
#define EX_TYPE_DEFAULT_MCE_SAFE 14
|
||||||
#define EX_TYPE_FAULT_MCE_SAFE 15
|
#define EX_TYPE_FAULT_MCE_SAFE 15
|
||||||
#define EX_TYPE_POP_ZERO 16
|
#define EX_TYPE_POP_ZERO 16
|
||||||
|
|
||||||
#define EX_TYPE_IMM_REG 17 /* reg := (long)imm */
|
#define EX_TYPE_IMM_REG 17 /* reg := (long)imm */
|
||||||
|
#define EX_TYPE_EFAULT_REG (EX_TYPE_IMM_REG | EX_DATA_IMM(-EFAULT))
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -17,13 +17,9 @@ do { \
|
|||||||
int oldval = 0, ret; \
|
int oldval = 0, ret; \
|
||||||
asm volatile("1:\t" insn "\n" \
|
asm volatile("1:\t" insn "\n" \
|
||||||
"2:\n" \
|
"2:\n" \
|
||||||
"\t.section .fixup,\"ax\"\n" \
|
_ASM_EXTABLE_TYPE_REG(1b, 2b, EX_TYPE_EFAULT_REG, %1) \
|
||||||
"3:\tmov\t%3, %1\n" \
|
|
||||||
"\tjmp\t2b\n" \
|
|
||||||
"\t.previous\n" \
|
|
||||||
_ASM_EXTABLE_UA(1b, 3b) \
|
|
||||||
: "=r" (oldval), "=r" (ret), "+m" (*uaddr) \
|
: "=r" (oldval), "=r" (ret), "+m" (*uaddr) \
|
||||||
: "i" (-EFAULT), "0" (oparg), "1" (0)); \
|
: "0" (oparg), "1" (0)); \
|
||||||
if (ret) \
|
if (ret) \
|
||||||
goto label; \
|
goto label; \
|
||||||
*oval = oldval; \
|
*oval = oldval; \
|
||||||
@ -39,15 +35,11 @@ do { \
|
|||||||
"3:\t" LOCK_PREFIX "cmpxchgl %3, %2\n" \
|
"3:\t" LOCK_PREFIX "cmpxchgl %3, %2\n" \
|
||||||
"\tjnz\t2b\n" \
|
"\tjnz\t2b\n" \
|
||||||
"4:\n" \
|
"4:\n" \
|
||||||
"\t.section .fixup,\"ax\"\n" \
|
_ASM_EXTABLE_TYPE_REG(1b, 4b, EX_TYPE_EFAULT_REG, %1) \
|
||||||
"5:\tmov\t%5, %1\n" \
|
_ASM_EXTABLE_TYPE_REG(3b, 4b, EX_TYPE_EFAULT_REG, %1) \
|
||||||
"\tjmp\t4b\n" \
|
|
||||||
"\t.previous\n" \
|
|
||||||
_ASM_EXTABLE_UA(1b, 5b) \
|
|
||||||
_ASM_EXTABLE_UA(3b, 5b) \
|
|
||||||
: "=&a" (oldval), "=&r" (ret), \
|
: "=&a" (oldval), "=&r" (ret), \
|
||||||
"+m" (*uaddr), "=&r" (tem) \
|
"+m" (*uaddr), "=&r" (tem) \
|
||||||
: "r" (oparg), "i" (-EFAULT), "1" (0)); \
|
: "r" (oparg), "1" (0)); \
|
||||||
if (ret) \
|
if (ret) \
|
||||||
goto label; \
|
goto label; \
|
||||||
*oval = oldval; \
|
*oval = oldval; \
|
||||||
@ -95,15 +87,11 @@ static inline int futex_atomic_cmpxchg_inatomic(u32 *uval, u32 __user *uaddr,
|
|||||||
if (!user_access_begin(uaddr, sizeof(u32)))
|
if (!user_access_begin(uaddr, sizeof(u32)))
|
||||||
return -EFAULT;
|
return -EFAULT;
|
||||||
asm volatile("\n"
|
asm volatile("\n"
|
||||||
"1:\t" LOCK_PREFIX "cmpxchgl %4, %2\n"
|
"1:\t" LOCK_PREFIX "cmpxchgl %3, %2\n"
|
||||||
"2:\n"
|
"2:\n"
|
||||||
"\t.section .fixup, \"ax\"\n"
|
_ASM_EXTABLE_TYPE_REG(1b, 2b, EX_TYPE_EFAULT_REG, %0) \
|
||||||
"3:\tmov %3, %0\n"
|
|
||||||
"\tjmp 2b\n"
|
|
||||||
"\t.previous\n"
|
|
||||||
_ASM_EXTABLE_UA(1b, 3b)
|
|
||||||
: "+r" (ret), "=a" (oldval), "+m" (*uaddr)
|
: "+r" (ret), "=a" (oldval), "+m" (*uaddr)
|
||||||
: "i" (-EFAULT), "r" (newval), "1" (oldval)
|
: "r" (newval), "1" (oldval)
|
||||||
: "memory"
|
: "memory"
|
||||||
);
|
);
|
||||||
user_access_end();
|
user_access_end();
|
||||||
|
Loading…
Reference in New Issue
Block a user