diff options
author | Linus Torvalds <torvalds@woody.osdl.org> | 2006-12-07 11:59:11 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@woody.osdl.org> | 2006-12-07 11:59:11 -0500 |
commit | 4522d58275f124105819723e24e912c8e5bf3cdd (patch) | |
tree | b92c29014fadffe049c1925676037f0092b8d112 /arch/i386/kernel/ptrace.c | |
parent | 6cf24f031bc97cb5a7c9df3b6e73c45b628b2b28 (diff) | |
parent | 64a26a731235b59c9d73bbe82c1f896d57400d37 (diff) |
Merge branch 'for-linus' of git://one.firstfloor.org/home/andi/git/linux-2.6
* 'for-linus' of git://one.firstfloor.org/home/andi/git/linux-2.6: (156 commits)
[PATCH] x86-64: Export smp_call_function_single
[PATCH] i386: Clean up smp_tune_scheduling()
[PATCH] unwinder: move .eh_frame to RODATA
[PATCH] unwinder: fully support linker generated .eh_frame_hdr section
[PATCH] x86-64: don't use set_irq_regs()
[PATCH] x86-64: check vector in setup_ioapic_dest to verify if need setup_IO_APIC_irq
[PATCH] x86-64: Make ix86 default to HIGHMEM4G instead of NOHIGHMEM
[PATCH] i386: replace kmalloc+memset with kzalloc
[PATCH] x86-64: remove remaining pc98 code
[PATCH] x86-64: remove unused variable
[PATCH] x86-64: Fix constraints in atomic_add_return()
[PATCH] x86-64: fix asm constraints in i386 atomic_add_return
[PATCH] x86-64: Correct documentation for bzImage protocol v2.05
[PATCH] x86-64: replace kmalloc+memset with kzalloc in MTRR code
[PATCH] x86-64: Fix numaq build error
[PATCH] x86-64: include/asm-x86_64/cpufeature.h isn't a userspace header
[PATCH] unwinder: Add debugging output to the Dwarf2 unwinder
[PATCH] x86-64: Clarify error message in GART code
[PATCH] x86-64: Fix interrupt race in idle callback (3rd try)
[PATCH] x86-64: Remove unwind stack pointer alignment forcing again
...
Fixed conflict in include/linux/uaccess.h manually
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'arch/i386/kernel/ptrace.c')
-rw-r--r-- | arch/i386/kernel/ptrace.c | 18 |
1 files changed, 6 insertions, 12 deletions
diff --git a/arch/i386/kernel/ptrace.c b/arch/i386/kernel/ptrace.c index 775f50e9395b..f3f94ac5736a 100644 --- a/arch/i386/kernel/ptrace.c +++ b/arch/i386/kernel/ptrace.c | |||
@@ -94,13 +94,9 @@ static int putreg(struct task_struct *child, | |||
94 | return -EIO; | 94 | return -EIO; |
95 | child->thread.fs = value; | 95 | child->thread.fs = value; |
96 | return 0; | 96 | return 0; |
97 | case GS: | ||
98 | if (value && (value & 3) != 3) | ||
99 | return -EIO; | ||
100 | child->thread.gs = value; | ||
101 | return 0; | ||
102 | case DS: | 97 | case DS: |
103 | case ES: | 98 | case ES: |
99 | case GS: | ||
104 | if (value && (value & 3) != 3) | 100 | if (value && (value & 3) != 3) |
105 | return -EIO; | 101 | return -EIO; |
106 | value &= 0xffff; | 102 | value &= 0xffff; |
@@ -116,8 +112,8 @@ static int putreg(struct task_struct *child, | |||
116 | value |= get_stack_long(child, EFL_OFFSET) & ~FLAG_MASK; | 112 | value |= get_stack_long(child, EFL_OFFSET) & ~FLAG_MASK; |
117 | break; | 113 | break; |
118 | } | 114 | } |
119 | if (regno > GS*4) | 115 | if (regno > ES*4) |
120 | regno -= 2*4; | 116 | regno -= 1*4; |
121 | put_stack_long(child, regno - sizeof(struct pt_regs), value); | 117 | put_stack_long(child, regno - sizeof(struct pt_regs), value); |
122 | return 0; | 118 | return 0; |
123 | } | 119 | } |
@@ -131,18 +127,16 @@ static unsigned long getreg(struct task_struct *child, | |||
131 | case FS: | 127 | case FS: |
132 | retval = child->thread.fs; | 128 | retval = child->thread.fs; |
133 | break; | 129 | break; |
134 | case GS: | ||
135 | retval = child->thread.gs; | ||
136 | break; | ||
137 | case DS: | 130 | case DS: |
138 | case ES: | 131 | case ES: |
132 | case GS: | ||
139 | case SS: | 133 | case SS: |
140 | case CS: | 134 | case CS: |
141 | retval = 0xffff; | 135 | retval = 0xffff; |
142 | /* fall through */ | 136 | /* fall through */ |
143 | default: | 137 | default: |
144 | if (regno > GS*4) | 138 | if (regno > ES*4) |
145 | regno -= 2*4; | 139 | regno -= 1*4; |
146 | regno = regno - sizeof(struct pt_regs); | 140 | regno = regno - sizeof(struct pt_regs); |
147 | retval &= get_stack_long(child, regno); | 141 | retval &= get_stack_long(child, regno); |
148 | } | 142 | } |