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 61f93d36fdSRobert Watson static int aflag, bflag, dflag, eflag, hflag, Nflag, nflag, oflag; 62d9fcd86cSMike Makonnen static int 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 *); 71d45564dcSHajimu UMEMOTO static int set_IK(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", 78855b068aSRuslan Ermilov "usage: sysctl [-bdehNnoqx] 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 92f93d36fdSRobert Watson while ((ch = getopt(argc, argv, "AabdehNnoqwxX")) != -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; 113ca5fac55SDag-Erling Smørgrav case 'N': 114ca5fac55SDag-Erling Smørgrav Nflag = 1; 115ca5fac55SDag-Erling Smørgrav break; 116ca5fac55SDag-Erling Smørgrav case 'n': 117ca5fac55SDag-Erling Smørgrav nflag = 1; 118ca5fac55SDag-Erling Smørgrav break; 1199a2402bcSDag-Erling Smørgrav case 'o': 1209a2402bcSDag-Erling Smørgrav oflag = 1; 1219a2402bcSDag-Erling Smørgrav break; 122f93d36fdSRobert Watson case 'q': 123f93d36fdSRobert Watson qflag = 1; 124f93d36fdSRobert Watson break; 125ca5fac55SDag-Erling Smørgrav case 'w': 1269a2402bcSDag-Erling Smørgrav /* compatibility */ 1279a2402bcSDag-Erling Smørgrav /* ignored */ 128ca5fac55SDag-Erling Smørgrav break; 129ca5fac55SDag-Erling Smørgrav case 'X': 1309a2402bcSDag-Erling Smørgrav /* compatibility */ 1319a2402bcSDag-Erling Smørgrav aflag = xflag = 1; 1329a2402bcSDag-Erling Smørgrav break; 1339a2402bcSDag-Erling Smørgrav case 'x': 1349a2402bcSDag-Erling Smørgrav xflag = 1; 135ca5fac55SDag-Erling Smørgrav break; 136ca5fac55SDag-Erling Smørgrav default: 137ca5fac55SDag-Erling Smørgrav usage(); 138dea673e9SRodney W. Grimes } 139dea673e9SRodney W. Grimes } 140dea673e9SRodney W. Grimes argc -= optind; 141dea673e9SRodney W. Grimes argv += optind; 142dea673e9SRodney W. Grimes 1439a2402bcSDag-Erling Smørgrav if (Nflag && nflag) 14481e7454aSDag-Erling Smørgrav usage(); 1459a2402bcSDag-Erling Smørgrav if (aflag && argc == 0) 1461d86b91cSPoul-Henning Kamp exit(sysctl_all(0, 0)); 147dea673e9SRodney W. Grimes if (argc == 0) 148dea673e9SRodney W. Grimes usage(); 149d9fcd86cSMike Makonnen 150d9fcd86cSMike Makonnen warncount = 0; 151dea673e9SRodney W. Grimes while (argc-- > 0) 1521d86b91cSPoul-Henning Kamp parse(*argv++); 153d9fcd86cSMike Makonnen exit(warncount); 154dea673e9SRodney W. Grimes } 155dea673e9SRodney W. Grimes 156dea673e9SRodney W. Grimes /* 157dea673e9SRodney W. Grimes * Parse a name into a MIB entry. 158dea673e9SRodney W. Grimes * Lookup and print out the MIB entry if it exists. 159dea673e9SRodney W. Grimes * Set a new value if requested. 160dea673e9SRodney W. Grimes */ 1611d86b91cSPoul-Henning Kamp static void 1621d86b91cSPoul-Henning Kamp parse(char *string) 163dea673e9SRodney W. Grimes { 1641d86b91cSPoul-Henning Kamp int len, i, j; 165dea673e9SRodney W. Grimes void *newval = 0; 1661ce1a53dSJim Pirzyk int intval; 1671ce1a53dSJim Pirzyk unsigned int uintval; 1681ce1a53dSJim Pirzyk long longval; 1691ce1a53dSJim Pirzyk unsigned long ulongval; 1701ce1a53dSJim Pirzyk size_t newsize = 0; 171dea673e9SRodney W. Grimes quad_t quadval; 172dea673e9SRodney W. Grimes int mib[CTL_MAXNAME]; 173a78d3eafSRobert Watson char *cp, *bufp, buf[BUFSIZ], *endptr, fmt[BUFSIZ]; 1741d86b91cSPoul-Henning Kamp u_int kind; 175dea673e9SRodney W. Grimes 176dea673e9SRodney W. Grimes bufp = buf; 1771d4961c0SSuleiman Souhlal if (snprintf(buf, BUFSIZ, "%s", string) >= BUFSIZ) 1781d4961c0SSuleiman Souhlal errx(1, "oid too long: '%s'", string); 179dea673e9SRodney W. Grimes if ((cp = strchr(string, '=')) != NULL) { 180dea673e9SRodney W. Grimes *strchr(buf, '=') = '\0'; 181dea673e9SRodney W. Grimes *cp++ = '\0'; 182dea673e9SRodney W. Grimes while (isspace(*cp)) 183dea673e9SRodney W. Grimes cp++; 184dea673e9SRodney W. Grimes newval = cp; 185dea673e9SRodney W. Grimes newsize = strlen(cp); 186dea673e9SRodney W. Grimes } 1871d86b91cSPoul-Henning Kamp len = name2oid(bufp, mib); 1881d86b91cSPoul-Henning Kamp 189f93d36fdSRobert Watson if (len < 0) { 190f93d36fdSRobert Watson if (qflag) 191f93d36fdSRobert Watson exit(1); 192f93d36fdSRobert Watson else 193d9b1bc77SPhilippe Charnier errx(1, "unknown oid '%s'", bufp); 194f93d36fdSRobert Watson } 1951d86b91cSPoul-Henning Kamp 196d58f0054SPoul-Henning Kamp if (oidfmt(mib, len, fmt, &kind)) 197d9b1bc77SPhilippe Charnier err(1, "couldn't find format of oid '%s'", bufp); 1981d86b91cSPoul-Henning Kamp 1999a2402bcSDag-Erling Smørgrav if (newval == NULL) { 2001d86b91cSPoul-Henning Kamp if ((kind & CTLTYPE) == CTLTYPE_NODE) { 201b2680e20SMatthew N. Dodd if (dflag) { 202b2680e20SMatthew N. Dodd i = show_var(mib, len); 203b2680e20SMatthew N. Dodd if (!i && !bflag) 204b2680e20SMatthew N. Dodd putchar('\n'); 205b2680e20SMatthew N. Dodd } 2061d86b91cSPoul-Henning Kamp sysctl_all(mib, len); 2071d86b91cSPoul-Henning Kamp } else { 2081d86b91cSPoul-Henning Kamp i = show_var(mib, len); 2091d86b91cSPoul-Henning Kamp if (!i && !bflag) 2101d86b91cSPoul-Henning Kamp putchar('\n'); 211dea673e9SRodney W. Grimes } 2121d86b91cSPoul-Henning Kamp } else { 2131d86b91cSPoul-Henning Kamp if ((kind & CTLTYPE) == CTLTYPE_NODE) 2141d86b91cSPoul-Henning Kamp errx(1, "oid '%s' isn't a leaf node", bufp); 215dea673e9SRodney W. Grimes 216ac8711d2SMike Silbersack if (!(kind & CTLFLAG_WR)) { 2179b4b73b7SMike Silbersack if (kind & CTLFLAG_TUN) { 218ac8711d2SMike Silbersack warnx("oid '%s' is a read only tunable", bufp); 219ac8711d2SMike Silbersack errx(1, "Tunable values are set in /boot/loader.conf"); 2209b4b73b7SMike Silbersack } else { 2211d86b91cSPoul-Henning Kamp errx(1, "oid '%s' is read only", bufp); 2229b4b73b7SMike Silbersack } 223ac8711d2SMike Silbersack } 224dea673e9SRodney W. Grimes 225a78d3eafSRobert Watson if ((kind & CTLTYPE) == CTLTYPE_INT || 226a78d3eafSRobert Watson (kind & CTLTYPE) == CTLTYPE_UINT || 227a78d3eafSRobert Watson (kind & CTLTYPE) == CTLTYPE_LONG || 2284d90830fSDima Dorfman (kind & CTLTYPE) == CTLTYPE_ULONG || 2294d90830fSDima Dorfman (kind & CTLTYPE) == CTLTYPE_QUAD) { 230a78d3eafSRobert Watson if (strlen(newval) == 0) 231a78d3eafSRobert Watson errx(1, "empty numeric value"); 232a78d3eafSRobert Watson } 233a78d3eafSRobert Watson 2341d86b91cSPoul-Henning Kamp switch (kind & CTLTYPE) { 235dea673e9SRodney W. Grimes case CTLTYPE_INT: 236d45564dcSHajimu UMEMOTO if (strcmp(fmt, "IK") == 0) { 23721e1f596SDavid Malone if (!set_IK(newval, &intval)) 238d45564dcSHajimu UMEMOTO errx(1, "invalid value '%s'", 239fd8c668aSDavid Malone (char *)newval); 240d45564dcSHajimu UMEMOTO } else { 241d45564dcSHajimu UMEMOTO intval = (int)strtol(newval, &endptr, 242d45564dcSHajimu UMEMOTO 0); 243a78d3eafSRobert Watson if (endptr == newval || *endptr != '\0') 244a78d3eafSRobert Watson errx(1, "invalid integer '%s'", 245fd8c668aSDavid Malone (char *)newval); 246d45564dcSHajimu UMEMOTO } 247dea673e9SRodney W. Grimes newval = &intval; 24831fb4661SDima Dorfman newsize = sizeof(intval); 249dea673e9SRodney W. Grimes break; 2501ce1a53dSJim Pirzyk case CTLTYPE_UINT: 251a78d3eafSRobert Watson uintval = (int) strtoul(newval, &endptr, 0); 252a78d3eafSRobert Watson if (endptr == newval || *endptr != '\0') 253a78d3eafSRobert Watson errx(1, "invalid unsigned integer '%s'", 254fd8c668aSDavid Malone (char *)newval); 2551ce1a53dSJim Pirzyk newval = &uintval; 25621e1f596SDavid Malone newsize = sizeof(uintval); 2571ce1a53dSJim Pirzyk break; 2581ce1a53dSJim Pirzyk case CTLTYPE_LONG: 259a78d3eafSRobert Watson longval = strtol(newval, &endptr, 0); 260a78d3eafSRobert Watson if (endptr == newval || *endptr != '\0') 261a78d3eafSRobert Watson errx(1, "invalid long integer '%s'", 262fd8c668aSDavid Malone (char *)newval); 2631ce1a53dSJim Pirzyk newval = &longval; 26421e1f596SDavid Malone newsize = sizeof(longval); 2651ce1a53dSJim Pirzyk break; 2661ce1a53dSJim Pirzyk case CTLTYPE_ULONG: 267a78d3eafSRobert Watson ulongval = strtoul(newval, &endptr, 0); 268a78d3eafSRobert Watson if (endptr == newval || *endptr != '\0') 269a78d3eafSRobert Watson errx(1, "invalid unsigned long integer" 270fd8c668aSDavid Malone " '%s'", (char *)newval); 2711ce1a53dSJim Pirzyk newval = &ulongval; 27221e1f596SDavid Malone newsize = sizeof(ulongval); 2731d86b91cSPoul-Henning Kamp break; 2741d86b91cSPoul-Henning Kamp case CTLTYPE_STRING: 2751d86b91cSPoul-Henning Kamp break; 276dea673e9SRodney W. Grimes case CTLTYPE_QUAD: 277dea673e9SRodney W. Grimes sscanf(newval, "%qd", &quadval); 278dea673e9SRodney W. Grimes newval = &quadval; 27931fb4661SDima Dorfman newsize = sizeof(quadval); 280dea673e9SRodney W. Grimes break; 281d58f0054SPoul-Henning Kamp case CTLTYPE_OPAQUE: 282d58f0054SPoul-Henning Kamp if (strcmp(fmt, "T,dev_t") == 0) { 28321e1f596SDavid Malone set_T_dev_t (newval, &newval, &newsize); 284d58f0054SPoul-Henning Kamp break; 285d58f0054SPoul-Henning Kamp } 286d58f0054SPoul-Henning Kamp /* FALLTHROUGH */ 2871d86b91cSPoul-Henning Kamp default: 2881d86b91cSPoul-Henning Kamp errx(1, "oid '%s' is type %d," 28914b94d04SJohn Polstra " cannot set that", bufp, 29014b94d04SJohn Polstra kind & CTLTYPE); 291dea673e9SRodney W. Grimes } 2921d86b91cSPoul-Henning Kamp 2931d86b91cSPoul-Henning Kamp i = show_var(mib, len); 2941d86b91cSPoul-Henning Kamp if (sysctl(mib, len, 0, 0, newval, newsize) == -1) { 2951d86b91cSPoul-Henning Kamp if (!i && !bflag) 2961d86b91cSPoul-Henning Kamp putchar('\n'); 297dea673e9SRodney W. Grimes switch (errno) { 298dea673e9SRodney W. Grimes case EOPNOTSUPP: 299d9b1bc77SPhilippe Charnier errx(1, "%s: value is not available", 3001d86b91cSPoul-Henning Kamp string); 301dea673e9SRodney W. Grimes case ENOTDIR: 302d9b1bc77SPhilippe Charnier errx(1, "%s: specification is incomplete", 303dea673e9SRodney W. Grimes string); 304dea673e9SRodney W. Grimes case ENOMEM: 305d9b1bc77SPhilippe Charnier errx(1, "%s: type is unknown to this program", 306dea673e9SRodney W. Grimes string); 307dea673e9SRodney W. Grimes default: 308d9b1bc77SPhilippe Charnier warn("%s", string); 309d9fcd86cSMike Makonnen warncount++; 310dea673e9SRodney W. Grimes return; 311dea673e9SRodney W. Grimes } 312dea673e9SRodney W. Grimes } 3131d86b91cSPoul-Henning Kamp if (!bflag) 3141d86b91cSPoul-Henning Kamp printf(" -> "); 3151d86b91cSPoul-Henning Kamp i = nflag; 3161d86b91cSPoul-Henning Kamp nflag = 1; 3171d86b91cSPoul-Henning Kamp j = show_var(mib, len); 3181d86b91cSPoul-Henning Kamp if (!j && !bflag) 3191d86b91cSPoul-Henning Kamp putchar('\n'); 3201d86b91cSPoul-Henning Kamp nflag = i; 321dea673e9SRodney W. Grimes } 322dea673e9SRodney W. Grimes } 323dea673e9SRodney W. Grimes 3241d86b91cSPoul-Henning Kamp /* These functions will dump out various interesting structures. */ 325dea673e9SRodney W. Grimes 3261d86b91cSPoul-Henning Kamp static int 3271d86b91cSPoul-Henning Kamp S_clockinfo(int l2, void *p) 3281d86b91cSPoul-Henning Kamp { 3291d86b91cSPoul-Henning Kamp struct clockinfo *ci = (struct clockinfo*)p; 33021e1f596SDavid Malone 331996076bbSAlfred Perlstein if (l2 != sizeof(*ci)) { 332996076bbSAlfred Perlstein warnx("S_clockinfo %d != %d", l2, sizeof(*ci)); 3336b6b665bSBruce Evans return (1); 334996076bbSAlfred Perlstein } 33545817aaaSDag-Erling Smørgrav printf(hflag ? "{ hz = %'d, tick = %'d, profhz = %'d, stathz = %'d }" : 33645817aaaSDag-Erling Smørgrav "{ hz = %d, tick = %d, profhz = %d, stathz = %d }", 337b35c8f28SPoul-Henning Kamp ci->hz, ci->tick, ci->profhz, ci->stathz); 3381d86b91cSPoul-Henning Kamp return (0); 339dea673e9SRodney W. Grimes } 340dea673e9SRodney W. Grimes 3411d86b91cSPoul-Henning Kamp static int 3421d86b91cSPoul-Henning Kamp S_loadavg(int l2, void *p) 3431d86b91cSPoul-Henning Kamp { 3441d86b91cSPoul-Henning Kamp struct loadavg *tv = (struct loadavg*)p; 3451d86b91cSPoul-Henning Kamp 346996076bbSAlfred Perlstein if (l2 != sizeof(*tv)) { 347996076bbSAlfred Perlstein warnx("S_loadavg %d != %d", l2, sizeof(*tv)); 3486b6b665bSBruce Evans return (1); 349996076bbSAlfred Perlstein } 35045817aaaSDag-Erling Smørgrav printf(hflag ? "{ %'.2f %'.2f %'.2f }" : "{ %.2f %.2f %.2f }", 3511d86b91cSPoul-Henning Kamp (double)tv->ldavg[0]/(double)tv->fscale, 3521d86b91cSPoul-Henning Kamp (double)tv->ldavg[1]/(double)tv->fscale, 3531d86b91cSPoul-Henning Kamp (double)tv->ldavg[2]/(double)tv->fscale); 3541d86b91cSPoul-Henning Kamp return (0); 355dea673e9SRodney W. Grimes } 356dea673e9SRodney W. Grimes 3571d86b91cSPoul-Henning Kamp static int 3581d86b91cSPoul-Henning Kamp S_timeval(int l2, void *p) 3591d86b91cSPoul-Henning Kamp { 3601d86b91cSPoul-Henning Kamp struct timeval *tv = (struct timeval*)p; 361c2deb608SBruce Evans time_t tv_sec; 3621d86b91cSPoul-Henning Kamp char *p1, *p2; 363dea673e9SRodney W. Grimes 364996076bbSAlfred Perlstein if (l2 != sizeof(*tv)) { 365996076bbSAlfred Perlstein warnx("S_timeval %d != %d", l2, sizeof(*tv)); 3666b6b665bSBruce Evans return (1); 367996076bbSAlfred Perlstein } 368db87e2dcSJohn Hay printf(hflag ? "{ sec = %'jd, usec = %'ld } " : 369db87e2dcSJohn Hay "{ sec = %jd, usec = %ld } ", 370db87e2dcSJohn Hay (intmax_t)tv->tv_sec, tv->tv_usec); 371c2deb608SBruce Evans tv_sec = tv->tv_sec; 372c2deb608SBruce Evans p1 = strdup(ctime(&tv_sec)); 3731d86b91cSPoul-Henning Kamp for (p2=p1; *p2 ; p2++) 3741d86b91cSPoul-Henning Kamp if (*p2 == '\n') 3751d86b91cSPoul-Henning Kamp *p2 = '\0'; 3761d86b91cSPoul-Henning Kamp fputs(p1, stdout); 3771d86b91cSPoul-Henning Kamp return (0); 3781d86b91cSPoul-Henning Kamp } 3791d86b91cSPoul-Henning Kamp 3801d86b91cSPoul-Henning Kamp static int 381f7550ecfSMatthew Dillon S_vmtotal(int l2, void *p) 382f7550ecfSMatthew Dillon { 383f7550ecfSMatthew Dillon struct vmtotal *v = (struct vmtotal *)p; 384654e22e7SMatthew Dillon int pageKilo = getpagesize() / 1024; 385f7550ecfSMatthew Dillon 386f7550ecfSMatthew Dillon if (l2 != sizeof(*v)) { 387f7550ecfSMatthew Dillon warnx("S_vmtotal %d != %d", l2, sizeof(*v)); 3886b6b665bSBruce Evans return (1); 389f7550ecfSMatthew Dillon } 390f7550ecfSMatthew Dillon 391654e22e7SMatthew Dillon printf( 392654e22e7SMatthew Dillon "\nSystem wide totals computed every five seconds:" 393654e22e7SMatthew Dillon " (values in kilobytes)\n"); 394f7550ecfSMatthew Dillon printf("===============================================\n"); 395654e22e7SMatthew Dillon printf( 396bad4d172SRuslan Ermilov "Processes:\t\t(RUNQ: %hd Disk Wait: %hd Page Wait: " 397bad4d172SRuslan Ermilov "%hd Sleep: %hd)\n", 398f7550ecfSMatthew Dillon v->t_rq, v->t_dw, v->t_pw, v->t_sl); 399654e22e7SMatthew Dillon printf( 400bad4d172SRuslan Ermilov "Virtual Memory:\t\t(Total: %dK, Active %dK)\n", 401bad4d172SRuslan Ermilov v->t_vm * pageKilo, v->t_avm * pageKilo); 402bad4d172SRuslan Ermilov printf("Real Memory:\t\t(Total: %dK Active %dK)\n", 403bad4d172SRuslan Ermilov v->t_rm * pageKilo, v->t_arm * pageKilo); 404bad4d172SRuslan Ermilov printf("Shared Virtual Memory:\t(Total: %dK Active: %dK)\n", 405bad4d172SRuslan Ermilov v->t_vmshr * pageKilo, v->t_avmshr * pageKilo); 406bad4d172SRuslan Ermilov printf("Shared Real Memory:\t(Total: %dK Active: %dK)\n", 407bad4d172SRuslan Ermilov v->t_rmshr * pageKilo, v->t_armshr * pageKilo); 408bad4d172SRuslan Ermilov printf("Free Memory Pages:\t%dK\n", v->t_free * pageKilo); 409f7550ecfSMatthew Dillon 410f7550ecfSMatthew Dillon return (0); 411f7550ecfSMatthew Dillon } 412f7550ecfSMatthew Dillon 413f7550ecfSMatthew Dillon static int 4141d86b91cSPoul-Henning Kamp T_dev_t(int l2, void *p) 4151d86b91cSPoul-Henning Kamp { 4161d86b91cSPoul-Henning Kamp dev_t *d = (dev_t *)p; 41721e1f596SDavid Malone 418996076bbSAlfred Perlstein if (l2 != sizeof(*d)) { 419996076bbSAlfred Perlstein warnx("T_dev_T %d != %d", l2, sizeof(*d)); 4206b6b665bSBruce Evans return (1); 421996076bbSAlfred Perlstein } 4226ed3a297SPoul-Henning Kamp if ((int)(*d) != -1) { 4236ed3a297SPoul-Henning Kamp if (minor(*d) > 255 || minor(*d) < 0) 4246ed3a297SPoul-Henning Kamp printf("{ major = %d, minor = 0x%x }", 4256ed3a297SPoul-Henning Kamp major(*d), minor(*d)); 4266ed3a297SPoul-Henning Kamp else 4271d86b91cSPoul-Henning Kamp printf("{ major = %d, minor = %d }", 4281d86b91cSPoul-Henning Kamp major(*d), minor(*d)); 4296ed3a297SPoul-Henning Kamp } 4301d86b91cSPoul-Henning Kamp return (0); 4311d86b91cSPoul-Henning Kamp } 4321d86b91cSPoul-Henning Kamp 433d58f0054SPoul-Henning Kamp static void 4347e9c84c7SPeter Wemm set_T_dev_t(char *path, void **val, size_t *size) 435d58f0054SPoul-Henning Kamp { 436d58f0054SPoul-Henning Kamp static struct stat statb; 437d58f0054SPoul-Henning Kamp 438d58f0054SPoul-Henning Kamp if (strcmp(path, "none") && strcmp(path, "off")) { 439d58f0054SPoul-Henning Kamp int rc = stat (path, &statb); 440d58f0054SPoul-Henning Kamp if (rc) { 441d58f0054SPoul-Henning Kamp err(1, "cannot stat %s", path); 442d58f0054SPoul-Henning Kamp } 443d58f0054SPoul-Henning Kamp 444d58f0054SPoul-Henning Kamp if (!S_ISCHR(statb.st_mode)) { 445d58f0054SPoul-Henning Kamp errx(1, "must specify a device special file."); 446d58f0054SPoul-Henning Kamp } 447d58f0054SPoul-Henning Kamp } else { 448d58f0054SPoul-Henning Kamp statb.st_rdev = NODEV; 449d58f0054SPoul-Henning Kamp } 45021e1f596SDavid Malone *val = (void *) &statb.st_rdev; 45121e1f596SDavid Malone *size = sizeof(statb.st_rdev); 452d58f0054SPoul-Henning Kamp } 453d58f0054SPoul-Henning Kamp 454d45564dcSHajimu UMEMOTO static int 455d45564dcSHajimu UMEMOTO set_IK(char *str, int *val) 456d45564dcSHajimu UMEMOTO { 457d45564dcSHajimu UMEMOTO float temp; 458d45564dcSHajimu UMEMOTO int len, kelv; 459d45564dcSHajimu UMEMOTO char *p, *endptr; 460d45564dcSHajimu UMEMOTO 461d45564dcSHajimu UMEMOTO if ((len = strlen(str)) == 0) 462d45564dcSHajimu UMEMOTO return (0); 463d45564dcSHajimu UMEMOTO p = &str[len - 1]; 464d45564dcSHajimu UMEMOTO if (*p == 'C' || *p == 'F') { 465d45564dcSHajimu UMEMOTO *p = '\0'; 466d45564dcSHajimu UMEMOTO temp = strtof(str, &endptr); 467d45564dcSHajimu UMEMOTO if (endptr == str || *endptr != '\0') 468d45564dcSHajimu UMEMOTO return (0); 469d45564dcSHajimu UMEMOTO if (*p == 'F') 470d45564dcSHajimu UMEMOTO temp = (temp - 32) * 5 / 9; 471d45564dcSHajimu UMEMOTO kelv = temp * 10 + 2732; 472d45564dcSHajimu UMEMOTO } else { 473d45564dcSHajimu UMEMOTO kelv = (int)strtol(str, &endptr, 10); 474d45564dcSHajimu UMEMOTO if (endptr == str || *endptr != '\0') 475d45564dcSHajimu UMEMOTO return (0); 476d45564dcSHajimu UMEMOTO } 477d45564dcSHajimu UMEMOTO *val = kelv; 478d45564dcSHajimu UMEMOTO return (1); 479d45564dcSHajimu UMEMOTO } 480d45564dcSHajimu UMEMOTO 4811d86b91cSPoul-Henning Kamp /* 4821d86b91cSPoul-Henning Kamp * These functions uses a presently undocumented interface to the kernel 4831d86b91cSPoul-Henning Kamp * to walk the tree and get the type so it can print the value. 4841d86b91cSPoul-Henning Kamp * This interface is under work and consideration, and should probably 4851d86b91cSPoul-Henning Kamp * be killed with a big axe by the first person who can find the time. 4861d86b91cSPoul-Henning Kamp * (be aware though, that the proper interface isn't as obvious as it 4871d86b91cSPoul-Henning Kamp * may seem, there are various conflicting requirements. 4881d86b91cSPoul-Henning Kamp */ 4891d86b91cSPoul-Henning Kamp 4901d86b91cSPoul-Henning Kamp static int 4911d86b91cSPoul-Henning Kamp name2oid(char *name, int *oidp) 4921d86b91cSPoul-Henning Kamp { 4931d86b91cSPoul-Henning Kamp int oid[2]; 494dbf9b92fSDoug Rabson int i; 495dbf9b92fSDoug Rabson size_t j; 4961d86b91cSPoul-Henning Kamp 4971d86b91cSPoul-Henning Kamp oid[0] = 0; 4981d86b91cSPoul-Henning Kamp oid[1] = 3; 4991d86b91cSPoul-Henning Kamp 5001d86b91cSPoul-Henning Kamp j = CTL_MAXNAME * sizeof(int); 5011d86b91cSPoul-Henning Kamp i = sysctl(oid, 2, oidp, &j, name, strlen(name)); 5021d86b91cSPoul-Henning Kamp if (i < 0) 50321e1f596SDavid Malone return (i); 5041d86b91cSPoul-Henning Kamp j /= sizeof(int); 5051d86b91cSPoul-Henning Kamp return (j); 5061d86b91cSPoul-Henning Kamp } 5071d86b91cSPoul-Henning Kamp 5081d86b91cSPoul-Henning Kamp static int 5091d86b91cSPoul-Henning Kamp oidfmt(int *oid, int len, char *fmt, u_int *kind) 5101d86b91cSPoul-Henning Kamp { 5111d86b91cSPoul-Henning Kamp int qoid[CTL_MAXNAME+2]; 5121d86b91cSPoul-Henning Kamp u_char buf[BUFSIZ]; 513dbf9b92fSDoug Rabson int i; 514dbf9b92fSDoug Rabson size_t j; 5151d86b91cSPoul-Henning Kamp 5161d86b91cSPoul-Henning Kamp qoid[0] = 0; 5171d86b91cSPoul-Henning Kamp qoid[1] = 4; 5181d86b91cSPoul-Henning Kamp memcpy(qoid + 2, oid, len * sizeof(int)); 5191d86b91cSPoul-Henning Kamp 52031fb4661SDima Dorfman j = sizeof(buf); 5211d86b91cSPoul-Henning Kamp i = sysctl(qoid, len + 2, buf, &j, 0, 0); 5221d86b91cSPoul-Henning Kamp if (i) 523d9b1bc77SPhilippe Charnier err(1, "sysctl fmt %d %d %d", i, j, errno); 5241d86b91cSPoul-Henning Kamp 5251d86b91cSPoul-Henning Kamp if (kind) 5261d86b91cSPoul-Henning Kamp *kind = *(u_int *)buf; 5271d86b91cSPoul-Henning Kamp 5281d86b91cSPoul-Henning Kamp if (fmt) 5291d86b91cSPoul-Henning Kamp strcpy(fmt, (char *)(buf + sizeof(u_int))); 53021e1f596SDavid Malone return (0); 5311d86b91cSPoul-Henning Kamp } 5321d86b91cSPoul-Henning Kamp 53360cf2c12SLuigi Rizzo /* 5341d86b91cSPoul-Henning Kamp * This formats and outputs the value of one variable 5351d86b91cSPoul-Henning Kamp * 5361d86b91cSPoul-Henning Kamp * Returns zero if anything was actually output. 5371d86b91cSPoul-Henning Kamp * Returns one if didn't know what to do with this. 5381d86b91cSPoul-Henning Kamp * Return minus one if we had errors. 5391d86b91cSPoul-Henning Kamp */ 5401d86b91cSPoul-Henning Kamp 5411d86b91cSPoul-Henning Kamp static int 5421d86b91cSPoul-Henning Kamp show_var(int *oid, int nlen) 5431d86b91cSPoul-Henning Kamp { 544ccf25977SRuslan Ermilov u_char buf[BUFSIZ], *val, *oval, *p; 545fd8c668aSDavid Malone char name[BUFSIZ], *fmt; 546fd8c668aSDavid Malone const char *sep, *sep1; 5471d86b91cSPoul-Henning Kamp int qoid[CTL_MAXNAME+2]; 54821e1f596SDavid Malone uintmax_t umv; 54921e1f596SDavid Malone intmax_t mv; 550e37d2b30SDavid Malone int i, hexlen; 55141e419cbSDavid Malone size_t intlen; 552dbf9b92fSDoug Rabson size_t j, len; 5531d86b91cSPoul-Henning Kamp u_int kind; 554a89ab9bbSDag-Erling Smørgrav int (*func)(int, void *); 5551d86b91cSPoul-Henning Kamp 5569f98e452SMatthew N. Dodd bzero(buf, BUFSIZ); 5579f98e452SMatthew N. Dodd bzero(name, BUFSIZ); 55881e7454aSDag-Erling Smørgrav qoid[0] = 0; 55981e7454aSDag-Erling Smørgrav memcpy(qoid + 2, oid, nlen * sizeof(int)); 56081e7454aSDag-Erling Smørgrav 56181e7454aSDag-Erling Smørgrav qoid[1] = 1; 56231fb4661SDima Dorfman j = sizeof(name); 56381e7454aSDag-Erling Smørgrav i = sysctl(qoid, nlen + 2, name, &j, 0, 0); 56481e7454aSDag-Erling Smørgrav if (i || !j) 56581e7454aSDag-Erling Smørgrav err(1, "sysctl name %d %d %d", i, j, errno); 56681e7454aSDag-Erling Smørgrav 567ca5fac55SDag-Erling Smørgrav if (Nflag) { 568ca5fac55SDag-Erling Smørgrav printf("%s", name); 569ca5fac55SDag-Erling Smørgrav return (0); 570ca5fac55SDag-Erling Smørgrav } 571ca5fac55SDag-Erling Smørgrav 572d0b8aabbSAnton Berezin if (eflag) 573d0b8aabbSAnton Berezin sep = "="; 574d0b8aabbSAnton Berezin else 575d0b8aabbSAnton Berezin sep = ": "; 576d0b8aabbSAnton Berezin 5776105f815SLuigi Rizzo if (dflag) { /* just print description */ 5786105f815SLuigi Rizzo qoid[1] = 5; 5796105f815SLuigi Rizzo j = sizeof(buf); 5806105f815SLuigi Rizzo i = sysctl(qoid, nlen + 2, buf, &j, 0, 0); 5816105f815SLuigi Rizzo if (!nflag) 5826105f815SLuigi Rizzo printf("%s%s", name, sep); 5836105f815SLuigi Rizzo printf("%s", buf); 5846105f815SLuigi Rizzo return (0); 5856105f815SLuigi Rizzo } 5861d86b91cSPoul-Henning Kamp /* find an estimate of how much we need for this var */ 5871d86b91cSPoul-Henning Kamp j = 0; 5881d86b91cSPoul-Henning Kamp i = sysctl(oid, nlen, 0, &j, 0, 0); 5891d86b91cSPoul-Henning Kamp j += j; /* we want to be sure :-) */ 5901d86b91cSPoul-Henning Kamp 591ccf25977SRuslan Ermilov val = oval = malloc(j + 1); 592ccf25977SRuslan Ermilov if (val == NULL) { 593ccf25977SRuslan Ermilov warnx("malloc failed"); 5946b6b665bSBruce Evans return (1); 595ccf25977SRuslan Ermilov } 5961d86b91cSPoul-Henning Kamp len = j; 5971d86b91cSPoul-Henning Kamp i = sysctl(oid, nlen, val, &len, 0, 0); 598ccf25977SRuslan Ermilov if (i || !len) { 599ccf25977SRuslan Ermilov free(oval); 6001d86b91cSPoul-Henning Kamp return (1); 601ccf25977SRuslan Ermilov } 6021d86b91cSPoul-Henning Kamp 6031d86b91cSPoul-Henning Kamp if (bflag) { 6041d86b91cSPoul-Henning Kamp fwrite(val, 1, len, stdout); 605ccf25977SRuslan Ermilov free(oval); 6061d86b91cSPoul-Henning Kamp return (0); 6071d86b91cSPoul-Henning Kamp } 60876d3dc52SAndrey A. Chernov val[len] = '\0'; 609d58f0054SPoul-Henning Kamp fmt = buf; 610d58f0054SPoul-Henning Kamp oidfmt(oid, nlen, fmt, &kind); 6111d86b91cSPoul-Henning Kamp p = val; 6121d86b91cSPoul-Henning Kamp switch (*fmt) { 6131d86b91cSPoul-Henning Kamp case 'A': 6141d86b91cSPoul-Henning Kamp if (!nflag) 615d0b8aabbSAnton Berezin printf("%s%s", name, sep); 6169866352eSPeter Wemm printf("%.*s", len, p); 617ccf25977SRuslan Ermilov free(oval); 6181d86b91cSPoul-Henning Kamp return (0); 6191d86b91cSPoul-Henning Kamp 6201d86b91cSPoul-Henning Kamp case 'I': 621dbf9b92fSDoug Rabson case 'L': 62241e419cbSDavid Malone case 'Q': 623dbf9b92fSDoug Rabson if (!nflag) 624d0b8aabbSAnton Berezin printf("%s%s", name, sep); 62541e419cbSDavid Malone switch (*fmt) { 626e37d2b30SDavid Malone case 'I': intlen = sizeof(int); break; 627e37d2b30SDavid Malone case 'L': intlen = sizeof(long); break; 628e37d2b30SDavid Malone case 'Q': intlen = sizeof(quad_t); break; 62941e419cbSDavid Malone } 630e37d2b30SDavid Malone hexlen = 2 + (intlen * CHAR_BIT + 3) / 4; 631fd8c668aSDavid Malone sep1 = ""; 63241e419cbSDavid Malone while (len >= intlen) { 63341e419cbSDavid Malone switch (*fmt) { 63441e419cbSDavid Malone case 'I': 635e37d2b30SDavid Malone umv = *(u_int *)p; 636e37d2b30SDavid Malone mv = *(int *)p; 63741e419cbSDavid Malone break; 63841e419cbSDavid Malone case 'L': 639e37d2b30SDavid Malone umv = *(u_long *)p; 640e37d2b30SDavid Malone mv = *(long *)p; 64141e419cbSDavid Malone break; 64241e419cbSDavid Malone case 'Q': 643e37d2b30SDavid Malone umv = *(u_quad_t *)p; 644e37d2b30SDavid Malone mv = *(quad_t *)p; 64541e419cbSDavid Malone break; 64641e419cbSDavid Malone } 647fd8c668aSDavid Malone fputs(sep1, stdout); 64841e419cbSDavid Malone if (fmt[1] == 'U') 64921e1f596SDavid Malone printf(hflag ? "%'ju" : "%ju", umv); 65041e419cbSDavid Malone else if (fmt[1] == 'X') 651e37d2b30SDavid Malone printf("%#0*jx", hexlen, umv); 65241e419cbSDavid Malone else if (fmt[1] == 'K') { 653e37d2b30SDavid Malone if (mv < 0) 65421e1f596SDavid Malone printf("%jd", mv); 6559701cd40SJohn Baldwin else 65621e1f596SDavid Malone printf("%.1fC", (mv - 2732.0) / 10); 657c591d41fSPeter Wemm } else 658fd8c668aSDavid Malone printf(hflag ? "%'jd" : "%jd", mv); 659fd8c668aSDavid Malone sep1 = " "; 66041e419cbSDavid Malone len -= intlen; 66141e419cbSDavid Malone p += intlen; 662aa02fb57SPoul-Henning Kamp } 663ccf25977SRuslan Ermilov free(oval); 664dbf9b92fSDoug Rabson return (0); 665dbf9b92fSDoug Rabson 666dbf9b92fSDoug Rabson case 'P': 667dbf9b92fSDoug Rabson if (!nflag) 668d0b8aabbSAnton Berezin printf("%s%s", name, sep); 669dbf9b92fSDoug Rabson printf("%p", *(void **)p); 670ccf25977SRuslan Ermilov free(oval); 671dbf9b92fSDoug Rabson return (0); 672dbf9b92fSDoug Rabson 6731d86b91cSPoul-Henning Kamp case 'T': 6741d86b91cSPoul-Henning Kamp case 'S': 6751d86b91cSPoul-Henning Kamp i = 0; 676a89ab9bbSDag-Erling Smørgrav if (strcmp(fmt, "S,clockinfo") == 0) 677a89ab9bbSDag-Erling Smørgrav func = S_clockinfo; 678a89ab9bbSDag-Erling Smørgrav else if (strcmp(fmt, "S,timeval") == 0) 679a89ab9bbSDag-Erling Smørgrav func = S_timeval; 680a89ab9bbSDag-Erling Smørgrav else if (strcmp(fmt, "S,loadavg") == 0) 681a89ab9bbSDag-Erling Smørgrav func = S_loadavg; 682f7550ecfSMatthew Dillon else if (strcmp(fmt, "S,vmtotal") == 0) 683f7550ecfSMatthew Dillon func = S_vmtotal; 684a89ab9bbSDag-Erling Smørgrav else if (strcmp(fmt, "T,dev_t") == 0) 685a89ab9bbSDag-Erling Smørgrav func = T_dev_t; 686a89ab9bbSDag-Erling Smørgrav else 687a89ab9bbSDag-Erling Smørgrav func = NULL; 6881d86b91cSPoul-Henning Kamp if (func) { 6891d86b91cSPoul-Henning Kamp if (!nflag) 690d0b8aabbSAnton Berezin printf("%s%s", name, sep); 69148cd487aSHartmut Brandt i = (*func)(len, p); 692ccf25977SRuslan Ermilov free(oval); 69348cd487aSHartmut Brandt return (i); 6941d86b91cSPoul-Henning Kamp } 6951d86b91cSPoul-Henning Kamp /* FALLTHROUGH */ 696dea673e9SRodney W. Grimes default: 697ccf25977SRuslan Ermilov if (!oflag && !xflag) { 698ccf25977SRuslan Ermilov free(oval); 6991d86b91cSPoul-Henning Kamp return (1); 700ccf25977SRuslan Ermilov } 7011d86b91cSPoul-Henning Kamp if (!nflag) 702d0b8aabbSAnton Berezin printf("%s%s", name, sep); 7031d86b91cSPoul-Henning Kamp printf("Format:%s Length:%d Dump:0x", fmt, len); 704a89ab9bbSDag-Erling Smørgrav while (len-- && (xflag || p < val + 16)) 7051d86b91cSPoul-Henning Kamp printf("%02x", *p++); 706a89ab9bbSDag-Erling Smørgrav if (!xflag && len > 16) 7071d86b91cSPoul-Henning Kamp printf("..."); 708ccf25977SRuslan Ermilov free(oval); 7091d86b91cSPoul-Henning Kamp return (0); 7101d86b91cSPoul-Henning Kamp } 711ccf25977SRuslan Ermilov free(oval); 7121d86b91cSPoul-Henning Kamp return (1); 713dea673e9SRodney W. Grimes } 714dea673e9SRodney W. Grimes 7151d86b91cSPoul-Henning Kamp static int 7161d86b91cSPoul-Henning Kamp sysctl_all(int *oid, int len) 717dea673e9SRodney W. Grimes { 7181d86b91cSPoul-Henning Kamp int name1[22], name2[22]; 719dbf9b92fSDoug Rabson int i, j; 720dbf9b92fSDoug Rabson size_t l1, l2; 721dea673e9SRodney W. Grimes 7221d86b91cSPoul-Henning Kamp name1[0] = 0; 7231d86b91cSPoul-Henning Kamp name1[1] = 2; 7241d86b91cSPoul-Henning Kamp l1 = 2; 7251d86b91cSPoul-Henning Kamp if (len) { 7261d86b91cSPoul-Henning Kamp memcpy(name1+2, oid, len * sizeof(int)); 7271d86b91cSPoul-Henning Kamp l1 += len; 7281d86b91cSPoul-Henning Kamp } else { 7291d86b91cSPoul-Henning Kamp name1[2] = 1; 7301d86b91cSPoul-Henning Kamp l1++; 7311d86b91cSPoul-Henning Kamp } 732a89ab9bbSDag-Erling Smørgrav for (;;) { 73331fb4661SDima Dorfman l2 = sizeof(name2); 7341d86b91cSPoul-Henning Kamp j = sysctl(name1, l1, name2, &l2, 0, 0); 735c1160fe4SBill Fumerola if (j < 0) { 7361d86b91cSPoul-Henning Kamp if (errno == ENOENT) 73721e1f596SDavid Malone return (0); 7381d86b91cSPoul-Henning Kamp else 739d9b1bc77SPhilippe Charnier err(1, "sysctl(getnext) %d %d", j, l2); 740c1160fe4SBill Fumerola } 7411d86b91cSPoul-Henning Kamp 7421d86b91cSPoul-Henning Kamp l2 /= sizeof(int); 7431d86b91cSPoul-Henning Kamp 744fd8c668aSDavid Malone if (len < 0 || l2 < (unsigned int)len) 74521e1f596SDavid Malone return (0); 7461d86b91cSPoul-Henning Kamp 7471d86b91cSPoul-Henning Kamp for (i = 0; i < len; i++) 7481d86b91cSPoul-Henning Kamp if (name2[i] != oid[i]) 74921e1f596SDavid Malone return (0); 7501d86b91cSPoul-Henning Kamp 7511d86b91cSPoul-Henning Kamp i = show_var(name2, l2); 7521d86b91cSPoul-Henning Kamp if (!i && !bflag) 7531d86b91cSPoul-Henning Kamp putchar('\n'); 7541d86b91cSPoul-Henning Kamp 7551d86b91cSPoul-Henning Kamp memcpy(name1+2, name2, l2 * sizeof(int)); 7561d86b91cSPoul-Henning Kamp l1 = 2 + l2; 7571d86b91cSPoul-Henning Kamp } 758dea673e9SRodney W. Grimes } 759