 1bd0950835
			
		
	
	
	1bd0950835
	
	
	
		
			
			Use the generic ptrace_resume code for PTRACE_SYSCALL, PTRACE_CONT, PTRACE_KILL and PTRACE_SINGLESTEP. This implies defining arch_has_single_step in <asm/ptrace.h> and implementing the user_enable_single_step and user_disable_single_step functions, which also causes the breakpoint information to be cleared on fork, which could be considered a bug fix. Also the TIF_SYSCALL_TRACE thread flag is now cleared on PTRACE_KILL which it previously wasn't which is consistent with all architectures using the modern ptrace code. XXX: I'm not sure arch_has_single_step() is placed in the exactly correct location, please verify in which of the ptrace headers it should really be. Signed-off-by: Christoph Hellwig <hch@lst.de> Cc: Oleg Nesterov <oleg@redhat.com> Cc: Roland McGrath <roland@redhat.com> Cc: Jeff Dike <jdike@addtoit.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
		
			
				
	
	
		
			57 lines
		
	
	
	
		
			1.5 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			57 lines
		
	
	
	
		
			1.5 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
| /* 
 | |
|  * Copyright (C) 2000 - 2007 Jeff Dike (jdike@{addtoit,linux.intel}.com)
 | |
|  * Licensed under the GPL
 | |
|  */
 | |
| 
 | |
| #ifndef __UM_PTRACE_GENERIC_H
 | |
| #define __UM_PTRACE_GENERIC_H
 | |
| 
 | |
| #ifndef __ASSEMBLY__
 | |
| 
 | |
| #include <asm/ptrace-abi.h>
 | |
| #include <asm/user.h>
 | |
| #include "sysdep/ptrace.h"
 | |
| 
 | |
| struct pt_regs {
 | |
| 	struct uml_pt_regs regs;
 | |
| };
 | |
| 
 | |
| #define arch_has_single_step()	(1)
 | |
| 
 | |
| #define EMPTY_REGS { .regs = EMPTY_UML_PT_REGS }
 | |
| 
 | |
| #define PT_REGS_IP(r) UPT_IP(&(r)->regs)
 | |
| #define PT_REGS_SP(r) UPT_SP(&(r)->regs)
 | |
| 
 | |
| #define PT_REG(r, reg) UPT_REG(&(r)->regs, reg)
 | |
| #define PT_REGS_SET(r, reg, val) UPT_SET(&(r)->regs, reg, val)
 | |
| 
 | |
| #define PT_REGS_SET_SYSCALL_RETURN(r, res) \
 | |
| 	UPT_SET_SYSCALL_RETURN(&(r)->regs, res)
 | |
| #define PT_REGS_RESTART_SYSCALL(r) UPT_RESTART_SYSCALL(&(r)->regs)
 | |
| 
 | |
| #define PT_REGS_SYSCALL_NR(r) UPT_SYSCALL_NR(&(r)->regs)
 | |
| 
 | |
| #define PT_REGS_SC(r) UPT_SC(&(r)->regs)
 | |
| 
 | |
| #define instruction_pointer(regs) PT_REGS_IP(regs)
 | |
| 
 | |
| struct task_struct;
 | |
| 
 | |
| extern long subarch_ptrace(struct task_struct *child, long request, long addr,
 | |
| 			   long data);
 | |
| extern unsigned long getreg(struct task_struct *child, int regno);
 | |
| extern int putreg(struct task_struct *child, int regno, unsigned long value);
 | |
| extern int get_fpregs(struct user_i387_struct __user *buf,
 | |
| 		      struct task_struct *child);
 | |
| extern int set_fpregs(struct user_i387_struct __user *buf,
 | |
| 		      struct task_struct *child);
 | |
| 
 | |
| extern void show_regs(struct pt_regs *regs);
 | |
| 
 | |
| extern int arch_copy_tls(struct task_struct *new);
 | |
| extern void clear_flushed_tls(struct task_struct *task);
 | |
| 
 | |
| #endif
 | |
| 
 | |
| #endif
 |