syscall.c 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Copyright (C) 2002 - 2007 Jeff Dike (jdike@{addtoit,linux.intel}.com)
  4. */
  5. #include <linux/kernel.h>
  6. #include <linux/ptrace.h>
  7. #include <linux/seccomp.h>
  8. #include <kern_util.h>
  9. #include <sysdep/ptrace.h>
  10. #include <sysdep/ptrace_user.h>
  11. #include <sysdep/syscalls.h>
  12. #include <linux/time-internal.h>
  13. #include <asm/unistd.h>
  14. void handle_syscall(struct uml_pt_regs *r)
  15. {
  16. struct pt_regs *regs = container_of(r, struct pt_regs, regs);
  17. int syscall;
  18. /*
  19. * If we have infinite CPU resources, then make every syscall also a
  20. * preemption point, since we don't have any other preemption in this
  21. * case, and kernel threads would basically never run until userspace
  22. * went to sleep, even if said userspace interacts with the kernel in
  23. * various ways.
  24. */
  25. if (time_travel_mode == TT_MODE_INFCPU ||
  26. time_travel_mode == TT_MODE_EXTERNAL)
  27. schedule();
  28. /* Initialize the syscall number and default return value. */
  29. UPT_SYSCALL_NR(r) = PT_SYSCALL_NR(r->gp);
  30. PT_REGS_SET_SYSCALL_RETURN(regs, -ENOSYS);
  31. if (syscall_trace_enter(regs))
  32. goto out;
  33. /* Do the seccomp check after ptrace; failures should be fast. */
  34. if (secure_computing() == -1)
  35. goto out;
  36. syscall = UPT_SYSCALL_NR(r);
  37. if (syscall >= 0 && syscall < __NR_syscalls)
  38. PT_REGS_SET_SYSCALL_RETURN(regs,
  39. EXECUTE_SYSCALL(syscall, regs));
  40. out:
  41. syscall_trace_leave(regs);
  42. }