1dea673e9SRodney W. Grimes /* 2dea673e9SRodney W. Grimes * Copyright (c) 1993 3dea673e9SRodney W. Grimes * The Regents of the University of California. All rights reserved. 4dea673e9SRodney W. Grimes * 5dea673e9SRodney W. Grimes * Redistribution and use in source and binary forms, with or without 6dea673e9SRodney W. Grimes * modification, are permitted provided that the following conditions 7dea673e9SRodney W. Grimes * are met: 8dea673e9SRodney W. Grimes * 1. Redistributions of source code must retain the above copyright 9dea673e9SRodney W. Grimes * notice, this list of conditions and the following disclaimer. 10dea673e9SRodney W. Grimes * 2. Redistributions in binary form must reproduce the above copyright 11dea673e9SRodney W. Grimes * notice, this list of conditions and the following disclaimer in the 12dea673e9SRodney W. Grimes * documentation and/or other materials provided with the distribution. 13dea673e9SRodney W. Grimes * 4. Neither the name of the University nor the names of its contributors 14dea673e9SRodney W. Grimes * may be used to endorse or promote products derived from this software 15dea673e9SRodney W. Grimes * without specific prior written permission. 16dea673e9SRodney W. Grimes * 17dea673e9SRodney W. Grimes * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 18dea673e9SRodney W. Grimes * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 19dea673e9SRodney W. Grimes * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 20dea673e9SRodney W. Grimes * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 21dea673e9SRodney W. Grimes * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 22dea673e9SRodney W. Grimes * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 23dea673e9SRodney W. Grimes * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 24dea673e9SRodney W. Grimes * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 25dea673e9SRodney W. Grimes * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 26dea673e9SRodney W. Grimes * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 27dea673e9SRodney W. Grimes * SUCH DAMAGE. 28dea673e9SRodney W. Grimes */ 29dea673e9SRodney W. Grimes 30dea673e9SRodney W. Grimes #ifndef lint 31d9b1bc77SPhilippe Charnier static const char copyright[] = 32dea673e9SRodney W. Grimes "@(#) Copyright (c) 1993\n\ 33dea673e9SRodney W. Grimes The Regents of the University of California. All rights reserved.\n"; 34dea673e9SRodney W. Grimes #endif /* not lint */ 35dea673e9SRodney W. Grimes 36dea673e9SRodney W. Grimes #ifndef lint 37d9b1bc77SPhilippe Charnier #if 0 38d9b1bc77SPhilippe Charnier static char sccsid[] = "@(#)from: sysctl.c 8.1 (Berkeley) 6/6/93"; 39d9b1bc77SPhilippe Charnier #endif 4035c13fa0SGarrett Wollman static const char rcsid[] = 417f3dea24SPeter Wemm "$FreeBSD$"; 42dea673e9SRodney W. Grimes #endif /* not lint */ 43dea673e9SRodney W. Grimes 44ce685842SBruce Evans #include <sys/param.h> 45ce685842SBruce Evans #include <sys/time.h> 46ce685842SBruce Evans #include <sys/resource.h> 47dea673e9SRodney W. Grimes #include <sys/stat.h> 48dea673e9SRodney W. Grimes #include <sys/sysctl.h> 49f7550ecfSMatthew Dillon #include <sys/vmmeter.h> 50dea673e9SRodney W. Grimes 51d9b1bc77SPhilippe Charnier #include <ctype.h> 52d9b1bc77SPhilippe Charnier #include <err.h> 53dea673e9SRodney W. Grimes #include <errno.h> 5441e419cbSDavid Malone #include <inttypes.h> 5545817aaaSDag-Erling Smørgrav #include <locale.h> 56dea673e9SRodney W. Grimes #include <stdio.h> 57dea673e9SRodney W. Grimes #include <stdlib.h> 58dea673e9SRodney W. Grimes #include <string.h> 59d9b1bc77SPhilippe Charnier #include <unistd.h> 60dea673e9SRodney W. Grimes 6124b2aa32SGavin Atkinson static int aflag, bflag, dflag, eflag, hflag, iflag; 6224b2aa32SGavin Atkinson static int Nflag, nflag, oflag, qflag, xflag, warncount; 63dea673e9SRodney W. Grimes 641d86b91cSPoul-Henning Kamp static int oidfmt(int *, int, char *, u_int *); 651d86b91cSPoul-Henning Kamp static void parse(char *); 661d86b91cSPoul-Henning Kamp static int show_var(int *, int); 671d86b91cSPoul-Henning Kamp static int sysctl_all(int *oid, int len); 681d86b91cSPoul-Henning Kamp static int name2oid(char *, int *); 69dea673e9SRodney W. Grimes 707e9c84c7SPeter Wemm static void set_T_dev_t(char *, void **, size_t *); 71a7b5ad27SEd Schouten static int set_IK(const char *, int *); 72d58f0054SPoul-Henning Kamp 731d86b91cSPoul-Henning Kamp static void 741d86b91cSPoul-Henning Kamp usage(void) 751d86b91cSPoul-Henning Kamp { 76dea673e9SRodney W. Grimes 779a2402bcSDag-Erling Smørgrav (void)fprintf(stderr, "%s\n%s\n", 78aea5fda5SGavin Atkinson "usage: sysctl [-bdehiNnoqx] name[=value] ...", 79855b068aSRuslan Ermilov " sysctl [-bdehNnoqx] -a"); 801d86b91cSPoul-Henning Kamp exit(1); 811d86b91cSPoul-Henning Kamp } 82dea673e9SRodney W. Grimes 83dea673e9SRodney W. Grimes int 841d86b91cSPoul-Henning Kamp main(int argc, char **argv) 85dea673e9SRodney W. Grimes { 861d86b91cSPoul-Henning Kamp int ch; 8745817aaaSDag-Erling Smørgrav 8845817aaaSDag-Erling Smørgrav setlocale(LC_NUMERIC, ""); 891d86b91cSPoul-Henning Kamp setbuf(stdout,0); 901d86b91cSPoul-Henning Kamp setbuf(stderr,0); 91dea673e9SRodney W. Grimes 9224b2aa32SGavin Atkinson while ((ch = getopt(argc, argv, "AabdehiNnoqwxX")) != -1) { 93dea673e9SRodney W. Grimes switch (ch) { 94ca5fac55SDag-Erling Smørgrav case 'A': 959a2402bcSDag-Erling Smørgrav /* compatibility */ 969a2402bcSDag-Erling Smørgrav aflag = oflag = 1; 97ca5fac55SDag-Erling Smørgrav break; 98ca5fac55SDag-Erling Smørgrav case 'a': 99ca5fac55SDag-Erling Smørgrav aflag = 1; 100ca5fac55SDag-Erling Smørgrav break; 101ca5fac55SDag-Erling Smørgrav case 'b': 102ca5fac55SDag-Erling Smørgrav bflag = 1; 103ca5fac55SDag-Erling Smørgrav break; 1046105f815SLuigi Rizzo case 'd': 1056105f815SLuigi Rizzo dflag = 1; 1066105f815SLuigi Rizzo break; 107d0b8aabbSAnton Berezin case 'e': 108d0b8aabbSAnton Berezin eflag = 1; 109d0b8aabbSAnton Berezin break; 11045817aaaSDag-Erling Smørgrav case 'h': 11145817aaaSDag-Erling Smørgrav hflag = 1; 11245817aaaSDag-Erling Smørgrav break; 11324b2aa32SGavin Atkinson case 'i': 11424b2aa32SGavin Atkinson iflag = 1; 11524b2aa32SGavin Atkinson break; 116ca5fac55SDag-Erling Smørgrav case 'N': 117ca5fac55SDag-Erling Smørgrav Nflag = 1; 118ca5fac55SDag-Erling Smørgrav break; 119ca5fac55SDag-Erling Smørgrav case 'n': 120ca5fac55SDag-Erling Smørgrav nflag = 1; 121ca5fac55SDag-Erling Smørgrav break; 1229a2402bcSDag-Erling Smørgrav case 'o': 1239a2402bcSDag-Erling Smørgrav oflag = 1; 1249a2402bcSDag-Erling Smørgrav break; 125f93d36fdSRobert Watson case 'q': 126f93d36fdSRobert Watson qflag = 1; 127f93d36fdSRobert Watson break; 128ca5fac55SDag-Erling Smørgrav case 'w': 1299a2402bcSDag-Erling Smørgrav /* compatibility */ 1309a2402bcSDag-Erling Smørgrav /* ignored */ 131ca5fac55SDag-Erling Smørgrav break; 132ca5fac55SDag-Erling Smørgrav case 'X': 1339a2402bcSDag-Erling Smørgrav /* compatibility */ 1349a2402bcSDag-Erling Smørgrav aflag = xflag = 1; 1359a2402bcSDag-Erling Smørgrav break; 1369a2402bcSDag-Erling Smørgrav case 'x': 1379a2402bcSDag-Erling Smørgrav xflag = 1; 138ca5fac55SDag-Erling Smørgrav break; 139ca5fac55SDag-Erling Smørgrav default: 140ca5fac55SDag-Erling Smørgrav usage(); 141dea673e9SRodney W. Grimes } 142dea673e9SRodney W. Grimes } 143dea673e9SRodney W. Grimes argc -= optind; 144dea673e9SRodney W. Grimes argv += optind; 145dea673e9SRodney W. Grimes 1469a2402bcSDag-Erling Smørgrav if (Nflag && nflag) 14781e7454aSDag-Erling Smørgrav usage(); 1489a2402bcSDag-Erling Smørgrav if (aflag && argc == 0) 1491d86b91cSPoul-Henning Kamp exit(sysctl_all(0, 0)); 150dea673e9SRodney W. Grimes if (argc == 0) 151dea673e9SRodney W. Grimes usage(); 152d9fcd86cSMike Makonnen 153d9fcd86cSMike Makonnen warncount = 0; 154dea673e9SRodney W. Grimes while (argc-- > 0) 1551d86b91cSPoul-Henning Kamp parse(*argv++); 156d9fcd86cSMike Makonnen exit(warncount); 157dea673e9SRodney W. Grimes } 158dea673e9SRodney W. Grimes 159dea673e9SRodney W. Grimes /* 160dea673e9SRodney W. Grimes * Parse a name into a MIB entry. 161dea673e9SRodney W. Grimes * Lookup and print out the MIB entry if it exists. 162dea673e9SRodney W. Grimes * Set a new value if requested. 163dea673e9SRodney W. Grimes */ 1641d86b91cSPoul-Henning Kamp static void 1651d86b91cSPoul-Henning Kamp parse(char *string) 166dea673e9SRodney W. Grimes { 1671d86b91cSPoul-Henning Kamp int len, i, j; 168dea673e9SRodney W. Grimes void *newval = 0; 1691ce1a53dSJim Pirzyk int intval; 1701ce1a53dSJim Pirzyk unsigned int uintval; 1711ce1a53dSJim Pirzyk long longval; 1721ce1a53dSJim Pirzyk unsigned long ulongval; 1731ce1a53dSJim Pirzyk size_t newsize = 0; 174dea673e9SRodney W. Grimes quad_t quadval; 175dea673e9SRodney W. Grimes int mib[CTL_MAXNAME]; 176a78d3eafSRobert Watson char *cp, *bufp, buf[BUFSIZ], *endptr, fmt[BUFSIZ]; 1771d86b91cSPoul-Henning Kamp u_int kind; 178dea673e9SRodney W. Grimes 179dea673e9SRodney W. Grimes bufp = buf; 1801d4961c0SSuleiman Souhlal if (snprintf(buf, BUFSIZ, "%s", string) >= BUFSIZ) 1811d4961c0SSuleiman Souhlal errx(1, "oid too long: '%s'", string); 182dea673e9SRodney W. Grimes if ((cp = strchr(string, '=')) != NULL) { 183dea673e9SRodney W. Grimes *strchr(buf, '=') = '\0'; 184dea673e9SRodney W. Grimes *cp++ = '\0'; 185dea673e9SRodney W. Grimes while (isspace(*cp)) 186dea673e9SRodney W. Grimes cp++; 187dea673e9SRodney W. Grimes newval = cp; 188dea673e9SRodney W. Grimes newsize = strlen(cp); 189dea673e9SRodney W. Grimes } 1901d86b91cSPoul-Henning Kamp len = name2oid(bufp, mib); 1911d86b91cSPoul-Henning Kamp 192f93d36fdSRobert Watson if (len < 0) { 19324b2aa32SGavin Atkinson if (iflag) 19424b2aa32SGavin Atkinson return; 195f93d36fdSRobert Watson if (qflag) 196f93d36fdSRobert Watson exit(1); 197f93d36fdSRobert Watson else 198d9b1bc77SPhilippe Charnier errx(1, "unknown oid '%s'", bufp); 199f93d36fdSRobert Watson } 2001d86b91cSPoul-Henning Kamp 201d58f0054SPoul-Henning Kamp if (oidfmt(mib, len, fmt, &kind)) 202d9b1bc77SPhilippe Charnier err(1, "couldn't find format of oid '%s'", bufp); 2031d86b91cSPoul-Henning Kamp 2049a2402bcSDag-Erling Smørgrav if (newval == NULL) { 2051d86b91cSPoul-Henning Kamp if ((kind & CTLTYPE) == CTLTYPE_NODE) { 206b2680e20SMatthew N. Dodd if (dflag) { 207b2680e20SMatthew N. Dodd i = show_var(mib, len); 208b2680e20SMatthew N. Dodd if (!i && !bflag) 209b2680e20SMatthew N. Dodd putchar('\n'); 210b2680e20SMatthew N. Dodd } 2111d86b91cSPoul-Henning Kamp sysctl_all(mib, len); 2121d86b91cSPoul-Henning Kamp } else { 2131d86b91cSPoul-Henning Kamp i = show_var(mib, len); 2141d86b91cSPoul-Henning Kamp if (!i && !bflag) 2151d86b91cSPoul-Henning Kamp putchar('\n'); 216dea673e9SRodney W. Grimes } 2171d86b91cSPoul-Henning Kamp } else { 2181d86b91cSPoul-Henning Kamp if ((kind & CTLTYPE) == CTLTYPE_NODE) 2191d86b91cSPoul-Henning Kamp errx(1, "oid '%s' isn't a leaf node", bufp); 220dea673e9SRodney W. Grimes 221ac8711d2SMike Silbersack if (!(kind & CTLFLAG_WR)) { 2229b4b73b7SMike Silbersack if (kind & CTLFLAG_TUN) { 223ac8711d2SMike Silbersack warnx("oid '%s' is a read only tunable", bufp); 224ac8711d2SMike Silbersack errx(1, "Tunable values are set in /boot/loader.conf"); 2259b4b73b7SMike Silbersack } else { 2261d86b91cSPoul-Henning Kamp errx(1, "oid '%s' is read only", bufp); 2279b4b73b7SMike Silbersack } 228ac8711d2SMike Silbersack } 229dea673e9SRodney W. Grimes 230a78d3eafSRobert Watson if ((kind & CTLTYPE) == CTLTYPE_INT || 231a78d3eafSRobert Watson (kind & CTLTYPE) == CTLTYPE_UINT || 232a78d3eafSRobert Watson (kind & CTLTYPE) == CTLTYPE_LONG || 2334d90830fSDima Dorfman (kind & CTLTYPE) == CTLTYPE_ULONG || 2344d90830fSDima Dorfman (kind & CTLTYPE) == CTLTYPE_QUAD) { 235a78d3eafSRobert Watson if (strlen(newval) == 0) 236a78d3eafSRobert Watson errx(1, "empty numeric value"); 237a78d3eafSRobert Watson } 238a78d3eafSRobert Watson 2391d86b91cSPoul-Henning Kamp switch (kind & CTLTYPE) { 240dea673e9SRodney W. Grimes case CTLTYPE_INT: 241d45564dcSHajimu UMEMOTO if (strcmp(fmt, "IK") == 0) { 24221e1f596SDavid Malone if (!set_IK(newval, &intval)) 243d45564dcSHajimu UMEMOTO errx(1, "invalid value '%s'", 244fd8c668aSDavid Malone (char *)newval); 245d45564dcSHajimu UMEMOTO } else { 246d45564dcSHajimu UMEMOTO intval = (int)strtol(newval, &endptr, 247d45564dcSHajimu UMEMOTO 0); 248a78d3eafSRobert Watson if (endptr == newval || *endptr != '\0') 249a78d3eafSRobert Watson errx(1, "invalid integer '%s'", 250fd8c668aSDavid Malone (char *)newval); 251d45564dcSHajimu UMEMOTO } 252dea673e9SRodney W. Grimes newval = &intval; 25331fb4661SDima Dorfman newsize = sizeof(intval); 254dea673e9SRodney W. Grimes break; 2551ce1a53dSJim Pirzyk case CTLTYPE_UINT: 256a78d3eafSRobert Watson uintval = (int) strtoul(newval, &endptr, 0); 257a78d3eafSRobert Watson if (endptr == newval || *endptr != '\0') 258a78d3eafSRobert Watson errx(1, "invalid unsigned integer '%s'", 259fd8c668aSDavid Malone (char *)newval); 2601ce1a53dSJim Pirzyk newval = &uintval; 26121e1f596SDavid Malone newsize = sizeof(uintval); 2621ce1a53dSJim Pirzyk break; 2631ce1a53dSJim Pirzyk case CTLTYPE_LONG: 264a78d3eafSRobert Watson longval = strtol(newval, &endptr, 0); 265a78d3eafSRobert Watson if (endptr == newval || *endptr != '\0') 266a78d3eafSRobert Watson errx(1, "invalid long integer '%s'", 267fd8c668aSDavid Malone (char *)newval); 2681ce1a53dSJim Pirzyk newval = &longval; 26921e1f596SDavid Malone newsize = sizeof(longval); 2701ce1a53dSJim Pirzyk break; 2711ce1a53dSJim Pirzyk case CTLTYPE_ULONG: 272a78d3eafSRobert Watson ulongval = strtoul(newval, &endptr, 0); 273a78d3eafSRobert Watson if (endptr == newval || *endptr != '\0') 274a78d3eafSRobert Watson errx(1, "invalid unsigned long integer" 275fd8c668aSDavid Malone " '%s'", (char *)newval); 2761ce1a53dSJim Pirzyk newval = &ulongval; 27721e1f596SDavid Malone newsize = sizeof(ulongval); 2781d86b91cSPoul-Henning Kamp break; 2791d86b91cSPoul-Henning Kamp case CTLTYPE_STRING: 2801d86b91cSPoul-Henning Kamp break; 281dea673e9SRodney W. Grimes case CTLTYPE_QUAD: 2826d7a8f6cSUlrich Spörlein quadval = strtoq(newval, &endptr, 0); 2836d7a8f6cSUlrich Spörlein if (endptr == newval || *endptr != '\0') 2846d7a8f6cSUlrich Spörlein errx(1, "invalid quad integer" 2856d7a8f6cSUlrich Spörlein " '%s'", (char *)newval); 286dea673e9SRodney W. Grimes newval = &quadval; 28731fb4661SDima Dorfman newsize = sizeof(quadval); 288dea673e9SRodney W. Grimes break; 289d58f0054SPoul-Henning Kamp case CTLTYPE_OPAQUE: 290d58f0054SPoul-Henning Kamp if (strcmp(fmt, "T,dev_t") == 0) { 29121e1f596SDavid Malone set_T_dev_t (newval, &newval, &newsize); 292d58f0054SPoul-Henning Kamp break; 293d58f0054SPoul-Henning Kamp } 294d58f0054SPoul-Henning Kamp /* FALLTHROUGH */ 2951d86b91cSPoul-Henning Kamp default: 2961d86b91cSPoul-Henning Kamp errx(1, "oid '%s' is type %d," 29714b94d04SJohn Polstra " cannot set that", bufp, 29814b94d04SJohn Polstra kind & CTLTYPE); 299dea673e9SRodney W. Grimes } 3001d86b91cSPoul-Henning Kamp 3011d86b91cSPoul-Henning Kamp i = show_var(mib, len); 3021d86b91cSPoul-Henning Kamp if (sysctl(mib, len, 0, 0, newval, newsize) == -1) { 3031d86b91cSPoul-Henning Kamp if (!i && !bflag) 3041d86b91cSPoul-Henning Kamp putchar('\n'); 305dea673e9SRodney W. Grimes switch (errno) { 306dea673e9SRodney W. Grimes case EOPNOTSUPP: 307d9b1bc77SPhilippe Charnier errx(1, "%s: value is not available", 3081d86b91cSPoul-Henning Kamp string); 309dea673e9SRodney W. Grimes case ENOTDIR: 310d9b1bc77SPhilippe Charnier errx(1, "%s: specification is incomplete", 311dea673e9SRodney W. Grimes string); 312dea673e9SRodney W. Grimes case ENOMEM: 313d9b1bc77SPhilippe Charnier errx(1, "%s: type is unknown to this program", 314dea673e9SRodney W. Grimes string); 315dea673e9SRodney W. Grimes default: 316d9b1bc77SPhilippe Charnier warn("%s", string); 317d9fcd86cSMike Makonnen warncount++; 318dea673e9SRodney W. Grimes return; 319dea673e9SRodney W. Grimes } 320dea673e9SRodney W. Grimes } 3211d86b91cSPoul-Henning Kamp if (!bflag) 3221d86b91cSPoul-Henning Kamp printf(" -> "); 3231d86b91cSPoul-Henning Kamp i = nflag; 3241d86b91cSPoul-Henning Kamp nflag = 1; 3251d86b91cSPoul-Henning Kamp j = show_var(mib, len); 3261d86b91cSPoul-Henning Kamp if (!j && !bflag) 3271d86b91cSPoul-Henning Kamp putchar('\n'); 3281d86b91cSPoul-Henning Kamp nflag = i; 329dea673e9SRodney W. Grimes } 330dea673e9SRodney W. Grimes } 331dea673e9SRodney W. Grimes 3321d86b91cSPoul-Henning Kamp /* These functions will dump out various interesting structures. */ 333dea673e9SRodney W. Grimes 3341d86b91cSPoul-Henning Kamp static int 3351d86b91cSPoul-Henning Kamp S_clockinfo(int l2, void *p) 3361d86b91cSPoul-Henning Kamp { 3371d86b91cSPoul-Henning Kamp struct clockinfo *ci = (struct clockinfo*)p; 33821e1f596SDavid Malone 339996076bbSAlfred Perlstein if (l2 != sizeof(*ci)) { 3406d7a8f6cSUlrich Spörlein warnx("S_clockinfo %d != %zu", l2, sizeof(*ci)); 3416b6b665bSBruce Evans return (1); 342996076bbSAlfred Perlstein } 34345817aaaSDag-Erling Smørgrav printf(hflag ? "{ hz = %'d, tick = %'d, profhz = %'d, stathz = %'d }" : 34445817aaaSDag-Erling Smørgrav "{ hz = %d, tick = %d, profhz = %d, stathz = %d }", 345b35c8f28SPoul-Henning Kamp ci->hz, ci->tick, ci->profhz, ci->stathz); 3461d86b91cSPoul-Henning Kamp return (0); 347dea673e9SRodney W. Grimes } 348dea673e9SRodney W. Grimes 3491d86b91cSPoul-Henning Kamp static int 3501d86b91cSPoul-Henning Kamp S_loadavg(int l2, void *p) 3511d86b91cSPoul-Henning Kamp { 3521d86b91cSPoul-Henning Kamp struct loadavg *tv = (struct loadavg*)p; 3531d86b91cSPoul-Henning Kamp 354996076bbSAlfred Perlstein if (l2 != sizeof(*tv)) { 3556d7a8f6cSUlrich Spörlein warnx("S_loadavg %d != %zu", l2, sizeof(*tv)); 3566b6b665bSBruce Evans return (1); 357996076bbSAlfred Perlstein } 35845817aaaSDag-Erling Smørgrav printf(hflag ? "{ %'.2f %'.2f %'.2f }" : "{ %.2f %.2f %.2f }", 3591d86b91cSPoul-Henning Kamp (double)tv->ldavg[0]/(double)tv->fscale, 3601d86b91cSPoul-Henning Kamp (double)tv->ldavg[1]/(double)tv->fscale, 3611d86b91cSPoul-Henning Kamp (double)tv->ldavg[2]/(double)tv->fscale); 3621d86b91cSPoul-Henning Kamp return (0); 363dea673e9SRodney W. Grimes } 364dea673e9SRodney W. Grimes 3651d86b91cSPoul-Henning Kamp static int 3661d86b91cSPoul-Henning Kamp S_timeval(int l2, void *p) 3671d86b91cSPoul-Henning Kamp { 3681d86b91cSPoul-Henning Kamp struct timeval *tv = (struct timeval*)p; 369c2deb608SBruce Evans time_t tv_sec; 3701d86b91cSPoul-Henning Kamp char *p1, *p2; 371dea673e9SRodney W. Grimes 372996076bbSAlfred Perlstein if (l2 != sizeof(*tv)) { 3736d7a8f6cSUlrich Spörlein warnx("S_timeval %d != %zu", l2, sizeof(*tv)); 3746b6b665bSBruce Evans return (1); 375996076bbSAlfred Perlstein } 376db87e2dcSJohn Hay printf(hflag ? "{ sec = %'jd, usec = %'ld } " : 377db87e2dcSJohn Hay "{ sec = %jd, usec = %ld } ", 378db87e2dcSJohn Hay (intmax_t)tv->tv_sec, tv->tv_usec); 379c2deb608SBruce Evans tv_sec = tv->tv_sec; 380c2deb608SBruce Evans p1 = strdup(ctime(&tv_sec)); 3811d86b91cSPoul-Henning Kamp for (p2=p1; *p2 ; p2++) 3821d86b91cSPoul-Henning Kamp if (*p2 == '\n') 3831d86b91cSPoul-Henning Kamp *p2 = '\0'; 3841d86b91cSPoul-Henning Kamp fputs(p1, stdout); 3851d86b91cSPoul-Henning Kamp return (0); 3861d86b91cSPoul-Henning Kamp } 3871d86b91cSPoul-Henning Kamp 3881d86b91cSPoul-Henning Kamp static int 389f7550ecfSMatthew Dillon S_vmtotal(int l2, void *p) 390f7550ecfSMatthew Dillon { 391f7550ecfSMatthew Dillon struct vmtotal *v = (struct vmtotal *)p; 392654e22e7SMatthew Dillon int pageKilo = getpagesize() / 1024; 393f7550ecfSMatthew Dillon 394f7550ecfSMatthew Dillon if (l2 != sizeof(*v)) { 3956d7a8f6cSUlrich Spörlein warnx("S_vmtotal %d != %zu", l2, sizeof(*v)); 3966b6b665bSBruce Evans return (1); 397f7550ecfSMatthew Dillon } 398f7550ecfSMatthew Dillon 399654e22e7SMatthew Dillon printf( 400654e22e7SMatthew Dillon "\nSystem wide totals computed every five seconds:" 401654e22e7SMatthew Dillon " (values in kilobytes)\n"); 402f7550ecfSMatthew Dillon printf("===============================================\n"); 403654e22e7SMatthew Dillon printf( 404bad4d172SRuslan Ermilov "Processes:\t\t(RUNQ: %hd Disk Wait: %hd Page Wait: " 405bad4d172SRuslan Ermilov "%hd Sleep: %hd)\n", 406f7550ecfSMatthew Dillon v->t_rq, v->t_dw, v->t_pw, v->t_sl); 407654e22e7SMatthew Dillon printf( 408bad4d172SRuslan Ermilov "Virtual Memory:\t\t(Total: %dK, Active %dK)\n", 409bad4d172SRuslan Ermilov v->t_vm * pageKilo, v->t_avm * pageKilo); 410bad4d172SRuslan Ermilov printf("Real Memory:\t\t(Total: %dK Active %dK)\n", 411bad4d172SRuslan Ermilov v->t_rm * pageKilo, v->t_arm * pageKilo); 412bad4d172SRuslan Ermilov printf("Shared Virtual Memory:\t(Total: %dK Active: %dK)\n", 413bad4d172SRuslan Ermilov v->t_vmshr * pageKilo, v->t_avmshr * pageKilo); 414bad4d172SRuslan Ermilov printf("Shared Real Memory:\t(Total: %dK Active: %dK)\n", 415bad4d172SRuslan Ermilov v->t_rmshr * pageKilo, v->t_armshr * pageKilo); 416bad4d172SRuslan Ermilov printf("Free Memory Pages:\t%dK\n", v->t_free * pageKilo); 417f7550ecfSMatthew Dillon 418f7550ecfSMatthew Dillon return (0); 419f7550ecfSMatthew Dillon } 420f7550ecfSMatthew Dillon 421f7550ecfSMatthew Dillon static int 4221d86b91cSPoul-Henning Kamp T_dev_t(int l2, void *p) 4231d86b91cSPoul-Henning Kamp { 4241d86b91cSPoul-Henning Kamp dev_t *d = (dev_t *)p; 42521e1f596SDavid Malone 426996076bbSAlfred Perlstein if (l2 != sizeof(*d)) { 4276d7a8f6cSUlrich Spörlein warnx("T_dev_T %d != %zu", l2, sizeof(*d)); 4286b6b665bSBruce Evans return (1); 429996076bbSAlfred Perlstein } 4308f1c21a6SEd Schouten printf("%s", devname(*d, S_IFCHR)); 4311d86b91cSPoul-Henning Kamp return (0); 4321d86b91cSPoul-Henning Kamp } 4331d86b91cSPoul-Henning Kamp 434d58f0054SPoul-Henning Kamp static void 4357e9c84c7SPeter Wemm set_T_dev_t(char *path, void **val, size_t *size) 436d58f0054SPoul-Henning Kamp { 437d58f0054SPoul-Henning Kamp static struct stat statb; 438d58f0054SPoul-Henning Kamp 439d58f0054SPoul-Henning Kamp if (strcmp(path, "none") && strcmp(path, "off")) { 440d58f0054SPoul-Henning Kamp int rc = stat (path, &statb); 441d58f0054SPoul-Henning Kamp if (rc) { 442d58f0054SPoul-Henning Kamp err(1, "cannot stat %s", path); 443d58f0054SPoul-Henning Kamp } 444d58f0054SPoul-Henning Kamp 445d58f0054SPoul-Henning Kamp if (!S_ISCHR(statb.st_mode)) { 446d58f0054SPoul-Henning Kamp errx(1, "must specify a device special file."); 447d58f0054SPoul-Henning Kamp } 448d58f0054SPoul-Henning Kamp } else { 449d58f0054SPoul-Henning Kamp statb.st_rdev = NODEV; 450d58f0054SPoul-Henning Kamp } 45121e1f596SDavid Malone *val = (void *) &statb.st_rdev; 45221e1f596SDavid Malone *size = sizeof(statb.st_rdev); 453d58f0054SPoul-Henning Kamp } 454d58f0054SPoul-Henning Kamp 455d45564dcSHajimu UMEMOTO static int 456a7b5ad27SEd Schouten set_IK(const char *str, int *val) 457d45564dcSHajimu UMEMOTO { 458d45564dcSHajimu UMEMOTO float temp; 459d45564dcSHajimu UMEMOTO int len, kelv; 460a7b5ad27SEd Schouten const char *p; 461a7b5ad27SEd Schouten char *endptr; 462d45564dcSHajimu UMEMOTO 463d45564dcSHajimu UMEMOTO if ((len = strlen(str)) == 0) 464d45564dcSHajimu UMEMOTO return (0); 465d45564dcSHajimu UMEMOTO p = &str[len - 1]; 466d45564dcSHajimu UMEMOTO if (*p == 'C' || *p == 'F') { 467d45564dcSHajimu UMEMOTO temp = strtof(str, &endptr); 468a7b5ad27SEd Schouten if (endptr == str || endptr != p) 469d45564dcSHajimu UMEMOTO return (0); 470d45564dcSHajimu UMEMOTO if (*p == 'F') 471d45564dcSHajimu UMEMOTO temp = (temp - 32) * 5 / 9; 472d45564dcSHajimu UMEMOTO kelv = temp * 10 + 2732; 473d45564dcSHajimu UMEMOTO } else { 474d45564dcSHajimu UMEMOTO kelv = (int)strtol(str, &endptr, 10); 475d45564dcSHajimu UMEMOTO if (endptr == str || *endptr != '\0') 476d45564dcSHajimu UMEMOTO return (0); 477d45564dcSHajimu UMEMOTO } 478d45564dcSHajimu UMEMOTO *val = kelv; 479d45564dcSHajimu UMEMOTO return (1); 480d45564dcSHajimu UMEMOTO } 481d45564dcSHajimu UMEMOTO 4821d86b91cSPoul-Henning Kamp /* 4831d86b91cSPoul-Henning Kamp * These functions uses a presently undocumented interface to the kernel 4841d86b91cSPoul-Henning Kamp * to walk the tree and get the type so it can print the value. 4851d86b91cSPoul-Henning Kamp * This interface is under work and consideration, and should probably 4861d86b91cSPoul-Henning Kamp * be killed with a big axe by the first person who can find the time. 4871d86b91cSPoul-Henning Kamp * (be aware though, that the proper interface isn't as obvious as it 4881d86b91cSPoul-Henning Kamp * may seem, there are various conflicting requirements. 4891d86b91cSPoul-Henning Kamp */ 4901d86b91cSPoul-Henning Kamp 4911d86b91cSPoul-Henning Kamp static int 4921d86b91cSPoul-Henning Kamp name2oid(char *name, int *oidp) 4931d86b91cSPoul-Henning Kamp { 4941d86b91cSPoul-Henning Kamp int oid[2]; 495dbf9b92fSDoug Rabson int i; 496dbf9b92fSDoug Rabson size_t j; 4971d86b91cSPoul-Henning Kamp 4981d86b91cSPoul-Henning Kamp oid[0] = 0; 4991d86b91cSPoul-Henning Kamp oid[1] = 3; 5001d86b91cSPoul-Henning Kamp 5011d86b91cSPoul-Henning Kamp j = CTL_MAXNAME * sizeof(int); 5021d86b91cSPoul-Henning Kamp i = sysctl(oid, 2, oidp, &j, name, strlen(name)); 5031d86b91cSPoul-Henning Kamp if (i < 0) 50421e1f596SDavid Malone return (i); 5051d86b91cSPoul-Henning Kamp j /= sizeof(int); 5061d86b91cSPoul-Henning Kamp return (j); 5071d86b91cSPoul-Henning Kamp } 5081d86b91cSPoul-Henning Kamp 5091d86b91cSPoul-Henning Kamp static int 5101d86b91cSPoul-Henning Kamp oidfmt(int *oid, int len, char *fmt, u_int *kind) 5111d86b91cSPoul-Henning Kamp { 5121d86b91cSPoul-Henning Kamp int qoid[CTL_MAXNAME+2]; 5131d86b91cSPoul-Henning Kamp u_char buf[BUFSIZ]; 514dbf9b92fSDoug Rabson int i; 515dbf9b92fSDoug Rabson size_t j; 5161d86b91cSPoul-Henning Kamp 5171d86b91cSPoul-Henning Kamp qoid[0] = 0; 5181d86b91cSPoul-Henning Kamp qoid[1] = 4; 5191d86b91cSPoul-Henning Kamp memcpy(qoid + 2, oid, len * sizeof(int)); 5201d86b91cSPoul-Henning Kamp 52131fb4661SDima Dorfman j = sizeof(buf); 5221d86b91cSPoul-Henning Kamp i = sysctl(qoid, len + 2, buf, &j, 0, 0); 5231d86b91cSPoul-Henning Kamp if (i) 5246d7a8f6cSUlrich Spörlein err(1, "sysctl fmt %d %zu %d", i, j, errno); 5251d86b91cSPoul-Henning Kamp 5261d86b91cSPoul-Henning Kamp if (kind) 5271d86b91cSPoul-Henning Kamp *kind = *(u_int *)buf; 5281d86b91cSPoul-Henning Kamp 5291d86b91cSPoul-Henning Kamp if (fmt) 5301d86b91cSPoul-Henning Kamp strcpy(fmt, (char *)(buf + sizeof(u_int))); 53121e1f596SDavid Malone return (0); 5321d86b91cSPoul-Henning Kamp } 5331d86b91cSPoul-Henning Kamp 53460cf2c12SLuigi Rizzo /* 5351d86b91cSPoul-Henning Kamp * This formats and outputs the value of one variable 5361d86b91cSPoul-Henning Kamp * 5371d86b91cSPoul-Henning Kamp * Returns zero if anything was actually output. 5381d86b91cSPoul-Henning Kamp * Returns one if didn't know what to do with this. 5391d86b91cSPoul-Henning Kamp * Return minus one if we had errors. 5401d86b91cSPoul-Henning Kamp */ 5411d86b91cSPoul-Henning Kamp 5421d86b91cSPoul-Henning Kamp static int 5431d86b91cSPoul-Henning Kamp show_var(int *oid, int nlen) 5441d86b91cSPoul-Henning Kamp { 545ccf25977SRuslan Ermilov u_char buf[BUFSIZ], *val, *oval, *p; 546fd8c668aSDavid Malone char name[BUFSIZ], *fmt; 547fd8c668aSDavid Malone const char *sep, *sep1; 5481d86b91cSPoul-Henning Kamp int qoid[CTL_MAXNAME+2]; 54921e1f596SDavid Malone uintmax_t umv; 55021e1f596SDavid Malone intmax_t mv; 551e37d2b30SDavid Malone int i, hexlen; 55241e419cbSDavid Malone size_t intlen; 553dbf9b92fSDoug Rabson size_t j, len; 5541d86b91cSPoul-Henning Kamp u_int kind; 555a89ab9bbSDag-Erling Smørgrav int (*func)(int, void *); 5561d86b91cSPoul-Henning Kamp 5576d7a8f6cSUlrich Spörlein /* Silence GCC. */ 5586d7a8f6cSUlrich Spörlein umv = mv = intlen = 0; 5596d7a8f6cSUlrich Spörlein 5609f98e452SMatthew N. Dodd bzero(buf, BUFSIZ); 5619f98e452SMatthew N. Dodd bzero(name, BUFSIZ); 56281e7454aSDag-Erling Smørgrav qoid[0] = 0; 56381e7454aSDag-Erling Smørgrav memcpy(qoid + 2, oid, nlen * sizeof(int)); 56481e7454aSDag-Erling Smørgrav 56581e7454aSDag-Erling Smørgrav qoid[1] = 1; 56631fb4661SDima Dorfman j = sizeof(name); 56781e7454aSDag-Erling Smørgrav i = sysctl(qoid, nlen + 2, name, &j, 0, 0); 56881e7454aSDag-Erling Smørgrav if (i || !j) 5696d7a8f6cSUlrich Spörlein err(1, "sysctl name %d %zu %d", i, j, errno); 57081e7454aSDag-Erling Smørgrav 571ca5fac55SDag-Erling Smørgrav if (Nflag) { 572ca5fac55SDag-Erling Smørgrav printf("%s", name); 573ca5fac55SDag-Erling Smørgrav return (0); 574ca5fac55SDag-Erling Smørgrav } 575ca5fac55SDag-Erling Smørgrav 576d0b8aabbSAnton Berezin if (eflag) 577d0b8aabbSAnton Berezin sep = "="; 578d0b8aabbSAnton Berezin else 579d0b8aabbSAnton Berezin sep = ": "; 580d0b8aabbSAnton Berezin 5816105f815SLuigi Rizzo if (dflag) { /* just print description */ 5826105f815SLuigi Rizzo qoid[1] = 5; 5836105f815SLuigi Rizzo j = sizeof(buf); 5846105f815SLuigi Rizzo i = sysctl(qoid, nlen + 2, buf, &j, 0, 0); 5856105f815SLuigi Rizzo if (!nflag) 5866105f815SLuigi Rizzo printf("%s%s", name, sep); 5876105f815SLuigi Rizzo printf("%s", buf); 5886105f815SLuigi Rizzo return (0); 5896105f815SLuigi Rizzo } 5901d86b91cSPoul-Henning Kamp /* find an estimate of how much we need for this var */ 5911d86b91cSPoul-Henning Kamp j = 0; 5921d86b91cSPoul-Henning Kamp i = sysctl(oid, nlen, 0, &j, 0, 0); 5931d86b91cSPoul-Henning Kamp j += j; /* we want to be sure :-) */ 5941d86b91cSPoul-Henning Kamp 595ccf25977SRuslan Ermilov val = oval = malloc(j + 1); 596ccf25977SRuslan Ermilov if (val == NULL) { 597ccf25977SRuslan Ermilov warnx("malloc failed"); 5986b6b665bSBruce Evans return (1); 599ccf25977SRuslan Ermilov } 6001d86b91cSPoul-Henning Kamp len = j; 6011d86b91cSPoul-Henning Kamp i = sysctl(oid, nlen, val, &len, 0, 0); 602ccf25977SRuslan Ermilov if (i || !len) { 603ccf25977SRuslan Ermilov free(oval); 6041d86b91cSPoul-Henning Kamp return (1); 605ccf25977SRuslan Ermilov } 6061d86b91cSPoul-Henning Kamp 6071d86b91cSPoul-Henning Kamp if (bflag) { 6081d86b91cSPoul-Henning Kamp fwrite(val, 1, len, stdout); 609ccf25977SRuslan Ermilov free(oval); 6101d86b91cSPoul-Henning Kamp return (0); 6111d86b91cSPoul-Henning Kamp } 61276d3dc52SAndrey A. Chernov val[len] = '\0'; 613d58f0054SPoul-Henning Kamp fmt = buf; 614d58f0054SPoul-Henning Kamp oidfmt(oid, nlen, fmt, &kind); 6151d86b91cSPoul-Henning Kamp p = val; 6161d86b91cSPoul-Henning Kamp switch (*fmt) { 6171d86b91cSPoul-Henning Kamp case 'A': 6181d86b91cSPoul-Henning Kamp if (!nflag) 619d0b8aabbSAnton Berezin printf("%s%s", name, sep); 6206d7a8f6cSUlrich Spörlein printf("%.*s", (int)len, p); 621ccf25977SRuslan Ermilov free(oval); 6221d86b91cSPoul-Henning Kamp return (0); 6231d86b91cSPoul-Henning Kamp 6241d86b91cSPoul-Henning Kamp case 'I': 625dbf9b92fSDoug Rabson case 'L': 62641e419cbSDavid Malone case 'Q': 627dbf9b92fSDoug Rabson if (!nflag) 628d0b8aabbSAnton Berezin printf("%s%s", name, sep); 62941e419cbSDavid Malone switch (*fmt) { 630e37d2b30SDavid Malone case 'I': intlen = sizeof(int); break; 631e37d2b30SDavid Malone case 'L': intlen = sizeof(long); break; 632e37d2b30SDavid Malone case 'Q': intlen = sizeof(quad_t); break; 63341e419cbSDavid Malone } 634e37d2b30SDavid Malone hexlen = 2 + (intlen * CHAR_BIT + 3) / 4; 635fd8c668aSDavid Malone sep1 = ""; 63641e419cbSDavid Malone while (len >= intlen) { 63741e419cbSDavid Malone switch (*fmt) { 63841e419cbSDavid Malone case 'I': 639e37d2b30SDavid Malone umv = *(u_int *)p; 640e37d2b30SDavid Malone mv = *(int *)p; 64141e419cbSDavid Malone break; 64241e419cbSDavid Malone case 'L': 643e37d2b30SDavid Malone umv = *(u_long *)p; 644e37d2b30SDavid Malone mv = *(long *)p; 64541e419cbSDavid Malone break; 64641e419cbSDavid Malone case 'Q': 647e37d2b30SDavid Malone umv = *(u_quad_t *)p; 648e37d2b30SDavid Malone mv = *(quad_t *)p; 64941e419cbSDavid Malone break; 65041e419cbSDavid Malone } 651fd8c668aSDavid Malone fputs(sep1, stdout); 65241e419cbSDavid Malone if (fmt[1] == 'U') 65321e1f596SDavid Malone printf(hflag ? "%'ju" : "%ju", umv); 65441e419cbSDavid Malone else if (fmt[1] == 'X') 655e37d2b30SDavid Malone printf("%#0*jx", hexlen, umv); 65641e419cbSDavid Malone else if (fmt[1] == 'K') { 657e37d2b30SDavid Malone if (mv < 0) 65821e1f596SDavid Malone printf("%jd", mv); 6599701cd40SJohn Baldwin else 66021e1f596SDavid Malone printf("%.1fC", (mv - 2732.0) / 10); 661c591d41fSPeter Wemm } else 662fd8c668aSDavid Malone printf(hflag ? "%'jd" : "%jd", mv); 663fd8c668aSDavid Malone sep1 = " "; 66441e419cbSDavid Malone len -= intlen; 66541e419cbSDavid Malone p += intlen; 666aa02fb57SPoul-Henning Kamp } 667ccf25977SRuslan Ermilov free(oval); 668dbf9b92fSDoug Rabson return (0); 669dbf9b92fSDoug Rabson 670dbf9b92fSDoug Rabson case 'P': 671dbf9b92fSDoug Rabson if (!nflag) 672d0b8aabbSAnton Berezin printf("%s%s", name, sep); 673dbf9b92fSDoug Rabson printf("%p", *(void **)p); 674ccf25977SRuslan Ermilov free(oval); 675dbf9b92fSDoug Rabson return (0); 676dbf9b92fSDoug Rabson 6771d86b91cSPoul-Henning Kamp case 'T': 6781d86b91cSPoul-Henning Kamp case 'S': 6791d86b91cSPoul-Henning Kamp i = 0; 680a89ab9bbSDag-Erling Smørgrav if (strcmp(fmt, "S,clockinfo") == 0) 681a89ab9bbSDag-Erling Smørgrav func = S_clockinfo; 682a89ab9bbSDag-Erling Smørgrav else if (strcmp(fmt, "S,timeval") == 0) 683a89ab9bbSDag-Erling Smørgrav func = S_timeval; 684a89ab9bbSDag-Erling Smørgrav else if (strcmp(fmt, "S,loadavg") == 0) 685a89ab9bbSDag-Erling Smørgrav func = S_loadavg; 686f7550ecfSMatthew Dillon else if (strcmp(fmt, "S,vmtotal") == 0) 687f7550ecfSMatthew Dillon func = S_vmtotal; 688a89ab9bbSDag-Erling Smørgrav else if (strcmp(fmt, "T,dev_t") == 0) 689a89ab9bbSDag-Erling Smørgrav func = T_dev_t; 690a89ab9bbSDag-Erling Smørgrav else 691a89ab9bbSDag-Erling Smørgrav func = NULL; 6921d86b91cSPoul-Henning Kamp if (func) { 6931d86b91cSPoul-Henning Kamp if (!nflag) 694d0b8aabbSAnton Berezin printf("%s%s", name, sep); 69548cd487aSHartmut Brandt i = (*func)(len, p); 696ccf25977SRuslan Ermilov free(oval); 69748cd487aSHartmut Brandt return (i); 6981d86b91cSPoul-Henning Kamp } 6991d86b91cSPoul-Henning Kamp /* FALLTHROUGH */ 700dea673e9SRodney W. Grimes default: 701ccf25977SRuslan Ermilov if (!oflag && !xflag) { 702ccf25977SRuslan Ermilov free(oval); 7031d86b91cSPoul-Henning Kamp return (1); 704ccf25977SRuslan Ermilov } 7051d86b91cSPoul-Henning Kamp if (!nflag) 706d0b8aabbSAnton Berezin printf("%s%s", name, sep); 7076d7a8f6cSUlrich Spörlein printf("Format:%s Length:%zu Dump:0x", fmt, len); 708a89ab9bbSDag-Erling Smørgrav while (len-- && (xflag || p < val + 16)) 7091d86b91cSPoul-Henning Kamp printf("%02x", *p++); 710a89ab9bbSDag-Erling Smørgrav if (!xflag && len > 16) 7111d86b91cSPoul-Henning Kamp printf("..."); 712ccf25977SRuslan Ermilov free(oval); 7131d86b91cSPoul-Henning Kamp return (0); 7141d86b91cSPoul-Henning Kamp } 715ccf25977SRuslan Ermilov free(oval); 7161d86b91cSPoul-Henning Kamp return (1); 717dea673e9SRodney W. Grimes } 718dea673e9SRodney W. Grimes 7191d86b91cSPoul-Henning Kamp static int 7201d86b91cSPoul-Henning Kamp sysctl_all(int *oid, int len) 721dea673e9SRodney W. Grimes { 7221d86b91cSPoul-Henning Kamp int name1[22], name2[22]; 723dbf9b92fSDoug Rabson int i, j; 724dbf9b92fSDoug Rabson size_t l1, l2; 725dea673e9SRodney W. Grimes 7261d86b91cSPoul-Henning Kamp name1[0] = 0; 7271d86b91cSPoul-Henning Kamp name1[1] = 2; 7281d86b91cSPoul-Henning Kamp l1 = 2; 7291d86b91cSPoul-Henning Kamp if (len) { 7301d86b91cSPoul-Henning Kamp memcpy(name1+2, oid, len * sizeof(int)); 7311d86b91cSPoul-Henning Kamp l1 += len; 7321d86b91cSPoul-Henning Kamp } else { 7331d86b91cSPoul-Henning Kamp name1[2] = 1; 7341d86b91cSPoul-Henning Kamp l1++; 7351d86b91cSPoul-Henning Kamp } 736a89ab9bbSDag-Erling Smørgrav for (;;) { 73731fb4661SDima Dorfman l2 = sizeof(name2); 7381d86b91cSPoul-Henning Kamp j = sysctl(name1, l1, name2, &l2, 0, 0); 739c1160fe4SBill Fumerola if (j < 0) { 7401d86b91cSPoul-Henning Kamp if (errno == ENOENT) 74121e1f596SDavid Malone return (0); 7421d86b91cSPoul-Henning Kamp else 7436d7a8f6cSUlrich Spörlein err(1, "sysctl(getnext) %d %zu", j, l2); 744c1160fe4SBill Fumerola } 7451d86b91cSPoul-Henning Kamp 7461d86b91cSPoul-Henning Kamp l2 /= sizeof(int); 7471d86b91cSPoul-Henning Kamp 748fd8c668aSDavid Malone if (len < 0 || l2 < (unsigned int)len) 74921e1f596SDavid Malone return (0); 7501d86b91cSPoul-Henning Kamp 7511d86b91cSPoul-Henning Kamp for (i = 0; i < len; i++) 7521d86b91cSPoul-Henning Kamp if (name2[i] != oid[i]) 75321e1f596SDavid Malone return (0); 7541d86b91cSPoul-Henning Kamp 7551d86b91cSPoul-Henning Kamp i = show_var(name2, l2); 7561d86b91cSPoul-Henning Kamp if (!i && !bflag) 7571d86b91cSPoul-Henning Kamp putchar('\n'); 7581d86b91cSPoul-Henning Kamp 7591d86b91cSPoul-Henning Kamp memcpy(name1+2, name2, l2 * sizeof(int)); 7601d86b91cSPoul-Henning Kamp l1 = 2 + l2; 7611d86b91cSPoul-Henning Kamp } 762dea673e9SRodney W. Grimes } 763