4a6ed09b0f
Since we now rely on PTRACE_EVENT_CLONE being available (added in Linux 2.5.46), we're relying on NPTL. This commit removes the support for older LinuxThreads, as well as the workarounds for vendor 2.4 kernels with NPTL backported. - Rely on tkill being available. - Assume gdb doesn't get cancel signals. - Remove code that checks the LinuxThreads restart and cancel signals in the inferior. - Assume that __WALL is available. - Assume that non-leader threads report WIFEXITED. - Thus, no longer need to send signal 0 to check whether threads are still alive. - Update comments throughout. Tested on x86_64 Fedora 20, native and gdbserver. gdb/ChangeLog: * configure.ac: Remove tkill checks. * configure, config.in: Regenerate. * linux-nat.c: Remove HAVE_TKILL_SYSCALL check. Update top level comments. (linux_nat_post_attach_wait): Remove 'cloned' parameter. Use __WALL. (attach_proc_task_lwp_callback): Don't set the cloned flag. (linux_nat_attach): Adjust. (kill_lwp): Remove HAVE_TKILL_SYSCALL check. No longer fall back to 'kill'. (linux_handle_extended_wait): Use __WALL. Don't set the cloned flag. (wait_lwp): Use __WALL. Update comments. (running_callback, stop_and_resume_callback): Delete. (linux_nat_filter_event): Don't stop and resume all lwps. Don't check if the event LWP has previously exited. (check_zombie_leaders): Update comments. (linux_nat_wait_1): Use __WALL. (kill_wait_callback): Don't handle clone processes separately. Use __WALL instead. (linux_thread_alive): Delete. (linux_nat_thread_alive): Return true as long as the LWP is in the LWP list. (linux_nat_update_thread_list): Assume the kernel supports PTRACE_EVENT_CLONE. (get_signo): Delete. (lin_thread_get_thread_signals): Remove LinuxThreads references. No longer check __pthread_sig_restart / __pthread_sig_cancel in the inferior. * linux-nat.h (struct lwp_info) <cloned>: Delete field. * linux-thread-db.c: Update comments. (_initialize_thread_db): Remove LinuxThreads references. * nat/linux-waitpid.c (my_waitpid): No longer emulate __WALL. Pass down flags unmodified. * linux-waitpid.h (my_waitpid): Update documentation. gdb/gdbserver/ChangeLog: * linux-low.c (linux_kill_one_lwp): Remove references to LinuxThreads. (kill_lwp): Remove HAVE_TKILL_SYSCALL check. No longer fall back to 'kill'. (linux_init_signals): Delete. (initialize_low): Adjust. * thread-db.c (thread_db_init): Remove LinuxThreads reference.
98 lines
2.5 KiB
C
98 lines
2.5 KiB
C
/* Wrapper implementation for waitpid for GNU/Linux (LWP layer).
|
|
|
|
Copyright (C) 2001-2015 Free Software Foundation, Inc.
|
|
|
|
This file is part of GDB.
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
|
|
|
#include "common-defs.h"
|
|
|
|
#ifdef GDBSERVER
|
|
/* FIXME: server.h is required for the definition of debug_threads
|
|
which is used in the gdbserver-specific debug printing in
|
|
linux_debug. This code should be made available to GDB also,
|
|
but the lack of a suitable flag to enable it prevents this. */
|
|
#include "server.h"
|
|
#endif
|
|
|
|
#include "linux-nat.h"
|
|
#include "linux-waitpid.h"
|
|
#include "gdb_wait.h"
|
|
|
|
/* Print debugging output based on the format string FORMAT and
|
|
its parameters. */
|
|
|
|
static inline void
|
|
linux_debug (const char *format, ...)
|
|
{
|
|
#ifdef GDBSERVER
|
|
if (debug_threads)
|
|
{
|
|
va_list args;
|
|
va_start (args, format);
|
|
vfprintf (stderr, format, args);
|
|
va_end (args);
|
|
}
|
|
#endif
|
|
}
|
|
|
|
/* Convert wait status STATUS to a string. Used for printing debug
|
|
messages only. */
|
|
|
|
char *
|
|
status_to_str (int status)
|
|
{
|
|
static char buf[64];
|
|
|
|
if (WIFSTOPPED (status))
|
|
{
|
|
if (WSTOPSIG (status) == SYSCALL_SIGTRAP)
|
|
snprintf (buf, sizeof (buf), "%s (stopped at syscall)",
|
|
strsignal (SIGTRAP));
|
|
else
|
|
snprintf (buf, sizeof (buf), "%s (stopped)",
|
|
strsignal (WSTOPSIG (status)));
|
|
}
|
|
else if (WIFSIGNALED (status))
|
|
snprintf (buf, sizeof (buf), "%s (terminated)",
|
|
strsignal (WTERMSIG (status)));
|
|
else
|
|
snprintf (buf, sizeof (buf), "%d (exited)", WEXITSTATUS (status));
|
|
|
|
return buf;
|
|
}
|
|
|
|
/* See linux-waitpid.h. */
|
|
|
|
int
|
|
my_waitpid (int pid, int *status, int flags)
|
|
{
|
|
int ret, out_errno;
|
|
|
|
linux_debug ("my_waitpid (%d, 0x%x)\n", pid, flags);
|
|
|
|
do
|
|
{
|
|
ret = waitpid (pid, status, flags);
|
|
}
|
|
while (ret == -1 && errno == EINTR);
|
|
out_errno = errno;
|
|
|
|
linux_debug ("my_waitpid (%d, 0x%x): status(%x), %d\n",
|
|
pid, flags, (ret > 0 && status != NULL) ? *status : -1, ret);
|
|
|
|
errno = out_errno;
|
|
return ret;
|
|
}
|