ADDR_COMPAT_LAYOUT breaks PTRACE_SEIZE

Andreas Schwab schwab at linux-m68k.org
Mon Mar 23 02:39:44 AEDT 2015


On ppc64, a process running with the ADDR_COMPAT_LAYOUT personality
causes ptrace(PTRACE_SEIZE) to hang in the kernel, unkillable.

#include <stdlib.h>
#include <unistd.h>
#include <signal.h>
#include <sys/personality.h>
#include <sys/ptrace.h>
#include <sys/wait.h>

int
main (void)
{
  pid_t child;

  personality (ADDR_COMPAT_LAYOUT);
  child = fork ();
  if (child == 0)
    {
      kill (getpid (), SIGSTOP);
      exit (0);
    }

  ptrace (PTRACE_SEIZE, child, NULL, NULL);
  wait (NULL);
  ptrace (PTRACE_CONT, child, NULL, NULL);
}

Andreas.

-- 
Andreas Schwab, schwab at linux-m68k.org
GPG Key fingerprint = 58CA 54C7 6D53 942B 1756  01D3 44D5 214B 8276 4ED5
"And now for something completely different."


More information about the Linuxppc-dev mailing list