Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 100051
b: refs/heads/master
c: 40faf46
h: refs/heads/master
i:
  100049: 81b80ac
  100047: b35bc7a
v: v3
  • Loading branch information
Glauber Costa authored and Ingo Molnar committed Jul 9, 2008
1 parent a109903 commit b10f7b7
Show file tree
Hide file tree
Showing 4 changed files with 35 additions and 31 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: ef8c1a2d0e990d0f4f15e1d45eeb262755e3d4c3
refs/heads/master: 40faf463e62de0b29722910eded7dd26cd8b684b
25 changes: 13 additions & 12 deletions trunk/arch/x86/lib/getuser_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 @@ -28,36 +29,36 @@
.text
ENTRY(__get_user_1)
CFI_STARTPROC
GET_THREAD_INFO(%edx)
cmp TI_addr_limit(%edx),%eax
GET_THREAD_INFO(%_ASM_DX)
cmp TI_addr_limit(%_ASM_DX),%_ASM_AX
jae bad_get_user
1: movzb (%eax),%edx
1: movzb (%_ASM_AX),%edx
xor %eax,%eax
ret
CFI_ENDPROC
ENDPROC(__get_user_1)

ENTRY(__get_user_2)
CFI_STARTPROC
add $1,%eax
add $1,%_ASM_AX
jc bad_get_user
GET_THREAD_INFO(%edx)
cmp TI_addr_limit(%edx),%eax
GET_THREAD_INFO(%_ASM_DX)
cmp TI_addr_limit(%_ASM_DX),%_ASM_AX
jae bad_get_user
2: movzwl -1(%eax),%edx
2: movzwl -1(%_ASM_AX),%edx
xor %eax,%eax
ret
CFI_ENDPROC
ENDPROC(__get_user_2)

ENTRY(__get_user_4)
CFI_STARTPROC
add $3,%eax
add $3,%_ASM_AX
jc bad_get_user
GET_THREAD_INFO(%edx)
cmp TI_addr_limit(%edx),%eax
GET_THREAD_INFO(%_ASM_DX)
cmp TI_addr_limit(%_ASM_DX),%_ASM_AX
jae bad_get_user
3: mov -3(%eax),%edx
3: mov -3(%_ASM_AX),%edx
xor %eax,%eax
ret
CFI_ENDPROC
Expand All @@ -66,7 +67,7 @@ ENDPROC(__get_user_4)
bad_get_user:
CFI_STARTPROC
xor %edx,%edx
mov $-14,%eax
mov $-14,%_ASM_AX
ret
CFI_ENDPROC
END(bad_get_user)
Expand Down
36 changes: 18 additions & 18 deletions trunk/arch/x86/lib/getuser_64.S
Original file line number Diff line number Diff line change
Expand Up @@ -13,14 +13,13 @@
/*
* __get_user_X
*
* Inputs: %rcx contains the address.
* Inputs: %rax contains the address.
* The register is modified, but all changes are undone
* before returning because the C code doesn't know about it.
*
* Outputs: %rax is error code (0 or -EFAULT)
* %rdx contains zero-extended value
*
* %r8 is destroyed.
*
* These functions should not modify any other registers,
* as they get called from within inline assembly.
Expand All @@ -32,53 +31,54 @@
#include <asm/errno.h>
#include <asm/asm-offsets.h>
#include <asm/thread_info.h>
#include <asm/asm.h>

.text
ENTRY(__get_user_1)
CFI_STARTPROC
GET_THREAD_INFO(%rdx)
cmp TI_addr_limit(%rdx),%rax
GET_THREAD_INFO(%_ASM_DX)
cmp TI_addr_limit(%_ASM_DX),%_ASM_AX
jae bad_get_user
1: movzb (%rax),%edx
1: movzb (%_ASM_AX),%edx
xor %eax,%eax
ret
CFI_ENDPROC
ENDPROC(__get_user_1)

ENTRY(__get_user_2)
CFI_STARTPROC
add $1,%rax
add $1,%_ASM_AX
jc bad_get_user
GET_THREAD_INFO(%rdx)
cmp TI_addr_limit(%rdx),%rax
GET_THREAD_INFO(%_ASM_DX)
cmp TI_addr_limit(%_ASM_DX),%_ASM_AX
jae bad_get_user
2: movzwl -1(%rax),%edx
2: movzwl -1(%_ASM_AX),%edx
xor %eax,%eax
ret
CFI_ENDPROC
ENDPROC(__get_user_2)

ENTRY(__get_user_4)
CFI_STARTPROC
add $3,%rax
add $3,%_ASM_AX
jc bad_get_user
GET_THREAD_INFO(%rdx)
cmp TI_addr_limit(%rdx),%rax
GET_THREAD_INFO(%_ASM_DX)
cmp TI_addr_limit(%_ASM_DX),%_ASM_AX
jae bad_get_user
3: mov -3(%rax),%edx
3: mov -3(%_ASM_AX),%edx
xor %eax,%eax
ret
CFI_ENDPROC
ENDPROC(__get_user_4)

ENTRY(__get_user_8)
CFI_STARTPROC
add $7,%rax
add $7,%_ASM_AX
jc bad_get_user
GET_THREAD_INFO(%rdx)
cmp TI_addr_limit(%rdx),%rax
GET_THREAD_INFO(%_ASM_DX)
cmp TI_addr_limit(%_ASM_DX),%_ASM_AX
jae bad_get_user
4: movq -7(%rax),%rdx
4: movq -7(%_ASM_AX),%_ASM_DX
xor %eax,%eax
ret
CFI_ENDPROC
Expand All @@ -87,7 +87,7 @@ ENDPROC(__get_user_8)
bad_get_user:
CFI_STARTPROC
xor %edx,%edx
mov $(-EFAULT),%rax
mov $(-EFAULT),%_ASM_AX
ret
CFI_ENDPROC
END(bad_get_user)
Expand Down
3 changes: 3 additions & 0 deletions trunk/include/asm-x86/asm.h
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@
#endif

#define __ASM_SIZE(inst) __ASM_SEL(inst##l, inst##q)
#define __ASM_REG(reg) __ASM_SEL(e##reg, r##reg)

#define _ASM_PTR __ASM_SEL(.long, .quad)
#define _ASM_ALIGN __ASM_SEL(.balign 4, .balign 8)
Expand All @@ -24,6 +25,8 @@
#define _ASM_ADD __ASM_SIZE(add)
#define _ASM_SUB __ASM_SIZE(sub)
#define _ASM_XADD __ASM_SIZE(xadd)
#define _ASM_AX __ASM_REG(ax)
#define _ASM_DX __ASM_REG(dx)

/* Exception table entry */
# define _ASM_EXTABLE(from,to) \
Expand Down

0 comments on commit b10f7b7

Please sign in to comment.