flagday: kill pt_regs argument of do_fork()
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
This commit is contained in:
		
					parent
					
						
							
								18c26c27ae
							
						
					
				
			
			
				commit
				
					
						e80d6661c3
					
				
			
		
					 9 changed files with 19 additions and 26 deletions
				
			
		|  | @ -135,7 +135,7 @@ asmlinkage int bfin_clone(unsigned long clone_flags, unsigned long newsp) | ||||||
| #endif | #endif | ||||||
| 	if (newsp) | 	if (newsp) | ||||||
| 		newsp -= 12; | 		newsp -= 12; | ||||||
| 	return do_fork(clone_flags, newsp, regs, 0, NULL, NULL); | 	return do_fork(clone_flags, newsp, 0, NULL, NULL); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| int | int | ||||||
|  |  | ||||||
|  | @ -116,13 +116,12 @@ GLOBAL_ENTRY(sys_clone2) | ||||||
| 	mov loc1=r16				// save ar.pfs across do_fork | 	mov loc1=r16				// save ar.pfs across do_fork | ||||||
| 	.body | 	.body | ||||||
| 	mov out1=in1 | 	mov out1=in1 | ||||||
| 	mov out3=in2 | 	mov out2=in2 | ||||||
| 	tbit.nz p6,p0=in0,CLONE_SETTLS_BIT | 	tbit.nz p6,p0=in0,CLONE_SETTLS_BIT | ||||||
| 	mov out4=in3	// parent_tidptr: valid only w/CLONE_PARENT_SETTID | 	mov out3=in3	// parent_tidptr: valid only w/CLONE_PARENT_SETTID | ||||||
| 	;;
 | 	;;
 | ||||||
| (p6)	st8 [r2]=in5				// store TLS in r16 for copy_thread() | (p6)	st8 [r2]=in5				// store TLS in r16 for copy_thread() | ||||||
| 	mov out5=in4	// child_tidptr:  valid only w/CLONE_CHILD_SETTID or CLONE_CHILD_CLEARTID | 	mov out4=in4	// child_tidptr:  valid only w/CLONE_CHILD_SETTID or CLONE_CHILD_CLEARTID | ||||||
| 	adds out2=IA64_SWITCH_STACK_SIZE+16,sp	// out2 = ®s |  | ||||||
| 	mov out0=in0				// out0 = clone_flags | 	mov out0=in0				// out0 = clone_flags | ||||||
| 	br.call.sptk.many rp=do_fork | 	br.call.sptk.many rp=do_fork | ||||||
| .ret1:	.restore sp
 | .ret1:	.restore sp
 | ||||||
|  | @ -148,13 +147,12 @@ GLOBAL_ENTRY(sys_clone) | ||||||
| 	mov loc1=r16				// save ar.pfs across do_fork | 	mov loc1=r16				// save ar.pfs across do_fork | ||||||
| 	.body | 	.body | ||||||
| 	mov out1=in1 | 	mov out1=in1 | ||||||
| 	mov out3=16				// stacksize (compensates for 16-byte scratch area) | 	mov out2=16				// stacksize (compensates for 16-byte scratch area) | ||||||
| 	tbit.nz p6,p0=in0,CLONE_SETTLS_BIT | 	tbit.nz p6,p0=in0,CLONE_SETTLS_BIT | ||||||
| 	mov out4=in2	// parent_tidptr: valid only w/CLONE_PARENT_SETTID | 	mov out3=in2	// parent_tidptr: valid only w/CLONE_PARENT_SETTID | ||||||
| 	;;
 | 	;;
 | ||||||
| (p6)	st8 [r2]=in4				// store TLS in r13 (tp) | (p6)	st8 [r2]=in4				// store TLS in r13 (tp) | ||||||
| 	mov out5=in3	// child_tidptr:  valid only w/CLONE_CHILD_SETTID or CLONE_CHILD_CLEARTID | 	mov out4=in3	// child_tidptr:  valid only w/CLONE_CHILD_SETTID or CLONE_CHILD_CLEARTID | ||||||
| 	adds out2=IA64_SWITCH_STACK_SIZE+16,sp	// out2 = ®s |  | ||||||
| 	mov out0=in0				// out0 = clone_flags | 	mov out0=in0				// out0 = clone_flags | ||||||
| 	br.call.sptk.many rp=do_fork | 	br.call.sptk.many rp=do_fork | ||||||
| .ret2:	.restore sp
 | .ret2:	.restore sp
 | ||||||
