mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-06 12:09:26 +08:00
c8693053f8
GDB currently doesn't build on 32-bit Solaris: * On Solaris 11.4/x86: In file included from /usr/include/sys/procfs.h:26, from /vol/src/gnu/gdb/hg/master/dist/gdb/i386-sol2-nat.c:24: /usr/include/sys/old_procfs.h:31:2: error: #error "Cannot use procfs in the large file compilation environment" #error "Cannot use procfs in the large file compilation environment" ^~~~~ * On Solaris 11.3/x86 there are several more instances of this. The interaction between procfs and large-file support historically has been a royal mess on Solaris: * There are two versions of the procfs interface: ** The old ioctl-based /proc, deprecated and not used any longer in either gdb or binutils. ** The `new' (introduced in Solaris 2.6, 1997) structured /proc. * There are two headers one can possibly include: ** <procfs.h> which only provides the structured /proc, definining _STRUCTURED_PROC=1 and then including ... ** <sys/procfs.h> which defaults to _STRUCTURED_PROC=0, the ioctl-based /proc, but provides structured /proc if _STRUCTURED_PROC == 1. * procfs and the large-file environment didn't go well together: ** Until Solaris 11.3, <sys/procfs.h> would always #error in 32-bit compilations when the large-file environment was active (_FILE_OFFSET_BITS == 64). ** In both Solaris 11.4 and Illumos, this restriction was lifted for structured /proc. So one has to be careful always to define _STRUCTURED_PROC=1 when testing for or using <sys/procfs.h> on Solaris. As the errors above show, this isn't always the case in binutils-gdb right now. Also one may need to disable large-file support for 32-bit compilations on Solaris. config/largefile.m4 meant to do this by wrapping the AC_SYS_LARGEFILE autoconf macro with appropriate checks, yielding ACX_LARGEFILE. Unfortunately the macro doesn't always succeed because it neglects the _STRUCTURED_PROC part. To make things even worse, since GCC 9 g++ predefines _FILE_OFFSET_BITS=64 on Solaris. So even if largefile.m4 deciced not to enable large-file support, this has no effect, breaking the gdb build. This patch addresses all this as follows: * All tests for the <sys/procfs.h> header are made with _STRUCTURED_PROC=1, the definition going into the various config.h files instead of having to make them (and sometimes failing) in the affected sources. * To cope with the g++ predefine of _FILE_OFFSET_BITS=64, -U_FILE_OFFSET_BITS is added to various *_CPPFLAGS variables. It had been far easier to have just #undef _FILE_OFFSET_BITS in config.h, but unfortunately such a construct in config.in is commented by config.status irrespective of indentation and whitespace if large-file support is disabled. I found no way around this and putting the #undef in several global headers for bfd, binutils, ld, and gdb seemed way more invasive. * Last, the applicability check in largefile.m4 was modified only to disable largefile support if really needed. To do so, it checks if <sys/procfs.h> compiles with _FILE_OFFSET_BITS=64 defined. If it doesn't, the disabling only happens if gdb exists in-tree and isn't disabled, otherwise (building binutils from a tarball), there's no conflict. What initially confused me was the check for $plugins here, which originally caused the disabling not to take place. Since AC_PLUGINGS does enable plugin support if <dlfcn.h> exists (which it does on Solaris), the disabling never happened. I could find no explanation why the linker plugin needs large-file support but thought it would be enough if gld and GCC's lto-plugin agreed on the _FILE_OFFSET_BITS value. Unfortunately, that's not enough: lto-plugin uses the simple-object interface from libiberty, which includes off_t arguments. So to fully disable large-file support would mean also disabling it in libiberty and its users: gcc and libstdc++-v3. This seems highly undesirable, so I decided to disable the linker plugin instead if large-file support won't work. The patch allows binutils+gdb to build on i386-pc-solaris2.11 (both Solaris 11.3 and 11.4, using GCC 9.3.0 which is the worst case due to predefined _FILE_OFFSET_BITS=64). Also regtested on amd64-pc-solaris2.11 (again on Solaris 11.3 and 11.4), x86_64-pc-linux-gnu and i686-pc-linux-gnu. config: * largefile.m4 (ACX_LARGEFILE) <sparc-*-solaris*|i?86-*-solaris*>: Check for <sys/procfs.h> incompatilibity with large-file support on Solaris. Only disable large-file support and perhaps plugins if needed. Set, substitute LARGEFILE_CPPFLAGS if so. bfd: * bfd.m4 (BFD_SYS_PROCFS_H): New macro. (BFD_HAVE_SYS_PROCFS_TYPE): Require BFD_SYS_PROCFS_H. Don't define _STRUCTURED_PROC. (BFD_HAVE_SYS_PROCFS_TYPE_MEMBER): Likewise. * elf.c [HAVE_SYS_PROCFS_H] (_STRUCTURED_PROC): Don't define. * configure.ac: Use BFD_SYS_PROCFS_H to check for <sys/procfs.h>. * configure, config.in: Regenerate. * Makefile.am (AM_CPPFLAGS): Add LARGEFILE_CPPFLAGS. * Makefile.in, doc/Makefile.in: Regenerate. binutils: * Makefile.am (AM_CPPFLAGS): Add LARGEFILE_CPPFLAGS. * Makefile.in, doc/Makefile.in: Regenerate. * configure: Regenerate. gas: * Makefile.am (AM_CPPFLAGS): Add LARGEFILE_CPPFLAGS. * Makefile.in, doc/Makefile.in: Regenerate. * configure: Regenerate. gdb: * proc-api.c (_STRUCTURED_PROC): Don't define. * proc-events.c: Likewise. * proc-flags.c: Likewise. * proc-why.c: Likewise. * procfs.c: Likewise. * Makefile.in (INTERNAL_CPPFLAGS): Add LARGEFILE_CPPFLAGS. * configure, config.in: Regenerate. gdbserver: * configure, config.in: Regenerate. gdbsupport: * Makefile.am (AM_CPPFLAGS): Add LARGEFILE_CPPFLAGS. * common.m4 (GDB_AC_COMMON): Use BFD_SYS_PROCFS_H to check for <sys/procfs.h>. * Makefile.in: Regenerate. * configure, config.in: Regenerate. gnulib: * configure.ac: Run ACX_LARGEFILE before gl_EARLY. * configure: Regenerate. gprof: * Makefile.am (AM_CPPFLAGS): Add LARGEFILE_CPPFLAGS. * Makefile.in: Regenerate. * configure: Regenerate. ld: * Makefile.am (AM_CPPFLAGS): Add LARGEFILE_CPPFLAGS. * Makefile.in: Regenerate. * configure: Regenerate.
112 lines
4.2 KiB
C
112 lines
4.2 KiB
C
/* Machine independent support for Solaris /proc (process file system) for GDB.
|
|
Copyright (C) 1999-2020 Free Software Foundation, Inc.
|
|
Written by Michael Snyder at Cygnus Solutions.
|
|
Based on work by Fred Fish, Stu Grossman, Geoff Noer, and others.
|
|
|
|
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/>. */
|
|
|
|
/*
|
|
* Pretty-print the prstatus flags.
|
|
*
|
|
* Arguments: unsigned long flags, int verbose
|
|
*
|
|
*/
|
|
|
|
#include "defs.h"
|
|
|
|
#include <sys/types.h>
|
|
#include <sys/procfs.h>
|
|
|
|
#include "proc-utils.h"
|
|
|
|
/* Much of the information used in the /proc interface, particularly for
|
|
printing status information, is kept as tables of structures of the
|
|
following form. These tables can be used to map numeric values to
|
|
their symbolic names and to a string that describes their specific use. */
|
|
|
|
struct trans {
|
|
int value; /* The numeric value */
|
|
const char *name; /* The equivalent symbolic value */
|
|
const char *desc; /* Short description of value */
|
|
};
|
|
|
|
/* Translate bits in the pr_flags member of the prstatus structure,
|
|
into the names and desc information. */
|
|
|
|
static struct trans pr_flag_table[] =
|
|
{
|
|
/* lwp is stopped */
|
|
{ PR_STOPPED, "PR_STOPPED", "Process (LWP) is stopped" },
|
|
/* lwp is stopped on an event of interest */
|
|
{ PR_ISTOP, "PR_ISTOP", "Stopped on an event of interest" },
|
|
/* lwp has a stop directive in effect */
|
|
{ PR_DSTOP, "PR_DSTOP", "A stop directive is in effect" },
|
|
/* lwp has a single-step directive in effect */
|
|
{ PR_STEP, "PR_STEP", "A single step directive is in effect" },
|
|
/* lwp is sleeping in a system call */
|
|
{ PR_ASLEEP, "PR_ASLEEP", "Sleeping in an (interruptible) system call" },
|
|
/* contents of pr_instr undefined */
|
|
{ PR_PCINVAL, "PR_PCINVAL", "PC (pr_instr) is invalid" },
|
|
/* this lwp is the aslwp */
|
|
{ PR_ASLWP, "PR_ASLWP", "This is the asynchronous signal LWP" },
|
|
/* this lwp is the /proc agent lwp */
|
|
{ PR_AGENT, "PR_AGENT", "This is the /proc agent LWP" },
|
|
/* this is a system process */
|
|
{ PR_ISSYS, "PR_ISSYS", "Is a system process/thread" },
|
|
/* process is the parent of a vfork()d child */
|
|
{ PR_VFORKP, "PR_VFORKP", "Process is the parent of a vforked child" },
|
|
/* process's process group is orphaned */
|
|
{ PR_ORPHAN, "PR_ORPHAN", "Process's process group is orphaned" },
|
|
/* inherit-on-fork is in effect */
|
|
{ PR_FORK, "PR_FORK", "Inherit-on-fork is in effect" },
|
|
/* run-on-last-close is in effect */
|
|
{ PR_RLC, "PR_RLC", "Run-on-last-close is in effect" },
|
|
/* kill-on-last-close is in effect */
|
|
{ PR_KLC, "PR_KLC", "Kill-on-last-close is in effect" },
|
|
/* asynchronous-stop is in effect */
|
|
{ PR_ASYNC, "PR_ASYNC", "Asynchronous stop is in effect" },
|
|
/* micro-state usage accounting is in effect */
|
|
{ PR_MSACCT, "PR_MSACCT", "Microstate accounting enabled" },
|
|
/* breakpoint trap pc adjustment is in effect */
|
|
{ PR_BPTADJ, "PR_BPTADJ", "Breakpoint PC adjustment in effect" },
|
|
/* ptrace-compatibility mode is in effect */
|
|
{ PR_PTRACE, "PR_PTRACE", "Process is being controlled by ptrace" },
|
|
/* micro-state accounting inherited on fork */
|
|
{ PR_MSFORK, "PR_PCOMPAT", "Micro-state accounting inherited on fork" },
|
|
};
|
|
|
|
void
|
|
proc_prettyfprint_flags (FILE *file, unsigned long flags, int verbose)
|
|
{
|
|
int i;
|
|
|
|
for (i = 0; i < sizeof (pr_flag_table) / sizeof (pr_flag_table[0]); i++)
|
|
if (flags & pr_flag_table[i].value)
|
|
{
|
|
fprintf (file, "%s ", pr_flag_table[i].name);
|
|
if (verbose)
|
|
fprintf (file, "%s\n", pr_flag_table[i].desc);
|
|
}
|
|
if (!verbose)
|
|
fprintf (file, "\n");
|
|
}
|
|
|
|
void
|
|
proc_prettyprint_flags (unsigned long flags, int verbose)
|
|
{
|
|
proc_prettyfprint_flags (stdout, flags, verbose);
|
|
}
|