mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 49f731f197
			
		
	
	
		49f731f197
		
	
	
	
	
		
			
			__NR_syscall_max is only used by x86 and UML. In contrast, __NR_syscalls is widely used by all the architectures. Convert __NR_syscall_max to __NR_syscalls and adjust the usage sites. This prepares x86 to switch to the generic syscallhdr.sh script. Signed-off-by: Masahiro Yamada <masahiroy@kernel.org> Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Link: https://lore.kernel.org/r/20210517073815.97426-6-masahiroy@kernel.org
		
			
				
	
	
		
			51 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			51 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| // SPDX-License-Identifier: GPL-2.0
 | |
| /*
 | |
|  * Copyright (C) 2002 - 2007 Jeff Dike (jdike@{addtoit,linux.intel}.com)
 | |
|  */
 | |
| 
 | |
| #include <linux/kernel.h>
 | |
| #include <linux/ptrace.h>
 | |
| #include <linux/seccomp.h>
 | |
| #include <kern_util.h>
 | |
| #include <sysdep/ptrace.h>
 | |
| #include <sysdep/ptrace_user.h>
 | |
| #include <sysdep/syscalls.h>
 | |
| #include <linux/time-internal.h>
 | |
| #include <asm/unistd.h>
 | |
| 
 | |
| void handle_syscall(struct uml_pt_regs *r)
 | |
| {
 | |
| 	struct pt_regs *regs = container_of(r, struct pt_regs, regs);
 | |
| 	int syscall;
 | |
| 
 | |
| 	/*
 | |
| 	 * If we have infinite CPU resources, then make every syscall also a
 | |
| 	 * preemption point, since we don't have any other preemption in this
 | |
| 	 * case, and kernel threads would basically never run until userspace
 | |
| 	 * went to sleep, even if said userspace interacts with the kernel in
 | |
| 	 * various ways.
 | |
| 	 */
 | |
| 	if (time_travel_mode == TT_MODE_INFCPU ||
 | |
| 	    time_travel_mode == TT_MODE_EXTERNAL)
 | |
| 		schedule();
 | |
| 
 | |
| 	/* Initialize the syscall number and default return value. */
 | |
| 	UPT_SYSCALL_NR(r) = PT_SYSCALL_NR(r->gp);
 | |
| 	PT_REGS_SET_SYSCALL_RETURN(regs, -ENOSYS);
 | |
| 
 | |
| 	if (syscall_trace_enter(regs))
 | |
| 		goto out;
 | |
| 
 | |
| 	/* Do the seccomp check after ptrace; failures should be fast. */
 | |
| 	if (secure_computing() == -1)
 | |
| 		goto out;
 | |
| 
 | |
| 	syscall = UPT_SYSCALL_NR(r);
 | |
| 	if (syscall >= 0 && syscall < __NR_syscalls)
 | |
| 		PT_REGS_SET_SYSCALL_RETURN(regs,
 | |
| 				EXECUTE_SYSCALL(syscall, regs));
 | |
| 
 | |
| out:
 | |
| 	syscall_trace_leave(regs);
 | |
| }
 |