From: Linus Torvalds Date: Tue, 29 Mar 2022 00:29:53 +0000 (-0700) Subject: Merge tag 'ptrace-cleanups-for-v5.18' of git://git.kernel.org/pub/scm/linux/kernel... X-Git-Url: http://git.maquefel.me/?a=commitdiff_plain;h=1930a6e739c4b4a654a69164dbe39e554d228915;p=linux.git Merge tag 'ptrace-cleanups-for-v5.18' of git://git./linux/kernel/git/ebiederm/user-namespace Pull ptrace cleanups from Eric Biederman: "This set of changes removes tracehook.h, moves modification of all of the ptrace fields inside of siglock to remove races, adds a missing permission check to ptrace.c The removal of tracehook.h is quite significant as it has been a major source of confusion in recent years. Much of that confusion was around task_work and TIF_NOTIFY_SIGNAL (which I have now decoupled making the semantics clearer). For people who don't know tracehook.h is a vestiage of an attempt to implement uprobes like functionality that was never fully merged, and was later superseeded by uprobes when uprobes was merged. For many years now we have been removing what tracehook functionaly a little bit at a time. To the point where anything left in tracehook.h was some weird strange thing that was difficult to understand" * tag 'ptrace-cleanups-for-v5.18' of git://git.kernel.org/pub/scm/linux/kernel/git/ebiederm/user-namespace: ptrace: Remove duplicated include in ptrace.c ptrace: Check PTRACE_O_SUSPEND_SECCOMP permission on PTRACE_SEIZE ptrace: Return the signal to continue with from ptrace_stop ptrace: Move setting/clearing ptrace_message into ptrace_stop tracehook: Remove tracehook.h resume_user_mode: Move to resume_user_mode.h resume_user_mode: Remove #ifdef TIF_NOTIFY_RESUME in set_notify_resume signal: Move set_notify_signal and clear_notify_signal into sched/signal.h task_work: Decouple TIF_NOTIFY_SIGNAL and task_work task_work: Call tracehook_notify_signal from get_signal on all architectures task_work: Introduce task_work_pending task_work: Remove unnecessary include from posix_timers.h ptrace: Remove tracehook_signal_handler ptrace: Remove arch_syscall_{enter,exit}_tracehook ptrace: Create ptrace_report_syscall_{entry,exit} in ptrace.h ptrace/arm: Rename tracehook_report_syscall report_syscall ptrace: Move ptrace_report_syscall into ptrace.h --- 1930a6e739c4b4a654a69164dbe39e554d228915 diff --cc block/blk-cgroup.c index d53b0d69dd736,4d8be1634bc62..0430926426fe3 --- a/block/blk-cgroup.c +++ b/block/blk-cgroup.c @@@ -26,7 -26,9 +26,7 @@@ #include #include #include - #include -#include + #include #include #include #include "blk.h" diff --cc kernel/entry/common.c index ed10a95a6b1dc,a86823cad8531..ef8d94a98b7ec --- a/kernel/entry/common.c +++ b/kernel/entry/common.c @@@ -2,8 -2,8 +2,9 @@@ #include #include + #include #include +#include #include #include #include @@@ -139,28 -139,8 +140,20 @@@ void noinstr exit_to_user_mode(void } /* Workaround to allow gradual conversion of architecture code */ - void __weak arch_do_signal_or_restart(struct pt_regs *regs, bool has_signal) { } - - static void handle_signal_work(struct pt_regs *regs, unsigned long ti_work) - { - if (ti_work & _TIF_NOTIFY_SIGNAL) - tracehook_notify_signal(); - - arch_do_signal_or_restart(regs, ti_work & _TIF_SIGPENDING); - } + void __weak arch_do_signal_or_restart(struct pt_regs *regs) { } +#ifdef CONFIG_RT_DELAYED_SIGNALS +static inline void raise_delayed_signal(void) +{ + if (unlikely(current->forced_info.si_signo)) { + force_sig_info(¤t->forced_info); + current->forced_info.si_signo = 0; + } +} +#else +static inline void raise_delayed_signal(void) { } +#endif + static unsigned long exit_to_user_mode_loop(struct pt_regs *regs, unsigned long ti_work) { diff --cc kernel/sched/fair.c index ee0664c9d291e,095b0aa378df0..d4bd299d67abf --- a/kernel/sched/fair.c +++ b/kernel/sched/fair.c @@@ -20,38 -20,7 +20,39 @@@ * Adaptive scheduling granularity, math enhancements by Peter Zijlstra * Copyright (C) 2007 Red Hat, Inc., Peter Zijlstra */ +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include +#include +#include +#include +#include +#include +#include ++#include + +#include + +#include + #include "sched.h" +#include "stats.h" +#include "autogroup.h" /* * Targeted preemption latency for CPU-bound tasks: