diff options
Diffstat (limited to 'arch/avr32/kernel/ptrace.c')
| -rw-r--r-- | arch/avr32/kernel/ptrace.c | 53 |
1 files changed, 7 insertions, 46 deletions
diff --git a/arch/avr32/kernel/ptrace.c b/arch/avr32/kernel/ptrace.c index 1fed38fcf59..dd5b882aab4 100644 --- a/arch/avr32/kernel/ptrace.c +++ b/arch/avr32/kernel/ptrace.c | |||
| @@ -28,9 +28,9 @@ static struct pt_regs *get_user_regs(struct task_struct *tsk) | |||
| 28 | THREAD_SIZE - sizeof(struct pt_regs)); | 28 | THREAD_SIZE - sizeof(struct pt_regs)); |
| 29 | } | 29 | } |
| 30 | 30 | ||
| 31 | static void ptrace_single_step(struct task_struct *tsk) | 31 | static void user_enable_single_step(struct task_struct *tsk) |
| 32 | { | 32 | { |
| 33 | pr_debug("ptrace_single_step: pid=%u, PC=0x%08lx, SR=0x%08lx\n", | 33 | pr_debug("user_enable_single_step: pid=%u, PC=0x%08lx, SR=0x%08lx\n", |
| 34 | tsk->pid, task_pt_regs(tsk)->pc, task_pt_regs(tsk)->sr); | 34 | tsk->pid, task_pt_regs(tsk)->pc, task_pt_regs(tsk)->sr); |
| 35 | 35 | ||
| 36 | /* | 36 | /* |
| @@ -49,6 +49,11 @@ static void ptrace_single_step(struct task_struct *tsk) | |||
| 49 | set_tsk_thread_flag(tsk, TIF_SINGLE_STEP); | 49 | set_tsk_thread_flag(tsk, TIF_SINGLE_STEP); |
| 50 | } | 50 | } |
| 51 | 51 | ||
| 52 | void user_disable_single_step(struct task_struct *child) | ||
| 53 | { | ||
| 54 | /* XXX(hch): a no-op here seems wrong.. */ | ||
| 55 | } | ||
| 56 | |||
| 52 | /* | 57 | /* |
| 53 | * Called by kernel/ptrace.c when detaching | 58 | * Called by kernel/ptrace.c when detaching |
| 54 | * | 59 | * |
| @@ -167,50 +172,6 @@ long arch_ptrace(struct task_struct *child, long request, long addr, long data) | |||
| 167 | ret = ptrace_write_user(child, addr, data); | 172 | ret = ptrace_write_user(child, addr, data); |
| 168 | break; | 173 | break; |
| 169 | 174 | ||
| 170 | /* continue and stop at next (return from) syscall */ | ||
| 171 | case PTRACE_SYSCALL: | ||
| 172 | /* restart after signal */ | ||
| 173 | case PTRACE_CONT: | ||
| 174 | ret = -EIO; | ||
| 175 | if (!valid_signal(data)) | ||
| 176 | break; | ||
| 177 | if (request == PTRACE_SYSCALL) | ||
| 178 | set_tsk_thread_flag(child, TIF_SYSCALL_TRACE); | ||
| 179 | else | ||
| 180 | clear_tsk_thread_flag(child, TIF_SYSCALL_TRACE); | ||
| 181 | child->exit_code = data; | ||
| 182 | /* XXX: Are we sure no breakpoints are active here? */ | ||
| 183 | wake_up_process(child); | ||
| 184 | ret = 0; | ||
| 185 | break; | ||
| 186 | |||
| 187 | /* | ||
| 188 | * Make the child exit. Best I can do is send it a | ||
| 189 | * SIGKILL. Perhaps it should be put in the status that it | ||
| 190 | * wants to exit. | ||
| 191 | */ | ||
| 192 | case PTRACE_KILL: | ||
| 193 | ret = 0; | ||
| 194 | if (child->exit_state == EXIT_ZOMBIE) | ||
| 195 | break; | ||
| 196 | child->exit_code = SIGKILL; | ||
| 197 | wake_up_process(child); | ||
| 198 | break; | ||
| 199 | |||
| 200 | /* | ||
| 201 | * execute single instruction. | ||
| 202 | */ | ||
| 203 | case PTRACE_SINGLESTEP: | ||
| 204 | ret = -EIO; | ||
| 205 | if (!valid_signal(data)) | ||
| 206 | break; | ||
| 207 | clear_tsk_thread_flag(child, TIF_SYSCALL_TRACE); | ||
| 208 | ptrace_single_step(child); | ||
| 209 | child->exit_code = data; | ||
| 210 | wake_up_process(child); | ||
| 211 | ret = 0; | ||
| 212 | break; | ||
| 213 | |||
| 214 | case PTRACE_GETREGS: | 175 | case PTRACE_GETREGS: |
| 215 | ret = ptrace_getregs(child, (void __user *)data); | 176 | ret = ptrace_getregs(child, (void __user *)data); |
| 216 | break; | 177 | break; |
