mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-24 12:35:55 +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.
769 lines
23 KiB
C
769 lines
23 KiB
C
/* Machine-independent support for Solaris /proc (process file system)
|
||
|
||
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 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 "events of interest".
|
||
|
||
This module includes pretty-print routines for:
|
||
* faults (hardware exceptions)
|
||
* signals (software interrupts)
|
||
* syscalls
|
||
|
||
FIXME: At present, the syscall translation table must be
|
||
initialized, which is not true of the other translation tables. */
|
||
|
||
#include "defs.h"
|
||
|
||
#include <sys/types.h>
|
||
#include <sys/procfs.h>
|
||
#include <sys/syscall.h>
|
||
#include <sys/fault.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. */
|
||
};
|
||
|
||
|
||
/* Pretty print syscalls. */
|
||
|
||
/* Syscall translation table. */
|
||
|
||
#define MAX_SYSCALLS 262 /* Pretty arbitrary. */
|
||
static const char *syscall_table[MAX_SYSCALLS];
|
||
|
||
static void
|
||
init_syscall_table (void)
|
||
{
|
||
syscall_table[SYS_accept] = "accept";
|
||
#ifdef SYS_access
|
||
syscall_table[SYS_access] = "access";
|
||
#endif
|
||
syscall_table[SYS_acct] = "acct";
|
||
syscall_table[SYS_acctctl] = "acctctl";
|
||
syscall_table[SYS_acl] = "acl";
|
||
#ifdef SYS_adi
|
||
syscall_table[SYS_adi] = "adi";
|
||
#endif
|
||
syscall_table[SYS_adjtime] = "adjtime";
|
||
syscall_table[SYS_alarm] = "alarm";
|
||
syscall_table[SYS_auditsys] = "auditsys";
|
||
syscall_table[SYS_autofssys] = "autofssys";
|
||
syscall_table[SYS_bind] = "bind";
|
||
syscall_table[SYS_brand] = "brand";
|
||
syscall_table[SYS_brk] = "brk";
|
||
syscall_table[SYS_chdir] = "chdir";
|
||
#ifdef SYS_chmod
|
||
syscall_table[SYS_chmod] = "chmod";
|
||
#endif
|
||
#ifdef SYS_chown
|
||
syscall_table[SYS_chown] = "chown";
|
||
#endif
|
||
syscall_table[SYS_chroot] = "chroot";
|
||
syscall_table[SYS_cladm] = "cladm";
|
||
syscall_table[SYS_clock_getres] = "clock_getres";
|
||
syscall_table[SYS_clock_gettime] = "clock_gettime";
|
||
syscall_table[SYS_clock_settime] = "clock_settime";
|
||
syscall_table[SYS_close] = "close";
|
||
syscall_table[SYS_connect] = "connect";
|
||
syscall_table[SYS_context] = "context";
|
||
syscall_table[SYS_corectl] = "corectl";
|
||
syscall_table[SYS_cpc] = "cpc";
|
||
#ifdef SYS_creat
|
||
syscall_table[SYS_creat] = "creat";
|
||
#endif
|
||
#ifdef SYS_creat64
|
||
syscall_table[SYS_creat64] = "creat64";
|
||
#endif
|
||
syscall_table[SYS_door] = "door";
|
||
#ifdef SYS_dup
|
||
syscall_table[SYS_dup] = "dup";
|
||
#endif
|
||
#ifdef SYS_evsys
|
||
syscall_table[SYS_evsys] = "evsys";
|
||
#endif
|
||
#ifdef SYS_evtrapret
|
||
syscall_table[SYS_evtrapret] = "evtrapret";
|
||
#endif
|
||
syscall_table[SYS_exacctsys] = "exacctsys";
|
||
#ifdef SYS_exec
|
||
syscall_table[SYS_exec] = "exec";
|
||
#endif
|
||
syscall_table[SYS_execve] = "execve";
|
||
syscall_table[SYS_exit] = "exit";
|
||
#ifdef SYS_faccessat
|
||
syscall_table[SYS_faccessat] = "faccessat";
|
||
#endif
|
||
syscall_table[SYS_facl] = "facl";
|
||
syscall_table[SYS_fchdir] = "fchdir";
|
||
#ifdef SYS_fchmod
|
||
syscall_table[SYS_fchmod] = "fchmod";
|
||
#endif
|
||
#ifdef SYS_fchmodat
|
||
syscall_table[SYS_fchmodat] = "fchmodat";
|
||
#endif
|
||
#ifdef SYS_fchown
|
||
syscall_table[SYS_fchown] = "fchown";
|
||
#endif
|
||
#ifdef SYS_fchownat
|
||
syscall_table[SYS_fchownat] = "fchownat";
|
||
#endif
|
||
syscall_table[SYS_fchroot] = "fchroot";
|
||
syscall_table[SYS_fcntl] = "fcntl";
|
||
syscall_table[SYS_fdsync] = "fdsync";
|
||
#ifdef SYS_fork1
|
||
syscall_table[SYS_fork1] = "fork1";
|
||
#endif
|
||
#ifdef SYS_forkall
|
||
syscall_table[SYS_forkall] = "forkall";
|
||
#endif
|
||
#ifdef SYS_forksys
|
||
syscall_table[SYS_forksys] = "forksys";
|
||
#endif
|
||
syscall_table[SYS_fpathconf] = "fpathconf";
|
||
#ifdef SYS_frealpathat
|
||
syscall_table[SYS_frealpathat] = "frealpathat";
|
||
#endif
|
||
#ifdef SYS_fsat
|
||
syscall_table[SYS_fsat] = "fsat";
|
||
#endif
|
||
#ifdef SYS_fstat
|
||
syscall_table[SYS_fstat] = "fstat";
|
||
#endif
|
||
#ifdef SYS_fstat64
|
||
syscall_table[SYS_fstat64] = "fstat64";
|
||
#endif
|
||
#ifdef SYS_fstatat
|
||
syscall_table[SYS_fstatat] = "fstatat";
|
||
#endif
|
||
#ifdef SYS_fstatat64
|
||
syscall_table[SYS_fstatat64] = "fstatat64";
|
||
#endif
|
||
syscall_table[SYS_fstatfs] = "fstatfs";
|
||
syscall_table[SYS_fstatvfs] = "fstatvfs";
|
||
syscall_table[SYS_fstatvfs64] = "fstatvfs64";
|
||
#ifdef SYS_fxstat
|
||
syscall_table[SYS_fxstat] = "fxstat";
|
||
#endif
|
||
syscall_table[SYS_getcwd] = "getcwd";
|
||
syscall_table[SYS_getdents] = "getdents";
|
||
syscall_table[SYS_getdents64] = "getdents64";
|
||
syscall_table[SYS_getgid] = "getgid";
|
||
syscall_table[SYS_getgroups] = "getgroups";
|
||
syscall_table[SYS_getitimer] = "getitimer";
|
||
syscall_table[SYS_getloadavg] = "getloadavg";
|
||
syscall_table[SYS_getmsg] = "getmsg";
|
||
syscall_table[SYS_getpagesizes] = "getpagesizes";
|
||
syscall_table[SYS_getpeername] = "getpeername";
|
||
syscall_table[SYS_getpid] = "getpid";
|
||
syscall_table[SYS_getpmsg] = "getpmsg";
|
||
#ifdef SYS_getrandom
|
||
syscall_table[SYS_getrandom] = "getrandom";
|
||
#endif
|
||
syscall_table[SYS_getrlimit] = "getrlimit";
|
||
syscall_table[SYS_getrlimit64] = "getrlimit64";
|
||
syscall_table[SYS_getsockname] = "getsockname";
|
||
syscall_table[SYS_getsockopt] = "getsockopt";
|
||
syscall_table[SYS_gettimeofday] = "gettimeofday";
|
||
syscall_table[SYS_getuid] = "getuid";
|
||
syscall_table[SYS_gtty] = "gtty";
|
||
syscall_table[SYS_hrtsys] = "hrtsys";
|
||
syscall_table[SYS_inst_sync] = "inst_sync";
|
||
syscall_table[SYS_install_utrap] = "install_utrap";
|
||
syscall_table[SYS_ioctl] = "ioctl";
|
||
#ifdef SYS_issetugid
|
||
syscall_table[SYS_issetugid] = "issetugid";
|
||
#endif
|
||
syscall_table[SYS_kaio] = "kaio";
|
||
syscall_table[SYS_kill] = "kill";
|
||
syscall_table[SYS_labelsys] = "labelsys";
|
||
#ifdef SYS_lchown
|
||
syscall_table[SYS_lchown] = "lchown";
|
||
#endif
|
||
syscall_table[SYS_lgrpsys] = "lgrpsys";
|
||
#ifdef SYS_link
|
||
syscall_table[SYS_link] = "link";
|
||
#endif
|
||
#ifdef SYS_linkat
|
||
syscall_table[SYS_linkat] = "linkat";
|
||
#endif
|
||
syscall_table[SYS_listen] = "listen";
|
||
syscall_table[SYS_llseek] = "llseek";
|
||
syscall_table[SYS_lseek] = "lseek";
|
||
#ifdef SYS_lstat
|
||
syscall_table[SYS_lstat] = "lstat";
|
||
#endif
|
||
#ifdef SYS_lstat64
|
||
syscall_table[SYS_lstat64] = "lstat64";
|
||
#endif
|
||
syscall_table[SYS_lwp_cond_broadcast] = "lwp_cond_broadcast";
|
||
syscall_table[SYS_lwp_cond_signal] = "lwp_cond_signal";
|
||
syscall_table[SYS_lwp_cond_wait] = "lwp_cond_wait";
|
||
syscall_table[SYS_lwp_continue] = "lwp_continue";
|
||
syscall_table[SYS_lwp_create] = "lwp_create";
|
||
syscall_table[SYS_lwp_detach] = "lwp_detach";
|
||
syscall_table[SYS_lwp_exit] = "lwp_exit";
|
||
syscall_table[SYS_lwp_info] = "lwp_info";
|
||
#ifdef SYS_lwp_kill
|
||
syscall_table[SYS_lwp_kill] = "lwp_kill";
|
||
#endif
|
||
#ifdef SYS_lwp_mutex_lock
|
||
syscall_table[SYS_lwp_mutex_lock] = "lwp_mutex_lock";
|
||
#endif
|
||
syscall_table[SYS_lwp_mutex_register] = "lwp_mutex_register";
|
||
syscall_table[SYS_lwp_mutex_timedlock] = "lwp_mutex_timedlock";
|
||
syscall_table[SYS_lwp_mutex_trylock] = "lwp_mutex_trylock";
|
||
syscall_table[SYS_lwp_mutex_unlock] = "lwp_mutex_unlock";
|
||
syscall_table[SYS_lwp_mutex_wakeup] = "lwp_mutex_wakeup";
|
||
#ifdef SYS_lwp_name
|
||
syscall_table[SYS_lwp_name] = "lwp_name";
|
||
#endif
|
||
syscall_table[SYS_lwp_park] = "lwp_park";
|
||
syscall_table[SYS_lwp_private] = "lwp_private";
|
||
syscall_table[SYS_lwp_rwlock_sys] = "lwp_rwlock_sys";
|
||
syscall_table[SYS_lwp_self] = "lwp_self";
|
||
syscall_table[SYS_lwp_sema_post] = "lwp_sema_post";
|
||
syscall_table[SYS_lwp_sema_timedwait] = "lwp_sema_timedwait";
|
||
syscall_table[SYS_lwp_sema_trywait] = "lwp_sema_trywait";
|
||
#ifdef SYS_lwp_sema_wait
|
||
syscall_table[SYS_lwp_sema_wait] = "lwp_sema_wait";
|
||
#endif
|
||
syscall_table[SYS_lwp_sigmask] = "lwp_sigmask";
|
||
#ifdef SYS_lwp_sigqueue
|
||
syscall_table[SYS_lwp_sigqueue] = "lwp_sigqueue";
|
||
#endif
|
||
syscall_table[SYS_lwp_suspend] = "lwp_suspend";
|
||
syscall_table[SYS_lwp_wait] = "lwp_wait";
|
||
#ifdef SYS_lxstat
|
||
syscall_table[SYS_lxstat] = "lxstat";
|
||
#endif
|
||
syscall_table[SYS_memcntl] = "memcntl";
|
||
#ifdef SYS_memsys
|
||
syscall_table[SYS_memsys] = "memsys";
|
||
#endif
|
||
syscall_table[SYS_mincore] = "mincore";
|
||
#ifdef SYS_mkdir
|
||
syscall_table[SYS_mkdir] = "mkdir";
|
||
#endif
|
||
#ifdef SYS_mkdirat
|
||
syscall_table[SYS_mkdirat] = "mkdirat";
|
||
#endif
|
||
#ifdef SYS_mknod
|
||
syscall_table[SYS_mknod] = "mknod";
|
||
#endif
|
||
#ifdef SYS_mknodat
|
||
syscall_table[SYS_mknodat] = "mknodat";
|
||
#endif
|
||
syscall_table[SYS_mmap] = "mmap";
|
||
syscall_table[SYS_mmap64] = "mmap64";
|
||
#ifdef SYS_mmapobj
|
||
syscall_table[SYS_mmapobj] = "mmapobj";
|
||
#endif
|
||
syscall_table[SYS_modctl] = "modctl";
|
||
syscall_table[SYS_mount] = "mount";
|
||
syscall_table[SYS_mprotect] = "mprotect";
|
||
syscall_table[SYS_msgsys] = "msgsys";
|
||
syscall_table[SYS_munmap] = "munmap";
|
||
syscall_table[SYS_nanosleep] = "nanosleep";
|
||
syscall_table[SYS_nfssys] = "nfssys";
|
||
syscall_table[SYS_nice] = "nice";
|
||
syscall_table[SYS_ntp_adjtime] = "ntp_adjtime";
|
||
syscall_table[SYS_ntp_gettime] = "ntp_gettime";
|
||
#ifdef SYS_open
|
||
syscall_table[SYS_open] = "open";
|
||
#endif
|
||
#ifdef SYS_open64
|
||
syscall_table[SYS_open64] = "open64";
|
||
#endif
|
||
#ifdef SYS_openat
|
||
syscall_table[SYS_openat] = "openat";
|
||
#endif
|
||
#ifdef SYS_openat64
|
||
syscall_table[SYS_openat64] = "openat64";
|
||
#endif
|
||
syscall_table[SYS_p_online] = "p_online";
|
||
syscall_table[SYS_pathconf] = "pathconf";
|
||
syscall_table[SYS_pause] = "pause";
|
||
syscall_table[SYS_pcsample] = "pcsample";
|
||
syscall_table[SYS_pgrpsys] = "pgrpsys";
|
||
syscall_table[SYS_pipe] = "pipe";
|
||
#ifdef SYS_plock
|
||
syscall_table[SYS_plock] = "plock";
|
||
#endif
|
||
#ifdef SYS_poll
|
||
syscall_table[SYS_poll] = "poll";
|
||
#endif
|
||
syscall_table[SYS_pollsys] = "pollsys";
|
||
syscall_table[SYS_port] = "port";
|
||
syscall_table[SYS_pread] = "pread";
|
||
syscall_table[SYS_pread64] = "pread64";
|
||
syscall_table[SYS_priocntlsys] = "priocntlsys";
|
||
syscall_table[SYS_privsys] = "privsys";
|
||
#ifdef SYS_processor_bind
|
||
syscall_table[SYS_processor_bind] = "processor_bind";
|
||
#endif
|
||
#ifdef SYS_processor_info
|
||
syscall_table[SYS_processor_info] = "processor_info";
|
||
#endif
|
||
#ifdef SYS_processor_sys
|
||
syscall_table[SYS_processor_sys] = "processor_sys";
|
||
#endif
|
||
syscall_table[SYS_profil] = "profil";
|
||
syscall_table[SYS_pset] = "pset";
|
||
syscall_table[SYS_putmsg] = "putmsg";
|
||
syscall_table[SYS_putpmsg] = "putpmsg";
|
||
syscall_table[SYS_pwrite] = "pwrite";
|
||
syscall_table[SYS_pwrite64] = "pwrite64";
|
||
syscall_table[SYS_rctlsys] = "rctlsys";
|
||
syscall_table[SYS_read] = "read";
|
||
#ifdef SYS_readlink
|
||
syscall_table[SYS_readlink] = "readlink";
|
||
#endif
|
||
#ifdef SYS_readlinkat
|
||
syscall_table[SYS_readlinkat] = "readlinkat";
|
||
#endif
|
||
syscall_table[SYS_readv] = "readv";
|
||
syscall_table[SYS_recv] = "recv";
|
||
syscall_table[SYS_recvfrom] = "recvfrom";
|
||
#ifdef SYS_recvmmsg
|
||
syscall_table[SYS_recvmmsg] = "recvmmsg";
|
||
#endif
|
||
syscall_table[SYS_recvmsg] = "recvmsg";
|
||
#ifdef SYS_reflinkat
|
||
syscall_table[SYS_reflinkat] = "reflinkat";
|
||
#endif
|
||
#ifdef SYS_rename
|
||
syscall_table[SYS_rename] = "rename";
|
||
#endif
|
||
#ifdef SYS_renameat
|
||
syscall_table[SYS_renameat] = "renameat";
|
||
#endif
|
||
syscall_table[SYS_resolvepath] = "resolvepath";
|
||
#ifdef SYS_rmdir
|
||
syscall_table[SYS_rmdir] = "rmdir";
|
||
#endif
|
||
syscall_table[SYS_rpcsys] = "rpcsys";
|
||
syscall_table[SYS_rusagesys] = "rusagesys";
|
||
syscall_table[SYS_schedctl] = "schedctl";
|
||
#ifdef SYS_secsys
|
||
syscall_table[SYS_secsys] = "secsys";
|
||
#endif
|
||
syscall_table[SYS_semsys] = "semsys";
|
||
syscall_table[SYS_send] = "send";
|
||
syscall_table[SYS_sendfilev] = "sendfilev";
|
||
#ifdef SYS_sendmmsg
|
||
syscall_table[SYS_sendmmsg] = "sendmmsg";
|
||
#endif
|
||
syscall_table[SYS_sendmsg] = "sendmsg";
|
||
syscall_table[SYS_sendto] = "sendto";
|
||
syscall_table[SYS_setegid] = "setegid";
|
||
syscall_table[SYS_seteuid] = "seteuid";
|
||
syscall_table[SYS_setgid] = "setgid";
|
||
syscall_table[SYS_setgroups] = "setgroups";
|
||
syscall_table[SYS_setitimer] = "setitimer";
|
||
syscall_table[SYS_setregid] = "setregid";
|
||
syscall_table[SYS_setreuid] = "setreuid";
|
||
syscall_table[SYS_setrlimit] = "setrlimit";
|
||
syscall_table[SYS_setrlimit64] = "setrlimit64";
|
||
syscall_table[SYS_setsockopt] = "setsockopt";
|
||
syscall_table[SYS_setuid] = "setuid";
|
||
syscall_table[SYS_sharefs] = "sharefs";
|
||
syscall_table[SYS_shmsys] = "shmsys";
|
||
syscall_table[SYS_shutdown] = "shutdown";
|
||
#ifdef SYS_sidsys
|
||
syscall_table[SYS_sidsys] = "sidsys";
|
||
#endif
|
||
syscall_table[SYS_sigaction] = "sigaction";
|
||
syscall_table[SYS_sigaltstack] = "sigaltstack";
|
||
#ifdef SYS_signal
|
||
syscall_table[SYS_signal] = "signal";
|
||
#endif
|
||
syscall_table[SYS_signotify] = "signotify";
|
||
syscall_table[SYS_sigpending] = "sigpending";
|
||
syscall_table[SYS_sigprocmask] = "sigprocmask";
|
||
syscall_table[SYS_sigqueue] = "sigqueue";
|
||
#ifdef SYS_sigresend
|
||
syscall_table[SYS_sigresend] = "sigresend";
|
||
#endif
|
||
syscall_table[SYS_sigsendsys] = "sigsendsys";
|
||
syscall_table[SYS_sigsuspend] = "sigsuspend";
|
||
syscall_table[SYS_sigtimedwait] = "sigtimedwait";
|
||
syscall_table[SYS_so_socket] = "so_socket";
|
||
syscall_table[SYS_so_socketpair] = "so_socketpair";
|
||
syscall_table[SYS_sockconfig] = "sockconfig";
|
||
#ifdef SYS_sparc_fixalign
|
||
syscall_table[SYS_sparc_fixalign] = "sparc_fixalign";
|
||
#endif
|
||
syscall_table[SYS_sparc_utrap_install] = "sparc_utrap_install";
|
||
#ifdef SYS_spawn
|
||
syscall_table[SYS_spawn] = "spawn";
|
||
#endif
|
||
#ifdef SYS_stat
|
||
syscall_table[SYS_stat] = "stat";
|
||
#endif
|
||
#ifdef SYS_stat64
|
||
syscall_table[SYS_stat64] = "stat64";
|
||
#endif
|
||
syscall_table[SYS_statfs] = "statfs";
|
||
syscall_table[SYS_statvfs] = "statvfs";
|
||
syscall_table[SYS_statvfs64] = "statvfs64";
|
||
syscall_table[SYS_stime] = "stime";
|
||
syscall_table[SYS_stty] = "stty";
|
||
#ifdef SYS_symlink
|
||
syscall_table[SYS_symlink] = "symlink";
|
||
#endif
|
||
#ifdef SYS_symlinkat
|
||
syscall_table[SYS_symlinkat] = "symlinkat";
|
||
#endif
|
||
syscall_table[SYS_sync] = "sync";
|
||
syscall_table[SYS_syscall] = "syscall";
|
||
syscall_table[SYS_sysconfig] = "sysconfig";
|
||
syscall_table[SYS_sysfs] = "sysfs";
|
||
syscall_table[SYS_sysi86] = "sysi86";
|
||
#ifdef SYS_syssun
|
||
syscall_table[SYS_syssun] = "syssun";
|
||
#endif
|
||
#ifdef SYS_system_stats
|
||
syscall_table[SYS_system_stats] = "system_stats";
|
||
#endif
|
||
syscall_table[SYS_systeminfo] = "systeminfo";
|
||
syscall_table[SYS_tasksys] = "tasksys";
|
||
syscall_table[SYS_time] = "time";
|
||
syscall_table[SYS_timer_create] = "timer_create";
|
||
syscall_table[SYS_timer_delete] = "timer_delete";
|
||
syscall_table[SYS_timer_getoverrun] = "timer_getoverrun";
|
||
syscall_table[SYS_timer_gettime] = "timer_gettime";
|
||
syscall_table[SYS_timer_settime] = "timer_settime";
|
||
syscall_table[SYS_times] = "times";
|
||
syscall_table[SYS_uadmin] = "uadmin";
|
||
syscall_table[SYS_ucredsys] = "ucredsys";
|
||
syscall_table[SYS_ulimit] = "ulimit";
|
||
syscall_table[SYS_umask] = "umask";
|
||
#ifdef SYS_umount
|
||
syscall_table[SYS_umount] = "umount";
|
||
#endif
|
||
syscall_table[SYS_umount2] = "umount2";
|
||
syscall_table[SYS_uname] = "uname";
|
||
#ifdef SYS_unlink
|
||
syscall_table[SYS_unlink] = "unlink";
|
||
#endif
|
||
#ifdef SYS_unlinkat
|
||
syscall_table[SYS_unlinkat] = "unlinkat";
|
||
#endif
|
||
#ifdef SYS_utime
|
||
syscall_table[SYS_utime] = "utime";
|
||
#endif
|
||
#ifdef SYS_utimensat
|
||
syscall_table[SYS_utimensat] = "utimensat";
|
||
#endif
|
||
#ifdef SYS_utimes
|
||
syscall_table[SYS_utimes] = "utimes";
|
||
#endif
|
||
#ifdef SYS_utimesys
|
||
syscall_table[SYS_utimesys] = "utimesys";
|
||
#endif
|
||
syscall_table[SYS_utssys] = "utssys";
|
||
syscall_table[SYS_uucopy] = "uucopy";
|
||
syscall_table[SYS_uucopystr] = "uucopystr";
|
||
#ifdef SYS_uuidsys
|
||
syscall_table[SYS_uuidsys] = "uuidsys";
|
||
#endif
|
||
#ifdef SYS_va_mask
|
||
syscall_table[SYS_va_mask] = "va_mask";
|
||
#endif
|
||
syscall_table[SYS_vfork] = "vfork";
|
||
syscall_table[SYS_vhangup] = "vhangup";
|
||
#ifdef SYS_wait
|
||
syscall_table[SYS_wait] = "wait";
|
||
#endif
|
||
#ifdef SYS_waitid
|
||
syscall_table[SYS_waitid] = "waitid";
|
||
#endif
|
||
#ifdef SYS_waitsys
|
||
syscall_table[SYS_waitsys] = "waitsys";
|
||
#endif
|
||
syscall_table[SYS_write] = "write";
|
||
syscall_table[SYS_writev] = "writev";
|
||
#ifdef SYS_xmknod
|
||
syscall_table[SYS_xmknod] = "xmknod";
|
||
#endif
|
||
#ifdef SYS_xstat
|
||
syscall_table[SYS_xstat] = "xstat";
|
||
#endif
|
||
syscall_table[SYS_yield] = "yield";
|
||
syscall_table[SYS_zone] = "zone";
|
||
}
|
||
|
||
/* Prettyprint syscall NUM. */
|
||
|
||
void
|
||
proc_prettyfprint_syscall (FILE *file, int num, int verbose)
|
||
{
|
||
if (syscall_table[num])
|
||
fprintf (file, "SYS_%s ", syscall_table[num]);
|
||
else
|
||
fprintf (file, "<Unknown syscall %d> ", num);
|
||
}
|
||
|
||
void
|
||
proc_prettyprint_syscall (int num, int verbose)
|
||
{
|
||
proc_prettyfprint_syscall (stdout, num, verbose);
|
||
}
|
||
|
||
/* Prettyprint all syscalls in SYSSET. */
|
||
|
||
void
|
||
proc_prettyfprint_syscalls (FILE *file, sysset_t *sysset, int verbose)
|
||
{
|
||
int i;
|
||
|
||
for (i = 0; i < MAX_SYSCALLS; i++)
|
||
if (prismember (sysset, i))
|
||
{
|
||
proc_prettyfprint_syscall (file, i, verbose);
|
||
}
|
||
fprintf (file, "\n");
|
||
}
|
||
|
||
void
|
||
proc_prettyprint_syscalls (sysset_t *sysset, int verbose)
|
||
{
|
||
proc_prettyfprint_syscalls (stdout, sysset, verbose);
|
||
}
|
||
|
||
/* Prettyprint signals. */
|
||
|
||
/* Signal translation table, ordered ANSI-standard signals first,
|
||
other signals second, with signals in each block ordered by their
|
||
numerical values on a typical POSIX platform. */
|
||
|
||
static struct trans signal_table[] =
|
||
{
|
||
{ 0, "<no signal>", "no signal" },
|
||
|
||
/* SIGINT, SIGILL, SIGABRT, SIGFPE, SIGSEGV and SIGTERM
|
||
are ANSI-standard signals and are always available. */
|
||
|
||
{ SIGINT, "SIGINT", "Interrupt (rubout)" },
|
||
{ SIGILL, "SIGILL", "Illegal instruction" }, /* not reset when caught */
|
||
{ SIGABRT, "SIGABRT", "used by abort()" }, /* replaces SIGIOT */
|
||
{ SIGFPE, "SIGFPE", "Floating point exception" },
|
||
{ SIGSEGV, "SIGSEGV", "Segmentation violation" },
|
||
{ SIGTERM, "SIGTERM", "Software termination signal from kill" },
|
||
|
||
/* All other signals need preprocessor conditionals. */
|
||
|
||
{ SIGHUP, "SIGHUP", "Hangup" },
|
||
{ SIGQUIT, "SIGQUIT", "Quit (ASCII FS)" },
|
||
{ SIGTRAP, "SIGTRAP", "Trace trap" }, /* not reset when caught */
|
||
{ SIGIOT, "SIGIOT", "IOT instruction" },
|
||
{ SIGEMT, "SIGEMT", "EMT instruction" },
|
||
{ SIGKILL, "SIGKILL", "Kill" }, /* Solaris: cannot be caught/ignored */
|
||
{ SIGBUS, "SIGBUS", "Bus error" },
|
||
{ SIGSYS, "SIGSYS", "Bad argument to system call" },
|
||
{ SIGPIPE, "SIGPIPE", "Write to pipe with no one to read it" },
|
||
{ SIGALRM, "SIGALRM", "Alarm clock" },
|
||
{ SIGUSR1, "SIGUSR1", "User defined signal 1" },
|
||
{ SIGUSR2, "SIGUSR2", "User defined signal 2" },
|
||
{ SIGCHLD, "SIGCHLD", "Child status changed" }, /* Posix version */
|
||
{ SIGCLD, "SIGCLD", "Child status changed" }, /* Solaris version */
|
||
{ SIGPWR, "SIGPWR", "Power-fail restart" },
|
||
{ SIGWINCH, "SIGWINCH", "Window size change" },
|
||
{ SIGURG, "SIGURG", "Urgent socket condition" },
|
||
{ SIGPOLL, "SIGPOLL", "Pollable event" },
|
||
{ SIGIO, "SIGIO", "Socket I/O possible" }, /* alias for SIGPOLL */
|
||
{ SIGSTOP, "SIGSTOP", "Stop, not from tty" }, /* cannot be caught or
|
||
ignored */
|
||
{ SIGTSTP, "SIGTSTP", "User stop from tty" },
|
||
{ SIGCONT, "SIGCONT", "Stopped process has been continued" },
|
||
{ SIGTTIN, "SIGTTIN", "Background tty read attempted" },
|
||
{ SIGTTOU, "SIGTTOU", "Background tty write attempted" },
|
||
{ SIGVTALRM, "SIGVTALRM", "Virtual timer expired" },
|
||
{ SIGPROF, "SIGPROF", "Profiling timer expired" },
|
||
{ SIGXCPU, "SIGXCPU", "Exceeded CPU limit" },
|
||
{ SIGXFSZ, "SIGXFSZ", "Exceeded file size limit" },
|
||
{ SIGWAITING, "SIGWAITING", "Process's LWPs are blocked" },
|
||
{ SIGLWP, "SIGLWP", "Used by thread library" },
|
||
{ SIGFREEZE, "SIGFREEZE", "Used by CPR" },
|
||
{ SIGTHAW, "SIGTHAW", "Used by CPR" },
|
||
{ SIGCANCEL, "SIGCANCEL", "Used by libthread" },
|
||
{ SIGLOST, "SIGLOST", "Resource lost" },
|
||
|
||
/* FIXME: add real-time signals. */
|
||
};
|
||
|
||
/* Prettyprint signal number SIGNO. */
|
||
|
||
void
|
||
proc_prettyfprint_signal (FILE *file, int signo, int verbose)
|
||
{
|
||
int i;
|
||
|
||
for (i = 0; i < sizeof (signal_table) / sizeof (signal_table[0]); i++)
|
||
if (signo == signal_table[i].value)
|
||
{
|
||
fprintf (file, "%s", signal_table[i].name);
|
||
if (verbose)
|
||
fprintf (file, ": %s\n", signal_table[i].desc);
|
||
else
|
||
fprintf (file, " ");
|
||
return;
|
||
}
|
||
fprintf (file, "Unknown signal %d%c", signo, verbose ? '\n' : ' ');
|
||
}
|
||
|
||
void
|
||
proc_prettyprint_signal (int signo, int verbose)
|
||
{
|
||
proc_prettyfprint_signal (stdout, signo, verbose);
|
||
}
|
||
|
||
/* Prettyprint all signals in SIGSET. */
|
||
|
||
void
|
||
proc_prettyfprint_signalset (FILE *file, sigset_t *sigset, int verbose)
|
||
{
|
||
int i;
|
||
|
||
/* Loop over all signal numbers from 0 to NSIG, using them as the
|
||
index to prismember. The signal table had better not contain
|
||
aliases, for if it does they will both be printed. */
|
||
|
||
for (i = 0; i < NSIG; i++)
|
||
if (prismember (sigset, i))
|
||
proc_prettyfprint_signal (file, i, verbose);
|
||
|
||
if (!verbose)
|
||
fprintf (file, "\n");
|
||
}
|
||
|
||
void
|
||
proc_prettyprint_signalset (sigset_t *sigset, int verbose)
|
||
{
|
||
proc_prettyfprint_signalset (stdout, sigset, verbose);
|
||
}
|
||
|
||
|
||
/* Prettyprint faults. */
|
||
|
||
/* Fault translation table. */
|
||
|
||
static struct trans fault_table[] =
|
||
{
|
||
{ FLTILL, "FLTILL", "Illegal instruction" },
|
||
{ FLTPRIV, "FLTPRIV", "Privileged instruction" },
|
||
{ FLTBPT, "FLTBPT", "Breakpoint trap" },
|
||
{ FLTTRACE, "FLTTRACE", "Trace trap" },
|
||
{ FLTACCESS, "FLTACCESS", "Memory access fault" },
|
||
{ FLTBOUNDS, "FLTBOUNDS", "Memory bounds violation" },
|
||
{ FLTIOVF, "FLTIOVF", "Integer overflow" },
|
||
{ FLTIZDIV, "FLTIZDIV", "Integer zero divide" },
|
||
{ FLTFPE, "FLTFPE", "Floating-point exception" },
|
||
{ FLTSTACK, "FLTSTACK", "Unrecoverable stack fault" },
|
||
{ FLTPAGE, "FLTPAGE", "Recoverable page fault" },
|
||
{ FLTWATCH, "FLTWATCH", "User watchpoint" },
|
||
};
|
||
|
||
/* Work horse. Accepts an index into the fault table, prints it
|
||
pretty. */
|
||
|
||
static void
|
||
prettyfprint_faulttable_entry (FILE *file, int i, int verbose)
|
||
{
|
||
fprintf (file, "%s", fault_table[i].name);
|
||
if (verbose)
|
||
fprintf (file, ": %s\n", fault_table[i].desc);
|
||
else
|
||
fprintf (file, " ");
|
||
}
|
||
|
||
/* Prettyprint hardware fault number FAULTNO. */
|
||
|
||
void
|
||
proc_prettyfprint_fault (FILE *file, int faultno, int verbose)
|
||
{
|
||
int i;
|
||
|
||
for (i = 0; i < ARRAY_SIZE (fault_table); i++)
|
||
if (faultno == fault_table[i].value)
|
||
{
|
||
prettyfprint_faulttable_entry (file, i, verbose);
|
||
return;
|
||
}
|
||
|
||
fprintf (file, "Unknown hardware fault %d%c",
|
||
faultno, verbose ? '\n' : ' ');
|
||
}
|
||
|
||
void
|
||
proc_prettyprint_fault (int faultno, int verbose)
|
||
{
|
||
proc_prettyfprint_fault (stdout, faultno, verbose);
|
||
}
|
||
|
||
/* Prettyprint all faults in FLTSET. */
|
||
|
||
void
|
||
proc_prettyfprint_faultset (FILE *file, fltset_t *fltset, int verbose)
|
||
{
|
||
int i;
|
||
|
||
/* Loop through the fault table, using the value field as the index
|
||
to prismember. The fault table had better not contain aliases,
|
||
for if it does they will both be printed. */
|
||
|
||
for (i = 0; i < ARRAY_SIZE (fault_table); i++)
|
||
if (prismember (fltset, fault_table[i].value))
|
||
prettyfprint_faulttable_entry (file, i, verbose);
|
||
|
||
if (!verbose)
|
||
fprintf (file, "\n");
|
||
}
|
||
|
||
void
|
||
proc_prettyprint_faultset (fltset_t *fltset, int verbose)
|
||
{
|
||
proc_prettyfprint_faultset (stdout, fltset, verbose);
|
||
}
|
||
|
||
/* TODO: actions, holds... */
|
||
|
||
void
|
||
proc_prettyprint_actionset (struct sigaction *actions, int verbose)
|
||
{
|
||
}
|
||
|
||
void _initialize_proc_events ();
|
||
void
|
||
_initialize_proc_events ()
|
||
{
|
||
init_syscall_table ();
|
||
}
|