Commit 7b90dc40 authored by Mark Rutland's avatar Mark Rutland Committed by Catalin Marinas

arm64: uaccess cleanup macro naming

Now the uaccess primitives use LDTR/STTR unconditionally, the
uao_{ldp,stp,user_alternative} asm macros are misnamed, and have a
redundant argument. Let's remove the redundant argument and rename these
to user_{ldp,stp,ldst} respectively to clean this up.
Signed-off-by: default avatarMark Rutland <mark.rutland@arm.com>
Reviewed-by: default avatarRobin Murohy <robin.murphy@arm.com>
Cc: Christoph Hellwig <hch@lst.de>
Cc: James Morse <james.morse@arm.com>
Cc: Will Deacon <will@kernel.org>
Link: https://lore.kernel.org/r/20201202131558.39270-9-mark.rutland@arm.comSigned-off-by: default avatarCatalin Marinas <catalin.marinas@arm.com>
parent fc703d80
...@@ -63,7 +63,7 @@ alternative_else_nop_endif ...@@ -63,7 +63,7 @@ alternative_else_nop_endif
* This is complicated as there is no post-increment or pair versions of the * This is complicated as there is no post-increment or pair versions of the
* unprivileged instructions, and USER() only works for single instructions. * unprivileged instructions, and USER() only works for single instructions.
*/ */
.macro uao_ldp l, reg1, reg2, addr, post_inc .macro user_ldp l, reg1, reg2, addr, post_inc
8888: ldtr \reg1, [\addr]; 8888: ldtr \reg1, [\addr];
8889: ldtr \reg2, [\addr, #8]; 8889: ldtr \reg2, [\addr, #8];
add \addr, \addr, \post_inc; add \addr, \addr, \post_inc;
...@@ -72,7 +72,7 @@ alternative_else_nop_endif ...@@ -72,7 +72,7 @@ alternative_else_nop_endif
_asm_extable 8889b,\l; _asm_extable 8889b,\l;
.endm .endm
.macro uao_stp l, reg1, reg2, addr, post_inc .macro user_stp l, reg1, reg2, addr, post_inc
8888: sttr \reg1, [\addr]; 8888: sttr \reg1, [\addr];
8889: sttr \reg2, [\addr, #8]; 8889: sttr \reg2, [\addr, #8];
add \addr, \addr, \post_inc; add \addr, \addr, \post_inc;
...@@ -81,8 +81,8 @@ alternative_else_nop_endif ...@@ -81,8 +81,8 @@ alternative_else_nop_endif
_asm_extable 8889b,\l; _asm_extable 8889b,\l;
.endm .endm
.macro uao_user_alternative l, inst, alt_inst, reg, addr, post_inc .macro user_ldst l, inst, reg, addr, post_inc
8888: \alt_inst \reg, [\addr]; 8888: \inst \reg, [\addr];
add \addr, \addr, \post_inc; add \addr, \addr, \post_inc;
_asm_extable 8888b,\l; _asm_extable 8888b,\l;
......
...@@ -24,20 +24,20 @@ SYM_FUNC_START(__arch_clear_user) ...@@ -24,20 +24,20 @@ SYM_FUNC_START(__arch_clear_user)
subs x1, x1, #8 subs x1, x1, #8
b.mi 2f b.mi 2f
1: 1:
uao_user_alternative 9f, str, sttr, xzr, x0, 8 user_ldst 9f, sttr, xzr, x0, 8
subs x1, x1, #8 subs x1, x1, #8
b.pl 1b b.pl 1b
2: adds x1, x1, #4 2: adds x1, x1, #4
b.mi 3f b.mi 3f
uao_user_alternative 9f, str, sttr, wzr, x0, 4 user_ldst 9f, sttr, wzr, x0, 4
sub x1, x1, #4 sub x1, x1, #4
3: adds x1, x1, #2 3: adds x1, x1, #2
b.mi 4f b.mi 4f
uao_user_alternative 9f, strh, sttrh, wzr, x0, 2 user_ldst 9f, sttrh, wzr, x0, 2
sub x1, x1, #2 sub x1, x1, #2
4: adds x1, x1, #1 4: adds x1, x1, #1
b.mi 5f b.mi 5f
uao_user_alternative 9f, strb, sttrb, wzr, x0, 0 user_ldst 9f, sttrb, wzr, x0, 0
5: mov x0, #0 5: mov x0, #0
ret ret
SYM_FUNC_END(__arch_clear_user) SYM_FUNC_END(__arch_clear_user)
......
...@@ -21,7 +21,7 @@ ...@@ -21,7 +21,7 @@
*/ */
.macro ldrb1 reg, ptr, val .macro ldrb1 reg, ptr, val
uao_user_alternative 9998f, ldrb, ldtrb, \reg, \ptr, \val user_ldst 9998f, ldtrb, \reg, \ptr, \val
.endm .endm
.macro strb1 reg, ptr, val .macro strb1 reg, ptr, val
...@@ -29,7 +29,7 @@ ...@@ -29,7 +29,7 @@
.endm .endm
.macro ldrh1 reg, ptr, val .macro ldrh1 reg, ptr, val
uao_user_alternative 9998f, ldrh, ldtrh, \reg, \ptr, \val user_ldst 9998f, ldtrh, \reg, \ptr, \val
.endm .endm
.macro strh1 reg, ptr, val .macro strh1 reg, ptr, val
...@@ -37,7 +37,7 @@ ...@@ -37,7 +37,7 @@
.endm .endm
.macro ldr1 reg, ptr, val .macro ldr1 reg, ptr, val
uao_user_alternative 9998f, ldr, ldtr, \reg, \ptr, \val user_ldst 9998f, ldtr, \reg, \ptr, \val
.endm .endm
.macro str1 reg, ptr, val .macro str1 reg, ptr, val
...@@ -45,7 +45,7 @@ ...@@ -45,7 +45,7 @@
.endm .endm
.macro ldp1 reg1, reg2, ptr, val .macro ldp1 reg1, reg2, ptr, val
uao_ldp 9998f, \reg1, \reg2, \ptr, \val user_ldp 9998f, \reg1, \reg2, \ptr, \val
.endm .endm
.macro stp1 reg1, reg2, ptr, val .macro stp1 reg1, reg2, ptr, val
......
...@@ -22,35 +22,35 @@ ...@@ -22,35 +22,35 @@
* x0 - bytes not copied * x0 - bytes not copied
*/ */
.macro ldrb1 reg, ptr, val .macro ldrb1 reg, ptr, val
uao_user_alternative 9998f, ldrb, ldtrb, \reg, \ptr, \val user_ldst 9998f, ldtrb, \reg, \ptr, \val
.endm .endm
.macro strb1 reg, ptr, val .macro strb1 reg, ptr, val
uao_user_alternative 9998f, strb, sttrb, \reg, \ptr, \val user_ldst 9998f, sttrb, \reg, \ptr, \val
.endm .endm
.macro ldrh1 reg, ptr, val .macro ldrh1 reg, ptr, val
uao_user_alternative 9998f, ldrh, ldtrh, \reg, \ptr, \val user_ldst 9998f, ldtrh, \reg, \ptr, \val
.endm .endm
.macro strh1 reg, ptr, val .macro strh1 reg, ptr, val
uao_user_alternative 9998f, strh, sttrh, \reg, \ptr, \val user_ldst 9998f, sttrh, \reg, \ptr, \val
.endm .endm
.macro ldr1 reg, ptr, val .macro ldr1 reg, ptr, val
uao_user_alternative 9998f, ldr, ldtr, \reg, \ptr, \val user_ldst 9998f, ldtr, \reg, \ptr, \val
.endm .endm
.macro str1 reg, ptr, val .macro str1 reg, ptr, val
uao_user_alternative 9998f, str, sttr, \reg, \ptr, \val user_ldst 9998f, sttr, \reg, \ptr, \val
.endm .endm
.macro ldp1 reg1, reg2, ptr, val .macro ldp1 reg1, reg2, ptr, val
uao_ldp 9998f, \reg1, \reg2, \ptr, \val user_ldp 9998f, \reg1, \reg2, \ptr, \val
.endm .endm
.macro stp1 reg1, reg2, ptr, val .macro stp1 reg1, reg2, ptr, val
uao_stp 9998f, \reg1, \reg2, \ptr, \val user_stp 9998f, \reg1, \reg2, \ptr, \val
.endm .endm
end .req x5 end .req x5
......
...@@ -24,7 +24,7 @@ ...@@ -24,7 +24,7 @@
.endm .endm
.macro strb1 reg, ptr, val .macro strb1 reg, ptr, val
uao_user_alternative 9998f, strb, sttrb, \reg, \ptr, \val user_ldst 9998f, sttrb, \reg, \ptr, \val
.endm .endm
.macro ldrh1 reg, ptr, val .macro ldrh1 reg, ptr, val
...@@ -32,7 +32,7 @@ ...@@ -32,7 +32,7 @@
.endm .endm
.macro strh1 reg, ptr, val .macro strh1 reg, ptr, val
uao_user_alternative 9998f, strh, sttrh, \reg, \ptr, \val user_ldst 9998f, sttrh, \reg, \ptr, \val
.endm .endm
.macro ldr1 reg, ptr, val .macro ldr1 reg, ptr, val
...@@ -40,7 +40,7 @@ ...@@ -40,7 +40,7 @@
.endm .endm
.macro str1 reg, ptr, val .macro str1 reg, ptr, val
uao_user_alternative 9998f, str, sttr, \reg, \ptr, \val user_ldst 9998f, sttr, \reg, \ptr, \val
.endm .endm
.macro ldp1 reg1, reg2, ptr, val .macro ldp1 reg1, reg2, ptr, val
...@@ -48,7 +48,7 @@ ...@@ -48,7 +48,7 @@
.endm .endm
.macro stp1 reg1, reg2, ptr, val .macro stp1 reg1, reg2, ptr, val
uao_stp 9998f, \reg1, \reg2, \ptr, \val user_stp 9998f, \reg1, \reg2, \ptr, \val
.endm .endm
end .req x5 end .req x5
......
...@@ -67,7 +67,7 @@ SYM_FUNC_START(mte_copy_tags_from_user) ...@@ -67,7 +67,7 @@ SYM_FUNC_START(mte_copy_tags_from_user)
mov x3, x1 mov x3, x1
cbz x2, 2f cbz x2, 2f
1: 1:
uao_user_alternative 2f, ldrb, ldtrb, w4, x1, 0 user_ldst 2f, ldtrb, w4, x1, 0
lsl x4, x4, #MTE_TAG_SHIFT lsl x4, x4, #MTE_TAG_SHIFT
stg x4, [x0], #MTE_GRANULE_SIZE stg x4, [x0], #MTE_GRANULE_SIZE
add x1, x1, #1 add x1, x1, #1
...@@ -94,7 +94,7 @@ SYM_FUNC_START(mte_copy_tags_to_user) ...@@ -94,7 +94,7 @@ SYM_FUNC_START(mte_copy_tags_to_user)
1: 1:
ldg x4, [x1] ldg x4, [x1]
ubfx x4, x4, #MTE_TAG_SHIFT, #MTE_TAG_SIZE ubfx x4, x4, #MTE_TAG_SHIFT, #MTE_TAG_SIZE
uao_user_alternative 2f, strb, sttrb, w4, x0, 0 user_ldst 2f, sttrb, w4, x0, 0
add x0, x0, #1 add x0, x0, #1
add x1, x1, #MTE_GRANULE_SIZE add x1, x1, #MTE_GRANULE_SIZE
subs x2, x2, #1 subs x2, x2, #1
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment