Skip to content

Commit 99641e0

Browse files
author
Peter Zijlstra
committed
x86/uaccess: Remove .fixup usage
For the !CC_AS_ASM_GOTO_OUTPUT (aka. the legacy codepath), remove the .fixup usage by employing both EX_TYPE_EFAULT_REG and EX_FLAG_CLEAR. Like was already done for X86_32's version of __get_user_asm_u64() use the "a" register for output, specifically so we can use CLEAR_AX. Signed-off-by: Peter Zijlstra (Intel) <[email protected]> Reviewed-by: Josh Poimboeuf <[email protected]> Link: https://lore.kernel.org/r/[email protected]
1 parent 4c132d1 commit 99641e0

File tree

1 file changed

+17
-22
lines changed

1 file changed

+17
-22
lines changed

arch/x86/include/asm/uaccess.h

Lines changed: 17 additions & 22 deletions
Original file line numberDiff line numberDiff line change
@@ -351,24 +351,22 @@ do { \
351351
"1: movl %[lowbits],%%eax\n" \
352352
"2: movl %[highbits],%%edx\n" \
353353
"3:\n" \
354-
".section .fixup,\"ax\"\n" \
355-
"4: mov %[efault],%[errout]\n" \
356-
" xorl %%eax,%%eax\n" \
357-
" xorl %%edx,%%edx\n" \
358-
" jmp 3b\n" \
359-
".previous\n" \
360-
_ASM_EXTABLE_UA(1b, 4b) \
361-
_ASM_EXTABLE_UA(2b, 4b) \
354+
_ASM_EXTABLE_TYPE_REG(1b, 3b, EX_TYPE_EFAULT_REG | \
355+
EX_FLAG_CLEAR_AX_DX, \
356+
%[errout]) \
357+
_ASM_EXTABLE_TYPE_REG(2b, 3b, EX_TYPE_EFAULT_REG | \
358+
EX_FLAG_CLEAR_AX_DX, \
359+
%[errout]) \
362360
: [errout] "=r" (retval), \
363361
[output] "=&A"(x) \
364362
: [lowbits] "m" (__m(__ptr)), \
365363
[highbits] "m" __m(((u32 __user *)(__ptr)) + 1), \
366-
[efault] "i" (-EFAULT), "0" (retval)); \
364+
"0" (retval)); \
367365
})
368366

369367
#else
370368
#define __get_user_asm_u64(x, ptr, retval) \
371-
__get_user_asm(x, ptr, retval, "q", "=r")
369+
__get_user_asm(x, ptr, retval, "q")
372370
#endif
373371

374372
#define __get_user_size(x, ptr, size, retval) \
@@ -379,14 +377,14 @@ do { \
379377
__chk_user_ptr(ptr); \
380378
switch (size) { \
381379
case 1: \
382-
__get_user_asm(x_u8__, ptr, retval, "b", "=q"); \
380+
__get_user_asm(x_u8__, ptr, retval, "b"); \
383381
(x) = x_u8__; \
384382
break; \
385383
case 2: \
386-
__get_user_asm(x, ptr, retval, "w", "=r"); \
384+
__get_user_asm(x, ptr, retval, "w"); \
387385
break; \
388386
case 4: \
389-
__get_user_asm(x, ptr, retval, "l", "=r"); \
387+
__get_user_asm(x, ptr, retval, "l"); \
390388
break; \
391389
case 8: \
392390
__get_user_asm_u64(x, ptr, retval); \
@@ -396,20 +394,17 @@ do { \
396394
} \
397395
} while (0)
398396

399-
#define __get_user_asm(x, addr, err, itype, ltype) \
397+
#define __get_user_asm(x, addr, err, itype) \
400398
asm volatile("\n" \
401399
"1: mov"itype" %[umem],%[output]\n" \
402400
"2:\n" \
403-
".section .fixup,\"ax\"\n" \
404-
"3: mov %[efault],%[errout]\n" \
405-
" xorl %k[output],%k[output]\n" \
406-
" jmp 2b\n" \
407-
".previous\n" \
408-
_ASM_EXTABLE_UA(1b, 3b) \
401+
_ASM_EXTABLE_TYPE_REG(1b, 2b, EX_TYPE_EFAULT_REG | \
402+
EX_FLAG_CLEAR_AX, \
403+
%[errout]) \
409404
: [errout] "=r" (err), \
410-
[output] ltype(x) \
405+
[output] "=a" (x) \
411406
: [umem] "m" (__m(addr)), \
412-
[efault] "i" (-EFAULT), "0" (err))
407+
"0" (err))
413408

414409
#endif // CONFIG_CC_HAS_ASM_GOTO_OUTPUT
415410

0 commit comments

Comments
 (0)