blob: b5dca53c6c8f47a39576b80f1e0bf815741a4e45 [file] [log] [blame]
Wichert Akkerman76baf7c1999-02-19 00:21:36 +00001/*
2 * Copyright (c) 1991, 1992 Paul Kranenburg <pk@cs.few.eur.nl>
3 * Copyright (c) 1993 Branko Lankester <branko@hacktic.nl>
4 * Copyright (c) 1993, 1994, 1995, 1996 Rick Sladkey <jrs@world.std.com>
5 * All rights reserved.
6 *
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
9 * are met:
10 * 1. Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * 2. Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the distribution.
15 * 3. The name of the author may not be used to endorse or promote products
16 * derived from this software without specific prior written permission.
17 *
18 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
19 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
20 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
21 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
22 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
23 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
27 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28 *
29 * $Id$
30 */
31
32#include "defs.h"
33
34#ifdef LINUX
35#define _LINUX_SOCKET_H
36
37#define MS_RDONLY 1 /* Mount read-only */
38#define MS_NOSUID 2 /* Ignore suid and sgid bits */
39#define MS_NODEV 4 /* Disallow access to device special files */
40#define MS_NOEXEC 8 /* Disallow program execution */
41#define MS_SYNCHRONOUS 16 /* Writes are synced at once */
42#define MS_REMOUNT 32 /* Alter flags of a mounted FS */
43
44#include <sys/socket.h>
45#include <netinet/in.h>
46#include <arpa/inet.h>
47
Nate Sammons8d5860c1999-07-03 18:53:05 +000048#include <sys/syscall.h>
49
50#ifdef SYS_personality
Wichert Akkerman76baf7c1999-02-19 00:21:36 +000051/* Workaround for kernel namespace pollution. */
Wichert Akkerman2e2553a1999-05-09 00:29:58 +000052#define _LINUX_PTRACE_H
Nate Sammons8d5860c1999-07-03 18:53:05 +000053/* Yuck yuck yuck. We can't include linux/ptrace.h, but personality.h
54 makes a declaration with struct pt_regs, which is defined there. */
55struct pt_regs;
Wichert Akkerman76baf7c1999-02-19 00:21:36 +000056#define sys_personality kernel_sys_personality
57#include <linux/personality.h>
58#undef sys_personality
Nate Sammons8d5860c1999-07-03 18:53:05 +000059#endif /* SYS_personality */
Wichert Akkerman76baf7c1999-02-19 00:21:36 +000060
Nate Sammons8d5860c1999-07-03 18:53:05 +000061#ifdef SYS_capget
Wichert Akkerman76baf7c1999-02-19 00:21:36 +000062#include <linux/capability.h>
63#endif
64
Nate Sammons8d5860c1999-07-03 18:53:05 +000065#ifdef SYS_cacheflush
Wichert Akkerman2e2553a1999-05-09 00:29:58 +000066#include <asm/cachectl.h>
67#endif
68
Wichert Akkerman22fe9d21999-05-27 12:00:57 +000069#ifdef LINUX
70#include <linux/sysctl.h>
71#endif
72
Wichert Akkerman76baf7c1999-02-19 00:21:36 +000073static struct xlat mount_flags[] = {
74 { MS_RDONLY, "MS_RDONLY" },
75 { MS_NOSUID, "MS_NOSUID" },
76 { MS_NODEV, "MS_NODEV" },
77 { MS_NOEXEC, "MS_NOEXEC" },
78#ifdef MS_SYNCHRONOUS
79 { MS_SYNCHRONOUS,"MS_SYNCHRONOUS"},
80#else
81 { MS_SYNC, "MS_SYNC" },
82#endif
83 { MS_REMOUNT, "MS_REMOUNT" },
84 { 0, NULL },
85};
86
87int
88sys_mount(tcp)
89struct tcb *tcp;
90{
91 if (entering(tcp)) {
92 printpath(tcp, tcp->u_arg[0]);
93 tprintf(", ");
94 printpath(tcp, tcp->u_arg[1]);
95 tprintf(", ");
96 printpath(tcp, tcp->u_arg[2]);
97 tprintf(", ");
98 printflags(mount_flags, tcp->u_arg[3]);
99 tprintf(", %#lx", tcp->u_arg[4]);
100 }
101 return 0;
102}
103
Wichert Akkermandacfb6e1999-06-03 14:21:07 +0000104int
105sys_umount2(tcp)
106struct tcb *tcp;
107{
108 if (entering(tcp)) {
109 printstr(tcp, tcp->u_arg[0], -1);
110 tprintf(", ");
111 if (tcp->u_arg[1] & 1)
112 tprintf("MNT_FORCE");
113 else
114 tprintf("0");
115 }
116 return 0;
117}
118
Wichert Akkerman76baf7c1999-02-19 00:21:36 +0000119static struct xlat personality_options[] = {
120#ifdef PER_LINUX
121 { PER_LINUX, "PER_LINUX" },
122#endif
123#ifdef PER_LINUX_32BIT
124 { PER_LINUX_32BIT, "PER_LINUX" },
125#endif
126#ifdef PER_SVR4
127 { PER_SVR4, "PER_SVR4" },
128#endif
129#ifdef PER_SVR3
130 { PER_SVR3, "PER_SVR3" },
131#endif
132#ifdef PER_SCOSVR3
133 { PER_SCOSVR3, "PER_SCOSVR3" },
134#endif
135#ifdef PER_WYSEV386
136 { PER_WYSEV386, "PER_WYSEV386" },
137#endif
138#ifdef PER_ISCR4
139 { PER_ISCR4, "PER_ISCR4" },
140#endif
141#ifdef PER_BSD
142 { PER_BSD, "PER_BSD" },
143#endif
144#ifdef PER_XENIX
145 { PER_XENIX, "PER_XENIX" },
146#endif
147 { 0, NULL },
148};
149
150int
151sys_personality(tcp)
152struct tcb *tcp;
153{
154 if (entering(tcp))
155 printxval(personality_options, tcp->u_arg[0], "PER_???");
156 return 0;
157}
158
Wichert Akkerman2e2553a1999-05-09 00:29:58 +0000159#ifdef M68K
160static struct xlat cacheflush_scope[] = {
161#ifdef FLUSH_SCOPE_LINE
162 { FLUSH_SCOPE_LINE, "FLUSH_SCOPE_LINE" },
163#endif
164#ifdef FLUSH_SCOPE_PAGE
165 { FLUSH_SCOPE_PAGE, "FLUSH_SCOPE_PAGE" },
166#endif
167#ifdef FLUSH_SCOPE_ALL
168 { FLUSH_SCOPE_ALL, "FLUSH_SCOPE_ALL" },
169#endif
170 { 0, NULL },
171};
172
173static struct xlat cacheflush_flags[] = {
174#ifdef FLUSH_CACHE_BOTH
175 { FLUSH_CACHE_BOTH, "FLUSH_CACHE_BOTH" },
176#endif
177#ifdef FLUSH_CACHE_DATA
178 { FLUSH_CACHE_DATA, "FLUSH_CACHE_DATA" },
179#endif
180#ifdef FLUSH_CACHE_INSN
181 { FLUSH_CACHE_INSN, "FLUSH_CACHE_INSN" },
182#endif
183 { 0, NULL },
184};
185
186int
187sys_cacheflush(tcp)
188struct tcb *tcp;
189{
190 if (entering(tcp)) {
191 /* addr */
192 tprintf("%#lx, ", tcp->u_arg[0]);
193 /* scope */
194 printxval(cacheflush_scope, tcp->u_arg[1], "FLUSH_SCOPE_???");
195 tprintf(", ");
196 /* flags */
197 printflags(cacheflush_flags, tcp->u_arg[2]);
198 /* len */
199 tprintf(", %lu", tcp->u_arg[3]);
200 }
201 return 0;
202}
203#endif /* M68K */
204
Wichert Akkerman76baf7c1999-02-19 00:21:36 +0000205#endif /* LINUX */
206
207#ifdef SUNOS4
208
209#include <sys/reboot.h>
210#define NFSCLIENT
211#define LOFS
212#define RFS
213#define PCFS
214#include <sys/mount.h>
215#include <sys/socket.h>
216#include <nfs/export.h>
217#include <rpc/types.h>
218#include <rpc/auth.h>
219
220/*ARGSUSED*/
221int
222sys_sync(tcp)
223struct tcb *tcp;
224{
225 return 0;
226}
227
228static struct xlat bootflags[] = {
229 { RB_AUTOBOOT, "RB_AUTOBOOT" }, /* for system auto-booting itself */
230 { RB_ASKNAME, "RB_ASKNAME" }, /* ask for file name to reboot from */
231 { RB_SINGLE, "RB_SINGLE" }, /* reboot to single user only */
232 { RB_NOSYNC, "RB_NOSYNC" }, /* dont sync before reboot */
233 { RB_HALT, "RB_HALT" }, /* don't reboot, just halt */
234 { RB_INITNAME, "RB_INITNAME" }, /* name given for /etc/init */
235 { RB_NOBOOTRC, "RB_NOBOOTRC" }, /* don't run /etc/rc.boot */
236 { RB_DEBUG, "RB_DEBUG" }, /* being run under debugger */
237 { RB_DUMP, "RB_DUMP" }, /* dump system core */
238 { RB_WRITABLE, "RB_WRITABLE" }, /* mount root read/write */
239 { RB_STRING, "RB_STRING" }, /* pass boot args to prom monitor */
240 { 0, NULL },
241};
242
243int
244sys_reboot(tcp)
245struct tcb *tcp;
246{
247 if (entering(tcp)) {
248 if (!printflags(bootflags, tcp->u_arg[0]))
249 tprintf("RB_???");
250 if (tcp->u_arg[0] & RB_STRING) {
251 printstr(tcp, tcp->u_arg[1], -1);
252 }
253 }
254 return 0;
255}
256
257int
258sys_sysacct(tcp)
259struct tcb *tcp;
260{
261 if (entering(tcp)) {
262 printstr(tcp, tcp->u_arg[0], -1);
263 }
264 return 0;
265}
266
267int
268sys_swapon(tcp)
269struct tcb *tcp;
270{
271 if (entering(tcp)) {
272 printstr(tcp, tcp->u_arg[0], -1);
273 }
274 return 0;
275}
276
277int
278sys_nfs_svc(tcp)
279struct tcb *tcp;
280{
281 if (entering(tcp)) {
282 printsock(tcp, tcp->u_arg[0]);
283 }
284 return 0;
285}
286
287static struct xlat mountflags[] = {
288 { M_RDONLY, "M_RDONLY" },
289 { M_NOSUID, "M_NOSUID" },
290 { M_NEWTYPE, "M_NEWTYPE" },
291 { M_GRPID, "M_GRPID" },
292#ifdef M_REMOUNT
293 { M_REMOUNT, "M_REMOUNT" },
294#endif
295#ifdef M_NOSUB
296 { M_NOSUB, "M_NOSUB" },
297#endif
298#ifdef M_MULTI
299 { M_MULTI, "M_MULTI" },
300#endif
301#ifdef M_SYS5
302 { M_SYS5, "M_SYS5" },
303#endif
304 { 0, NULL },
305};
306
307static struct xlat nfsflags[] = {
308 { NFSMNT_SOFT, "NFSMNT_SOFT" },
309 { NFSMNT_WSIZE, "NFSMNT_WSIZE" },
310 { NFSMNT_RSIZE, "NFSMNT_RSIZE" },
311 { NFSMNT_TIMEO, "NFSMNT_TIMEO" },
312 { NFSMNT_RETRANS, "NFSMNT_RETRANS" },
313 { NFSMNT_HOSTNAME, "NFSMNT_HOSTNAME" },
314 { NFSMNT_INT, "NFSMNT_INT" },
315 { NFSMNT_NOAC, "NFSMNT_NOAC" },
316 { NFSMNT_ACREGMIN, "NFSMNT_ACREGMIN" },
317 { NFSMNT_ACREGMAX, "NFSMNT_ACREGMAX" },
318 { NFSMNT_ACDIRMIN, "NFSMNT_ACDIRMIN" },
319 { NFSMNT_ACDIRMAX, "NFSMNT_ACDIRMAX" },
320#ifdef NFSMNT_SECURE
321 { NFSMNT_SECURE, "NFSMNT_SECURE" },
322#endif
323#ifdef NFSMNT_NOCTO
324 { NFSMNT_NOCTO, "NFSMNT_NOCTO" },
325#endif
326#ifdef NFSMNT_POSIX
327 { NFSMNT_POSIX, "NFSMNT_POSIX" },
328#endif
329 { 0, NULL },
330};
331
332int
333sys_mount(tcp)
334struct tcb *tcp;
335{
336 char type[4];
337
338 if (entering(tcp)) {
339 if (!(tcp->u_arg[2] & M_NEWTYPE) || umovestr(tcp,
340 tcp->u_arg[0], sizeof type, type) < 0) {
341 tprintf("OLDTYPE:#%lx", tcp->u_arg[0]);
342 } else {
343 tprintf("\"%s\", ", type);
344 }
345 printstr(tcp, tcp->u_arg[1], -1);
346 tprintf(", ");
347 if (!printflags(mountflags, tcp->u_arg[2] & ~M_NEWTYPE))
348 tprintf("0");
349 tprintf(", ");
350
351 if (strcmp(type, "4.2") == 0) {
352 struct ufs_args a;
353 if (umove(tcp, tcp->u_arg[3], &a) < 0)
354 return 0;
355 printstr(tcp, (int)a.fspec, -1);
356 } else if (strcmp(type, "lo") == 0) {
357 struct lo_args a;
358 if (umove(tcp, tcp->u_arg[3], &a) < 0)
359 return 0;
360 printstr(tcp, (int)a.fsdir, -1);
361 } else if (strcmp(type, "nfs") == 0) {
362 struct nfs_args a;
363 if (umove(tcp, tcp->u_arg[3], &a) < 0)
364 return 0;
365 tprintf("[");
366 printsock(tcp, (int) a.addr);
367 tprintf(", ");
368 if (!printflags(nfsflags, a.flags))
369 tprintf("NFSMNT_???");
370 tprintf(", ws:%u,rs:%u,to:%u,re:%u,",
371 a.wsize, a.rsize, a.timeo, a.retrans);
372 if (a.flags & NFSMNT_HOSTNAME && a.hostname)
373 printstr(tcp, (int)a.hostname, -1);
374 else
375 tprintf("%#lx", (unsigned long) a.hostname);
376 tprintf(",reg-min:%u,max:%u,dir-min:%u,max:%u,",
377 a.acregmin, a.acregmax, a.acdirmin, a.acdirmax);
378 if ((a.flags & NFSMNT_SECURE) && a.netname)
379 printstr(tcp, (int) a.netname, -1);
380 else
381 tprintf("%#lx", (unsigned long) a.netname);
382 tprintf("]");
383 } else if (strcmp(type, "rfs") == 0) {
384 struct rfs_args a;
385 struct token t;
386 if (umove(tcp, tcp->u_arg[3], &a) < 0)
387 return 0;
388 tprintf("[");
389 printstr(tcp, (int)a.rmtfs, -1);
390 if (umove(tcp, (int)a.token, &t) < 0)
391 return 0;
392 tprintf(", %u, %s]", t.t_id, t.t_uname);
393 } else if (strcmp(type, "pcfs") == 0) {
394 struct pc_args a;
395 if (umove(tcp, tcp->u_arg[3], &a) < 0)
396 return 0;
397 printstr(tcp, (int)a.fspec, -1);
398 }
399 }
400 return 0;
401}
402
403int
404sys_unmount(tcp)
405struct tcb *tcp;
406{
407 if (entering(tcp)) {
408 printstr(tcp, tcp->u_arg[0], -1);
409 }
410 return 0;
411}
412
413int
414sys_umount(tcp)
415struct tcb *tcp;
416{
417 return sys_unmount(tcp);
418}
419
420int
421sys_auditsys(tcp)
422struct tcb *tcp;
423{
424 /* XXX - no information available */
425 return printargs(tcp);
426}
427
428static struct xlat ex_auth_flags[] = {
429 { AUTH_UNIX, "AUTH_UNIX" },
430 { AUTH_DES, "AUTH_DES" },
431 { 0, NULL },
432};
433
434int
435sys_exportfs(tcp)
436struct tcb *tcp;
437{
438 struct export e;
439 int i;
440
441 if (entering(tcp)) {
442 printstr(tcp, tcp->u_arg[0], -1);
443 if (umove(tcp, tcp->u_arg[1], &e) < 0) {
444 tprintf("%#lx", tcp->u_arg[1]);
445 return 0;
446 }
447 tprintf("{fl:%u, anon:%u, ", e.ex_flags, e.ex_anon);
448 printxval(ex_auth_flags, e.ex_auth, "AUTH_???");
449 tprintf(", roots:[");
450 if (e.ex_auth == AUTH_UNIX) {
451 for (i=0; i<e.ex_u.exunix.rootaddrs.naddrs; i++) {
452 printsock(tcp,
453 (int)&e.ex_u.exunix.rootaddrs.addrvec[i]);
454 }
455 tprintf("], writers:[");
456 for (i=0; i<e.ex_writeaddrs.naddrs; i++) {
457 printsock(tcp,
458 (int)&e.ex_writeaddrs.addrvec[i]);
459 }
460 tprintf("]");
461 } else {
462 for (i=0; i<e.ex_u.exdes.nnames; i++) {
463 printsock(tcp,
464 (int)&e.ex_u.exdes.rootnames[i]);
465 tprintf(", ");
466 }
467 tprintf("], window:%u", e.ex_u.exdes.window);
468 }
469 tprintf("}");
470 }
471 return 0;
472}
473
474static struct xlat sysconflimits[] = {
475#ifdef _SC_ARG_MAX
476 { _SC_ARG_MAX, "_SC_ARG_MAX" }, /* space for argv & envp */
477#endif
478#ifdef _SC_CHILD_MAX
479 { _SC_CHILD_MAX, "_SC_CHILD_MAX" }, /* maximum children per process??? */
480#endif
481#ifdef _SC_CLK_TCK
482 { _SC_CLK_TCK, "_SC_CLK_TCK" }, /* clock ticks/sec */
483#endif
484#ifdef _SC_NGROUPS_MAX
485 { _SC_NGROUPS_MAX, "_SC_NGROUPS_MAX" }, /* number of groups if multple supp. */
486#endif
487#ifdef _SC_OPEN_MAX
488 { _SC_OPEN_MAX, "_SC_OPEN_MAX" }, /* max open files per process */
489#endif
490#ifdef _SC_JOB_CONTROL
491 { _SC_JOB_CONTROL, "_SC_JOB_CONTROL" }, /* do we have job control */
492#endif
493#ifdef _SC_SAVED_IDS
494 { _SC_SAVED_IDS, "_SC_SAVED_IDS" }, /* do we have saved uid/gids */
495#endif
496#ifdef _SC_VERSION
497 { _SC_VERSION, "_SC_VERSION" }, /* POSIX version supported */
498#endif
499 { 0, NULL },
500};
501
502static struct xlat pathconflimits[] = {
503#ifdef _PC_LINK_MAX
504 { _PC_LINK_MAX, "_PC_LINK_MAX" }, /* max links to file/dir */
505#endif
506#ifdef _PC_MAX_CANON
507 { _PC_MAX_CANON, "_PC_MAX_CANON" }, /* max line length */
508#endif
509#ifdef _PC_MAX_INPUT
510 { _PC_MAX_INPUT, "_PC_MAX_INPUT" }, /* max "packet" to a tty device */
511#endif
512#ifdef _PC_NAME_MAX
513 { _PC_NAME_MAX, "_PC_NAME_MAX" }, /* max pathname component length */
514#endif
515#ifdef _PC_PATH_MAX
516 { _PC_PATH_MAX, "_PC_PATH_MAX" }, /* max pathname length */
517#endif
518#ifdef _PC_PIPE_BUF
519 { _PC_PIPE_BUF, "_PC_PIPE_BUF" }, /* size of a pipe */
520#endif
521#ifdef _PC_CHOWN_RESTRICTED
522 { _PC_CHOWN_RESTRICTED, "_PC_CHOWN_RESTRICTED" }, /* can we give away files */
523#endif
524#ifdef _PC_NO_TRUNC
525 { _PC_NO_TRUNC, "_PC_NO_TRUNC" }, /* trunc or error on >NAME_MAX */
526#endif
527#ifdef _PC_VDISABLE
528 { _PC_VDISABLE, "_PC_VDISABLE" }, /* best char to shut off tty c_cc */
529#endif
530 { 0, NULL },
531};
532
533int
534sys_sysconf(tcp)
535struct tcb *tcp;
536{
537 if (entering(tcp)) {
538 printxval(sysconflimits, tcp->u_arg[0], "_SC_???");
539 }
540 return 0;
541}
542
543int
544sys_pathconf(tcp)
545struct tcb *tcp;
546{
547 if (entering(tcp)) {
548 printstr(tcp, tcp->u_arg[0], -1);
549 tprintf(", ");
550 printxval(pathconflimits, tcp->u_arg[1], "_SC_???");
551 }
552 return 0;
553}
554
555int
556sys_fpathconf(tcp)
557struct tcb *tcp;
558{
559 if (entering(tcp)) {
560 tprintf("%lu, ", tcp->u_arg[0]);
561 printxval(pathconflimits, tcp->u_arg[1], "_SC_???");
562 }
563 return 0;
564}
565
566#endif /* SUNOS4 */
567
568#ifdef SVR4
569
570#ifdef HAVE_SYS_SYSCONFIG_H
571#include <sys/sysconfig.h>
572#endif /* HAVE_SYS_SYSCONFIG_H */
573
574#include <sys/mount.h>
575#include <sys/systeminfo.h>
576#include <sys/utsname.h>
577
578static struct xlat sysconfig_options[] = {
579#ifdef _CONFIG_NGROUPS
580 { _CONFIG_NGROUPS, "_CONFIG_NGROUPS" },
581#endif
582#ifdef _CONFIG_CHILD_MAX
583 { _CONFIG_CHILD_MAX, "_CONFIG_CHILD_MAX" },
584#endif
585#ifdef _CONFIG_OPEN_FILES
586 { _CONFIG_OPEN_FILES, "_CONFIG_OPEN_FILES" },
587#endif
588#ifdef _CONFIG_POSIX_VER
589 { _CONFIG_POSIX_VER, "_CONFIG_POSIX_VER" },
590#endif
591#ifdef _CONFIG_PAGESIZE
592 { _CONFIG_PAGESIZE, "_CONFIG_PAGESIZE" },
593#endif
594#ifdef _CONFIG_CLK_TCK
595 { _CONFIG_CLK_TCK, "_CONFIG_CLK_TCK" },
596#endif
597#ifdef _CONFIG_XOPEN_VER
598 { _CONFIG_XOPEN_VER, "_CONFIG_XOPEN_VER" },
599#endif
600#ifdef _CONFIG_PROF_TCK
601 { _CONFIG_PROF_TCK, "_CONFIG_PROF_TCK" },
602#endif
603#ifdef _CONFIG_NPROC_CONF
604 { _CONFIG_NPROC_CONF, "_CONFIG_NPROC_CONF" },
605#endif
606#ifdef _CONFIG_NPROC_ONLN
607 { _CONFIG_NPROC_ONLN, "_CONFIG_NPROC_ONLN" },
608#endif
609#ifdef _CONFIG_AIO_LISTIO_MAX
610 { _CONFIG_AIO_LISTIO_MAX, "_CONFIG_AIO_LISTIO_MAX" },
611#endif
612#ifdef _CONFIG_AIO_MAX
613 { _CONFIG_AIO_MAX, "_CONFIG_AIO_MAX" },
614#endif
615#ifdef _CONFIG_AIO_PRIO_DELTA_MAX
616 { _CONFIG_AIO_PRIO_DELTA_MAX, "_CONFIG_AIO_PRIO_DELTA_MAX" },
617#endif
618#ifdef _CONFIG_CONFIG_DELAYTIMER_MAX
619 { _CONFIG_DELAYTIMER_MAX, "_CONFIG_DELAYTIMER_MAX" },
620#endif
621#ifdef _CONFIG_MQ_OPEN_MAX
622 { _CONFIG_MQ_OPEN_MAX, "_CONFIG_MQ_OPEN_MAX" },
623#endif
624#ifdef _CONFIG_MQ_PRIO_MAX
625 { _CONFIG_MQ_PRIO_MAX, "_CONFIG_MQ_PRIO_MAX" },
626#endif
627#ifdef _CONFIG_RTSIG_MAX
628 { _CONFIG_RTSIG_MAX, "_CONFIG_RTSIG_MAX" },
629#endif
630#ifdef _CONFIG_SEM_NSEMS_MAX
631 { _CONFIG_SEM_NSEMS_MAX, "_CONFIG_SEM_NSEMS_MAX" },
632#endif
633#ifdef _CONFIG_SEM_VALUE_MAX
634 { _CONFIG_SEM_VALUE_MAX, "_CONFIG_SEM_VALUE_MAX" },
635#endif
636#ifdef _CONFIG_SIGQUEUE_MAX
637 { _CONFIG_SIGQUEUE_MAX, "_CONFIG_SIGQUEUE_MAX" },
638#endif
639#ifdef _CONFIG_SIGRT_MIN
640 { _CONFIG_SIGRT_MIN, "_CONFIG_SIGRT_MIN" },
641#endif
642#ifdef _CONFIG_SIGRT_MAX
643 { _CONFIG_SIGRT_MAX, "_CONFIG_SIGRT_MAX" },
644#endif
645#ifdef _CONFIG_TIMER_MAX
646 { _CONFIG_TIMER_MAX, "_CONFIG_TIMER_MAX" },
647#endif
648#ifdef _CONFIG_CONFIG_PHYS_PAGES
649 { _CONFIG_PHYS_PAGES, "_CONFIG_PHYS_PAGES" },
650#endif
651#ifdef _CONFIG_AVPHYS_PAGES
652 { _CONFIG_AVPHYS_PAGES, "_CONFIG_AVPHYS_PAGES" },
653#endif
654 { 0, NULL },
655};
656
657int
658sys_sysconfig(tcp)
659struct tcb *tcp;
660{
661 if (entering(tcp))
662 printxval(sysconfig_options, tcp->u_arg[0], "_CONFIG_???");
663 return 0;
664}
665
666static struct xlat sysinfo_options[] = {
667 { SI_SYSNAME, "SI_SYSNAME" },
668 { SI_HOSTNAME, "SI_HOSTNAME" },
669 { SI_RELEASE, "SI_RELEASE" },
670 { SI_VERSION, "SI_VERSION" },
671 { SI_MACHINE, "SI_MACHINE" },
672 { SI_ARCHITECTURE, "SI_ARCHITECTURE" },
673 { SI_HW_SERIAL, "SI_HW_SERIAL" },
674 { SI_HW_PROVIDER, "SI_HW_PROVIDER" },
675 { SI_SRPC_DOMAIN, "SI_SRPC_DOMAIN" },
676#ifdef SI_SET_HOSTNAME
677 { SI_SET_HOSTNAME, "SI_SET_HOSTNAME" },
678#endif
679#ifdef SI_SET_SRPC_DOMAIN
680 { SI_SET_SRPC_DOMAIN, "SI_SET_SRPC_DOMAIN" },
681#endif
682#ifdef SI_SET_KERB_REALM
683 { SI_SET_KERB_REALM, "SI_SET_KERB_REALM" },
684#endif
685#ifdef SI_KERB_REALM
686 { SI_KERB_REALM, "SI_KERB_REALM" },
687#endif
688 { 0, NULL },
689};
690
691int
692sys_sysinfo(tcp)
693struct tcb *tcp;
694{
695 if (entering(tcp)) {
696 printxval(sysinfo_options, tcp->u_arg[0], "SI_???");
697 tprintf(", ");
698 }
699 else {
700 /* Technically some calls write values. So what. */
701 if (syserror(tcp))
702 tprintf("%#lx", tcp->u_arg[1]);
703 else
704 printpath(tcp, tcp->u_arg[1]);
705 tprintf(", %lu", tcp->u_arg[2]);
706 }
707 return 0;
708}
709
710#ifdef MIPS
711
712#include <sys/syssgi.h>
713
714static struct xlat syssgi_options[] = {
715 { SGI_SYSID, "SGI_SYSID" },
Wichert Akkerman8829a551999-06-11 13:18:40 +0000716#ifdef SGI_RDUBLK
Wichert Akkerman76baf7c1999-02-19 00:21:36 +0000717 { SGI_RDUBLK, "SGI_RDUBLK" },
Wichert Akkerman8829a551999-06-11 13:18:40 +0000718#endif
Wichert Akkerman76baf7c1999-02-19 00:21:36 +0000719 { SGI_TUNE, "SGI_TUNE" },
720 { SGI_IDBG, "SGI_IDBG" },
721 { SGI_INVENT, "SGI_INVENT" },
722 { SGI_RDNAME, "SGI_RDNAME" },
723 { SGI_SETLED, "SGI_SETLED" },
724 { SGI_SETNVRAM, "SGI_SETNVRAM" },
725 { SGI_GETNVRAM, "SGI_GETNVRAM" },
726 { SGI_QUERY_FTIMER, "SGI_QUERY_FTIMER" },
727 { SGI_QUERY_CYCLECNTR, "SGI_QUERY_CYCLECNTR" },
728 { SGI_PROCSZ, "SGI_PROCSZ" },
729 { SGI_SIGACTION, "SGI_SIGACTION" },
730 { SGI_SIGPENDING, "SGI_SIGPENDING" },
731 { SGI_SIGPROCMASK, "SGI_SIGPROCMASK" },
732 { SGI_SIGSUSPEND, "SGI_SIGSUSPEND" },
733 { SGI_SETSID, "SGI_SETSID" },
734 { SGI_SETPGID, "SGI_SETPGID" },
735 { SGI_SYSCONF, "SGI_SYSCONF" },
736 { SGI_WAIT4, "SGI_WAIT4" },
737 { SGI_PATHCONF, "SGI_PATHCONF" },
738 { SGI_READB, "SGI_READB" },
739 { SGI_WRITEB, "SGI_WRITEB" },
740 { SGI_SETGROUPS, "SGI_SETGROUPS" },
741 { SGI_GETGROUPS, "SGI_GETGROUPS" },
742 { SGI_SETTIMEOFDAY, "SGI_SETTIMEOFDAY" },
743 { SGI_SETTIMETRIM, "SGI_SETTIMETRIM" },
744 { SGI_GETTIMETRIM, "SGI_GETTIMETRIM" },
745 { SGI_SPROFIL, "SGI_SPROFIL" },
746 { SGI_RUSAGE, "SGI_RUSAGE" },
747 { SGI_SIGSTACK, "SGI_SIGSTACK" },
748 { SGI_SIGSTATUS, "SGI_SIGSTATUS" },
749 { SGI_NETPROC, "SGI_NETPROC" },
750 { SGI_SIGALTSTACK, "SGI_SIGALTSTACK" },
751 { SGI_BDFLUSHCNT, "SGI_BDFLUSHCNT" },
752 { SGI_SSYNC, "SGI_SSYNC" },
753 { SGI_NFSCNVT, "SGI_NFSCNVT" },
754 { SGI_GETPGID, "SGI_GETPGID" },
755 { SGI_GETSID, "SGI_GETSID" },
756 { SGI_IOPROBE, "SGI_IOPROBE" },
757 { SGI_CONFIG, "SGI_CONFIG" },
758 { SGI_ELFMAP, "SGI_ELFMAP" },
759 { SGI_MCONFIG, "SGI_MCONFIG" },
760 { SGI_GETPLABEL, "SGI_GETPLABEL" },
761 { SGI_SETPLABEL, "SGI_SETPLABEL" },
762 { SGI_GETLABEL, "SGI_GETLABEL" },
763 { SGI_SETLABEL, "SGI_SETLABEL" },
764 { SGI_SATREAD, "SGI_SATREAD" },
765 { SGI_SATWRITE, "SGI_SATWRITE" },
766 { SGI_SATCTL, "SGI_SATCTL" },
767 { SGI_LOADATTR, "SGI_LOADATTR" },
768 { SGI_UNLOADATTR, "SGI_UNLOADATTR" },
769#ifdef SGI_RECVLMSG
770 { SGI_RECVLMSG, "SGI_RECVLMSG" },
771#endif
772 { SGI_PLANGMOUNT, "SGI_PLANGMOUNT" },
773 { SGI_GETPSOACL, "SGI_GETPSOACL" },
774 { SGI_SETPSOACL, "SGI_SETPSOACL" },
Wichert Akkerman8829a551999-06-11 13:18:40 +0000775#ifdef SGI_EAG_GET_ATTR
776 { SGI_EAG_GET_ATTR, "SGI_EAG_GET_ATTR" },
777#endif
778#ifdef SGI_EAG_SET_ATTR
779 { SGI_EAG_SET_ATTR, "SGI_EAG_SET_ATTR" },
780#endif
781#ifdef SGI_EAG_GET_PROCATTR
782 { SGI_EAG_GET_PROCATTR, "SGI_EAG_GET_PROCATTR" },
783#endif
784#ifdef SGI_EAG_SET_PROCATTR
785 { SGI_EAG_SET_PROCATTR, "SGI_EAG_SET_PROCATTR" },
786#endif
787#ifdef SGI_FREVOKE
788 { SGI_FREVOKE, "SGI_FREVOKE" },
789#endif
790#ifdef SGI_SBE_GET_INFO
791 { SGI_SBE_GET_INFO, "SGI_SBE_GET_INFO" },
792#endif
793#ifdef SGI_SBE_CLR_INFO
794 { SGI_SBE_CLR_INFO, "SGI_SBE_CLR_INFO" },
795#endif
Wichert Akkerman76baf7c1999-02-19 00:21:36 +0000796 { SGI_RMI_FIXECC, "SGI_RMI_FIXECC" },
797 { SGI_R4K_CERRS, "SGI_R4K_CERRS" },
798 { SGI_GET_EVCONF, "SGI_GET_EVCONF" },
799 { SGI_MPCWAROFF, "SGI_MPCWAROFF" },
800 { SGI_SET_AUTOPWRON, "SGI_SET_AUTOPWRON" },
801 { SGI_SPIPE, "SGI_SPIPE" },
802 { SGI_SYMTAB, "SGI_SYMTAB" },
803#ifdef SGI_SET_FPDEBUG
804 { SGI_SET_FPDEBUG, "SGI_SET_FPDEBUG" },
805#endif
Wichert Akkerman8829a551999-06-11 13:18:40 +0000806#ifdef SGI_SET_FP_PRECISE
807 { SGI_SET_FP_PRECISE, "SGI_SET_FP_PRECISE" },
808#endif
Wichert Akkerman76baf7c1999-02-19 00:21:36 +0000809 { SGI_TOSSTSAVE, "SGI_TOSSTSAVE" },
810 { SGI_FDHI, "SGI_FDHI" },
Wichert Akkerman8829a551999-06-11 13:18:40 +0000811#ifdef SGI_SET_CONFIG_SMM
812 { SGI_SET_CONFIG_SMM, "SGI_SET_CONFIG_SMM" },
813#endif
814#ifdef SGI_SET_FP_PRESERVE
815 { SGI_SET_FP_PRESERVE, "SGI_SET_FP_PRESERVE" },
816#endif
Wichert Akkerman76baf7c1999-02-19 00:21:36 +0000817 { SGI_MINRSS, "SGI_MINRSS" },
Wichert Akkerman8829a551999-06-11 13:18:40 +0000818#ifdef SGI_GRIO
819 { SGI_GRIO, "SGI_GRIO" },
820#endif
821#ifdef SGI_XLV_SET_TAB
822 { SGI_XLV_SET_TAB, "SGI_XLV_SET_TAB" },
823#endif
824#ifdef SGI_XLV_GET_TAB
825 { SGI_XLV_GET_TAB, "SGI_XLV_GET_TAB" },
826#endif
827#ifdef SGI_GET_FP_PRECISE
828 { SGI_GET_FP_PRECISE, "SGI_GET_FP_PRECISE" },
829#endif
830#ifdef SGI_GET_CONFIG_SMM
831 { SGI_GET_CONFIG_SMM, "SGI_GET_CONFIG_SMM" },
832#endif
833#ifdef SGI_FP_IMPRECISE_SUPP
834 { SGI_FP_IMPRECISE_SUPP,"SGI_FP_IMPRECISE_SUPP" },
835#endif
836#ifdef SGI_CONFIG_NSMM_SUPP
837 { SGI_CONFIG_NSMM_SUPP, "SGI_CONFIG_NSMM_SUPP" },
838#endif
839#ifdef SGI_RT_TSTAMP_CREATE
840 { SGI_RT_TSTAMP_CREATE, "SGI_RT_TSTAMP_CREATE" },
841#endif
842#ifdef SGI_RT_TSTAMP_DELETE
843 { SGI_RT_TSTAMP_DELETE, "SGI_RT_TSTAMP_DELETE" },
844#endif
845#ifdef SGI_RT_TSTAMP_START
846 { SGI_RT_TSTAMP_START, "SGI_RT_TSTAMP_START" },
847#endif
848#ifdef SGI_RT_TSTAMP_STOP
849 { SGI_RT_TSTAMP_STOP, "SGI_RT_TSTAMP_STOP" },
850#endif
851#ifdef SGI_RT_TSTAMP_ADDR
852 { SGI_RT_TSTAMP_ADDR, "SGI_RT_TSTAMP_ADDR" },
853#endif
854#ifdef SGI_RT_TSTAMP_MASK
855 { SGI_RT_TSTAMP_MASK, "SGI_RT_TSTAMP_MASK" },
856#endif
857#ifdef SGI_RT_TSTAMP_EOB_MODE
858 { SGI_RT_TSTAMP_EOB_MODE,"SGI_RT_TSTAMP_EOB_MODE"},
859#endif
860#ifdef SGI_USE_FP_BCOPY
861 { SGI_USE_FP_BCOPY, "SGI_USE_FP_BCOPY" },
862#endif
863#ifdef SGI_GET_UST
864 { SGI_GET_UST, "SGI_GET_UST" },
865#endif
866#ifdef SGI_SPECULATIVE_EXEC
867 { SGI_SPECULATIVE_EXEC, "SGI_SPECULATIVE_EXEC" },
868#endif
869#ifdef SGI_XLV_NEXT_RQST
870 { SGI_XLV_NEXT_RQST, "SGI_XLV_NEXT_RQST" },
871#endif
872#ifdef SGI_XLV_ATTR_CURSOR
873 { SGI_XLV_ATTR_CURSOR, "SGI_XLV_ATTR_CURSOR" },
874#endif
875#ifdef SGI_XLV_ATTR_GET
876 { SGI_XLV_ATTR_GET, "SGI_XLV_ATTR_GET" },
877#endif
878#ifdef SGI_XLV_ATTR_SET
879 { SGI_XLV_ATTR_SET, "SGI_XLV_ATTR_SET" },
880#endif
881#ifdef SGI_BTOOLSIZE
882 { SGI_BTOOLSIZE, "SGI_BTOOLSIZE" },
883#endif
884#ifdef SGI_BTOOLGET
885 { SGI_BTOOLGET, "SGI_BTOOLGET" },
886#endif
887#ifdef SGI_BTOOLREINIT
888 { SGI_BTOOLREINIT, "SGI_BTOOLREINIT" },
889#endif
890#ifdef SGI_CREATE_UUID
891 { SGI_CREATE_UUID, "SGI_CREATE_UUID" },
892#endif
893#ifdef SGI_NOFPE
894 { SGI_NOFPE, "SGI_NOFPE" },
895#endif
896#ifdef SGI_OLD_SOFTFP
897 { SGI_OLD_SOFTFP, "SGI_OLD_SOFTFP" },
898#endif
899#ifdef SGI_FS_INUMBERS
900 { SGI_FS_INUMBERS, "SGI_FS_INUMBERS" },
901#endif
902#ifdef SGI_FS_BULKSTAT
903 { SGI_FS_BULKSTAT, "SGI_FS_BULKSTAT" },
904#endif
905#ifdef SGI_RT_TSTAMP_WAIT
906 { SGI_RT_TSTAMP_WAIT, "SGI_RT_TSTAMP_WAIT" },
907#endif
908#ifdef SGI_RT_TSTAMP_UPDATE
909 { SGI_RT_TSTAMP_UPDATE, "SGI_RT_TSTAMP_UPDATE" },
910#endif
911#ifdef SGI_PATH_TO_HANDLE
912 { SGI_PATH_TO_HANDLE, "SGI_PATH_TO_HANDLE" },
913#endif
914#ifdef SGI_PATH_TO_FSHANDLE
915 { SGI_PATH_TO_FSHANDLE, "SGI_PATH_TO_FSHANDLE" },
916#endif
917#ifdef SGI_FD_TO_HANDLE
918 { SGI_FD_TO_HANDLE, "SGI_FD_TO_HANDLE" },
919#endif
920#ifdef SGI_OPEN_BY_HANDLE
921 { SGI_OPEN_BY_HANDLE, "SGI_OPEN_BY_HANDLE" },
922#endif
923#ifdef SGI_READLINK_BY_HANDLE
924 { SGI_READLINK_BY_HANDLE,"SGI_READLINK_BY_HANDLE"},
925#endif
926#ifdef SGI_READ_DANGID
927 { SGI_READ_DANGID, "SGI_READ_DANGID" },
928#endif
929#ifdef SGI_CONST
930 { SGI_CONST, "SGI_CONST" },
931#endif
932#ifdef SGI_XFS_FSOPERATIONS
933 { SGI_XFS_FSOPERATIONS, "SGI_XFS_FSOPERATIONS" },
934#endif
935#ifdef SGI_SETASH
936 { SGI_SETASH, "SGI_SETASH" },
937#endif
938#ifdef SGI_GETASH
939 { SGI_GETASH, "SGI_GETASH" },
940#endif
941#ifdef SGI_SETPRID
942 { SGI_SETPRID, "SGI_SETPRID" },
943#endif
944#ifdef SGI_GETPRID
945 { SGI_GETPRID, "SGI_GETPRID" },
946#endif
947#ifdef SGI_SETSPINFO
948 { SGI_SETSPINFO, "SGI_SETSPINFO" },
949#endif
950#ifdef SGI_GETSPINFO
951 { SGI_GETSPINFO, "SGI_GETSPINFO" },
952#endif
953#ifdef SGI_SHAREII
954 { SGI_SHAREII, "SGI_SHAREII" },
955#endif
956#ifdef SGI_NEWARRAYSESS
957 { SGI_NEWARRAYSESS, "SGI_NEWARRAYSESS" },
958#endif
959#ifdef SGI_GETDFLTPRID
960 { SGI_GETDFLTPRID, "SGI_GETDFLTPRID" },
961#endif
962#ifdef SGI_SET_DISMISSED_EXC_CNT
963 { SGI_SET_DISMISSED_EXC_CNT,"SGI_SET_DISMISSED_EXC_CNT" },
964#endif
965#ifdef SGI_GET_DISMISSED_EXC_CNT
966 { SGI_GET_DISMISSED_EXC_CNT,"SGI_GET_DISMISSED_EXC_CNT" },
967#endif
968#ifdef SGI_CYCLECNTR_SIZE
969 { SGI_CYCLECNTR_SIZE, "SGI_CYCLECNTR_SIZE" },
970#endif
971#ifdef SGI_QUERY_FASTTIMER
972 { SGI_QUERY_FASTTIMER, "SGI_QUERY_FASTTIMER" },
973#endif
974#ifdef SGI_PIDSINASH
975 { SGI_PIDSINASH, "SGI_PIDSINASH" },
976#endif
977#ifdef SGI_ULI
978 { SGI_ULI, "SGI_ULI" },
979#endif
980#ifdef SGI_LPG_SHMGET
981 { SGI_LPG_SHMGET, "SGI_LPG_SHMGET" },
982#endif
983#ifdef SGI_LPG_MAP
984 { SGI_LPG_MAP, "SGI_LPG_MAP" },
985#endif
986#ifdef SGI_CACHEFS_SYS
987 { SGI_CACHEFS_SYS, "SGI_CACHEFS_SYS" },
988#endif
989#ifdef SGI_NFSNOTIFY
990 { SGI_NFSNOTIFY, "SGI_NFSNOTIFY" },
991#endif
992#ifdef SGI_LOCKDSYS
993 { SGI_LOCKDSYS, "SGI_LOCKDSYS" },
994#endif
995#ifdef SGI_EVENTCTR
996 { SGI_EVENTCTR, "SGI_EVENTCTR" },
997#endif
998#ifdef SGI_GETPRUSAGE
999 { SGI_GETPRUSAGE, "SGI_GETPRUSAGE" },
1000#endif
1001#ifdef SGI_PROCMASK_LOCATION
1002 { SGI_PROCMASK_LOCATION,"SGI_PROCMASK_LOCATION" },
1003#endif
1004#ifdef SGI_UNUSED
1005 { SGI_UNUSED, "SGI_UNUSED" },
1006#endif
1007#ifdef SGI_CKPT_SYS
1008 { SGI_CKPT_SYS, "SGI_CKPT_SYS" },
1009#endif
1010#ifdef SGI_CKPT_SYS
1011 { SGI_CKPT_SYS, "SGI_CKPT_SYS" },
1012#endif
1013#ifdef SGI_GETGRPPID
1014 { SGI_GETGRPPID, "SGI_GETGRPPID" },
1015#endif
1016#ifdef SGI_GETSESPID
1017 { SGI_GETSESPID, "SGI_GETSESPID" },
1018#endif
1019#ifdef SGI_ENUMASHS
1020 { SGI_ENUMASHS, "SGI_ENUMASHS" },
1021#endif
1022#ifdef SGI_SETASMACHID
1023 { SGI_SETASMACHID, "SGI_SETASMACHID" },
1024#endif
1025#ifdef SGI_GETASMACHID
1026 { SGI_GETASMACHID, "SGI_GETASMACHID" },
1027#endif
1028#ifdef SGI_GETARSESS
1029 { SGI_GETARSESS, "SGI_GETARSESS" },
1030#endif
1031#ifdef SGI_JOINARRAYSESS
1032 { SGI_JOINARRAYSESS, "SGI_JOINARRAYSESS" },
1033#endif
1034#ifdef SGI_SPROC_KILL
1035 { SGI_SPROC_KILL, "SGI_SPROC_KILL" },
1036#endif
1037#ifdef SGI_DBA_CONFIG
1038 { SGI_DBA_CONFIG, "SGI_DBA_CONFIG" },
1039#endif
1040#ifdef SGI_RELEASE_NAME
1041 { SGI_RELEASE_NAME, "SGI_RELEASE_NAME" },
1042#endif
1043#ifdef SGI_SYNCH_CACHE_HANDLER
1044 { SGI_SYNCH_CACHE_HANDLER,"SGI_SYNCH_CACHE_HANDLER"},
1045#endif
1046#ifdef SGI_SWASH_INIT
1047 { SGI_SWASH_INIT, "SGI_SWASH_INIT" },
1048#endif
1049#ifdef SGI_NUMA_MIGR_PAGE
1050 { SGI_NUMA_MIGR_PAGE, "SGI_NUMA_MIGR_PAGE" },
1051#endif
1052#ifdef SGI_NUMA_MIGR_PAGE_ALT
1053 { SGI_NUMA_MIGR_PAGE_ALT,"SGI_NUMA_MIGR_PAGE_ALT"},
1054#endif
1055#ifdef SGI_KAIO_USERINIT
1056 { SGI_KAIO_USERINIT, "SGI_KAIO_USERINIT" },
1057#endif
1058#ifdef SGI_KAIO_READ
1059 { SGI_KAIO_READ, "SGI_KAIO_READ" },
1060#endif
1061#ifdef SGI_KAIO_WRITE
1062 { SGI_KAIO_WRITE, "SGI_KAIO_WRITE" },
1063#endif
1064#ifdef SGI_KAIO_SUSPEND
1065 { SGI_KAIO_SUSPEND, "SGI_KAIO_SUSPEND" },
1066#endif
1067#ifdef SGI_KAIO_STATS
1068 { SGI_KAIO_STATS, "SGI_KAIO_STATS" },
1069#endif
1070#ifdef SGI_INITIAL_PT_SPROC
1071 { SGI_INITIAL_PT_SPROC, "SGI_INITIAL_PT_SPROC" },
1072#endif
Wichert Akkerman76baf7c1999-02-19 00:21:36 +00001073 { 0, NULL },
1074};
1075
1076int
1077sys_syssgi(tcp)
1078struct tcb *tcp;
1079{
1080 int i;
1081
1082 if (entering(tcp)) {
1083 printxval(syssgi_options, tcp->u_arg[0], "SGI_???");
1084 switch (tcp->u_arg[0]) {
1085 default:
1086 for (i = 1; i < tcp->u_nargs; i++)
1087 tprintf(", %#lx", tcp->u_arg[i]);
1088 break;
1089 }
1090 }
1091 return 0;
1092}
1093
1094#include <sys/types.h>
1095#include <rpc/rpc.h>
1096struct cred;
1097struct uio;
1098#include <sys/fsid.h>
1099#include <sys/vnode.h>
1100#include <sys/fs/nfs.h>
1101#include <sys/fs/nfs_clnt.h>
1102
1103static struct xlat mount_flags[] = {
1104 { MS_RDONLY, "MS_RDONLY" },
1105 { MS_FSS, "MS_FSS" },
1106 { MS_DATA, "MS_DATA" },
1107 { MS_NOSUID, "MS_NOSUID" },
1108 { MS_REMOUNT, "MS_REMOUNT" },
1109 { MS_NOTRUNC, "MS_NOTRUNC" },
1110 { MS_GRPID, "MS_GRPID" },
1111 { MS_NODEV, "MS_NODEV" },
1112 { MS_BEFORE, "MS_BEFORE" },
1113 { MS_AFTER, "MS_AFTER" },
1114 { 0, NULL },
1115};
1116
1117static struct xlat nfs_flags[] = {
1118 { NFSMNT_SOFT, "NFSMNT_SOFT" },
1119 { NFSMNT_WSIZE, "NFSMNT_WSIZE" },
1120 { NFSMNT_RSIZE, "NFSMNT_RSIZE" },
1121 { NFSMNT_TIMEO, "NFSMNT_TIMEO" },
1122 { NFSMNT_RETRANS, "NFSMNT_RETRANS" },
1123 { NFSMNT_HOSTNAME, "NFSMNT_HOSTNAME" },
Wichert Akkerman8829a551999-06-11 13:18:40 +00001124#ifdef NFSMNT_NOINT /* IRIX 6 */
1125 { NFSMNT_NOINT, "NFSMNT_NOINT" },
1126#endif
1127#ifdef NFSMNT_INT /* IRIX 5 */
Wichert Akkerman76baf7c1999-02-19 00:21:36 +00001128 { NFSMNT_INT, "NFSMNT_INT" },
Wichert Akkerman8829a551999-06-11 13:18:40 +00001129#endif
Wichert Akkerman76baf7c1999-02-19 00:21:36 +00001130 { NFSMNT_NOAC, "NFSMNT_NOAC" },
1131 { NFSMNT_ACREGMIN, "NFSMNT_ACREGMIN" },
1132 { NFSMNT_ACREGMAX, "NFSMNT_ACREGMAX" },
1133 { NFSMNT_ACDIRMIN, "NFSMNT_ACDIRMIN" },
1134 { NFSMNT_ACDIRMAX, "NFSMNT_ACDIRMAX" },
1135 { NFSMNT_PRIVATE, "NFSMNT_PRIVATE" },
1136 { NFSMNT_SYMTTL, "NFSMNT_SYMTTL" },
1137 { NFSMNT_LOOPBACK, "NFSMNT_LOOPBACK" },
1138 { NFSMNT_BASETYPE, "NFSMNT_BASETYPE" },
1139 { NFSMNT_NAMEMAX, "NFSMNT_NAMEMAX" },
Wichert Akkerman8829a551999-06-11 13:18:40 +00001140#ifdef NFSMNT_SHORTUID /* IRIX 6 */
1141 { NFSMNT_SHORTUID, "NFSMNT_SHORTUID" },
1142#endif
1143#ifdef NFSMNT_ASYNCNLM /* IRIX 6 */
1144 { NFSMNT_ASYNCNLM, "NFSMNT_ASYNCNLM" },
1145#endif
Wichert Akkerman76baf7c1999-02-19 00:21:36 +00001146 { 0, NULL },
1147};
1148
1149int
1150sys_mount(tcp)
1151struct tcb *tcp;
1152{
1153 if (entering(tcp)) {
1154 printpath(tcp, tcp->u_arg[0]);
1155 tprintf(", ");
1156 printpath(tcp, tcp->u_arg[1]);
1157 tprintf(", ");
1158 printflags(mount_flags, tcp->u_arg[2]);
1159 if (tcp->u_arg[2] & (MS_FSS | MS_DATA)) {
1160 tprintf(", ");
1161 tprintf("%ld", tcp->u_arg[3]);
1162 }
1163 if (tcp->u_arg[2] & MS_DATA) {
1164 int nfs_type = sysfs(GETFSIND, FSID_NFS);
1165
1166 tprintf(", ");
1167 if (tcp->u_arg[3] == nfs_type) {
1168 struct nfs_args args;
1169 if (umove(tcp, tcp->u_arg[4], &args) < 0)
1170 tprintf("%#lx", tcp->u_arg[4]);
1171 else {
1172 tprintf("addr=");
1173 printsock(tcp, (int) args.addr);
1174 tprintf(", flags=");
1175 if (!printflags(nfs_flags, args.flags))
1176 tprintf("NFSMNT_???");
1177 tprintf(", hostname=");
1178 printstr(tcp, (int) args.hostname, -1);
1179 tprintf(", ...}");
1180 }
1181 }
1182 else
1183 tprintf("%#lx", tcp->u_arg[4]);
1184 tprintf(", %ld", tcp->u_arg[5]);
1185 }
1186 }
1187 return 0;
1188}
1189
1190#else /* !MIPS */
1191
1192int
1193sys_mount(tcp)
1194struct tcb *tcp;
1195{
1196 if (entering(tcp)) {
1197 printpath(tcp, tcp->u_arg[0]);
1198 tprintf(", ");
1199 printpath(tcp, tcp->u_arg[1]);
1200 tprintf(", ...");
1201 }
1202 return 0;
1203}
1204
1205#endif /* !MIPS */
1206
1207#endif /* SVR4 */
1208
Nate Sammons8d5860c1999-07-03 18:53:05 +00001209#ifdef SYS_capget
Wichert Akkerman76baf7c1999-02-19 00:21:36 +00001210int
1211sys_capget(tcp)
1212struct tcb *tcp;
1213{
1214 cap_user_header_t arg0;
1215 cap_user_data_t arg1;
1216
1217 if(!entering(tcp)) {
1218 arg0 = (cap_user_header_t)tcp->u_arg[0];
1219 arg1 = (cap_user_data_t)tcp->u_arg[1];
1220 tprintf("{%lx, %d}, ", (unsigned long)arg0->version, arg0->pid);
1221 tprintf("{%lx, %lx, %lx}", (unsigned long)arg1->effective,
1222 (unsigned long)arg1->permitted, (unsigned long)arg1->inheritable);
1223 }
1224 return 0;
1225}
1226
1227int
1228sys_capset(tcp)
1229struct tcb *tcp;
1230{
1231 cap_user_header_t arg0;
1232 cap_user_data_t arg1;
1233
1234 if(entering(tcp)) {
1235 arg0 = (cap_user_header_t)tcp->u_arg[0];
1236 arg1 = (cap_user_data_t)tcp->u_arg[1];
1237 tprintf("{%lx, %d}, ", (unsigned long)arg0->version, arg0->pid);
1238 tprintf("{%lx, %lx, %lx}", (unsigned long)arg1->effective,
1239 (unsigned long)arg1->permitted, (unsigned long)arg1->inheritable);
1240 }
1241 return 0;
1242}
1243
1244#else
1245
1246int sys_capget(tcp)
1247struct tcb *tcp;
1248{
1249 return printargs(tcp);
1250}
1251
1252int sys_capset(tcp)
1253struct tcb *tcp;
1254{
1255 return printargs(tcp);
1256}
1257
1258#endif
1259
Wichert Akkerman22fe9d21999-05-27 12:00:57 +00001260#ifdef LINUX
1261static struct xlat sysctl_root[] = {
1262 { CTL_KERN, "CTL_KERN" },
1263 { CTL_VM, "CTL_VM" },
1264 { CTL_NET, "CTL_NET" },
1265 { CTL_PROC, "CTL_PROC" },
1266 { CTL_FS, "CTL_FS" },
1267 { CTL_DEBUG, "CTL_DEBUG" },
1268 { CTL_DEV, "CTL_DEV" },
1269 { 0, NULL }
1270};
1271
1272static struct xlat sysctl_kern[] = {
1273 { KERN_OSTYPE, "KERN_OSTYPE" },
1274 { KERN_OSRELEASE, "KERN_OSRELEASE" },
1275 { KERN_OSREV, "KERN_OSREV" },
1276 { KERN_VERSION, "KERN_VERSION" },
1277 { KERN_SECUREMASK, "KERN_SECUREMASK" },
1278 { KERN_PROF, "KERN_PROF" },
1279 { KERN_NODENAME, "KERN_NODENAME" },
1280 { KERN_DOMAINNAME, "KERN_DOMAINNAME" },
1281 { KERN_SECURELVL, "KERN_SECURELVL" },
1282 { KERN_PANIC, "KERN_PANIC" },
1283 { KERN_REALROOTDEV, "KERN_REALROOTDEV" },
1284 { KERN_JAVA_INTERPRETER, "KERN_JAVA_INTERPRETER" },
1285 { KERN_JAVA_APPLETVIEWER, "KERN_JAVA_APPLETVIEWER" },
1286 { KERN_SPARC_REBOOT, "KERN_SPARC_REBOOT" },
1287 { KERN_CTLALTDEL, "KERN_CTLALTDEL" },
1288 { KERN_PRINTK, "KERN_PRINTK" },
1289 { KERN_NAMETRANS, "KERN_NAMETRANS" },
1290 { KERN_PPC_HTABRECLAIM, "KERN_PPC_HTABRECLAIM" },
1291 { KERN_PPC_ZEROPAGED, "KERN_PPC_ZEROPAGED" },
1292 { KERN_PPC_POWERSAVE_NAP, "KERN_PPC_POWERSAVE_NAP" },
1293 { KERN_MODPROBE, "KERN_MODPROBE" },
1294 { KERN_SG_BIG_BUFF, "KERN_SG_BIG_BUFF" },
1295 { KERN_ACCT, "KERN_ACCT" },
1296 { KERN_PPC_L2CR, "KERN_PPC_L2CR" },
1297 { KERN_RTSIGNR, "KERN_RTSIGNR" },
1298 { KERN_RTSIGMAX, "KERN_RTSIGMAX" },
1299 { KERN_SHMMAX, "KERN_SHMMAX" },
1300 { KERN_MSGMAX, "KERN_MSGMAX" },
1301 { KERN_MSGMNB, "KERN_MSGMNB" },
1302 { KERN_MSGPOOL, "KERN_MSGPOOL" },
1303 { 0, NULL }
1304};
1305
1306static struct xlat sysctl_vm[] = {
1307 { VM_SWAPCTL, "VM_SWAPCTL" },
1308 { VM_SWAPOUT, "VM_SWAPOUT" },
1309 { VM_FREEPG, "VM_FREEPG" },
1310 { VM_BDFLUSH, "VM_BDFLUSH" },
1311 { VM_OVERCOMMIT_MEMORY, "VM_OVERCOMMIT_MEMORY" },
1312 { VM_BUFFERMEM, "VM_BUFFERMEM" },
1313 { VM_PAGECACHE, "VM_PAGECACHE" },
1314 { VM_PAGERDAEMON, "VM_PAGERDAEMON" },
1315 { VM_PGT_CACHE, "VM_PGT_CACHE" },
1316 { VM_PAGE_CLUSTER, "VM_PAGE_CLUSTER" },
1317 { 0, NULL },
1318};
1319
1320static struct xlat sysctl_net[] = {
1321 { NET_CORE, "NET_CORE" },
1322 { NET_ETHER, "NET_ETHER" },
1323 { NET_802, "NET_802" },
1324 { NET_UNIX, "NET_UNIX" },
1325 { NET_IPV4, "NET_IPV4" },
1326 { NET_IPX, "NET_IPX" },
1327 { NET_ATALK, "NET_ATALK" },
1328 { NET_NETROM, "NET_NETROM" },
1329 { NET_AX25, "NET_AX25" },
1330 { NET_BRIDGE, "NET_BRIDGE" },
1331 { NET_ROSE, "NET_ROSE" },
1332 { NET_IPV6, "NET_IPV6" },
1333 { NET_X25, "NET_X25" },
1334 { NET_TR, "NET_TR" },
1335 { NET_DECNET, "NET_DECNET" },
1336 { 0, NULL }
1337};
1338
1339static struct xlat sysctl_net_core[] = {
1340 { NET_CORE_WMEM_MAX, "NET_CORE_WMEM_MAX" },
1341 { NET_CORE_RMEM_MAX, "NET_CORE_RMEM_MAX" },
1342 { NET_CORE_WMEM_DEFAULT, "NET_CORE_WMEM_DEFAULT" },
1343 { NET_CORE_RMEM_DEFAULT, "NET_CORE_RMEM_DEFAULT" },
1344 { NET_CORE_MAX_BACKLOG, "NET_CORE_MAX_BACKLOG" },
1345 { NET_CORE_FASTROUTE, "NET_CORE_FASTROUTE" },
1346 { NET_CORE_MSG_COST, "NET_CORE_MSG_COST" },
1347 { NET_CORE_MSG_BURST, "NET_CORE_MSG_BURST" },
1348 { NET_CORE_OPTMEM_MAX, "NET_CORE_OPTMEM_MAX" },
1349 { 0, NULL }
1350};
1351
1352static struct xlat sysctl_net_unix[] = {
1353 { NET_UNIX_DESTROY_DELAY, "NET_UNIX_DESTROY_DELAY" },
1354 { NET_UNIX_DELETE_DELAY, "NET_UNIX_DELETE_DELAY" },
1355 { 0, NULL }
1356};
1357
1358static struct xlat sysctl_net_ipv4[] = {
1359 { NET_IPV4_FORWARD, "NET_IPV4_FORWARD" },
1360 { NET_IPV4_DYNADDR, "NET_IPV4_DYNADDR" },
1361 { NET_IPV4_CONF, "NET_IPV4_CONF" },
1362 { NET_IPV4_NEIGH, "NET_IPV4_NEIGH" },
1363 { NET_IPV4_ROUTE, "NET_IPV4_ROUTE" },
1364 { NET_IPV4_FIB_HASH, "NET_IPV4_FIB_HASH" },
1365 { NET_IPV4_TCP_TIMESTAMPS, "NET_IPV4_TCP_TIMESTAMPS" },
1366 { NET_IPV4_TCP_WINDOW_SCALING, "NET_IPV4_TCP_WINDOW_SCALING" },
1367 { NET_IPV4_TCP_SACK, "NET_IPV4_TCP_SACK" },
1368 { NET_IPV4_TCP_RETRANS_COLLAPSE, "NET_IPV4_TCP_RETRANS_COLLAPSE" },
1369 { NET_IPV4_DEFAULT_TTL, "NET_IPV4_DEFAULT_TTL" },
1370 { NET_IPV4_AUTOCONFIG, "NET_IPV4_AUTOCONFIG" },
1371 { NET_IPV4_NO_PMTU_DISC, "NET_IPV4_NO_PMTU_DISC" },
1372 { NET_IPV4_TCP_SYN_RETRIES, "NET_IPV4_TCP_SYN_RETRIES" },
1373 { NET_IPV4_IPFRAG_HIGH_THRESH, "NET_IPV4_IPFRAG_HIGH_THRESH" },
1374 { NET_IPV4_IPFRAG_LOW_THRESH, "NET_IPV4_IPFRAG_LOW_THRESH" },
1375 { NET_IPV4_IPFRAG_TIME, "NET_IPV4_IPFRAG_TIME" },
1376 { NET_IPV4_TCP_MAX_KA_PROBES, "NET_IPV4_TCP_MAX_KA_PROBES" },
1377 { NET_IPV4_TCP_KEEPALIVE_TIME, "NET_IPV4_TCP_KEEPALIVE_TIME" },
1378 { NET_IPV4_TCP_KEEPALIVE_PROBES, "NET_IPV4_TCP_KEEPALIVE_PROBES" },
1379 { NET_IPV4_TCP_RETRIES1, "NET_IPV4_TCP_RETRIES1" },
1380 { NET_IPV4_TCP_RETRIES2, "NET_IPV4_TCP_RETRIES2" },
1381 { NET_IPV4_TCP_FIN_TIMEOUT, "NET_IPV4_TCP_FIN_TIMEOUT" },
1382 { NET_IPV4_IP_MASQ_DEBUG, "NET_IPV4_IP_MASQ_DEBUG" },
1383 { NET_TCP_SYNCOOKIES, "NET_TCP_SYNCOOKIES" },
1384 { NET_TCP_STDURG, "NET_TCP_STDURG" },
1385 { NET_TCP_RFC1337, "NET_TCP_RFC1337" },
1386 { NET_TCP_SYN_TAILDROP, "NET_TCP_SYN_TAILDROP" },
1387 { NET_TCP_MAX_SYN_BACKLOG, "NET_TCP_MAX_SYN_BACKLOG" },
1388 { NET_IPV4_LOCAL_PORT_RANGE, "NET_IPV4_LOCAL_PORT_RANGE" },
1389 { NET_IPV4_ICMP_ECHO_IGNORE_ALL, "NET_IPV4_ICMP_ECHO_IGNORE_ALL" },
1390 { NET_IPV4_ICMP_ECHO_IGNORE_BROADCASTS, "NET_IPV4_ICMP_ECHO_IGNORE_BROADCASTS" },
1391 { NET_IPV4_ICMP_SOURCEQUENCH_RATE, "NET_IPV4_ICMP_SOURCEQUENCH_RATE" },
1392 { NET_IPV4_ICMP_DESTUNREACH_RATE, "NET_IPV4_ICMP_DESTUNREACH_RATE" },
1393 { NET_IPV4_ICMP_TIMEEXCEED_RATE, "NET_IPV4_ICMP_TIMEEXCEED_RATE" },
1394 { NET_IPV4_ICMP_PARAMPROB_RATE, "NET_IPV4_ICMP_PARAMPROB_RATE" },
1395 { NET_IPV4_ICMP_ECHOREPLY_RATE, "NET_IPV4_ICMP_ECHOREPLY_RATE" },
1396 { NET_IPV4_ICMP_IGNORE_BOGUS_ERROR_RESPONSES, "NET_IPV4_ICMP_IGNORE_BOGUS_ERROR_RESPONSES" },
1397 { NET_IPV4_IGMP_MAX_MEMBERSHIPS, "NET_IPV4_IGMP_MAX_MEMBERSHIPS" },
1398 { 0, NULL }
1399};
1400
1401static struct xlat sysctl_net_ipv4_route[] = {
1402 { NET_IPV4_ROUTE_FLUSH, "NET_IPV4_ROUTE_FLUSH" },
1403 { NET_IPV4_ROUTE_MIN_DELAY, "NET_IPV4_ROUTE_MIN_DELAY" },
1404 { NET_IPV4_ROUTE_MAX_DELAY, "NET_IPV4_ROUTE_MAX_DELAY" },
1405 { NET_IPV4_ROUTE_GC_THRESH, "NET_IPV4_ROUTE_GC_THRESH" },
1406 { NET_IPV4_ROUTE_MAX_SIZE, "NET_IPV4_ROUTE_MAX_SIZE" },
1407 { NET_IPV4_ROUTE_GC_MIN_INTERVAL, "NET_IPV4_ROUTE_GC_MIN_INTERVAL" },
1408 { NET_IPV4_ROUTE_GC_TIMEOUT, "NET_IPV4_ROUTE_GC_TIMEOUT" },
1409 { NET_IPV4_ROUTE_GC_INTERVAL, "NET_IPV4_ROUTE_GC_INTERVAL" },
1410 { NET_IPV4_ROUTE_REDIRECT_LOAD, "NET_IPV4_ROUTE_REDIRECT_LOAD" },
1411 { NET_IPV4_ROUTE_REDIRECT_NUMBER, "NET_IPV4_ROUTE_REDIRECT_NUMBER" },
1412 { NET_IPV4_ROUTE_REDIRECT_SILENCE, "NET_IPV4_ROUTE_REDIRECT_SILENCE" },
1413 { NET_IPV4_ROUTE_ERROR_COST, "NET_IPV4_ROUTE_ERROR_COST" },
1414 { NET_IPV4_ROUTE_ERROR_BURST, "NET_IPV4_ROUTE_ERROR_BURST" },
1415 { NET_IPV4_ROUTE_GC_ELASTICITY, "NET_IPV4_ROUTE_GC_ELASTICITY" },
1416 { 0, NULL }
1417};
1418
1419static struct xlat sysctl_net_ipv4_conf[] = {
1420 { NET_IPV4_CONF_FORWARDING, "NET_IPV4_CONF_FORWARDING" },
1421 { NET_IPV4_CONF_MC_FORWARDING, "NET_IPV4_CONF_MC_FORWARDING" },
1422 { NET_IPV4_CONF_PROXY_ARP, "NET_IPV4_CONF_PROXY_ARP" },
1423 { NET_IPV4_CONF_ACCEPT_REDIRECTS, "NET_IPV4_CONF_ACCEPT_REDIRECTS" },
1424 { NET_IPV4_CONF_SECURE_REDIRECTS, "NET_IPV4_CONF_SECURE_REDIRECTS" },
1425 { NET_IPV4_CONF_SEND_REDIRECTS, "NET_IPV4_CONF_SEND_REDIRECTS" },
1426 { NET_IPV4_CONF_SHARED_MEDIA, "NET_IPV4_CONF_SHARED_MEDIA" },
1427 { NET_IPV4_CONF_RP_FILTER, "NET_IPV4_CONF_RP_FILTER" },
1428 { NET_IPV4_CONF_ACCEPT_SOURCE_ROUTE, "NET_IPV4_CONF_ACCEPT_SOURCE_ROUTE" },
1429 { NET_IPV4_CONF_BOOTP_RELAY, "NET_IPV4_CONF_BOOTP_RELAY" },
1430 { NET_IPV4_CONF_LOG_MARTIANS, "NET_IPV4_CONF_LOG_MARTIANS" },
1431 { 0, NULL }
1432};
1433
1434static struct xlat sysctl_net_ipv6[] = {
1435 { NET_IPV6_CONF, "NET_IPV6_CONF" },
1436 { NET_IPV6_NEIGH, "NET_IPV6_NEIGH" },
1437 { NET_IPV6_ROUTE, "NET_IPV6_ROUTE" },
1438 { 0, NULL }
1439};
1440
1441static struct xlat sysctl_net_ipv6_route[] = {
1442 { NET_IPV6_ROUTE_FLUSH, "NET_IPV6_ROUTE_FLUSH" },
1443 { NET_IPV6_ROUTE_GC_THRESH, "NET_IPV6_ROUTE_GC_THRESH" },
1444 { NET_IPV6_ROUTE_MAX_SIZE, "NET_IPV6_ROUTE_MAX_SIZE" },
1445 { NET_IPV6_ROUTE_GC_MIN_INTERVAL, "NET_IPV6_ROUTE_GC_MIN_INTERVAL" },
1446 { NET_IPV6_ROUTE_GC_TIMEOUT, "NET_IPV6_ROUTE_GC_TIMEOUT" },
1447 { NET_IPV6_ROUTE_GC_INTERVAL, "NET_IPV6_ROUTE_GC_INTERVAL" },
1448 { NET_IPV6_ROUTE_GC_ELASTICITY, "NET_IPV6_ROUTE_GC_ELASTICITY" },
1449 { 0, NULL }
1450};
1451
1452int
1453sys_sysctl(tcp)
1454struct tcb *tcp;
1455{
1456 struct __sysctl_args info;
1457 int *name;
1458 umove (tcp, tcp->u_arg[0], &info);
1459
1460 name = alloca (sizeof (int) * info.nlen);
1461 umoven(tcp, (size_t) info.name, sizeof (int) * info.nlen, (char *) name);
1462
1463 if (entering(tcp)) {
1464 int cnt = 0;
1465
1466 tprintf("{{");
1467
1468 if (info.nlen == 0)
1469 goto out;
1470 printxval(sysctl_root, name[0], "CTL_???");
1471 ++cnt;
1472
1473 if (info.nlen == 1)
1474 goto out;
1475 switch (name[0]) {
1476 case CTL_KERN:
1477 tprintf(", ");
1478 printxval(sysctl_kern, name[1], "KERN_???");
1479 ++cnt;
1480 break;
1481 case CTL_VM:
1482 tprintf(", ");
1483 printxval(sysctl_vm, name[1], "VM_???");
1484 ++cnt;
1485 break;
1486 case CTL_NET:
1487 tprintf(", ");
1488 printxval(sysctl_net, name[1], "NET_???");
1489 ++cnt;
1490
1491 if (info.nlen == 2)
1492 goto out;
1493 switch (name[1]) {
1494 case NET_CORE:
1495 tprintf(", ");
1496 printxval(sysctl_net_core, name[2],
1497 "NET_CORE_???");
1498 break;
1499 case NET_UNIX:
1500 tprintf(", ");
1501 printxval(sysctl_net_unix, name[2],
1502 "NET_UNIX_???");
1503 break;
1504 case NET_IPV4:
1505 tprintf(", ");
1506 printxval(sysctl_net_ipv4, name[2],
1507 "NET_IPV4_???");
1508
1509 if (info.nlen == 3)
1510 goto out;
1511 switch (name[2]) {
1512 case NET_IPV4_ROUTE:
1513 tprintf(", ");
1514 printxval(sysctl_net_ipv4_route,
1515 name[3],
1516 "NET_IPV4_ROUTE_???");
1517 break;
1518 case NET_IPV4_CONF:
1519 tprintf(", ");
1520 printxval(sysctl_net_ipv4_conf,
1521 name[3],
1522 "NET_IPV4_CONF_???");
1523 break;
1524 default:
1525 goto out;
1526 }
1527 break;
1528 case NET_IPV6:
1529 tprintf(", ");
1530 printxval(sysctl_net_ipv6, name[2],
1531 "NET_IPV6_???");
1532
1533 if (info.nlen == 3)
1534 goto out;
1535 switch (name[2]) {
1536 case NET_IPV6_ROUTE:
1537 tprintf(", ");
1538 printxval(sysctl_net_ipv6_route,
1539 name[3],
1540 "NET_IPV6_ROUTE_???");
1541 break;
1542 default:
1543 goto out;
1544 }
1545 break;
1546 default:
1547 goto out;
1548 }
1549 break;
1550 default:
1551 goto out;
1552 }
1553 out:
1554 while (cnt < info.nlen)
1555 tprintf(", %x", name[cnt++]);
1556 tprintf("}, %d, ", info.nlen);
1557 } else {
1558 size_t oldlen;
1559 umove(tcp, (size_t)info.oldlenp, &oldlen);
1560 if (info.nlen >= 2
1561 && ((name[0] == CTL_KERN
1562 && (name[1] == KERN_OSRELEASE
1563 || name[1] == KERN_OSTYPE
1564 || name[1] == KERN_JAVA_INTERPRETER
1565 || name[1] == KERN_JAVA_APPLETVIEWER)))) {
1566 printpath(tcp, (size_t)info.oldval);
1567 tprintf(", %d, ", oldlen);
1568 if (info.newval == 0)
1569 tprintf("NULL");
1570 else if (syserror(tcp))
1571 tprintf("%p", info.newval);
1572 else
1573 printpath(tcp, (size_t)info.newval);
1574 tprintf(", %Zd", info.newlen);
1575 } else {
1576 tprintf("%p, %d, %p, %Zd", info.oldval, oldlen,
1577 info.newval, info.newlen);
1578 }
1579 tprintf("}");
1580 }
1581 return 0;
1582}
1583#else
1584int sys_sysctl(tcp)
1585struct tcb *tcp;
1586{
1587 return printargs(tcp);
1588}
1589#endif
1590