Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 100061
b: refs/heads/master
c: 2528de4
h: refs/heads/master
i:
  100059: 8898b03
v: v3
  • Loading branch information
Glauber Costa authored and Ingo Molnar committed Jul 9, 2008
1 parent cc3edaf commit a974d00
Show file tree
Hide file tree
Showing 4 changed files with 46 additions and 42 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: efea505d83873cfc8a7cdbb8a2a11d2c67467843
refs/heads/master: 2528de431ddb200653d1dc6ca90074bad9520f09
43 changes: 22 additions & 21 deletions trunk/arch/x86/lib/putuser_32.S
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@
#include <linux/linkage.h>
#include <asm/dwarf2.h>
#include <asm/thread_info.h>
#include <asm/asm.h>


/*
Expand All @@ -26,50 +27,50 @@
*/

#define ENTER CFI_STARTPROC ; \
GET_THREAD_INFO(%ebx)
GET_THREAD_INFO(%_ASM_BX)
#define EXIT ret ; \
CFI_ENDPROC

.text
ENTRY(__put_user_1)
ENTER
cmp TI_addr_limit(%ebx),%ecx
cmp TI_addr_limit(%_ASM_BX),%_ASM_CX
jae bad_put_user
1: movb %al,(%ecx)
1: movb %al,(%_ASM_CX)
xor %eax,%eax
EXIT
ENDPROC(__put_user_1)

ENTRY(__put_user_2)
ENTER
mov TI_addr_limit(%ebx),%ebx
sub $1,%ebx
cmp %ebx,%ecx
mov TI_addr_limit(%_ASM_BX),%_ASM_BX
sub $1,%_ASM_BX
cmp %_ASM_BX,%_ASM_CX
jae bad_put_user
2: movw %ax,(%ecx)
2: movw %ax,(%_ASM_CX)
xor %eax,%eax
EXIT
ENDPROC(__put_user_2)

ENTRY(__put_user_4)
ENTER
mov TI_addr_limit(%ebx),%ebx
sub $3,%ebx
cmp %ebx,%ecx
mov TI_addr_limit(%_ASM_BX),%_ASM_BX
sub $3,%_ASM_BX
cmp %_ASM_BX,%_ASM_CX
jae bad_put_user
3: movl %eax,(%ecx)
3: movl %eax,(%_ASM_CX)
xor %eax,%eax
EXIT
ENDPROC(__put_user_4)

ENTRY(__put_user_8)
ENTER
mov TI_addr_limit(%ebx),%ebx
sub $7,%ebx
cmp %ebx,%ecx
mov TI_addr_limit(%_ASM_BX),%_ASM_BX
sub $7,%_ASM_BX
cmp %_ASM_BX,%_ASM_CX
jae bad_put_user
4: movl %eax,(%ecx)
5: movl %edx,4(%ecx)
4: movl %_ASM_AX,(%_ASM_CX)
5: movl %edx,4(%_ASM_CX)
xor %eax,%eax
EXIT
ENDPROC(__put_user_8)
Expand All @@ -81,9 +82,9 @@ bad_put_user:
END(bad_put_user)

.section __ex_table,"a"
.long 1b,bad_put_user
.long 2b,bad_put_user
.long 3b,bad_put_user
.long 4b,bad_put_user
.long 5b,bad_put_user
_ASM_PTR 1b,bad_put_user
_ASM_PTR 2b,bad_put_user
_ASM_PTR 3b,bad_put_user
_ASM_PTR 4b,bad_put_user
_ASM_PTR 5b,bad_put_user
.previous
41 changes: 21 additions & 20 deletions trunk/arch/x86/lib/putuser_64.S
Original file line number Diff line number Diff line change
Expand Up @@ -30,64 +30,65 @@
#include <asm/errno.h>
#include <asm/asm-offsets.h>
#include <asm/thread_info.h>
#include <asm/asm.h>

#define ENTER CFI_STARTPROC ; \
GET_THREAD_INFO(%rbx)
GET_THREAD_INFO(%_ASM_BX)
#define EXIT ret ; \
CFI_ENDPROC

.text
ENTRY(__put_user_1)
ENTER
cmp TI_addr_limit(%rbx),%rcx
cmp TI_addr_limit(%_ASM_BX),%_ASM_CX
jae bad_put_user
1: movb %al,(%rcx)
1: movb %al,(%_ASM_CX)
xor %eax,%eax
EXIT
ENDPROC(__put_user_1)

ENTRY(__put_user_2)
ENTER
mov TI_addr_limit(%rbx),%rbx
sub $1, %rbx
cmp %rbx ,%rcx
mov TI_addr_limit(%_ASM_BX),%_ASM_BX
sub $1, %_ASM_BX
cmp %_ASM_BX ,%_ASM_CX
jae bad_put_user
2: movw %ax,(%rcx)
2: movw %ax,(%_ASM_CX)
xor %eax,%eax
EXIT
ENDPROC(__put_user_2)

ENTRY(__put_user_4)
ENTER
mov TI_addr_limit(%rbx),%rbx
sub $3, %rbx
cmp %rbx, %rcx
mov TI_addr_limit(%_ASM_BX),%_ASM_BX
sub $3, %_ASM_BX
cmp %_ASM_BX, %_ASM_CX
jae bad_put_user
3: movl %eax,(%rcx)
3: movl %eax,(%_ASM_CX)
xor %eax,%eax
EXIT
ENDPROC(__put_user_4)

ENTRY(__put_user_8)
ENTER
mov TI_addr_limit(%rbx),%rbx
sub $7, %rbx
cmp %rbx, %rcx
mov TI_addr_limit(%_ASM_BX),%_ASM_BX
sub $7, %_ASM_BX
cmp %_ASM_BX, %_ASM_CX
jae bad_put_user
4: movq %rax,(%rcx)
4: movq %_ASM_AX,(%_ASM_CX)
xor %eax,%eax
EXIT
ENDPROC(__put_user_8)

bad_put_user:
CFI_STARTPROC
mov $(-EFAULT),%rax
mov $(-EFAULT),%eax
EXIT
END(bad_put_user)

.section __ex_table,"a"
.quad 1b,bad_put_user
.quad 2b,bad_put_user
.quad 3b,bad_put_user
.quad 4b,bad_put_user
_ASM_PTR 1b,bad_put_user
_ASM_PTR 2b,bad_put_user
_ASM_PTR 3b,bad_put_user
_ASM_PTR 4b,bad_put_user
.previous
2 changes: 2 additions & 0 deletions trunk/include/asm-x86/asm.h
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,8 @@
#define _ASM_SUB __ASM_SIZE(sub)
#define _ASM_XADD __ASM_SIZE(xadd)
#define _ASM_AX __ASM_REG(ax)
#define _ASM_BX __ASM_REG(bx)
#define _ASM_CX __ASM_REG(cx)
#define _ASM_DX __ASM_REG(dx)

/* Exception table entry */
Expand Down

0 comments on commit a974d00

Please sign in to comment.