Commit 2528de43 authored by Glauber Costa's avatar Glauber Costa Committed by Ingo Molnar

x86: use macros from asm.h.

In putuser_32.S and putuser_64.S, replace things like .quad, .long,
and explicit references to [r|e]ax for the apropriate macros
in asm/asm.h.
Signed-off-by: default avatarGlauber Costa <gcosta@redhat.com>
Signed-off-by: default avatarH. Peter Anvin <hpa@zytor.com>
Signed-off-by: default avatarIngo Molnar <mingo@elte.hu>
parent efea505d
...@@ -11,6 +11,7 @@ ...@@ -11,6 +11,7 @@
#include <linux/linkage.h> #include <linux/linkage.h>
#include <asm/dwarf2.h> #include <asm/dwarf2.h>
#include <asm/thread_info.h> #include <asm/thread_info.h>
#include <asm/asm.h>
/* /*
...@@ -26,50 +27,50 @@ ...@@ -26,50 +27,50 @@
*/ */
#define ENTER CFI_STARTPROC ; \ #define ENTER CFI_STARTPROC ; \
GET_THREAD_INFO(%ebx) GET_THREAD_INFO(%_ASM_BX)
#define EXIT ret ; \ #define EXIT ret ; \
CFI_ENDPROC CFI_ENDPROC
.text .text
ENTRY(__put_user_1) ENTRY(__put_user_1)
ENTER ENTER
cmp TI_addr_limit(%ebx),%ecx cmp TI_addr_limit(%_ASM_BX),%_ASM_CX
jae bad_put_user jae bad_put_user
1: movb %al,(%ecx) 1: movb %al,(%_ASM_CX)
xor %eax,%eax xor %eax,%eax
EXIT EXIT
ENDPROC(__put_user_1) ENDPROC(__put_user_1)
ENTRY(__put_user_2) ENTRY(__put_user_2)
ENTER ENTER
mov TI_addr_limit(%ebx),%ebx mov TI_addr_limit(%_ASM_BX),%_ASM_BX
sub $1,%ebx sub $1,%_ASM_BX
cmp %ebx,%ecx cmp %_ASM_BX,%_ASM_CX
jae bad_put_user jae bad_put_user
2: movw %ax,(%ecx) 2: movw %ax,(%_ASM_CX)
xor %eax,%eax xor %eax,%eax
EXIT EXIT
ENDPROC(__put_user_2) ENDPROC(__put_user_2)
ENTRY(__put_user_4) ENTRY(__put_user_4)
ENTER ENTER
mov TI_addr_limit(%ebx),%ebx mov TI_addr_limit(%_ASM_BX),%_ASM_BX
sub $3,%ebx sub $3,%_ASM_BX
cmp %ebx,%ecx cmp %_ASM_BX,%_ASM_CX
jae bad_put_user jae bad_put_user
3: movl %eax,(%ecx) 3: movl %eax,(%_ASM_CX)
xor %eax,%eax xor %eax,%eax
EXIT EXIT
ENDPROC(__put_user_4) ENDPROC(__put_user_4)
ENTRY(__put_user_8) ENTRY(__put_user_8)
ENTER ENTER
mov TI_addr_limit(%ebx),%ebx mov TI_addr_limit(%_ASM_BX),%_ASM_BX
sub $7,%ebx sub $7,%_ASM_BX
cmp %ebx,%ecx cmp %_ASM_BX,%_ASM_CX
jae bad_put_user jae bad_put_user
4: movl %eax,(%ecx) 4: movl %_ASM_AX,(%_ASM_CX)
5: movl %edx,4(%ecx) 5: movl %edx,4(%_ASM_CX)
xor %eax,%eax xor %eax,%eax
EXIT EXIT
ENDPROC(__put_user_8) ENDPROC(__put_user_8)
...@@ -81,9 +82,9 @@ bad_put_user: ...@@ -81,9 +82,9 @@ bad_put_user:
END(bad_put_user) END(bad_put_user)
.section __ex_table,"a" .section __ex_table,"a"
.long 1b,bad_put_user _ASM_PTR 1b,bad_put_user
.long 2b,bad_put_user _ASM_PTR 2b,bad_put_user
.long 3b,bad_put_user _ASM_PTR 3b,bad_put_user
.long 4b,bad_put_user _ASM_PTR 4b,bad_put_user
.long 5b,bad_put_user _ASM_PTR 5b,bad_put_user
.previous .previous
...@@ -30,64 +30,65 @@ ...@@ -30,64 +30,65 @@
#include <asm/errno.h> #include <asm/errno.h>
#include <asm/asm-offsets.h> #include <asm/asm-offsets.h>
#include <asm/thread_info.h> #include <asm/thread_info.h>
#include <asm/asm.h>
#define ENTER CFI_STARTPROC ; \ #define ENTER CFI_STARTPROC ; \
GET_THREAD_INFO(%rbx) GET_THREAD_INFO(%_ASM_BX)
#define EXIT ret ; \ #define EXIT ret ; \
CFI_ENDPROC CFI_ENDPROC
.text .text
ENTRY(__put_user_1) ENTRY(__put_user_1)
ENTER ENTER
cmp TI_addr_limit(%rbx),%rcx cmp TI_addr_limit(%_ASM_BX),%_ASM_CX
jae bad_put_user jae bad_put_user
1: movb %al,(%rcx) 1: movb %al,(%_ASM_CX)
xor %eax,%eax xor %eax,%eax
EXIT EXIT
ENDPROC(__put_user_1) ENDPROC(__put_user_1)
ENTRY(__put_user_2) ENTRY(__put_user_2)
ENTER ENTER
mov TI_addr_limit(%rbx),%rbx mov TI_addr_limit(%_ASM_BX),%_ASM_BX
sub $1, %rbx sub $1, %_ASM_BX
cmp %rbx ,%rcx cmp %_ASM_BX ,%_ASM_CX
jae bad_put_user jae bad_put_user
2: movw %ax,(%rcx) 2: movw %ax,(%_ASM_CX)
xor %eax,%eax xor %eax,%eax
EXIT EXIT
ENDPROC(__put_user_2) ENDPROC(__put_user_2)
ENTRY(__put_user_4) ENTRY(__put_user_4)
ENTER ENTER
mov TI_addr_limit(%rbx),%rbx mov TI_addr_limit(%_ASM_BX),%_ASM_BX
sub $3, %rbx sub $3, %_ASM_BX
cmp %rbx, %rcx cmp %_ASM_BX, %_ASM_CX
jae bad_put_user jae bad_put_user
3: movl %eax,(%rcx) 3: movl %eax,(%_ASM_CX)
xor %eax,%eax xor %eax,%eax
EXIT EXIT
ENDPROC(__put_user_4) ENDPROC(__put_user_4)
ENTRY(__put_user_8) ENTRY(__put_user_8)
ENTER ENTER
mov TI_addr_limit(%rbx),%rbx mov TI_addr_limit(%_ASM_BX),%_ASM_BX
sub $7, %rbx sub $7, %_ASM_BX
cmp %rbx, %rcx cmp %_ASM_BX, %_ASM_CX
jae bad_put_user jae bad_put_user
4: movq %rax,(%rcx) 4: movq %_ASM_AX,(%_ASM_CX)
xor %eax,%eax xor %eax,%eax
EXIT EXIT
ENDPROC(__put_user_8) ENDPROC(__put_user_8)
bad_put_user: bad_put_user:
CFI_STARTPROC CFI_STARTPROC
mov $(-EFAULT),%rax mov $(-EFAULT),%eax
EXIT EXIT
END(bad_put_user) END(bad_put_user)
.section __ex_table,"a" .section __ex_table,"a"
.quad 1b,bad_put_user _ASM_PTR 1b,bad_put_user
.quad 2b,bad_put_user _ASM_PTR 2b,bad_put_user
.quad 3b,bad_put_user _ASM_PTR 3b,bad_put_user
.quad 4b,bad_put_user _ASM_PTR 4b,bad_put_user
.previous .previous
...@@ -28,6 +28,8 @@ ...@@ -28,6 +28,8 @@
#define _ASM_SUB __ASM_SIZE(sub) #define _ASM_SUB __ASM_SIZE(sub)
#define _ASM_XADD __ASM_SIZE(xadd) #define _ASM_XADD __ASM_SIZE(xadd)
#define _ASM_AX __ASM_REG(ax) #define _ASM_AX __ASM_REG(ax)
#define _ASM_BX __ASM_REG(bx)
#define _ASM_CX __ASM_REG(cx)
#define _ASM_DX __ASM_REG(dx) #define _ASM_DX __ASM_REG(dx)
/* Exception table entry */ /* Exception table entry */
......
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