|  | /* Machine-independent support for Solaris /proc (process file system) | 
|  |  | 
|  | Copyright (C) 1999-2025 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 <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) | 
|  | { | 
|  | } | 
|  |  | 
|  | INIT_GDB_FILE (proc_events) | 
|  | { | 
|  | init_syscall_table (); | 
|  | } |