Merge branch 'per_signal_struct_coredumps-for-v5.16' of git://git.kernel.org/pub...
authorLinus Torvalds <torvalds@linux-foundation.org>
Wed, 3 Nov 2021 19:15:29 +0000 (12:15 -0700)
committerLinus Torvalds <torvalds@linux-foundation.org>
Wed, 3 Nov 2021 19:15:29 +0000 (12:15 -0700)
commita602285ac11b019e9ce7c3907328e9f95f4967f0
tree387df215e3cb20d38b5122eaf727a0a39d334d5a
parent5c4e0a21fae877a7ef89be6dcc6263ec672372b8
parent3f66f86bfed33dee2e9c1d0e14486915bb0750b0
Merge branch 'per_signal_struct_coredumps-for-v5.16' of git://git./linux/kernel/git/ebiederm/user-namespace

Pull per signal_struct coredumps from Eric Biederman:
 "Current coredumps are mixed up with the exit code, the signal handling
  code, and the ptrace code making coredumps much more complicated than
  necessary and difficult to follow.

  This series of changes starts with ptrace_stop and cleans it up,
  making it easier to follow what is happening in ptrace_stop. Then
  cleans up the exec interactions with coredumps. Then cleans up the
  coredump interactions with exit. Finally the coredump interactions
  with the signal handling code is cleaned up.

  The first and last changes are bug fixes for minor bugs.

  I believe the fact that vfork followed by execve can kill the process
  the called vfork if exec fails is sufficient justification to change
  the userspace visible behavior.

  In previous discussions some of these changes were organized
  differently and individually appeared to make the code base worse. As
  currently written I believe they all stand on their own as cleanups
  and bug fixes.

  Which means that even if the worst should happen and the last change
  needs to be reverted for some unimaginable reason, the code base will
  still be improved.

  If the worst does not happen there are a more cleanups that can be
  made. Signals that generate coredumps can easily become eligible for
  short circuit delivery in complete_signal. The entire rendezvous for
  generating a coredump can move into get_signal. The function
  force_sig_info_to_task be written in a way that does not modify the
  signal handling state of the target task (because coredumps are
  eligible for short circuit delivery). Many of these future cleanups
  can be done another way but nothing so cleanly as if coredumps become
  per signal_struct"

* 'per_signal_struct_coredumps-for-v5.16' of git://git.kernel.org/pub/scm/linux/kernel/git/ebiederm/user-namespace:
  coredump: Limit coredumps to a single thread group
  coredump:  Don't perform any cleanups before dumping core
  exit: Factor coredump_exit_mm out of exit_mm
  exec: Check for a pending fatal signal instead of core_state
  ptrace: Remove the unnecessary arguments from arch_ptrace_stop
  signal: Remove the bogus sigkill_pending in ptrace_stop
arch/ia64/include/asm/ptrace.h
fs/binfmt_elf.c
fs/proc/array.c
include/linux/mm_types.h
include/linux/sched.h
kernel/exit.c
kernel/fork.c
kernel/signal.c
mm/debug.c
mm/oom_kill.c