19289f547SJohn Baldwin /*
29289f547SJohn Baldwin * Copyright (c) 2006 "David Kirchner" <dpk@dpk.net>. All rights reserved.
39289f547SJohn Baldwin *
49289f547SJohn Baldwin * Redistribution and use in source and binary forms, with or without
59289f547SJohn Baldwin * modification, are permitted provided that the following conditions
69289f547SJohn Baldwin * are met:
79289f547SJohn Baldwin * 1. Redistributions of source code must retain the above copyright
89289f547SJohn Baldwin * notice, this list of conditions and the following disclaimer.
99289f547SJohn Baldwin * 2. Redistributions in binary form must reproduce the above copyright
109289f547SJohn Baldwin * notice, this list of conditions and the following disclaimer in the
119289f547SJohn Baldwin * documentation and/or other materials provided with the distribution.
129289f547SJohn Baldwin *
139289f547SJohn Baldwin * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
149289f547SJohn Baldwin * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
159289f547SJohn Baldwin * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
169289f547SJohn Baldwin * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
179289f547SJohn Baldwin * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
189289f547SJohn Baldwin * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
199289f547SJohn Baldwin * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
209289f547SJohn Baldwin * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
219289f547SJohn Baldwin * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
229289f547SJohn Baldwin * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
239289f547SJohn Baldwin * SUCH DAMAGE.
249289f547SJohn Baldwin */
259289f547SJohn Baldwin
269289f547SJohn Baldwin #include <sys/cdefs.h>
279289f547SJohn Baldwin #define L2CAP_SOCKET_CHECKED
289289f547SJohn Baldwin
299289f547SJohn Baldwin #include <sys/types.h>
309289f547SJohn Baldwin #include <sys/acl.h>
319289f547SJohn Baldwin #include <sys/capsicum.h>
32ffb66079SJohn Baldwin #include <sys/event.h>
339289f547SJohn Baldwin #include <sys/extattr.h>
349289f547SJohn Baldwin #include <sys/linker.h>
359289f547SJohn Baldwin #include <sys/mman.h>
369289f547SJohn Baldwin #include <sys/mount.h>
37*bd23e71fSKyle Evans #include <sys/poll.h>
389289f547SJohn Baldwin #include <sys/procctl.h>
399289f547SJohn Baldwin #include <sys/ptrace.h>
409289f547SJohn Baldwin #include <sys/reboot.h>
419289f547SJohn Baldwin #include <sys/resource.h>
429289f547SJohn Baldwin #include <sys/rtprio.h>
439289f547SJohn Baldwin #include <sys/sem.h>
449289f547SJohn Baldwin #include <sys/shm.h>
459289f547SJohn Baldwin #include <sys/socket.h>
469289f547SJohn Baldwin #include <sys/stat.h>
479289f547SJohn Baldwin #include <sys/thr.h>
489289f547SJohn Baldwin #include <sys/umtx.h>
4939a3a438SJohn Baldwin #include <machine/sysarch.h>
509289f547SJohn Baldwin #include <netinet/in.h>
51472e8009SMichael Tuexen #include <netinet/sctp.h>
529289f547SJohn Baldwin #include <netinet/tcp.h>
539289f547SJohn Baldwin #include <netinet/udp.h>
54ed466c34SMichael Tuexen #include <netinet/udplite.h>
559289f547SJohn Baldwin #include <nfsserver/nfs.h>
569289f547SJohn Baldwin #include <ufs/ufs/quota.h>
57aa9bddf0SSteven Hartland #include <vm/vm.h>
589289f547SJohn Baldwin #include <vm/vm_param.h>
599289f547SJohn Baldwin #include <aio.h>
609289f547SJohn Baldwin #include <fcntl.h>
619289f547SJohn Baldwin #include <sched.h>
629289f547SJohn Baldwin #include <stdbool.h>
639289f547SJohn Baldwin #include <stdio.h>
649289f547SJohn Baldwin #include <stdlib.h>
659289f547SJohn Baldwin #include <strings.h>
669289f547SJohn Baldwin #include <sysdecode.h>
679289f547SJohn Baldwin #include <unistd.h>
689289f547SJohn Baldwin #include <sys/bitstring.h>
699289f547SJohn Baldwin #include <netgraph/bluetooth/include/ng_hci.h>
709289f547SJohn Baldwin #include <netgraph/bluetooth/include/ng_l2cap.h>
719289f547SJohn Baldwin #include <netgraph/bluetooth/include/ng_btsocket.h>
729289f547SJohn Baldwin
739dac6096SDmitry Chagin #include "support.h"
749289f547SJohn Baldwin
759289f547SJohn Baldwin #define X(a) { a, #a },
769289f547SJohn Baldwin #define XEND { 0, NULL }
779289f547SJohn Baldwin
789289f547SJohn Baldwin #define TABLE_START(n) static struct name_table n[] = {
799289f547SJohn Baldwin #define TABLE_ENTRY X
809289f547SJohn Baldwin #define TABLE_END XEND };
819289f547SJohn Baldwin
829289f547SJohn Baldwin #include "tables.h"
839289f547SJohn Baldwin
849289f547SJohn Baldwin #undef TABLE_START
859289f547SJohn Baldwin #undef TABLE_ENTRY
869289f547SJohn Baldwin #undef TABLE_END
879289f547SJohn Baldwin
889289f547SJohn Baldwin const char *
sysdecode_atfd(int fd)899289f547SJohn Baldwin sysdecode_atfd(int fd)
909289f547SJohn Baldwin {
919289f547SJohn Baldwin
929289f547SJohn Baldwin if (fd == AT_FDCWD)
939289f547SJohn Baldwin return ("AT_FDCWD");
949289f547SJohn Baldwin return (NULL);
959289f547SJohn Baldwin }
969289f547SJohn Baldwin
9739a3a438SJohn Baldwin bool
sysdecode_atflags(FILE * fp,int flag,int * rem)9839a3a438SJohn Baldwin sysdecode_atflags(FILE *fp, int flag, int *rem)
9939a3a438SJohn Baldwin {
10039a3a438SJohn Baldwin
10139a3a438SJohn Baldwin return (print_mask_int(fp, atflags, flag, rem));
10239a3a438SJohn Baldwin }
10339a3a438SJohn Baldwin
1049289f547SJohn Baldwin static struct name_table semctlops[] = {
1059289f547SJohn Baldwin X(GETNCNT) X(GETPID) X(GETVAL) X(GETALL) X(GETZCNT) X(SETVAL) X(SETALL)
1069289f547SJohn Baldwin X(IPC_RMID) X(IPC_SET) X(IPC_STAT) XEND
1079289f547SJohn Baldwin };
1089289f547SJohn Baldwin
1099289f547SJohn Baldwin const char *
sysdecode_semctl_cmd(int cmd)1109289f547SJohn Baldwin sysdecode_semctl_cmd(int cmd)
1119289f547SJohn Baldwin {
1129289f547SJohn Baldwin
1139289f547SJohn Baldwin return (lookup_value(semctlops, cmd));
1149289f547SJohn Baldwin }
1159289f547SJohn Baldwin
1169289f547SJohn Baldwin static struct name_table shmctlops[] = {
1179289f547SJohn Baldwin X(IPC_RMID) X(IPC_SET) X(IPC_STAT) XEND
1189289f547SJohn Baldwin };
1199289f547SJohn Baldwin
1209289f547SJohn Baldwin const char *
sysdecode_shmctl_cmd(int cmd)1219289f547SJohn Baldwin sysdecode_shmctl_cmd(int cmd)
1229289f547SJohn Baldwin {
1239289f547SJohn Baldwin
1249289f547SJohn Baldwin return (lookup_value(shmctlops, cmd));
1259289f547SJohn Baldwin }
1269289f547SJohn Baldwin
1279289f547SJohn Baldwin const char *
sysdecode_msgctl_cmd(int cmd)1289289f547SJohn Baldwin sysdecode_msgctl_cmd(int cmd)
1299289f547SJohn Baldwin {
1309289f547SJohn Baldwin
1319289f547SJohn Baldwin return (sysdecode_shmctl_cmd(cmd));
1329289f547SJohn Baldwin }
1339289f547SJohn Baldwin
1349289f547SJohn Baldwin static struct name_table semgetflags[] = {
1359289f547SJohn Baldwin X(IPC_CREAT) X(IPC_EXCL) X(SEM_R) X(SEM_A) X((SEM_R>>3)) X((SEM_A>>3))
1369289f547SJohn Baldwin X((SEM_R>>6)) X((SEM_A>>6)) XEND
1379289f547SJohn Baldwin };
1389289f547SJohn Baldwin
1399289f547SJohn Baldwin bool
sysdecode_semget_flags(FILE * fp,int flag,int * rem)1409289f547SJohn Baldwin sysdecode_semget_flags(FILE *fp, int flag, int *rem)
1419289f547SJohn Baldwin {
1429289f547SJohn Baldwin
1439289f547SJohn Baldwin return (print_mask_int(fp, semgetflags, flag, rem));
1449289f547SJohn Baldwin }
1459289f547SJohn Baldwin
1469289f547SJohn Baldwin static struct name_table idtypes[] = {
1479289f547SJohn Baldwin X(P_PID) X(P_PPID) X(P_PGID) X(P_SID) X(P_CID) X(P_UID) X(P_GID)
1489289f547SJohn Baldwin X(P_ALL) X(P_LWPID) X(P_TASKID) X(P_PROJID) X(P_POOLID) X(P_JAILID)
1499289f547SJohn Baldwin X(P_CTID) X(P_CPUID) X(P_PSETID) XEND
1509289f547SJohn Baldwin };
1519289f547SJohn Baldwin
1529289f547SJohn Baldwin /* XXX: idtype is really an idtype_t */
1539289f547SJohn Baldwin const char *
sysdecode_idtype(int idtype)1549289f547SJohn Baldwin sysdecode_idtype(int idtype)
1559289f547SJohn Baldwin {
1569289f547SJohn Baldwin
1579289f547SJohn Baldwin return (lookup_value(idtypes, idtype));
1589289f547SJohn Baldwin }
1599289f547SJohn Baldwin
1609289f547SJohn Baldwin /*
1619289f547SJohn Baldwin * [g|s]etsockopt's level argument can either be SOL_SOCKET or a
1629289f547SJohn Baldwin * protocol-specific value.
1639289f547SJohn Baldwin */
1649289f547SJohn Baldwin const char *
sysdecode_sockopt_level(int level)1659289f547SJohn Baldwin sysdecode_sockopt_level(int level)
1669289f547SJohn Baldwin {
1679289f547SJohn Baldwin const char *str;
1689289f547SJohn Baldwin
1699289f547SJohn Baldwin if (level == SOL_SOCKET)
1709289f547SJohn Baldwin return ("SOL_SOCKET");
1719289f547SJohn Baldwin
1729289f547SJohn Baldwin /* SOL_* constants for Bluetooth sockets. */
1739289f547SJohn Baldwin str = lookup_value(ngbtsolevel, level);
1749289f547SJohn Baldwin if (str != NULL)
1759289f547SJohn Baldwin return (str);
1769289f547SJohn Baldwin
1779289f547SJohn Baldwin /*
1789289f547SJohn Baldwin * IP and Infiniband sockets use IP protocols as levels. Not all
1799289f547SJohn Baldwin * protocols are valid but it is simpler to just allow all of them.
1809289f547SJohn Baldwin *
1819289f547SJohn Baldwin * XXX: IPPROTO_IP == 0, but UNIX domain sockets use a level of 0
1829289f547SJohn Baldwin * for private options.
1839289f547SJohn Baldwin */
1849289f547SJohn Baldwin str = sysdecode_ipproto(level);
1859289f547SJohn Baldwin if (str != NULL)
1869289f547SJohn Baldwin return (str);
1879289f547SJohn Baldwin
1889289f547SJohn Baldwin return (NULL);
1899289f547SJohn Baldwin }
1909289f547SJohn Baldwin
1919289f547SJohn Baldwin bool
sysdecode_vmprot(FILE * fp,int type,int * rem)1929289f547SJohn Baldwin sysdecode_vmprot(FILE *fp, int type, int *rem)
1939289f547SJohn Baldwin {
1949289f547SJohn Baldwin
1959289f547SJohn Baldwin return (print_mask_int(fp, vmprot, type, rem));
1969289f547SJohn Baldwin }
1979289f547SJohn Baldwin
1989289f547SJohn Baldwin static struct name_table sockflags[] = {
1999289f547SJohn Baldwin X(SOCK_CLOEXEC) X(SOCK_NONBLOCK) XEND
2009289f547SJohn Baldwin };
2019289f547SJohn Baldwin
2029289f547SJohn Baldwin bool
sysdecode_socket_type(FILE * fp,int type,int * rem)2039289f547SJohn Baldwin sysdecode_socket_type(FILE *fp, int type, int *rem)
2049289f547SJohn Baldwin {
2059289f547SJohn Baldwin const char *str;
2069289f547SJohn Baldwin uintmax_t val;
2079289f547SJohn Baldwin bool printed;
2089289f547SJohn Baldwin
2099289f547SJohn Baldwin str = lookup_value(socktype, type & ~(SOCK_CLOEXEC | SOCK_NONBLOCK));
2109289f547SJohn Baldwin if (str != NULL) {
2119289f547SJohn Baldwin fputs(str, fp);
2129289f547SJohn Baldwin *rem = 0;
2139289f547SJohn Baldwin printed = true;
2149289f547SJohn Baldwin } else {
2159289f547SJohn Baldwin *rem = type & ~(SOCK_CLOEXEC | SOCK_NONBLOCK);
2169289f547SJohn Baldwin printed = false;
2179289f547SJohn Baldwin }
2189289f547SJohn Baldwin val = type & (SOCK_CLOEXEC | SOCK_NONBLOCK);
2199289f547SJohn Baldwin print_mask_part(fp, sockflags, &val, &printed);
2209289f547SJohn Baldwin return (printed);
2219289f547SJohn Baldwin }
2229289f547SJohn Baldwin
2239289f547SJohn Baldwin bool
sysdecode_access_mode(FILE * fp,int mode,int * rem)2249289f547SJohn Baldwin sysdecode_access_mode(FILE *fp, int mode, int *rem)
2259289f547SJohn Baldwin {
2269289f547SJohn Baldwin
2279289f547SJohn Baldwin return (print_mask_int(fp, accessmode, mode, rem));
2289289f547SJohn Baldwin }
2299289f547SJohn Baldwin
2309289f547SJohn Baldwin /* XXX: 'type' is really an acl_type_t. */
2319289f547SJohn Baldwin const char *
sysdecode_acltype(int type)2329289f547SJohn Baldwin sysdecode_acltype(int type)
2339289f547SJohn Baldwin {
2349289f547SJohn Baldwin
2359289f547SJohn Baldwin return (lookup_value(acltype, type));
2369289f547SJohn Baldwin }
2379289f547SJohn Baldwin
2389289f547SJohn Baldwin bool
sysdecode_cap_fcntlrights(FILE * fp,uint32_t rights,uint32_t * rem)2399289f547SJohn Baldwin sysdecode_cap_fcntlrights(FILE *fp, uint32_t rights, uint32_t *rem)
2409289f547SJohn Baldwin {
2419289f547SJohn Baldwin
2429289f547SJohn Baldwin return (print_mask_int(fp, capfcntl, rights, rem));
2439289f547SJohn Baldwin }
2449289f547SJohn Baldwin
245f3f3e3c4SMateusz Guzik bool
sysdecode_close_range_flags(FILE * fp,int flags,int * rem)246f3f3e3c4SMateusz Guzik sysdecode_close_range_flags(FILE *fp, int flags, int *rem)
247f3f3e3c4SMateusz Guzik {
248f3f3e3c4SMateusz Guzik
249f3f3e3c4SMateusz Guzik return (print_mask_int(fp, closerangeflags, flags, rem));
250f3f3e3c4SMateusz Guzik }
251f3f3e3c4SMateusz Guzik
2529289f547SJohn Baldwin const char *
sysdecode_extattrnamespace(int namespace)2539289f547SJohn Baldwin sysdecode_extattrnamespace(int namespace)
2549289f547SJohn Baldwin {
2559289f547SJohn Baldwin
2569289f547SJohn Baldwin return (lookup_value(extattrns, namespace));
2579289f547SJohn Baldwin }
2589289f547SJohn Baldwin
2599289f547SJohn Baldwin const char *
sysdecode_fadvice(int advice)2609289f547SJohn Baldwin sysdecode_fadvice(int advice)
2619289f547SJohn Baldwin {
2629289f547SJohn Baldwin
2639289f547SJohn Baldwin return (lookup_value(fadvisebehav, advice));
2649289f547SJohn Baldwin }
2659289f547SJohn Baldwin
2669289f547SJohn Baldwin bool
sysdecode_open_flags(FILE * fp,int flags,int * rem)2679289f547SJohn Baldwin sysdecode_open_flags(FILE *fp, int flags, int *rem)
2689289f547SJohn Baldwin {
2699289f547SJohn Baldwin bool printed;
2709289f547SJohn Baldwin int mode;
2719289f547SJohn Baldwin uintmax_t val;
2729289f547SJohn Baldwin
2739289f547SJohn Baldwin mode = flags & O_ACCMODE;
2749289f547SJohn Baldwin flags &= ~O_ACCMODE;
2759289f547SJohn Baldwin switch (mode) {
2769289f547SJohn Baldwin case O_RDONLY:
2779289f547SJohn Baldwin if (flags & O_EXEC) {
2789289f547SJohn Baldwin flags &= ~O_EXEC;
2799289f547SJohn Baldwin fputs("O_EXEC", fp);
2809289f547SJohn Baldwin } else
2819289f547SJohn Baldwin fputs("O_RDONLY", fp);
2829289f547SJohn Baldwin printed = true;
2839289f547SJohn Baldwin mode = 0;
2849289f547SJohn Baldwin break;
2859289f547SJohn Baldwin case O_WRONLY:
2869289f547SJohn Baldwin fputs("O_WRONLY", fp);
2879289f547SJohn Baldwin printed = true;
2889289f547SJohn Baldwin mode = 0;
2899289f547SJohn Baldwin break;
2909289f547SJohn Baldwin case O_RDWR:
2919289f547SJohn Baldwin fputs("O_RDWR", fp);
2929289f547SJohn Baldwin printed = true;
2939289f547SJohn Baldwin mode = 0;
2949289f547SJohn Baldwin break;
2959289f547SJohn Baldwin default:
2969289f547SJohn Baldwin printed = false;
2979289f547SJohn Baldwin }
2989289f547SJohn Baldwin val = (unsigned)flags;
2999289f547SJohn Baldwin print_mask_part(fp, openflags, &val, &printed);
3009289f547SJohn Baldwin if (rem != NULL)
3019289f547SJohn Baldwin *rem = val | mode;
3029289f547SJohn Baldwin return (printed);
3039289f547SJohn Baldwin }
3049289f547SJohn Baldwin
3059289f547SJohn Baldwin bool
sysdecode_fcntl_fileflags(FILE * fp,int flags,int * rem)3069289f547SJohn Baldwin sysdecode_fcntl_fileflags(FILE *fp, int flags, int *rem)
3079289f547SJohn Baldwin {
3089289f547SJohn Baldwin bool printed;
3099289f547SJohn Baldwin int oflags;
3109289f547SJohn Baldwin
3119289f547SJohn Baldwin /*
3129289f547SJohn Baldwin * The file flags used with F_GETFL/F_SETFL mostly match the
3139289f547SJohn Baldwin * flags passed to open(2). However, a few open-only flag
3149289f547SJohn Baldwin * bits have been repurposed for fcntl-only flags.
3159289f547SJohn Baldwin */
3169289f547SJohn Baldwin oflags = flags & ~(O_NOFOLLOW | FRDAHEAD);
3179289f547SJohn Baldwin printed = sysdecode_open_flags(fp, oflags, rem);
3189289f547SJohn Baldwin if (flags & O_NOFOLLOW) {
3199289f547SJohn Baldwin fprintf(fp, "%sFPOIXSHM", printed ? "|" : "");
3209289f547SJohn Baldwin printed = true;
3219289f547SJohn Baldwin }
3229289f547SJohn Baldwin if (flags & FRDAHEAD) {
3239289f547SJohn Baldwin fprintf(fp, "%sFRDAHEAD", printed ? "|" : "");
3249289f547SJohn Baldwin printed = true;
3259289f547SJohn Baldwin }
3269289f547SJohn Baldwin return (printed);
3279289f547SJohn Baldwin }
3289289f547SJohn Baldwin
3299289f547SJohn Baldwin bool
sysdecode_flock_operation(FILE * fp,int operation,int * rem)3309289f547SJohn Baldwin sysdecode_flock_operation(FILE *fp, int operation, int *rem)
3319289f547SJohn Baldwin {
3329289f547SJohn Baldwin
3339289f547SJohn Baldwin return (print_mask_int(fp, flockops, operation, rem));
3349289f547SJohn Baldwin }
3359289f547SJohn Baldwin
33648f79574SJohn Baldwin static struct name_table getfsstatmode[] = {
33748f79574SJohn Baldwin X(MNT_WAIT) X(MNT_NOWAIT) XEND
33848f79574SJohn Baldwin };
33948f79574SJohn Baldwin
34048f79574SJohn Baldwin const char *
sysdecode_getfsstat_mode(int mode)34148f79574SJohn Baldwin sysdecode_getfsstat_mode(int mode)
3429289f547SJohn Baldwin {
3439289f547SJohn Baldwin
34448f79574SJohn Baldwin return (lookup_value(getfsstatmode, mode));
3459289f547SJohn Baldwin }
3469289f547SJohn Baldwin
3479289f547SJohn Baldwin const char *
sysdecode_getrusage_who(int who)348ee8aa41dSJohn Baldwin sysdecode_getrusage_who(int who)
349ee8aa41dSJohn Baldwin {
350ee8aa41dSJohn Baldwin
351ee8aa41dSJohn Baldwin return (lookup_value(rusage, who));
352ee8aa41dSJohn Baldwin }
353ee8aa41dSJohn Baldwin
354ffb66079SJohn Baldwin static struct name_table kevent_user_ffctrl[] = {
355ffb66079SJohn Baldwin X(NOTE_FFNOP) X(NOTE_FFAND) X(NOTE_FFOR) X(NOTE_FFCOPY)
356ffb66079SJohn Baldwin XEND
357ffb66079SJohn Baldwin };
358ffb66079SJohn Baldwin
359ffb66079SJohn Baldwin static struct name_table kevent_rdwr_fflags[] = {
360ffb66079SJohn Baldwin X(NOTE_LOWAT) X(NOTE_FILE_POLL) XEND
361ffb66079SJohn Baldwin };
362ffb66079SJohn Baldwin
363ffb66079SJohn Baldwin static struct name_table kevent_vnode_fflags[] = {
364ffb66079SJohn Baldwin X(NOTE_DELETE) X(NOTE_WRITE) X(NOTE_EXTEND) X(NOTE_ATTRIB)
365ffb66079SJohn Baldwin X(NOTE_LINK) X(NOTE_RENAME) X(NOTE_REVOKE) X(NOTE_OPEN) X(NOTE_CLOSE)
366ffb66079SJohn Baldwin X(NOTE_CLOSE_WRITE) X(NOTE_READ) XEND
367ffb66079SJohn Baldwin };
368ffb66079SJohn Baldwin
369ffb66079SJohn Baldwin static struct name_table kevent_proc_fflags[] = {
370ffb66079SJohn Baldwin X(NOTE_EXIT) X(NOTE_FORK) X(NOTE_EXEC) X(NOTE_TRACK) X(NOTE_TRACKERR)
371ffb66079SJohn Baldwin X(NOTE_CHILD) XEND
372ffb66079SJohn Baldwin };
373ffb66079SJohn Baldwin
374ffb66079SJohn Baldwin static struct name_table kevent_timer_fflags[] = {
375ffb66079SJohn Baldwin X(NOTE_SECONDS) X(NOTE_MSECONDS) X(NOTE_USECONDS) X(NOTE_NSECONDS)
376ffb66079SJohn Baldwin X(NOTE_ABSTIME) XEND
377ffb66079SJohn Baldwin };
378ffb66079SJohn Baldwin
379ffb66079SJohn Baldwin void
sysdecode_kevent_fflags(FILE * fp,short filter,int fflags,int base)380ffb66079SJohn Baldwin sysdecode_kevent_fflags(FILE *fp, short filter, int fflags, int base)
381ffb66079SJohn Baldwin {
382ffb66079SJohn Baldwin int rem;
383ffb66079SJohn Baldwin
384ffb66079SJohn Baldwin if (fflags == 0) {
385ffb66079SJohn Baldwin fputs("0", fp);
386ffb66079SJohn Baldwin return;
387ffb66079SJohn Baldwin }
388ffb66079SJohn Baldwin
389ffb66079SJohn Baldwin switch (filter) {
390ffb66079SJohn Baldwin case EVFILT_READ:
391ffb66079SJohn Baldwin case EVFILT_WRITE:
392ffb66079SJohn Baldwin if (!print_mask_int(fp, kevent_rdwr_fflags, fflags, &rem))
393ffb66079SJohn Baldwin fprintf(fp, "%#x", rem);
394ffb66079SJohn Baldwin else if (rem != 0)
395ffb66079SJohn Baldwin fprintf(fp, "|%#x", rem);
396ffb66079SJohn Baldwin break;
397ffb66079SJohn Baldwin case EVFILT_VNODE:
398ffb66079SJohn Baldwin if (!print_mask_int(fp, kevent_vnode_fflags, fflags, &rem))
399ffb66079SJohn Baldwin fprintf(fp, "%#x", rem);
400ffb66079SJohn Baldwin else if (rem != 0)
401ffb66079SJohn Baldwin fprintf(fp, "|%#x", rem);
402ffb66079SJohn Baldwin break;
403ffb66079SJohn Baldwin case EVFILT_PROC:
404ffb66079SJohn Baldwin case EVFILT_PROCDESC:
405ffb66079SJohn Baldwin if (!print_mask_int(fp, kevent_proc_fflags, fflags, &rem))
406ffb66079SJohn Baldwin fprintf(fp, "%#x", rem);
407ffb66079SJohn Baldwin else if (rem != 0)
408ffb66079SJohn Baldwin fprintf(fp, "|%#x", rem);
409ffb66079SJohn Baldwin break;
410ffb66079SJohn Baldwin case EVFILT_TIMER:
411ffb66079SJohn Baldwin if (!print_mask_int(fp, kevent_timer_fflags, fflags, &rem))
412ffb66079SJohn Baldwin fprintf(fp, "%#x", rem);
413ffb66079SJohn Baldwin else if (rem != 0)
414ffb66079SJohn Baldwin fprintf(fp, "|%#x", rem);
415ffb66079SJohn Baldwin break;
416ffb66079SJohn Baldwin case EVFILT_USER: {
417ffb66079SJohn Baldwin unsigned int ctrl, data;
418ffb66079SJohn Baldwin
419ffb66079SJohn Baldwin ctrl = fflags & NOTE_FFCTRLMASK;
420ffb66079SJohn Baldwin data = fflags & NOTE_FFLAGSMASK;
421ffb66079SJohn Baldwin
422ffb66079SJohn Baldwin if (fflags & NOTE_TRIGGER) {
423ffb66079SJohn Baldwin fputs("NOTE_TRIGGER", fp);
424ffb66079SJohn Baldwin if (fflags == NOTE_TRIGGER)
425ffb66079SJohn Baldwin return;
426ffb66079SJohn Baldwin fputc('|', fp);
427ffb66079SJohn Baldwin }
428ffb66079SJohn Baldwin
429ffb66079SJohn Baldwin /*
430ffb66079SJohn Baldwin * An event with 'ctrl' == NOTE_FFNOP is either a reported
431ffb66079SJohn Baldwin * (output) event for which only 'data' should be output
432ffb66079SJohn Baldwin * or a pointless input event. Assume that pointless
433ffb66079SJohn Baldwin * input events don't occur in practice. An event with
434ffb66079SJohn Baldwin * NOTE_TRIGGER is always an input event.
435ffb66079SJohn Baldwin */
436ffb66079SJohn Baldwin if (ctrl != NOTE_FFNOP || fflags & NOTE_TRIGGER) {
437ffb66079SJohn Baldwin fprintf(fp, "%s|%#x",
438ffb66079SJohn Baldwin lookup_value(kevent_user_ffctrl, ctrl), data);
439ffb66079SJohn Baldwin } else {
440ffb66079SJohn Baldwin print_integer(fp, data, base);
441ffb66079SJohn Baldwin }
442ffb66079SJohn Baldwin break;
443ffb66079SJohn Baldwin }
444ffb66079SJohn Baldwin default:
445ffb66079SJohn Baldwin print_integer(fp, fflags, base);
446ffb66079SJohn Baldwin break;
447ffb66079SJohn Baldwin }
448ffb66079SJohn Baldwin }
449ffb66079SJohn Baldwin
450ffb66079SJohn Baldwin bool
sysdecode_kevent_flags(FILE * fp,int flags,int * rem)451ffb66079SJohn Baldwin sysdecode_kevent_flags(FILE *fp, int flags, int *rem)
452ffb66079SJohn Baldwin {
453ffb66079SJohn Baldwin
454ffb66079SJohn Baldwin return (print_mask_int(fp, keventflags, flags, rem));
455ffb66079SJohn Baldwin }
456ffb66079SJohn Baldwin
457ffb66079SJohn Baldwin const char *
sysdecode_kevent_filter(int filter)458ffb66079SJohn Baldwin sysdecode_kevent_filter(int filter)
459ffb66079SJohn Baldwin {
460ffb66079SJohn Baldwin
461ffb66079SJohn Baldwin return (lookup_value(keventfilters, filter));
462ffb66079SJohn Baldwin }
463ffb66079SJohn Baldwin
464ee8aa41dSJohn Baldwin const char *
sysdecode_kldsym_cmd(int cmd)4659289f547SJohn Baldwin sysdecode_kldsym_cmd(int cmd)
4669289f547SJohn Baldwin {
4679289f547SJohn Baldwin
4689289f547SJohn Baldwin return (lookup_value(kldsymcmd, cmd));
4699289f547SJohn Baldwin }
4709289f547SJohn Baldwin
4719289f547SJohn Baldwin const char *
sysdecode_kldunload_flags(int flags)4729289f547SJohn Baldwin sysdecode_kldunload_flags(int flags)
4739289f547SJohn Baldwin {
4749289f547SJohn Baldwin
4759289f547SJohn Baldwin return (lookup_value(kldunloadfflags, flags));
4769289f547SJohn Baldwin }
4779289f547SJohn Baldwin
4789289f547SJohn Baldwin const char *
sysdecode_lio_listio_mode(int mode)4799289f547SJohn Baldwin sysdecode_lio_listio_mode(int mode)
4809289f547SJohn Baldwin {
4819289f547SJohn Baldwin
4829289f547SJohn Baldwin return (lookup_value(lio_listiomodes, mode));
4839289f547SJohn Baldwin }
4849289f547SJohn Baldwin
4859289f547SJohn Baldwin const char *
sysdecode_madvice(int advice)4869289f547SJohn Baldwin sysdecode_madvice(int advice)
4879289f547SJohn Baldwin {
4889289f547SJohn Baldwin
4899289f547SJohn Baldwin return (lookup_value(madvisebehav, advice));
4909289f547SJohn Baldwin }
4919289f547SJohn Baldwin
4929289f547SJohn Baldwin const char *
sysdecode_minherit_inherit(int inherit)4939289f547SJohn Baldwin sysdecode_minherit_inherit(int inherit)
4949289f547SJohn Baldwin {
4959289f547SJohn Baldwin
4969289f547SJohn Baldwin return (lookup_value(minheritflags, inherit));
4979289f547SJohn Baldwin }
4989289f547SJohn Baldwin
4999289f547SJohn Baldwin bool
sysdecode_mlockall_flags(FILE * fp,int flags,int * rem)5009289f547SJohn Baldwin sysdecode_mlockall_flags(FILE *fp, int flags, int *rem)
5019289f547SJohn Baldwin {
5029289f547SJohn Baldwin
5039289f547SJohn Baldwin return (print_mask_int(fp, mlockallflags, flags, rem));
5049289f547SJohn Baldwin }
5059289f547SJohn Baldwin
5069289f547SJohn Baldwin bool
sysdecode_mmap_prot(FILE * fp,int prot,int * rem)5079289f547SJohn Baldwin sysdecode_mmap_prot(FILE *fp, int prot, int *rem)
5089289f547SJohn Baldwin {
509c1dd36cfSPawel Biernacki int protm;
510c1dd36cfSPawel Biernacki bool printed;
5119289f547SJohn Baldwin
512c1dd36cfSPawel Biernacki printed = false;
513c1dd36cfSPawel Biernacki protm = PROT_MAX_EXTRACT(prot);
514569da02bSPawel Biernacki prot &= ~PROT_MAX(protm);
515c1dd36cfSPawel Biernacki if (protm != 0) {
516c1dd36cfSPawel Biernacki fputs("PROT_MAX(", fp);
517c1dd36cfSPawel Biernacki printed = print_mask_int(fp, mmapprot, protm, rem);
518c1dd36cfSPawel Biernacki fputs(")|", fp);
519c1dd36cfSPawel Biernacki }
520c1dd36cfSPawel Biernacki return (print_mask_int(fp, mmapprot, prot, rem) || printed);
5219289f547SJohn Baldwin }
5229289f547SJohn Baldwin
5239289f547SJohn Baldwin bool
sysdecode_fileflags(FILE * fp,fflags_t flags,fflags_t * rem)5249289f547SJohn Baldwin sysdecode_fileflags(FILE *fp, fflags_t flags, fflags_t *rem)
5259289f547SJohn Baldwin {
5269289f547SJohn Baldwin
5279289f547SJohn Baldwin return (print_mask_0(fp, fileflags, flags, rem));
5289289f547SJohn Baldwin }
5299289f547SJohn Baldwin
5309289f547SJohn Baldwin bool
sysdecode_filemode(FILE * fp,int mode,int * rem)5319289f547SJohn Baldwin sysdecode_filemode(FILE *fp, int mode, int *rem)
5329289f547SJohn Baldwin {
5339289f547SJohn Baldwin
5349289f547SJohn Baldwin return (print_mask_0(fp, filemode, mode, rem));
5359289f547SJohn Baldwin }
5369289f547SJohn Baldwin
5379289f547SJohn Baldwin bool
sysdecode_mount_flags(FILE * fp,int flags,int * rem)5389289f547SJohn Baldwin sysdecode_mount_flags(FILE *fp, int flags, int *rem)
5399289f547SJohn Baldwin {
5409289f547SJohn Baldwin
5419289f547SJohn Baldwin return (print_mask_int(fp, mountflags, flags, rem));
5429289f547SJohn Baldwin }
5439289f547SJohn Baldwin
5449289f547SJohn Baldwin bool
sysdecode_msync_flags(FILE * fp,int flags,int * rem)5459289f547SJohn Baldwin sysdecode_msync_flags(FILE *fp, int flags, int *rem)
5469289f547SJohn Baldwin {
5479289f547SJohn Baldwin
5489289f547SJohn Baldwin return (print_mask_int(fp, msyncflags, flags, rem));
5499289f547SJohn Baldwin }
5509289f547SJohn Baldwin
5519289f547SJohn Baldwin const char *
sysdecode_nfssvc_flags(int flags)5529289f547SJohn Baldwin sysdecode_nfssvc_flags(int flags)
5539289f547SJohn Baldwin {
5549289f547SJohn Baldwin
5559289f547SJohn Baldwin return (lookup_value(nfssvcflags, flags));
5569289f547SJohn Baldwin }
5579289f547SJohn Baldwin
5589289f547SJohn Baldwin static struct name_table pipe2flags[] = {
5599289f547SJohn Baldwin X(O_CLOEXEC) X(O_NONBLOCK) XEND
5609289f547SJohn Baldwin };
5619289f547SJohn Baldwin
5629289f547SJohn Baldwin bool
sysdecode_pipe2_flags(FILE * fp,int flags,int * rem)5639289f547SJohn Baldwin sysdecode_pipe2_flags(FILE *fp, int flags, int *rem)
5649289f547SJohn Baldwin {
5659289f547SJohn Baldwin
5669289f547SJohn Baldwin return (print_mask_0(fp, pipe2flags, flags, rem));
5679289f547SJohn Baldwin }
5689289f547SJohn Baldwin
569*bd23e71fSKyle Evans bool
sysdecode_pollfd_events(FILE * fp,int flags,int * rem)570*bd23e71fSKyle Evans sysdecode_pollfd_events(FILE *fp, int flags, int *rem)
571*bd23e71fSKyle Evans {
572*bd23e71fSKyle Evans
573*bd23e71fSKyle Evans return (print_mask_int(fp, pollfdevents, flags, rem));
574*bd23e71fSKyle Evans }
575*bd23e71fSKyle Evans
5769289f547SJohn Baldwin const char *
sysdecode_prio_which(int which)5779289f547SJohn Baldwin sysdecode_prio_which(int which)
5789289f547SJohn Baldwin {
5799289f547SJohn Baldwin
5809289f547SJohn Baldwin return (lookup_value(prio, which));
5819289f547SJohn Baldwin }
5829289f547SJohn Baldwin
5839289f547SJohn Baldwin const char *
sysdecode_procctl_cmd(int cmd)5849289f547SJohn Baldwin sysdecode_procctl_cmd(int cmd)
5859289f547SJohn Baldwin {
5869289f547SJohn Baldwin
5879289f547SJohn Baldwin return (lookup_value(procctlcmd, cmd));
5889289f547SJohn Baldwin }
5899289f547SJohn Baldwin
5909289f547SJohn Baldwin const char *
sysdecode_ptrace_request(int request)5919289f547SJohn Baldwin sysdecode_ptrace_request(int request)
5929289f547SJohn Baldwin {
5939289f547SJohn Baldwin
5949289f547SJohn Baldwin return (lookup_value(ptraceop, request));
5959289f547SJohn Baldwin }
5969289f547SJohn Baldwin
5979289f547SJohn Baldwin static struct name_table quotatypes[] = {
5989289f547SJohn Baldwin X(GRPQUOTA) X(USRQUOTA) XEND
5999289f547SJohn Baldwin };
6009289f547SJohn Baldwin
6019289f547SJohn Baldwin bool
sysdecode_quotactl_cmd(FILE * fp,int cmd)6029289f547SJohn Baldwin sysdecode_quotactl_cmd(FILE *fp, int cmd)
6039289f547SJohn Baldwin {
6049289f547SJohn Baldwin const char *primary, *type;
6059289f547SJohn Baldwin
6069289f547SJohn Baldwin primary = lookup_value(quotactlcmds, cmd >> SUBCMDSHIFT);
6079289f547SJohn Baldwin if (primary == NULL)
6089289f547SJohn Baldwin return (false);
6099289f547SJohn Baldwin fprintf(fp, "QCMD(%s,", primary);
6109289f547SJohn Baldwin type = lookup_value(quotatypes, cmd & SUBCMDMASK);
6119289f547SJohn Baldwin if (type != NULL)
6129289f547SJohn Baldwin fprintf(fp, "%s", type);
6139289f547SJohn Baldwin else
6149289f547SJohn Baldwin fprintf(fp, "%#x", cmd & SUBCMDMASK);
6159289f547SJohn Baldwin fprintf(fp, ")");
6169289f547SJohn Baldwin return (true);
6179289f547SJohn Baldwin }
6189289f547SJohn Baldwin
6199289f547SJohn Baldwin bool
sysdecode_reboot_howto(FILE * fp,int howto,int * rem)6209289f547SJohn Baldwin sysdecode_reboot_howto(FILE *fp, int howto, int *rem)
6219289f547SJohn Baldwin {
62230b94d0cSJohn Baldwin bool printed;
6239289f547SJohn Baldwin
62430b94d0cSJohn Baldwin /*
62530b94d0cSJohn Baldwin * RB_AUTOBOOT is special in that its value is zero, but it is
62630b94d0cSJohn Baldwin * also an implied argument if a different operation is not
6272b6e6d85SJohn Baldwin * requested via RB_HALT, RB_POWERCYCLE, RB_POWEROFF, or
6282b6e6d85SJohn Baldwin * RB_REROOT.
62930b94d0cSJohn Baldwin */
6302b6e6d85SJohn Baldwin if (howto != 0 && (howto & (RB_HALT | RB_POWEROFF | RB_REROOT |
6312b6e6d85SJohn Baldwin RB_POWERCYCLE)) == 0) {
63230b94d0cSJohn Baldwin fputs("RB_AUTOBOOT|", fp);
63330b94d0cSJohn Baldwin printed = true;
63430b94d0cSJohn Baldwin } else
63530b94d0cSJohn Baldwin printed = false;
63630b94d0cSJohn Baldwin return (print_mask_int(fp, rebootopt, howto, rem) || printed);
6379289f547SJohn Baldwin }
6389289f547SJohn Baldwin
6399289f547SJohn Baldwin bool
sysdecode_rfork_flags(FILE * fp,int flags,int * rem)6409289f547SJohn Baldwin sysdecode_rfork_flags(FILE *fp, int flags, int *rem)
6419289f547SJohn Baldwin {
6429289f547SJohn Baldwin
6439289f547SJohn Baldwin return (print_mask_int(fp, rforkflags, flags, rem));
6449289f547SJohn Baldwin }
6459289f547SJohn Baldwin
6469289f547SJohn Baldwin const char *
sysdecode_rlimit(int resource)6479289f547SJohn Baldwin sysdecode_rlimit(int resource)
6489289f547SJohn Baldwin {
6499289f547SJohn Baldwin
6509289f547SJohn Baldwin return (lookup_value(rlimit, resource));
6519289f547SJohn Baldwin }
6529289f547SJohn Baldwin
6539289f547SJohn Baldwin const char *
sysdecode_scheduler_policy(int policy)6549289f547SJohn Baldwin sysdecode_scheduler_policy(int policy)
6559289f547SJohn Baldwin {
6569289f547SJohn Baldwin
6579289f547SJohn Baldwin return (lookup_value(schedpolicy, policy));
6589289f547SJohn Baldwin }
6599289f547SJohn Baldwin
6609289f547SJohn Baldwin bool
sysdecode_sendfile_flags(FILE * fp,int flags,int * rem)6619289f547SJohn Baldwin sysdecode_sendfile_flags(FILE *fp, int flags, int *rem)
6629289f547SJohn Baldwin {
6639289f547SJohn Baldwin
6649289f547SJohn Baldwin return (print_mask_int(fp, sendfileflags, flags, rem));
6659289f547SJohn Baldwin }
6669289f547SJohn Baldwin
6679289f547SJohn Baldwin bool
sysdecode_shmat_flags(FILE * fp,int flags,int * rem)6689289f547SJohn Baldwin sysdecode_shmat_flags(FILE *fp, int flags, int *rem)
6699289f547SJohn Baldwin {
6709289f547SJohn Baldwin
6719289f547SJohn Baldwin return (print_mask_int(fp, shmatflags, flags, rem));
6729289f547SJohn Baldwin }
6739289f547SJohn Baldwin
6749289f547SJohn Baldwin const char *
sysdecode_shutdown_how(int how)6759289f547SJohn Baldwin sysdecode_shutdown_how(int how)
6769289f547SJohn Baldwin {
6779289f547SJohn Baldwin
6789289f547SJohn Baldwin return (lookup_value(shutdownhow, how));
6799289f547SJohn Baldwin }
6809289f547SJohn Baldwin
6819289f547SJohn Baldwin const char *
sysdecode_sigbus_code(int si_code)6829289f547SJohn Baldwin sysdecode_sigbus_code(int si_code)
6839289f547SJohn Baldwin {
6849289f547SJohn Baldwin
6859289f547SJohn Baldwin return (lookup_value(sigbuscode, si_code));
6869289f547SJohn Baldwin }
6879289f547SJohn Baldwin
6889289f547SJohn Baldwin const char *
sysdecode_sigchld_code(int si_code)6899289f547SJohn Baldwin sysdecode_sigchld_code(int si_code)
6909289f547SJohn Baldwin {
6919289f547SJohn Baldwin
6929289f547SJohn Baldwin return (lookup_value(sigchldcode, si_code));
6939289f547SJohn Baldwin }
6949289f547SJohn Baldwin
6959289f547SJohn Baldwin const char *
sysdecode_sigfpe_code(int si_code)6969289f547SJohn Baldwin sysdecode_sigfpe_code(int si_code)
6979289f547SJohn Baldwin {
6989289f547SJohn Baldwin
6999289f547SJohn Baldwin return (lookup_value(sigfpecode, si_code));
7009289f547SJohn Baldwin }
7019289f547SJohn Baldwin
7029289f547SJohn Baldwin const char *
sysdecode_sigill_code(int si_code)7039289f547SJohn Baldwin sysdecode_sigill_code(int si_code)
7049289f547SJohn Baldwin {
7059289f547SJohn Baldwin
7069289f547SJohn Baldwin return (lookup_value(sigillcode, si_code));
7079289f547SJohn Baldwin }
7089289f547SJohn Baldwin
7099289f547SJohn Baldwin const char *
sysdecode_sigsegv_code(int si_code)7109289f547SJohn Baldwin sysdecode_sigsegv_code(int si_code)
7119289f547SJohn Baldwin {
7129289f547SJohn Baldwin
7139289f547SJohn Baldwin return (lookup_value(sigsegvcode, si_code));
7149289f547SJohn Baldwin }
7159289f547SJohn Baldwin
7169289f547SJohn Baldwin const char *
sysdecode_sigtrap_code(int si_code)7179289f547SJohn Baldwin sysdecode_sigtrap_code(int si_code)
7189289f547SJohn Baldwin {
7199289f547SJohn Baldwin
7209289f547SJohn Baldwin return (lookup_value(sigtrapcode, si_code));
7219289f547SJohn Baldwin }
7229289f547SJohn Baldwin
7239289f547SJohn Baldwin const char *
sysdecode_sigprocmask_how(int how)7249289f547SJohn Baldwin sysdecode_sigprocmask_how(int how)
7259289f547SJohn Baldwin {
7269289f547SJohn Baldwin
7279289f547SJohn Baldwin return (lookup_value(sigprocmaskhow, how));
7289289f547SJohn Baldwin }
7299289f547SJohn Baldwin
7309289f547SJohn Baldwin const char *
sysdecode_socketdomain(int domain)7319289f547SJohn Baldwin sysdecode_socketdomain(int domain)
7329289f547SJohn Baldwin {
7339289f547SJohn Baldwin
7349289f547SJohn Baldwin return (lookup_value(sockdomain, domain));
7359289f547SJohn Baldwin }
7369289f547SJohn Baldwin
7379289f547SJohn Baldwin const char *
sysdecode_socket_protocol(int domain,int protocol)738738a93a4SMichael Tuexen sysdecode_socket_protocol(int domain, int protocol)
739738a93a4SMichael Tuexen {
740738a93a4SMichael Tuexen
741738a93a4SMichael Tuexen switch (domain) {
742738a93a4SMichael Tuexen case PF_INET:
743738a93a4SMichael Tuexen case PF_INET6:
744738a93a4SMichael Tuexen return (lookup_value(sockipproto, protocol));
745738a93a4SMichael Tuexen default:
746738a93a4SMichael Tuexen return (NULL);
747738a93a4SMichael Tuexen }
748738a93a4SMichael Tuexen }
749738a93a4SMichael Tuexen
750738a93a4SMichael Tuexen const char *
sysdecode_sockaddr_family(int sa_family)7519289f547SJohn Baldwin sysdecode_sockaddr_family(int sa_family)
7529289f547SJohn Baldwin {
7539289f547SJohn Baldwin
7549289f547SJohn Baldwin return (lookup_value(sockfamily, sa_family));
7559289f547SJohn Baldwin }
7569289f547SJohn Baldwin
7579289f547SJohn Baldwin const char *
sysdecode_ipproto(int protocol)7589289f547SJohn Baldwin sysdecode_ipproto(int protocol)
7599289f547SJohn Baldwin {
7609289f547SJohn Baldwin
7619289f547SJohn Baldwin return (lookup_value(sockipproto, protocol));
7629289f547SJohn Baldwin }
7639289f547SJohn Baldwin
7649289f547SJohn Baldwin const char *
sysdecode_sockopt_name(int level,int optname)7659289f547SJohn Baldwin sysdecode_sockopt_name(int level, int optname)
7669289f547SJohn Baldwin {
7679289f547SJohn Baldwin
7689289f547SJohn Baldwin if (level == SOL_SOCKET)
7699289f547SJohn Baldwin return (lookup_value(sockopt, optname));
7709289f547SJohn Baldwin if (level == IPPROTO_IP)
7719289f547SJohn Baldwin /* XXX: UNIX domain socket options use a level of 0 also. */
7729289f547SJohn Baldwin return (lookup_value(sockoptip, optname));
773702eb303SMichael Tuexen if (level == IPPROTO_IPV6)
774702eb303SMichael Tuexen return (lookup_value(sockoptipv6, optname));
775472e8009SMichael Tuexen if (level == IPPROTO_SCTP)
776472e8009SMichael Tuexen return (lookup_value(sockoptsctp, optname));
7779289f547SJohn Baldwin if (level == IPPROTO_TCP)
7789289f547SJohn Baldwin return (lookup_value(sockopttcp, optname));
7799289f547SJohn Baldwin if (level == IPPROTO_UDP)
7809289f547SJohn Baldwin return (lookup_value(sockoptudp, optname));
781ed466c34SMichael Tuexen if (level == IPPROTO_UDPLITE)
782ed466c34SMichael Tuexen return (lookup_value(sockoptudplite, optname));
7839289f547SJohn Baldwin return (NULL);
7849289f547SJohn Baldwin }
7859289f547SJohn Baldwin
7869289f547SJohn Baldwin bool
sysdecode_thr_create_flags(FILE * fp,int flags,int * rem)7879289f547SJohn Baldwin sysdecode_thr_create_flags(FILE *fp, int flags, int *rem)
7889289f547SJohn Baldwin {
7899289f547SJohn Baldwin
7909289f547SJohn Baldwin return (print_mask_int(fp, thrcreateflags, flags, rem));
7919289f547SJohn Baldwin }
7929289f547SJohn Baldwin
7939289f547SJohn Baldwin const char *
sysdecode_umtx_op(int op)7949289f547SJohn Baldwin sysdecode_umtx_op(int op)
7959289f547SJohn Baldwin {
7969289f547SJohn Baldwin
7979289f547SJohn Baldwin return (lookup_value(umtxop, op));
7989289f547SJohn Baldwin }
7999289f547SJohn Baldwin
8003b27074bSKyle Evans bool
sysdecode_umtx_op_flags(FILE * fp,int op,int * rem)8013b27074bSKyle Evans sysdecode_umtx_op_flags(FILE *fp, int op, int *rem)
8023b27074bSKyle Evans {
8033b27074bSKyle Evans uintmax_t val;
8043b27074bSKyle Evans bool printed;
8053b27074bSKyle Evans
8063b27074bSKyle Evans printed = false;
8073b27074bSKyle Evans val = (unsigned)op;
8083b27074bSKyle Evans print_mask_part(fp, umtxopflags, &val, &printed);
8093b27074bSKyle Evans if (rem != NULL)
8103b27074bSKyle Evans *rem = val;
8113b27074bSKyle Evans return (printed);
8123b27074bSKyle Evans }
8133b27074bSKyle Evans
8149289f547SJohn Baldwin const char *
sysdecode_vmresult(int result)8159289f547SJohn Baldwin sysdecode_vmresult(int result)
8169289f547SJohn Baldwin {
8179289f547SJohn Baldwin
8189289f547SJohn Baldwin return (lookup_value(vmresult, result));
8199289f547SJohn Baldwin }
8209289f547SJohn Baldwin
8219289f547SJohn Baldwin bool
sysdecode_wait4_options(FILE * fp,int options,int * rem)8229289f547SJohn Baldwin sysdecode_wait4_options(FILE *fp, int options, int *rem)
8239289f547SJohn Baldwin {
8249289f547SJohn Baldwin bool printed;
8259289f547SJohn Baldwin int opt6;
8269289f547SJohn Baldwin
8279289f547SJohn Baldwin /* A flags value of 0 is normal. */
8289289f547SJohn Baldwin if (options == 0) {
8299289f547SJohn Baldwin fputs("0", fp);
8309289f547SJohn Baldwin if (rem != NULL)
8319289f547SJohn Baldwin *rem = 0;
8329289f547SJohn Baldwin return (true);
8339289f547SJohn Baldwin }
8349289f547SJohn Baldwin
8359289f547SJohn Baldwin /*
8369289f547SJohn Baldwin * These flags are implicit and aren't valid flags for wait4()
8379289f547SJohn Baldwin * directly (though they don't fail with EINVAL).
8389289f547SJohn Baldwin */
8399289f547SJohn Baldwin opt6 = options & (WEXITED | WTRAPPED);
8409289f547SJohn Baldwin options &= ~opt6;
8419289f547SJohn Baldwin printed = print_mask_int(fp, wait6opt, options, rem);
8429289f547SJohn Baldwin if (rem != NULL)
8439289f547SJohn Baldwin *rem |= opt6;
8449289f547SJohn Baldwin return (printed);
8459289f547SJohn Baldwin }
8469289f547SJohn Baldwin
8479289f547SJohn Baldwin bool
sysdecode_wait6_options(FILE * fp,int options,int * rem)8489289f547SJohn Baldwin sysdecode_wait6_options(FILE *fp, int options, int *rem)
8499289f547SJohn Baldwin {
8509289f547SJohn Baldwin
8519289f547SJohn Baldwin return (print_mask_int(fp, wait6opt, options, rem));
8529289f547SJohn Baldwin }
8539289f547SJohn Baldwin
8549289f547SJohn Baldwin const char *
sysdecode_whence(int whence)8559289f547SJohn Baldwin sysdecode_whence(int whence)
8569289f547SJohn Baldwin {
8579289f547SJohn Baldwin
8589289f547SJohn Baldwin return (lookup_value(seekwhence, whence));
8599289f547SJohn Baldwin }
8609289f547SJohn Baldwin
8619289f547SJohn Baldwin const char *
sysdecode_fcntl_cmd(int cmd)8629289f547SJohn Baldwin sysdecode_fcntl_cmd(int cmd)
8639289f547SJohn Baldwin {
8649289f547SJohn Baldwin
8659289f547SJohn Baldwin return (lookup_value(fcntlcmd, cmd));
8669289f547SJohn Baldwin }
8679289f547SJohn Baldwin
8689289f547SJohn Baldwin static struct name_table fcntl_fd_arg[] = {
8699289f547SJohn Baldwin X(FD_CLOEXEC) X(0) XEND
8709289f547SJohn Baldwin };
8719289f547SJohn Baldwin
8729289f547SJohn Baldwin bool
sysdecode_fcntl_arg_p(int cmd)8739289f547SJohn Baldwin sysdecode_fcntl_arg_p(int cmd)
8749289f547SJohn Baldwin {
8759289f547SJohn Baldwin
8769289f547SJohn Baldwin switch (cmd) {
8779289f547SJohn Baldwin case F_GETFD:
8789289f547SJohn Baldwin case F_GETFL:
8799289f547SJohn Baldwin case F_GETOWN:
8809289f547SJohn Baldwin return (false);
8819289f547SJohn Baldwin default:
8829289f547SJohn Baldwin return (true);
8839289f547SJohn Baldwin }
8849289f547SJohn Baldwin }
8859289f547SJohn Baldwin
8869289f547SJohn Baldwin void
sysdecode_fcntl_arg(FILE * fp,int cmd,uintptr_t arg,int base)8879289f547SJohn Baldwin sysdecode_fcntl_arg(FILE *fp, int cmd, uintptr_t arg, int base)
8889289f547SJohn Baldwin {
8899289f547SJohn Baldwin int rem;
8909289f547SJohn Baldwin
8919289f547SJohn Baldwin switch (cmd) {
8929289f547SJohn Baldwin case F_SETFD:
8939289f547SJohn Baldwin if (!print_value(fp, fcntl_fd_arg, arg))
8949289f547SJohn Baldwin print_integer(fp, arg, base);
8959289f547SJohn Baldwin break;
8969289f547SJohn Baldwin case F_SETFL:
8979289f547SJohn Baldwin if (!sysdecode_fcntl_fileflags(fp, arg, &rem))
8989289f547SJohn Baldwin fprintf(fp, "%#x", rem);
8999289f547SJohn Baldwin else if (rem != 0)
9009289f547SJohn Baldwin fprintf(fp, "|%#x", rem);
9019289f547SJohn Baldwin break;
9029289f547SJohn Baldwin case F_GETLK:
9039289f547SJohn Baldwin case F_SETLK:
9049289f547SJohn Baldwin case F_SETLKW:
9059289f547SJohn Baldwin fprintf(fp, "%p", (void *)arg);
9069289f547SJohn Baldwin break;
9079289f547SJohn Baldwin default:
9089289f547SJohn Baldwin print_integer(fp, arg, base);
9099289f547SJohn Baldwin break;
9109289f547SJohn Baldwin }
9119289f547SJohn Baldwin }
9129289f547SJohn Baldwin
9139289f547SJohn Baldwin bool
sysdecode_mmap_flags(FILE * fp,int flags,int * rem)9149289f547SJohn Baldwin sysdecode_mmap_flags(FILE *fp, int flags, int *rem)
9159289f547SJohn Baldwin {
9169289f547SJohn Baldwin uintmax_t val;
9179289f547SJohn Baldwin bool printed;
9189289f547SJohn Baldwin int align;
9199289f547SJohn Baldwin
9209289f547SJohn Baldwin /*
9219289f547SJohn Baldwin * MAP_ALIGNED can't be handled directly by print_mask_int().
9229289f547SJohn Baldwin */
9239289f547SJohn Baldwin printed = false;
9249289f547SJohn Baldwin align = flags & MAP_ALIGNMENT_MASK;
9259289f547SJohn Baldwin val = (unsigned)flags & ~MAP_ALIGNMENT_MASK;
9269289f547SJohn Baldwin print_mask_part(fp, mmapflags, &val, &printed);
9279289f547SJohn Baldwin if (align != 0) {
9289289f547SJohn Baldwin if (printed)
9299289f547SJohn Baldwin fputc('|', fp);
9309289f547SJohn Baldwin if (align == MAP_ALIGNED_SUPER)
9319289f547SJohn Baldwin fputs("MAP_ALIGNED_SUPER", fp);
9329289f547SJohn Baldwin else
9339289f547SJohn Baldwin fprintf(fp, "MAP_ALIGNED(%d)",
9349289f547SJohn Baldwin align >> MAP_ALIGNMENT_SHIFT);
9359289f547SJohn Baldwin printed = true;
9369289f547SJohn Baldwin }
9379289f547SJohn Baldwin if (rem != NULL)
9389289f547SJohn Baldwin *rem = val;
9399289f547SJohn Baldwin return (printed);
9409289f547SJohn Baldwin }
9419289f547SJohn Baldwin
9429289f547SJohn Baldwin const char *
sysdecode_pathconf_name(int name)94339a3a438SJohn Baldwin sysdecode_pathconf_name(int name)
94439a3a438SJohn Baldwin {
94539a3a438SJohn Baldwin
94639a3a438SJohn Baldwin return (lookup_value(pathconfname, name));
94739a3a438SJohn Baldwin }
94839a3a438SJohn Baldwin
94939a3a438SJohn Baldwin const char *
sysdecode_rtprio_function(int function)9509289f547SJohn Baldwin sysdecode_rtprio_function(int function)
9519289f547SJohn Baldwin {
9529289f547SJohn Baldwin
9539289f547SJohn Baldwin return (lookup_value(rtpriofuncs, function));
9549289f547SJohn Baldwin }
9559289f547SJohn Baldwin
9569289f547SJohn Baldwin bool
sysdecode_msg_flags(FILE * fp,int flags,int * rem)9579289f547SJohn Baldwin sysdecode_msg_flags(FILE *fp, int flags, int *rem)
9589289f547SJohn Baldwin {
9599289f547SJohn Baldwin
9609289f547SJohn Baldwin return (print_mask_0(fp, msgflags, flags, rem));
9619289f547SJohn Baldwin }
9629289f547SJohn Baldwin
9639289f547SJohn Baldwin const char *
sysdecode_sigcode(int sig,int si_code)9649289f547SJohn Baldwin sysdecode_sigcode(int sig, int si_code)
9659289f547SJohn Baldwin {
9669289f547SJohn Baldwin const char *str;
9679289f547SJohn Baldwin
9689289f547SJohn Baldwin str = lookup_value(sigcode, si_code);
9699289f547SJohn Baldwin if (str != NULL)
9709289f547SJohn Baldwin return (str);
9719289f547SJohn Baldwin
9729289f547SJohn Baldwin switch (sig) {
9739289f547SJohn Baldwin case SIGILL:
9749289f547SJohn Baldwin return (sysdecode_sigill_code(si_code));
9759289f547SJohn Baldwin case SIGBUS:
9769289f547SJohn Baldwin return (sysdecode_sigbus_code(si_code));
9779289f547SJohn Baldwin case SIGSEGV:
9789289f547SJohn Baldwin return (sysdecode_sigsegv_code(si_code));
9799289f547SJohn Baldwin case SIGFPE:
9809289f547SJohn Baldwin return (sysdecode_sigfpe_code(si_code));
9819289f547SJohn Baldwin case SIGTRAP:
9829289f547SJohn Baldwin return (sysdecode_sigtrap_code(si_code));
9839289f547SJohn Baldwin case SIGCHLD:
9849289f547SJohn Baldwin return (sysdecode_sigchld_code(si_code));
9859289f547SJohn Baldwin default:
9869289f547SJohn Baldwin return (NULL);
9879289f547SJohn Baldwin }
9889289f547SJohn Baldwin }
9899289f547SJohn Baldwin
99039a3a438SJohn Baldwin const char *
sysdecode_sysarch_number(int number)99139a3a438SJohn Baldwin sysdecode_sysarch_number(int number)
99239a3a438SJohn Baldwin {
99339a3a438SJohn Baldwin
99439a3a438SJohn Baldwin return (lookup_value(sysarchnum, number));
99539a3a438SJohn Baldwin }
99639a3a438SJohn Baldwin
9979289f547SJohn Baldwin bool
sysdecode_umtx_cvwait_flags(FILE * fp,u_long flags,u_long * rem)9989289f547SJohn Baldwin sysdecode_umtx_cvwait_flags(FILE *fp, u_long flags, u_long *rem)
9999289f547SJohn Baldwin {
10009289f547SJohn Baldwin
10019289f547SJohn Baldwin return (print_mask_0ul(fp, umtxcvwaitflags, flags, rem));
10029289f547SJohn Baldwin }
10039289f547SJohn Baldwin
10049289f547SJohn Baldwin bool
sysdecode_umtx_rwlock_flags(FILE * fp,u_long flags,u_long * rem)10059289f547SJohn Baldwin sysdecode_umtx_rwlock_flags(FILE *fp, u_long flags, u_long *rem)
10069289f547SJohn Baldwin {
10079289f547SJohn Baldwin
10089289f547SJohn Baldwin return (print_mask_0ul(fp, umtxrwlockflags, flags, rem));
10099289f547SJohn Baldwin }
10109289f547SJohn Baldwin
10119289f547SJohn Baldwin void
sysdecode_cap_rights(FILE * fp,cap_rights_t * rightsp)10129289f547SJohn Baldwin sysdecode_cap_rights(FILE *fp, cap_rights_t *rightsp)
10139289f547SJohn Baldwin {
1014869199d9SMark Johnston cap_rights_t diff, sum, zero;
1015869199d9SMark Johnston const struct name_table *t;
1016c9c69ebaSEd Maste int i;
10179289f547SJohn Baldwin bool comma;
10189289f547SJohn Baldwin
1019c9c69ebaSEd Maste for (i = 0; i < CAPARSIZE(rightsp); i++) {
1020c9c69ebaSEd Maste if (CAPIDXBIT(rightsp->cr_rights[i]) != 1 << i) {
1021c9c69ebaSEd Maste fprintf(fp, "invalid cap_rights_t");
1022c9c69ebaSEd Maste return;
1023c9c69ebaSEd Maste }
1024c9c69ebaSEd Maste }
1025869199d9SMark Johnston cap_rights_init(&sum);
1026869199d9SMark Johnston diff = *rightsp;
1027869199d9SMark Johnston for (t = caprights, comma = false; t->str != NULL; t++) {
10283c047740STobias Kortkamp if (cap_rights_is_set(rightsp, t->val)) {
1029869199d9SMark Johnston cap_rights_clear(&diff, t->val);
1030869199d9SMark Johnston if (cap_rights_is_set(&sum, t->val)) {
1031869199d9SMark Johnston /* Don't print redundant rights. */
1032869199d9SMark Johnston continue;
1033869199d9SMark Johnston }
1034869199d9SMark Johnston cap_rights_set(&sum, t->val);
1035869199d9SMark Johnston
10369289f547SJohn Baldwin fprintf(fp, "%s%s", comma ? "," : "", t->str);
10379289f547SJohn Baldwin comma = true;
10389289f547SJohn Baldwin }
10399289f547SJohn Baldwin }
1040869199d9SMark Johnston if (!comma)
1041869199d9SMark Johnston fprintf(fp, "CAP_NONE");
1042869199d9SMark Johnston
1043869199d9SMark Johnston /*
1044869199d9SMark Johnston * Provide a breadcrumb if some of the provided rights are not included
1045869199d9SMark Johnston * in the table, likely due to a bug in the mktables script.
1046869199d9SMark Johnston */
1047869199d9SMark Johnston CAP_NONE(&zero);
1048869199d9SMark Johnston if (!cap_rights_contains(&zero, &diff))
1049869199d9SMark Johnston fprintf(fp, ",unknown rights");
1050869199d9SMark Johnston }
1051869199d9SMark Johnston
1052869199d9SMark Johnston /*
1053869199d9SMark Johnston * Pre-sort the set of rights, which has a partial ordering defined by the
1054869199d9SMark Johnston * subset relation. This lets sysdecode_cap_rights() print a list of minimal
1055869199d9SMark Johnston * length with a single pass over the "caprights" table.
1056869199d9SMark Johnston */
1057869199d9SMark Johnston static void __attribute__((constructor))
sysdecode_cap_rights_init(void)1058869199d9SMark Johnston sysdecode_cap_rights_init(void)
1059869199d9SMark Johnston {
1060869199d9SMark Johnston cap_rights_t tr, qr;
1061869199d9SMark Johnston struct name_table *t, *q, tmp;
1062869199d9SMark Johnston bool swapped;
1063869199d9SMark Johnston
1064869199d9SMark Johnston do {
1065869199d9SMark Johnston for (t = caprights, swapped = false; t->str != NULL; t++) {
1066869199d9SMark Johnston cap_rights_init(&tr, t->val);
1067869199d9SMark Johnston for (q = t + 1; q->str != NULL; q++) {
1068869199d9SMark Johnston cap_rights_init(&qr, q->val);
1069869199d9SMark Johnston if (cap_rights_contains(&qr, &tr)) {
1070869199d9SMark Johnston tmp = *t;
1071869199d9SMark Johnston *t = *q;
1072869199d9SMark Johnston *q = tmp;
1073869199d9SMark Johnston swapped = true;
1074869199d9SMark Johnston }
1075869199d9SMark Johnston }
1076869199d9SMark Johnston }
1077869199d9SMark Johnston } while (swapped);
10789289f547SJohn Baldwin }
1079a62bf68dSMichael Tuexen
1080a826eb5aSMichael Tuexen static struct name_table cmsgtypeip[] = {
1081a826eb5aSMichael Tuexen X(IP_RECVDSTADDR) X(IP_RECVTTL) X(IP_RECVOPTS) X(IP_RECVRETOPTS)
1082a826eb5aSMichael Tuexen X(IP_RECVIF) X(IP_RECVTOS) X(IP_FLOWID) X(IP_FLOWTYPE)
1083a826eb5aSMichael Tuexen X(IP_RSSBUCKETID) XEND
1084a826eb5aSMichael Tuexen };
1085a826eb5aSMichael Tuexen
1086a826eb5aSMichael Tuexen static struct name_table cmsgtypeipv6[] = {
1087a826eb5aSMichael Tuexen #if 0
1088a826eb5aSMichael Tuexen /* The RFC 2292 defines are kernel space only. */
1089a826eb5aSMichael Tuexen X(IPV6_2292PKTINFO) X(IPV6_2292HOPLIMIT) X(IPV6_2292HOPOPTS)
1090a826eb5aSMichael Tuexen X(IPV6_2292DSTOPTS) X(IPV6_2292RTHDR) X(IPV6_2292NEXTHOP)
1091a826eb5aSMichael Tuexen #endif
1092a826eb5aSMichael Tuexen X(IPV6_PKTINFO) X(IPV6_HOPLIMIT) X(IPV6_HOPOPTS)
1093a826eb5aSMichael Tuexen X(IPV6_DSTOPTS) X(IPV6_RTHDR) X(IPV6_NEXTHOP)
1094a826eb5aSMichael Tuexen X(IPV6_TCLASS) X(IPV6_FLOWID) X(IPV6_FLOWTYPE) X(IPV6_RSSBUCKETID)
1095a826eb5aSMichael Tuexen X(IPV6_PATHMTU) X(IPV6_RTHDRDSTOPTS) X(IPV6_USE_MIN_MTU)
1096a826eb5aSMichael Tuexen X(IPV6_DONTFRAG) X(IPV6_PREFER_TEMPADDR) XEND
1097a826eb5aSMichael Tuexen };
1098a826eb5aSMichael Tuexen
1099a826eb5aSMichael Tuexen static struct name_table cmsgtypesctp[] = {
1100a826eb5aSMichael Tuexen X(SCTP_INIT) X(SCTP_SNDRCV) X(SCTP_EXTRCV) X(SCTP_SNDINFO)
1101a826eb5aSMichael Tuexen X(SCTP_RCVINFO) X(SCTP_NXTINFO) X(SCTP_PRINFO) X(SCTP_AUTHINFO)
1102a826eb5aSMichael Tuexen X(SCTP_DSTADDRV4) X(SCTP_DSTADDRV6) XEND
1103a826eb5aSMichael Tuexen };
1104a826eb5aSMichael Tuexen
1105a826eb5aSMichael Tuexen const char *
sysdecode_cmsg_type(int cmsg_level,int cmsg_type)1106a826eb5aSMichael Tuexen sysdecode_cmsg_type(int cmsg_level, int cmsg_type)
1107a826eb5aSMichael Tuexen {
1108a826eb5aSMichael Tuexen
1109a826eb5aSMichael Tuexen if (cmsg_level == SOL_SOCKET)
1110a826eb5aSMichael Tuexen return (lookup_value(cmsgtypesocket, cmsg_type));
1111a826eb5aSMichael Tuexen if (cmsg_level == IPPROTO_IP)
1112a826eb5aSMichael Tuexen return (lookup_value(cmsgtypeip, cmsg_type));
1113a826eb5aSMichael Tuexen if (cmsg_level == IPPROTO_IPV6)
1114a826eb5aSMichael Tuexen return (lookup_value(cmsgtypeipv6, cmsg_type));
1115a826eb5aSMichael Tuexen if (cmsg_level == IPPROTO_SCTP)
1116a826eb5aSMichael Tuexen return (lookup_value(cmsgtypesctp, cmsg_type));
1117a826eb5aSMichael Tuexen return (NULL);
1118a826eb5aSMichael Tuexen }
1119a826eb5aSMichael Tuexen
1120a62bf68dSMichael Tuexen const char *
sysdecode_sctp_pr_policy(int policy)1121a62bf68dSMichael Tuexen sysdecode_sctp_pr_policy(int policy)
1122a62bf68dSMichael Tuexen {
1123a62bf68dSMichael Tuexen
1124a62bf68dSMichael Tuexen return (lookup_value(sctpprpolicy, policy));
1125a62bf68dSMichael Tuexen }
11261e6455d8SMichael Tuexen
11270faae8b9SMichael Tuexen static struct name_table sctpsndflags[] = {
11280faae8b9SMichael Tuexen X(SCTP_EOF) X(SCTP_ABORT) X(SCTP_UNORDERED) X(SCTP_ADDR_OVER)
1129bac4817bSMichael Tuexen X(SCTP_SENDALL) X(SCTP_EOR) X(SCTP_SACK_IMMEDIATELY) XEND
11300faae8b9SMichael Tuexen };
11310faae8b9SMichael Tuexen
11320faae8b9SMichael Tuexen bool
sysdecode_sctp_snd_flags(FILE * fp,int flags,int * rem)11330faae8b9SMichael Tuexen sysdecode_sctp_snd_flags(FILE *fp, int flags, int *rem)
11340faae8b9SMichael Tuexen {
11350faae8b9SMichael Tuexen
11360faae8b9SMichael Tuexen return (print_mask_int(fp, sctpsndflags, flags, rem));
11370faae8b9SMichael Tuexen }
11380faae8b9SMichael Tuexen
11390faae8b9SMichael Tuexen static struct name_table sctprcvflags[] = {
11400faae8b9SMichael Tuexen X(SCTP_UNORDERED) XEND
11410faae8b9SMichael Tuexen };
11420faae8b9SMichael Tuexen
11430faae8b9SMichael Tuexen bool
sysdecode_sctp_rcv_flags(FILE * fp,int flags,int * rem)11440faae8b9SMichael Tuexen sysdecode_sctp_rcv_flags(FILE *fp, int flags, int *rem)
11450faae8b9SMichael Tuexen {
11460faae8b9SMichael Tuexen
11470faae8b9SMichael Tuexen return (print_mask_int(fp, sctprcvflags, flags, rem));
11480faae8b9SMichael Tuexen }
11490faae8b9SMichael Tuexen
11500faae8b9SMichael Tuexen static struct name_table sctpnxtflags[] = {
11510faae8b9SMichael Tuexen X(SCTP_UNORDERED) X(SCTP_COMPLETE) X(SCTP_NOTIFICATION) XEND
11520faae8b9SMichael Tuexen };
11530faae8b9SMichael Tuexen
11540faae8b9SMichael Tuexen bool
sysdecode_sctp_nxt_flags(FILE * fp,int flags,int * rem)11550faae8b9SMichael Tuexen sysdecode_sctp_nxt_flags(FILE *fp, int flags, int *rem)
11560faae8b9SMichael Tuexen {
11570faae8b9SMichael Tuexen
11580faae8b9SMichael Tuexen return (print_mask_int(fp, sctpnxtflags, flags, rem));
11590faae8b9SMichael Tuexen }
11600faae8b9SMichael Tuexen
11611e6455d8SMichael Tuexen static struct name_table sctpsinfoflags[] = {
11621e6455d8SMichael Tuexen X(SCTP_EOF) X(SCTP_ABORT) X(SCTP_UNORDERED) X(SCTP_ADDR_OVER)
11631e6455d8SMichael Tuexen X(SCTP_SENDALL) X(SCTP_EOR) X(SCTP_SACK_IMMEDIATELY) XEND
11641e6455d8SMichael Tuexen };
11651e6455d8SMichael Tuexen
11661e6455d8SMichael Tuexen void
sysdecode_sctp_sinfo_flags(FILE * fp,int sinfo_flags)11671e6455d8SMichael Tuexen sysdecode_sctp_sinfo_flags(FILE *fp, int sinfo_flags)
11681e6455d8SMichael Tuexen {
11691e6455d8SMichael Tuexen const char *temp;
11701e6455d8SMichael Tuexen int rem;
11711e6455d8SMichael Tuexen bool printed;
11721e6455d8SMichael Tuexen
11731e6455d8SMichael Tuexen printed = print_mask_0(fp, sctpsinfoflags, sinfo_flags, &rem);
11741e6455d8SMichael Tuexen if (rem & ~SCTP_PR_SCTP_ALL) {
11751e6455d8SMichael Tuexen fprintf(fp, "%s%#x", printed ? "|" : "", rem & ~SCTP_PR_SCTP_ALL);
11761e6455d8SMichael Tuexen printed = true;
11771e6455d8SMichael Tuexen rem &= ~SCTP_PR_SCTP_ALL;
11781e6455d8SMichael Tuexen }
11791e6455d8SMichael Tuexen if (rem != 0) {
11801e6455d8SMichael Tuexen temp = sysdecode_sctp_pr_policy(rem);
11811e6455d8SMichael Tuexen if (temp != NULL) {
11821e6455d8SMichael Tuexen fprintf(fp, "%s%s", printed ? "|" : "", temp);
11831e6455d8SMichael Tuexen } else {
11841e6455d8SMichael Tuexen fprintf(fp, "%s%#x", printed ? "|" : "", rem);
11851e6455d8SMichael Tuexen }
11861e6455d8SMichael Tuexen }
11871e6455d8SMichael Tuexen }
1188c70019ddSKyle Evans
1189c70019ddSKyle Evans bool
sysdecode_shmflags(FILE * fp,int flags,int * rem)1190c70019ddSKyle Evans sysdecode_shmflags(FILE *fp, int flags, int *rem)
1191c70019ddSKyle Evans {
1192c70019ddSKyle Evans
1193c70019ddSKyle Evans return (print_mask_0(fp, shmflags, flags, rem));
1194c70019ddSKyle Evans }
11952fc3a51dSDmitry Chagin
11962fc3a51dSDmitry Chagin const char *
sysdecode_itimer(int which)11972fc3a51dSDmitry Chagin sysdecode_itimer(int which)
11982fc3a51dSDmitry Chagin {
11992fc3a51dSDmitry Chagin
12002fc3a51dSDmitry Chagin return (lookup_value(itimerwhich, which));
12012fc3a51dSDmitry Chagin }
1202