|  |  | ||||||
|  | @ -149,7 +149,7 @@ void flush_thread(void) | ||||||
| asmlinkage int m68k_clone(struct pt_regs *regs) | asmlinkage int m68k_clone(struct pt_regs *regs) | ||||||
| { | { | ||||||
| 	/* regs will be equal to current_pt_regs() */ | 	/* regs will be equal to current_pt_regs() */ | ||||||
| 	return do_fork(regs->d1, regs->d2, regs, 0, | 	return do_fork(regs->d1, regs->d2, 0, | ||||||
| 		       (int __user *)regs->d3, (int __user *)regs->d4); | 		       (int __user *)regs->d3, (int __user *)regs->d4); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -312,7 +312,7 @@ _sys32_clone(nabi_no_regargs struct pt_regs regs) | ||||||
| 	/* Use __dummy4 instead of getting it off the stack, so that
 | 	/* Use __dummy4 instead of getting it off the stack, so that
 | ||||||
| 	   syscall() works.  */ | 	   syscall() works.  */ | ||||||
| 	child_tidptr = (int __user *) __dummy4; | 	child_tidptr = (int __user *) __dummy4; | ||||||
| 	return do_fork(clone_flags, newsp, ®s, 0, | 	return do_fork(clone_flags, newsp, 0, | ||||||
| 	               parent_tidptr, child_tidptr); | 	               parent_tidptr, child_tidptr); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -92,7 +92,7 @@ save_static_function(sys_fork); | ||||||
| static int __used noinline | static int __used noinline | ||||||
| _sys_fork(nabi_no_regargs struct pt_regs regs) | _sys_fork(nabi_no_regargs struct pt_regs regs) | ||||||
| { | { | ||||||
| 	return do_fork(SIGCHLD, regs.regs[29], ®s, 0, NULL, NULL); | 	return do_fork(SIGCHLD, regs.regs[29], 0, NULL, NULL); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| save_static_function(sys_clone); | save_static_function(sys_clone); | ||||||
|  | @ -123,7 +123,7 @@ _sys_clone(nabi_no_regargs struct pt_regs regs) | ||||||
| #else | #else | ||||||
| 	child_tidptr = (int __user *) regs.regs[8]; | 	child_tidptr = (int __user *) regs.regs[8]; | ||||||
| #endif | #endif | ||||||
| 	return do_fork(clone_flags, newsp, ®s, 0, | 	return do_fork(clone_flags, newsp, 0, | ||||||
| 	               parent_tidptr, child_tidptr); | 	               parent_tidptr, child_tidptr); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -286,8 +286,7 @@ asmlinkage int sparc_do_fork(unsigned long clone_flags, | ||||||
| 	parent_tid_ptr = regs->u_regs[UREG_I2]; | 	parent_tid_ptr = regs->u_regs[UREG_I2]; | ||||||
| 	child_tid_ptr = regs->u_regs[UREG_I4]; | 	child_tid_ptr = regs->u_regs[UREG_I4]; | ||||||
| 
 | 
 | ||||||
| 	ret = do_fork(clone_flags, stack_start, | 	ret = do_fork(clone_flags, stack_start, stack_size, | ||||||
| 		      regs, stack_size, |  | ||||||
| 		      (int __user *) parent_tid_ptr, | 		      (int __user *) parent_tid_ptr, | ||||||
| 		      (int __user *) child_tid_ptr); | 		      (int __user *) child_tid_ptr); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -601,8 +601,7 @@ asmlinkage long sparc_do_fork(unsigned long clone_flags, | ||||||
| 		child_tid_ptr = (int __user *) regs->u_regs[UREG_I4]; | 		child_tid_ptr = (int __user *) regs->u_regs[UREG_I4]; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	ret = do_fork(clone_flags, stack_start, | 	ret = do_fork(clone_flags, stack_start, stack_size, | ||||||
| 		      regs, stack_size, |  | ||||||
| 		      parent_tid_ptr, child_tid_ptr); | 		      parent_tid_ptr, child_tid_ptr); | ||||||
| 
 | 
 | ||||||
| 	/* If we get an error and potentially restart the system
 | 	/* If we get an error and potentially restart the system
 | ||||||
|  |  | ||||||
|  | @ -2289,7 +2289,7 @@ extern int disallow_signal(int); | ||||||
| extern int do_execve(const char *, | extern int do_execve(const char *, | ||||||
| 		     const char __user * const __user *, | 		     const char __user * const __user *, | ||||||
| 		     const char __user * const __user *); | 		     const char __user * const __user *); | ||||||
| extern long do_fork(unsigned long, unsigned long, struct pt_regs *, unsigned long, int __user *, int __user *); | extern long do_fork(unsigned long, unsigned long, unsigned long, int __user *, int __user *); | ||||||
| struct task_struct *fork_idle(int); | struct task_struct *fork_idle(int); | ||||||
| #ifdef CONFIG_GENERIC_KERNEL_THREAD | #ifdef CONFIG_GENERIC_KERNEL_THREAD | ||||||
| extern pid_t kernel_thread(int (*fn)(void *), void *arg, unsigned long flags); | extern pid_t kernel_thread(int (*fn)(void *), void *arg, unsigned long flags); | ||||||
|  |  | ||||||
|  | @ -1527,8 +1527,6 @@ static inline void init_idle_pids(struct pid_link *links) | ||||||
| struct task_struct * __cpuinit fork_idle(int cpu) | struct task_struct * __cpuinit fork_idle(int cpu) | ||||||
| { | { | ||||||
| 	struct task_struct *task; | 	struct task_struct *task; | ||||||
| 	struct pt_regs regs; |  | ||||||
| 
 |  | ||||||
| 	task = copy_process(CLONE_VM, 0, 0, NULL, &init_struct_pid, 0); | 	task = copy_process(CLONE_VM, 0, 0, NULL, &init_struct_pid, 0); | ||||||
| 	if (!IS_ERR(task)) { | 	if (!IS_ERR(task)) { | ||||||
| 		init_idle_pids(task->pids); | 		init_idle_pids(task->pids); | ||||||
|  | @ -1546,7 +1544,6 @@ struct task_struct * __cpuinit fork_idle(int cpu) | ||||||
|  */ |  */ | ||||||
| long do_fork(unsigned long clone_flags, | long do_fork(unsigned long clone_flags, | ||||||
| 	      unsigned long stack_start, | 	      unsigned long stack_start, | ||||||
| 	      struct pt_regs *regs, |  | ||||||
| 	      unsigned long stack_size, | 	      unsigned long stack_size, | ||||||
| 	      int __user *parent_tidptr, | 	      int __user *parent_tidptr, | ||||||
| 	      int __user *child_tidptr) | 	      int __user *child_tidptr) | ||||||
|  | @ -1576,7 +1573,7 @@ long do_fork(unsigned long clone_flags, | ||||||
| 	 * requested, no event is reported; otherwise, report if the event | 	 * requested, no event is reported; otherwise, report if the event | ||||||
| 	 * for the type of forking is enabled. | 	 * for the type of forking is enabled. | ||||||
| 	 */ | 	 */ | ||||||
| 	if (!(clone_flags & CLONE_UNTRACED) && likely(user_mode(regs))) { | 	if (!(clone_flags & CLONE_UNTRACED)) { | ||||||
| 		if (clone_flags & CLONE_VFORK) | 		if (clone_flags & CLONE_VFORK) | ||||||
| 			trace = PTRACE_EVENT_VFORK; | 			trace = PTRACE_EVENT_VFORK; | ||||||
| 		else if ((clone_flags & CSIGNAL) != SIGCHLD) | 		else if ((clone_flags & CSIGNAL) != SIGCHLD) | ||||||
|  | @ -1632,7 +1629,7 @@ long do_fork(unsigned long clone_flags, | ||||||
|  */ |  */ | ||||||
| pid_t kernel_thread(int (*fn)(void *), void *arg, unsigned long flags) | pid_t kernel_thread(int (*fn)(void *), void *arg, unsigned long flags) | ||||||
| { | { | ||||||
| 	return do_fork(flags|CLONE_VM|CLONE_UNTRACED, (unsigned long)fn, NULL, | 	return do_fork(flags|CLONE_VM|CLONE_UNTRACED, (unsigned long)fn, | ||||||
| 		(unsigned long)arg, NULL, NULL); | 		(unsigned long)arg, NULL, NULL); | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|  | @ -1641,7 +1638,7 @@ pid_t kernel_thread(int (*fn)(void *), void *arg, unsigned long flags) | ||||||
| SYSCALL_DEFINE0(fork) | SYSCALL_DEFINE0(fork) | ||||||
| { | { | ||||||
| #ifdef CONFIG_MMU | #ifdef CONFIG_MMU | ||||||
| 	return do_fork(SIGCHLD, 0, current_pt_regs(), 0, NULL, NULL); | 	return do_fork(SIGCHLD, 0, 0, NULL, NULL); | ||||||
| #else | #else | ||||||
| 	/* can not support in nommu mode */ | 	/* can not support in nommu mode */ | ||||||
| 	return(-EINVAL); | 	return(-EINVAL); | ||||||
|  | @ -1652,7 +1649,7 @@ SYSCALL_DEFINE0(fork) | ||||||
| #ifdef __ARCH_WANT_SYS_VFORK | #ifdef __ARCH_WANT_SYS_VFORK | ||||||
| SYSCALL_DEFINE0(vfork) | SYSCALL_DEFINE0(vfork) | ||||||
| { | { | ||||||
| 	return do_fork(CLONE_VFORK | CLONE_VM | SIGCHLD, 0, current_pt_regs(), | 	return do_fork(CLONE_VFORK | CLONE_VM | SIGCHLD, 0,  | ||||||
| 			0, NULL, NULL); | 			0, NULL, NULL); | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|  | @ -1675,7 +1672,7 @@ SYSCALL_DEFINE5(clone, unsigned long, clone_flags, unsigned long, newsp, | ||||||
| 		 int, tls_val) | 		 int, tls_val) | ||||||
| #endif | #endif | ||||||
| { | { | ||||||
| 	return do_fork(clone_flags, newsp, current_pt_regs(), 0, | 	return do_fork(clone_flags, newsp, 0, | ||||||
| 		parent_tidptr, child_tidptr); | 		parent_tidptr, child_tidptr); | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Al Viro
				Al Viro