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