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 * 3. All advertising materials mentioning features or use of this software 14dea673e9SRodney W. Grimes * must display the following acknowledgement: 15dea673e9SRodney W. Grimes * This product includes software developed by the University of 16dea673e9SRodney W. Grimes * California, Berkeley and its contributors. 17dea673e9SRodney W. Grimes * 4. Neither the name of the University nor the names of its contributors 18dea673e9SRodney W. Grimes * may be used to endorse or promote products derived from this software 19dea673e9SRodney W. Grimes * without specific prior written permission. 20dea673e9SRodney W. Grimes * 21dea673e9SRodney W. Grimes * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 22dea673e9SRodney W. Grimes * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 23dea673e9SRodney W. Grimes * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 24dea673e9SRodney W. Grimes * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 25dea673e9SRodney W. Grimes * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 26dea673e9SRodney W. Grimes * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 27dea673e9SRodney W. Grimes * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 28dea673e9SRodney W. Grimes * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 29dea673e9SRodney W. Grimes * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 30dea673e9SRodney W. Grimes * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 31dea673e9SRodney W. Grimes * SUCH DAMAGE. 32dea673e9SRodney W. Grimes */ 33dea673e9SRodney W. Grimes 34dea673e9SRodney W. Grimes #ifndef lint 35d9b1bc77SPhilippe Charnier static const char copyright[] = 36dea673e9SRodney W. Grimes "@(#) Copyright (c) 1993\n\ 37dea673e9SRodney W. Grimes The Regents of the University of California. All rights reserved.\n"; 38dea673e9SRodney W. Grimes #endif /* not lint */ 39dea673e9SRodney W. Grimes 40dea673e9SRodney W. Grimes #ifndef lint 41d9b1bc77SPhilippe Charnier #if 0 42d9b1bc77SPhilippe Charnier static char sccsid[] = "@(#)from: sysctl.c 8.1 (Berkeley) 6/6/93"; 43d9b1bc77SPhilippe Charnier #endif 4435c13fa0SGarrett Wollman static const char rcsid[] = 457f3dea24SPeter Wemm "$FreeBSD$"; 46dea673e9SRodney W. Grimes #endif /* not lint */ 47dea673e9SRodney W. Grimes 48bca9bbeaSLuigi Rizzo #ifdef __i386__ 49bca9bbeaSLuigi Rizzo #include <sys/reboot.h> /* used for bootdev parsing */ 50bca9bbeaSLuigi Rizzo #endif 51ce685842SBruce Evans #include <sys/param.h> 52ce685842SBruce Evans #include <sys/time.h> 53ce685842SBruce Evans #include <sys/resource.h> 54dea673e9SRodney W. Grimes #include <sys/stat.h> 55dea673e9SRodney W. Grimes #include <sys/sysctl.h> 56f7550ecfSMatthew Dillon #include <sys/vmmeter.h> 57dea673e9SRodney W. Grimes 58d9b1bc77SPhilippe Charnier #include <ctype.h> 59d9b1bc77SPhilippe Charnier #include <err.h> 60dea673e9SRodney W. Grimes #include <errno.h> 61dea673e9SRodney W. Grimes #include <stdio.h> 62dea673e9SRodney W. Grimes #include <stdlib.h> 63dea673e9SRodney W. Grimes #include <string.h> 64d9b1bc77SPhilippe Charnier #include <unistd.h> 65dea673e9SRodney W. Grimes 666105f815SLuigi Rizzo static int aflag, bflag, dflag, eflag, Nflag, nflag, oflag, xflag; 67dea673e9SRodney W. Grimes 681d86b91cSPoul-Henning Kamp static int oidfmt(int *, int, char *, u_int *); 691d86b91cSPoul-Henning Kamp static void parse(char *); 701d86b91cSPoul-Henning Kamp static int show_var(int *, int); 711d86b91cSPoul-Henning Kamp static int sysctl_all (int *oid, int len); 721d86b91cSPoul-Henning Kamp static int name2oid(char *, int *); 73dea673e9SRodney W. Grimes 747e9c84c7SPeter Wemm static void set_T_dev_t (char *, void **, size_t *); 75d58f0054SPoul-Henning Kamp 761d86b91cSPoul-Henning Kamp static void 771d86b91cSPoul-Henning Kamp usage(void) 781d86b91cSPoul-Henning Kamp { 79dea673e9SRodney W. Grimes 809a2402bcSDag-Erling Smørgrav (void)fprintf(stderr, "%s\n%s\n", 816105f815SLuigi Rizzo "usage: sysctl [-bdeNnox] variable[=value] ...", 826105f815SLuigi Rizzo " sysctl [-bdeNnox] -a"); 831d86b91cSPoul-Henning Kamp exit(1); 841d86b91cSPoul-Henning Kamp } 85dea673e9SRodney W. Grimes 86dea673e9SRodney W. Grimes int 871d86b91cSPoul-Henning Kamp main(int argc, char **argv) 88dea673e9SRodney W. Grimes { 891d86b91cSPoul-Henning Kamp int ch; 901d86b91cSPoul-Henning Kamp setbuf(stdout,0); 911d86b91cSPoul-Henning Kamp setbuf(stderr,0); 92dea673e9SRodney W. Grimes 936105f815SLuigi Rizzo while ((ch = getopt(argc, argv, "AabdeNnowxX")) != -1) { 94dea673e9SRodney W. Grimes switch (ch) { 95ca5fac55SDag-Erling Smørgrav case 'A': 969a2402bcSDag-Erling Smørgrav /* compatibility */ 979a2402bcSDag-Erling Smørgrav aflag = oflag = 1; 98ca5fac55SDag-Erling Smørgrav break; 99ca5fac55SDag-Erling Smørgrav case 'a': 100ca5fac55SDag-Erling Smørgrav aflag = 1; 101ca5fac55SDag-Erling Smørgrav break; 102ca5fac55SDag-Erling Smørgrav case 'b': 103ca5fac55SDag-Erling Smørgrav bflag = 1; 104ca5fac55SDag-Erling Smørgrav break; 1056105f815SLuigi Rizzo case 'd': 1066105f815SLuigi Rizzo dflag = 1; 1076105f815SLuigi Rizzo break; 108d0b8aabbSAnton Berezin case 'e': 109d0b8aabbSAnton Berezin eflag = 1; 110d0b8aabbSAnton Berezin break; 111ca5fac55SDag-Erling Smørgrav case 'N': 112ca5fac55SDag-Erling Smørgrav Nflag = 1; 113ca5fac55SDag-Erling Smørgrav break; 114ca5fac55SDag-Erling Smørgrav case 'n': 115ca5fac55SDag-Erling Smørgrav nflag = 1; 116ca5fac55SDag-Erling Smørgrav break; 1179a2402bcSDag-Erling Smørgrav case 'o': 1189a2402bcSDag-Erling Smørgrav oflag = 1; 1199a2402bcSDag-Erling Smørgrav break; 120ca5fac55SDag-Erling Smørgrav case 'w': 1219a2402bcSDag-Erling Smørgrav /* compatibility */ 1229a2402bcSDag-Erling Smørgrav /* ignored */ 123ca5fac55SDag-Erling Smørgrav break; 124ca5fac55SDag-Erling Smørgrav case 'X': 1259a2402bcSDag-Erling Smørgrav /* compatibility */ 1269a2402bcSDag-Erling Smørgrav aflag = xflag = 1; 1279a2402bcSDag-Erling Smørgrav break; 1289a2402bcSDag-Erling Smørgrav case 'x': 1299a2402bcSDag-Erling Smørgrav xflag = 1; 130ca5fac55SDag-Erling Smørgrav break; 131ca5fac55SDag-Erling Smørgrav default: 132ca5fac55SDag-Erling Smørgrav usage(); 133dea673e9SRodney W. Grimes } 134dea673e9SRodney W. Grimes } 135dea673e9SRodney W. Grimes argc -= optind; 136dea673e9SRodney W. Grimes argv += optind; 137dea673e9SRodney W. Grimes 1389a2402bcSDag-Erling Smørgrav if (Nflag && nflag) 13981e7454aSDag-Erling Smørgrav usage(); 1409a2402bcSDag-Erling Smørgrav if (aflag && argc == 0) 1411d86b91cSPoul-Henning Kamp exit(sysctl_all(0, 0)); 142dea673e9SRodney W. Grimes if (argc == 0) 143dea673e9SRodney W. Grimes usage(); 144dea673e9SRodney W. Grimes while (argc-- > 0) 1451d86b91cSPoul-Henning Kamp parse(*argv++); 146dea673e9SRodney W. Grimes exit(0); 147dea673e9SRodney W. Grimes } 148dea673e9SRodney W. Grimes 149dea673e9SRodney W. Grimes /* 150dea673e9SRodney W. Grimes * Parse a name into a MIB entry. 151dea673e9SRodney W. Grimes * Lookup and print out the MIB entry if it exists. 152dea673e9SRodney W. Grimes * Set a new value if requested. 153dea673e9SRodney W. Grimes */ 1541d86b91cSPoul-Henning Kamp static void 1551d86b91cSPoul-Henning Kamp parse(char *string) 156dea673e9SRodney W. Grimes { 1571d86b91cSPoul-Henning Kamp int len, i, j; 158dea673e9SRodney W. Grimes void *newval = 0; 1591ce1a53dSJim Pirzyk int intval; 1601ce1a53dSJim Pirzyk unsigned int uintval; 1611ce1a53dSJim Pirzyk long longval; 1621ce1a53dSJim Pirzyk unsigned long ulongval; 1631ce1a53dSJim Pirzyk size_t newsize = 0; 164dea673e9SRodney W. Grimes quad_t quadval; 165dea673e9SRodney W. Grimes int mib[CTL_MAXNAME]; 166a78d3eafSRobert Watson char *cp, *bufp, buf[BUFSIZ], *endptr, fmt[BUFSIZ]; 1671d86b91cSPoul-Henning Kamp u_int kind; 168dea673e9SRodney W. Grimes 169dea673e9SRodney W. Grimes bufp = buf; 170dea673e9SRodney W. Grimes snprintf(buf, BUFSIZ, "%s", string); 171dea673e9SRodney W. Grimes if ((cp = strchr(string, '=')) != NULL) { 172dea673e9SRodney W. Grimes *strchr(buf, '=') = '\0'; 173dea673e9SRodney W. Grimes *cp++ = '\0'; 174dea673e9SRodney W. Grimes while (isspace(*cp)) 175dea673e9SRodney W. Grimes cp++; 176dea673e9SRodney W. Grimes newval = cp; 177dea673e9SRodney W. Grimes newsize = strlen(cp); 178dea673e9SRodney W. Grimes } 1791d86b91cSPoul-Henning Kamp len = name2oid(bufp, mib); 1801d86b91cSPoul-Henning Kamp 1811d86b91cSPoul-Henning Kamp if (len < 0) 182d9b1bc77SPhilippe Charnier errx(1, "unknown oid '%s'", bufp); 1831d86b91cSPoul-Henning Kamp 184d58f0054SPoul-Henning Kamp if (oidfmt(mib, len, fmt, &kind)) 185d9b1bc77SPhilippe Charnier err(1, "couldn't find format of oid '%s'", bufp); 1861d86b91cSPoul-Henning Kamp 1879a2402bcSDag-Erling Smørgrav if (newval == NULL) { 1881d86b91cSPoul-Henning Kamp if ((kind & CTLTYPE) == CTLTYPE_NODE) { 1891d86b91cSPoul-Henning Kamp sysctl_all(mib, len); 1901d86b91cSPoul-Henning Kamp } else { 1911d86b91cSPoul-Henning Kamp i = show_var(mib, len); 1921d86b91cSPoul-Henning Kamp if (!i && !bflag) 1931d86b91cSPoul-Henning Kamp putchar('\n'); 194dea673e9SRodney W. Grimes } 1951d86b91cSPoul-Henning Kamp } else { 1961d86b91cSPoul-Henning Kamp if ((kind & CTLTYPE) == CTLTYPE_NODE) 1971d86b91cSPoul-Henning Kamp errx(1, "oid '%s' isn't a leaf node", bufp); 198dea673e9SRodney W. Grimes 199ac8711d2SMike Silbersack if (!(kind & CTLFLAG_WR)) { 2009b4b73b7SMike Silbersack if (kind & CTLFLAG_TUN) { 201ac8711d2SMike Silbersack warnx("oid '%s' is a read only tunable", bufp); 202ac8711d2SMike Silbersack errx(1, "Tunable values are set in /boot/loader.conf"); 2039b4b73b7SMike Silbersack } else { 2041d86b91cSPoul-Henning Kamp errx(1, "oid '%s' is read only", bufp); 2059b4b73b7SMike Silbersack } 206ac8711d2SMike Silbersack } 207dea673e9SRodney W. Grimes 208a78d3eafSRobert Watson if ((kind & CTLTYPE) == CTLTYPE_INT || 209a78d3eafSRobert Watson (kind & CTLTYPE) == CTLTYPE_UINT || 210a78d3eafSRobert Watson (kind & CTLTYPE) == CTLTYPE_LONG || 211a78d3eafSRobert Watson (kind & CTLTYPE) == CTLTYPE_ULONG) { 212a78d3eafSRobert Watson if (strlen(newval) == 0) 213a78d3eafSRobert Watson errx(1, "empty numeric value"); 214a78d3eafSRobert Watson } 215a78d3eafSRobert Watson 2161d86b91cSPoul-Henning Kamp switch (kind & CTLTYPE) { 217dea673e9SRodney W. Grimes case CTLTYPE_INT: 218a78d3eafSRobert Watson intval = (int)strtol(newval, &endptr, 0); 219a78d3eafSRobert Watson if (endptr == newval || *endptr != '\0') 220a78d3eafSRobert Watson errx(1, "invalid integer '%s'", 221a78d3eafSRobert Watson newval); 222dea673e9SRodney W. Grimes newval = &intval; 22331fb4661SDima Dorfman newsize = sizeof(intval); 224dea673e9SRodney W. Grimes break; 2251ce1a53dSJim Pirzyk case CTLTYPE_UINT: 226a78d3eafSRobert Watson uintval = (int) strtoul(newval, &endptr, 0); 227a78d3eafSRobert Watson if (endptr == newval || *endptr != '\0') 228a78d3eafSRobert Watson errx(1, "invalid unsigned integer '%s'", 229a78d3eafSRobert Watson newval); 2301ce1a53dSJim Pirzyk newval = &uintval; 2311ce1a53dSJim Pirzyk newsize = sizeof uintval; 2321ce1a53dSJim Pirzyk break; 2331ce1a53dSJim Pirzyk case CTLTYPE_LONG: 234a78d3eafSRobert Watson longval = strtol(newval, &endptr, 0); 235a78d3eafSRobert Watson if (endptr == newval || *endptr != '\0') 236a78d3eafSRobert Watson errx(1, "invalid long integer '%s'", 237a78d3eafSRobert Watson newval); 2381ce1a53dSJim Pirzyk newval = &longval; 2391ce1a53dSJim Pirzyk newsize = sizeof longval; 2401ce1a53dSJim Pirzyk break; 2411ce1a53dSJim Pirzyk case CTLTYPE_ULONG: 242a78d3eafSRobert Watson ulongval = strtoul(newval, &endptr, 0); 243a78d3eafSRobert Watson if (endptr == newval || *endptr != '\0') 244a78d3eafSRobert Watson errx(1, "invalid unsigned long integer" 245a78d3eafSRobert Watson " '%s'", newval); 2461ce1a53dSJim Pirzyk newval = &ulongval; 2471ce1a53dSJim Pirzyk newsize = sizeof ulongval; 2481d86b91cSPoul-Henning Kamp break; 2491d86b91cSPoul-Henning Kamp case CTLTYPE_STRING: 2501d86b91cSPoul-Henning Kamp break; 251dea673e9SRodney W. Grimes case CTLTYPE_QUAD: 252dea673e9SRodney W. Grimes sscanf(newval, "%qd", &quadval); 253dea673e9SRodney W. Grimes newval = &quadval; 25431fb4661SDima Dorfman newsize = sizeof(quadval); 255dea673e9SRodney W. Grimes break; 256d58f0054SPoul-Henning Kamp case CTLTYPE_OPAQUE: 257d58f0054SPoul-Henning Kamp if (strcmp(fmt, "T,dev_t") == 0) { 258d58f0054SPoul-Henning Kamp set_T_dev_t ((char*)newval, &newval, &newsize); 259d58f0054SPoul-Henning Kamp break; 260d58f0054SPoul-Henning Kamp } 261d58f0054SPoul-Henning Kamp /* FALLTHROUGH */ 2621d86b91cSPoul-Henning Kamp default: 2631d86b91cSPoul-Henning Kamp errx(1, "oid '%s' is type %d," 26414b94d04SJohn Polstra " cannot set that", bufp, 26514b94d04SJohn Polstra kind & CTLTYPE); 266dea673e9SRodney W. Grimes } 2671d86b91cSPoul-Henning Kamp 2681d86b91cSPoul-Henning Kamp i = show_var(mib, len); 2691d86b91cSPoul-Henning Kamp if (sysctl(mib, len, 0, 0, newval, newsize) == -1) { 2701d86b91cSPoul-Henning Kamp if (!i && !bflag) 2711d86b91cSPoul-Henning Kamp putchar('\n'); 272dea673e9SRodney W. Grimes switch (errno) { 273dea673e9SRodney W. Grimes case EOPNOTSUPP: 274d9b1bc77SPhilippe Charnier errx(1, "%s: value is not available", 2751d86b91cSPoul-Henning Kamp string); 276dea673e9SRodney W. Grimes case ENOTDIR: 277d9b1bc77SPhilippe Charnier errx(1, "%s: specification is incomplete", 278dea673e9SRodney W. Grimes string); 279dea673e9SRodney W. Grimes case ENOMEM: 280d9b1bc77SPhilippe Charnier errx(1, "%s: type is unknown to this program", 281dea673e9SRodney W. Grimes string); 282dea673e9SRodney W. Grimes default: 283d9b1bc77SPhilippe Charnier warn("%s", string); 284dea673e9SRodney W. Grimes return; 285dea673e9SRodney W. Grimes } 286dea673e9SRodney W. Grimes } 2871d86b91cSPoul-Henning Kamp if (!bflag) 2881d86b91cSPoul-Henning Kamp printf(" -> "); 2891d86b91cSPoul-Henning Kamp i = nflag; 2901d86b91cSPoul-Henning Kamp nflag = 1; 2911d86b91cSPoul-Henning Kamp j = show_var(mib, len); 2921d86b91cSPoul-Henning Kamp if (!j && !bflag) 2931d86b91cSPoul-Henning Kamp putchar('\n'); 2941d86b91cSPoul-Henning Kamp nflag = i; 295dea673e9SRodney W. Grimes } 296dea673e9SRodney W. Grimes } 297dea673e9SRodney W. Grimes 2981d86b91cSPoul-Henning Kamp /* These functions will dump out various interesting structures. */ 299dea673e9SRodney W. Grimes 3001d86b91cSPoul-Henning Kamp static int 3011d86b91cSPoul-Henning Kamp S_clockinfo(int l2, void *p) 3021d86b91cSPoul-Henning Kamp { 3031d86b91cSPoul-Henning Kamp struct clockinfo *ci = (struct clockinfo*)p; 304996076bbSAlfred Perlstein if (l2 != sizeof(*ci)) { 305996076bbSAlfred Perlstein warnx("S_clockinfo %d != %d", l2, sizeof(*ci)); 306996076bbSAlfred Perlstein return (0); 307996076bbSAlfred Perlstein } 308b35c8f28SPoul-Henning Kamp printf("{ hz = %d, tick = %d, profhz = %d, stathz = %d }", 309b35c8f28SPoul-Henning Kamp ci->hz, ci->tick, ci->profhz, ci->stathz); 3101d86b91cSPoul-Henning Kamp return (0); 311dea673e9SRodney W. Grimes } 312dea673e9SRodney W. Grimes 3131d86b91cSPoul-Henning Kamp static int 3141d86b91cSPoul-Henning Kamp S_loadavg(int l2, void *p) 3151d86b91cSPoul-Henning Kamp { 3161d86b91cSPoul-Henning Kamp struct loadavg *tv = (struct loadavg*)p; 3171d86b91cSPoul-Henning Kamp 318996076bbSAlfred Perlstein if (l2 != sizeof(*tv)) { 319996076bbSAlfred Perlstein warnx("S_loadavg %d != %d", l2, sizeof(*tv)); 320996076bbSAlfred Perlstein return (0); 321996076bbSAlfred Perlstein } 3221d86b91cSPoul-Henning Kamp printf("{ %.2f %.2f %.2f }", 3231d86b91cSPoul-Henning Kamp (double)tv->ldavg[0]/(double)tv->fscale, 3241d86b91cSPoul-Henning Kamp (double)tv->ldavg[1]/(double)tv->fscale, 3251d86b91cSPoul-Henning Kamp (double)tv->ldavg[2]/(double)tv->fscale); 3261d86b91cSPoul-Henning Kamp return (0); 327dea673e9SRodney W. Grimes } 328dea673e9SRodney W. Grimes 3291d86b91cSPoul-Henning Kamp static int 3301d86b91cSPoul-Henning Kamp S_timeval(int l2, void *p) 3311d86b91cSPoul-Henning Kamp { 3321d86b91cSPoul-Henning Kamp struct timeval *tv = (struct timeval*)p; 333c2deb608SBruce Evans time_t tv_sec; 3341d86b91cSPoul-Henning Kamp char *p1, *p2; 335dea673e9SRodney W. Grimes 336996076bbSAlfred Perlstein if (l2 != sizeof(*tv)) { 337996076bbSAlfred Perlstein warnx("S_timeval %d != %d", l2, sizeof(*tv)); 338996076bbSAlfred Perlstein return (0); 339996076bbSAlfred Perlstein } 3401d86b91cSPoul-Henning Kamp printf("{ sec = %ld, usec = %ld } ", 3411d86b91cSPoul-Henning Kamp tv->tv_sec, tv->tv_usec); 342c2deb608SBruce Evans tv_sec = tv->tv_sec; 343c2deb608SBruce Evans p1 = strdup(ctime(&tv_sec)); 3441d86b91cSPoul-Henning Kamp for (p2=p1; *p2 ; p2++) 3451d86b91cSPoul-Henning Kamp if (*p2 == '\n') 3461d86b91cSPoul-Henning Kamp *p2 = '\0'; 3471d86b91cSPoul-Henning Kamp fputs(p1, stdout); 3481d86b91cSPoul-Henning Kamp return (0); 3491d86b91cSPoul-Henning Kamp } 3501d86b91cSPoul-Henning Kamp 3511d86b91cSPoul-Henning Kamp static int 352f7550ecfSMatthew Dillon S_vmtotal(int l2, void *p) 353f7550ecfSMatthew Dillon { 354f7550ecfSMatthew Dillon struct vmtotal *v = (struct vmtotal *)p; 355654e22e7SMatthew Dillon int pageKilo = getpagesize() / 1024; 356f7550ecfSMatthew Dillon 357f7550ecfSMatthew Dillon if (l2 != sizeof(*v)) { 358f7550ecfSMatthew Dillon warnx("S_vmtotal %d != %d", l2, sizeof(*v)); 359f7550ecfSMatthew Dillon return (0); 360f7550ecfSMatthew Dillon } 361f7550ecfSMatthew Dillon 362654e22e7SMatthew Dillon printf( 363654e22e7SMatthew Dillon "\nSystem wide totals computed every five seconds:" 364654e22e7SMatthew Dillon " (values in kilobytes)\n"); 365f7550ecfSMatthew Dillon printf("===============================================\n"); 366654e22e7SMatthew Dillon printf( 367654e22e7SMatthew Dillon "Processes:\t\t(RUNQ: %hu Disk Wait: %hu Page Wait: " 368654e22e7SMatthew Dillon "%hu Sleep: %hu)\n", 369f7550ecfSMatthew Dillon v->t_rq, v->t_dw, v->t_pw, v->t_sl); 370654e22e7SMatthew Dillon printf( 371654e22e7SMatthew Dillon "Virtual Memory:\t\t(Total: %luK, Active %lldK)\n", 372654e22e7SMatthew Dillon (unsigned long)v->t_vm / 1024, 373654e22e7SMatthew Dillon (long long)v->t_avm * pageKilo); 374654e22e7SMatthew Dillon printf("Real Memory:\t\t(Total: %lldK Active %lldK)\n", 375654e22e7SMatthew Dillon (long long)v->t_rm * pageKilo, (long long)v->t_arm * pageKilo); 376654e22e7SMatthew Dillon printf("Shared Virtual Memory:\t(Total: %lldK Active: %lldK)\n", 377654e22e7SMatthew Dillon (long long)v->t_vmshr * pageKilo, 378654e22e7SMatthew Dillon (long long)v->t_avmshr * pageKilo); 379654e22e7SMatthew Dillon printf("Shared Real Memory:\t(Total: %lldK Active: %lldK)\n", 380654e22e7SMatthew Dillon (long long)v->t_rmshr * pageKilo, 381654e22e7SMatthew Dillon (long long)v->t_armshr * pageKilo); 382654e22e7SMatthew Dillon printf("Free Memory Pages:\t%ldK\n", (long long)v->t_free * pageKilo); 383f7550ecfSMatthew Dillon 384f7550ecfSMatthew Dillon return (0); 385f7550ecfSMatthew Dillon } 386f7550ecfSMatthew Dillon 387f7550ecfSMatthew Dillon static int 3881d86b91cSPoul-Henning Kamp T_dev_t(int l2, void *p) 3891d86b91cSPoul-Henning Kamp { 3901d86b91cSPoul-Henning Kamp dev_t *d = (dev_t *)p; 391996076bbSAlfred Perlstein if (l2 != sizeof(*d)) { 392996076bbSAlfred Perlstein warnx("T_dev_T %d != %d", l2, sizeof(*d)); 393996076bbSAlfred Perlstein return (0); 394996076bbSAlfred Perlstein } 3956ed3a297SPoul-Henning Kamp if ((int)(*d) != -1) { 3966ed3a297SPoul-Henning Kamp if (minor(*d) > 255 || minor(*d) < 0) 3976ed3a297SPoul-Henning Kamp printf("{ major = %d, minor = 0x%x }", 3986ed3a297SPoul-Henning Kamp major(*d), minor(*d)); 3996ed3a297SPoul-Henning Kamp else 4001d86b91cSPoul-Henning Kamp printf("{ major = %d, minor = %d }", 4011d86b91cSPoul-Henning Kamp major(*d), minor(*d)); 4026ed3a297SPoul-Henning Kamp } 4031d86b91cSPoul-Henning Kamp return (0); 4041d86b91cSPoul-Henning Kamp } 4051d86b91cSPoul-Henning Kamp 406d58f0054SPoul-Henning Kamp static void 4077e9c84c7SPeter Wemm set_T_dev_t (char *path, void **val, size_t *size) 408d58f0054SPoul-Henning Kamp { 409d58f0054SPoul-Henning Kamp static struct stat statb; 410d58f0054SPoul-Henning Kamp 411d58f0054SPoul-Henning Kamp if (strcmp(path, "none") && strcmp(path, "off")) { 412d58f0054SPoul-Henning Kamp int rc = stat (path, &statb); 413d58f0054SPoul-Henning Kamp if (rc) { 414d58f0054SPoul-Henning Kamp err(1, "cannot stat %s", path); 415d58f0054SPoul-Henning Kamp } 416d58f0054SPoul-Henning Kamp 417d58f0054SPoul-Henning Kamp if (!S_ISCHR(statb.st_mode)) { 418d58f0054SPoul-Henning Kamp errx(1, "must specify a device special file."); 419d58f0054SPoul-Henning Kamp } 420d58f0054SPoul-Henning Kamp } else { 421d58f0054SPoul-Henning Kamp statb.st_rdev = NODEV; 422d58f0054SPoul-Henning Kamp } 423d58f0054SPoul-Henning Kamp *val = (char*) &statb.st_rdev; 424d58f0054SPoul-Henning Kamp *size = sizeof statb.st_rdev; 425d58f0054SPoul-Henning Kamp } 426d58f0054SPoul-Henning Kamp 4271d86b91cSPoul-Henning Kamp /* 4281d86b91cSPoul-Henning Kamp * These functions uses a presently undocumented interface to the kernel 4291d86b91cSPoul-Henning Kamp * to walk the tree and get the type so it can print the value. 4301d86b91cSPoul-Henning Kamp * This interface is under work and consideration, and should probably 4311d86b91cSPoul-Henning Kamp * be killed with a big axe by the first person who can find the time. 4321d86b91cSPoul-Henning Kamp * (be aware though, that the proper interface isn't as obvious as it 4331d86b91cSPoul-Henning Kamp * may seem, there are various conflicting requirements. 4341d86b91cSPoul-Henning Kamp */ 4351d86b91cSPoul-Henning Kamp 4361d86b91cSPoul-Henning Kamp static int 4371d86b91cSPoul-Henning Kamp name2oid(char *name, int *oidp) 4381d86b91cSPoul-Henning Kamp { 4391d86b91cSPoul-Henning Kamp int oid[2]; 440dbf9b92fSDoug Rabson int i; 441dbf9b92fSDoug Rabson size_t j; 4421d86b91cSPoul-Henning Kamp 4431d86b91cSPoul-Henning Kamp oid[0] = 0; 4441d86b91cSPoul-Henning Kamp oid[1] = 3; 4451d86b91cSPoul-Henning Kamp 4461d86b91cSPoul-Henning Kamp j = CTL_MAXNAME * sizeof(int); 4471d86b91cSPoul-Henning Kamp i = sysctl(oid, 2, oidp, &j, name, strlen(name)); 4481d86b91cSPoul-Henning Kamp if (i < 0) 4491d86b91cSPoul-Henning Kamp return i; 4501d86b91cSPoul-Henning Kamp j /= sizeof(int); 4511d86b91cSPoul-Henning Kamp return (j); 4521d86b91cSPoul-Henning Kamp } 4531d86b91cSPoul-Henning Kamp 4541d86b91cSPoul-Henning Kamp static int 4551d86b91cSPoul-Henning Kamp oidfmt(int *oid, int len, char *fmt, u_int *kind) 4561d86b91cSPoul-Henning Kamp { 4571d86b91cSPoul-Henning Kamp int qoid[CTL_MAXNAME+2]; 4581d86b91cSPoul-Henning Kamp u_char buf[BUFSIZ]; 459dbf9b92fSDoug Rabson int i; 460dbf9b92fSDoug Rabson size_t j; 4611d86b91cSPoul-Henning Kamp 4621d86b91cSPoul-Henning Kamp qoid[0] = 0; 4631d86b91cSPoul-Henning Kamp qoid[1] = 4; 4641d86b91cSPoul-Henning Kamp memcpy(qoid + 2, oid, len * sizeof(int)); 4651d86b91cSPoul-Henning Kamp 46631fb4661SDima Dorfman j = sizeof(buf); 4671d86b91cSPoul-Henning Kamp i = sysctl(qoid, len + 2, buf, &j, 0, 0); 4681d86b91cSPoul-Henning Kamp if (i) 469d9b1bc77SPhilippe Charnier err(1, "sysctl fmt %d %d %d", i, j, errno); 4701d86b91cSPoul-Henning Kamp 4711d86b91cSPoul-Henning Kamp if (kind) 4721d86b91cSPoul-Henning Kamp *kind = *(u_int *)buf; 4731d86b91cSPoul-Henning Kamp 4741d86b91cSPoul-Henning Kamp if (fmt) 4751d86b91cSPoul-Henning Kamp strcpy(fmt, (char *)(buf + sizeof(u_int))); 4761d86b91cSPoul-Henning Kamp return 0; 4771d86b91cSPoul-Henning Kamp } 4781d86b91cSPoul-Henning Kamp 47960cf2c12SLuigi Rizzo /* 4801d86b91cSPoul-Henning Kamp * This formats and outputs the value of one variable 4811d86b91cSPoul-Henning Kamp * 4821d86b91cSPoul-Henning Kamp * Returns zero if anything was actually output. 4831d86b91cSPoul-Henning Kamp * Returns one if didn't know what to do with this. 4841d86b91cSPoul-Henning Kamp * Return minus one if we had errors. 4851d86b91cSPoul-Henning Kamp */ 4861d86b91cSPoul-Henning Kamp 4871d86b91cSPoul-Henning Kamp static int 4881d86b91cSPoul-Henning Kamp show_var(int *oid, int nlen) 4891d86b91cSPoul-Henning Kamp { 4901d86b91cSPoul-Henning Kamp u_char buf[BUFSIZ], *val, *p; 491d0b8aabbSAnton Berezin char name[BUFSIZ], *fmt, *sep; 4921d86b91cSPoul-Henning Kamp int qoid[CTL_MAXNAME+2]; 493dbf9b92fSDoug Rabson int i; 494dbf9b92fSDoug Rabson size_t j, len; 4951d86b91cSPoul-Henning Kamp u_int kind; 496a89ab9bbSDag-Erling Smørgrav int (*func)(int, void *); 4971d86b91cSPoul-Henning Kamp 49881e7454aSDag-Erling Smørgrav qoid[0] = 0; 49981e7454aSDag-Erling Smørgrav memcpy(qoid + 2, oid, nlen * sizeof(int)); 50081e7454aSDag-Erling Smørgrav 50181e7454aSDag-Erling Smørgrav qoid[1] = 1; 50231fb4661SDima Dorfman j = sizeof(name); 50381e7454aSDag-Erling Smørgrav i = sysctl(qoid, nlen + 2, name, &j, 0, 0); 50481e7454aSDag-Erling Smørgrav if (i || !j) 50581e7454aSDag-Erling Smørgrav err(1, "sysctl name %d %d %d", i, j, errno); 50681e7454aSDag-Erling Smørgrav 507ca5fac55SDag-Erling Smørgrav if (Nflag) { 508ca5fac55SDag-Erling Smørgrav printf("%s", name); 509ca5fac55SDag-Erling Smørgrav return (0); 510ca5fac55SDag-Erling Smørgrav } 511ca5fac55SDag-Erling Smørgrav 512d0b8aabbSAnton Berezin if (eflag) 513d0b8aabbSAnton Berezin sep = "="; 514d0b8aabbSAnton Berezin else 515d0b8aabbSAnton Berezin sep = ": "; 516d0b8aabbSAnton Berezin 5176105f815SLuigi Rizzo if (dflag) { /* just print description */ 5186105f815SLuigi Rizzo qoid[1] = 5; 5196105f815SLuigi Rizzo j = sizeof(buf); 5206105f815SLuigi Rizzo i = sysctl(qoid, nlen + 2, buf, &j, 0, 0); 5216105f815SLuigi Rizzo if (!nflag) 5226105f815SLuigi Rizzo printf("%s%s", name, sep); 5236105f815SLuigi Rizzo printf("%s", buf); 5246105f815SLuigi Rizzo return (0); 5256105f815SLuigi Rizzo } 5261d86b91cSPoul-Henning Kamp /* find an estimate of how much we need for this var */ 5271d86b91cSPoul-Henning Kamp j = 0; 5281d86b91cSPoul-Henning Kamp i = sysctl(oid, nlen, 0, &j, 0, 0); 5291d86b91cSPoul-Henning Kamp j += j; /* we want to be sure :-) */ 5301d86b91cSPoul-Henning Kamp 531661b2c16SPeter Wemm val = alloca(j + 1); 5321d86b91cSPoul-Henning Kamp len = j; 5331d86b91cSPoul-Henning Kamp i = sysctl(oid, nlen, val, &len, 0, 0); 5341d86b91cSPoul-Henning Kamp if (i || !len) 5351d86b91cSPoul-Henning Kamp return (1); 5361d86b91cSPoul-Henning Kamp 5371d86b91cSPoul-Henning Kamp if (bflag) { 5381d86b91cSPoul-Henning Kamp fwrite(val, 1, len, stdout); 5391d86b91cSPoul-Henning Kamp return (0); 5401d86b91cSPoul-Henning Kamp } 54176d3dc52SAndrey A. Chernov val[len] = '\0'; 542d58f0054SPoul-Henning Kamp fmt = buf; 543d58f0054SPoul-Henning Kamp oidfmt(oid, nlen, fmt, &kind); 5441d86b91cSPoul-Henning Kamp p = val; 5451d86b91cSPoul-Henning Kamp switch (*fmt) { 5461d86b91cSPoul-Henning Kamp case 'A': 5471d86b91cSPoul-Henning Kamp if (!nflag) 548d0b8aabbSAnton Berezin printf("%s%s", name, sep); 5499866352eSPeter Wemm printf("%.*s", len, p); 5501d86b91cSPoul-Henning Kamp return (0); 5511d86b91cSPoul-Henning Kamp 5521d86b91cSPoul-Henning Kamp case 'I': 5531d86b91cSPoul-Henning Kamp if (!nflag) 554d0b8aabbSAnton Berezin printf("%s%s", name, sep); 5559701cd40SJohn Baldwin fmt++; 5562b4c0a3bSPoul-Henning Kamp val = ""; 5572b4c0a3bSPoul-Henning Kamp while (len >= sizeof(int)) { 5589701cd40SJohn Baldwin if(*fmt == 'U') 5599701cd40SJohn Baldwin printf("%s%u", val, *(unsigned int *)p); 5609701cd40SJohn Baldwin else 5612b4c0a3bSPoul-Henning Kamp printf("%s%d", val, *(int *)p); 5622b4c0a3bSPoul-Henning Kamp val = " "; 5632b4c0a3bSPoul-Henning Kamp len -= sizeof(int); 5642b4c0a3bSPoul-Henning Kamp p += sizeof(int); 5652b4c0a3bSPoul-Henning Kamp } 5661d86b91cSPoul-Henning Kamp return (0); 5671d86b91cSPoul-Henning Kamp 568dbf9b92fSDoug Rabson case 'L': 569dbf9b92fSDoug Rabson if (!nflag) 570d0b8aabbSAnton Berezin printf("%s%s", name, sep); 5719701cd40SJohn Baldwin fmt++; 572aa02fb57SPoul-Henning Kamp val = ""; 573aa02fb57SPoul-Henning Kamp while (len >= sizeof(long)) { 5749701cd40SJohn Baldwin if(*fmt == 'U') 575aa02fb57SPoul-Henning Kamp printf("%s%lu", val, *(unsigned long *)p); 5769701cd40SJohn Baldwin else 577aa02fb57SPoul-Henning Kamp printf("%s%ld", val, *(long *)p); 578aa02fb57SPoul-Henning Kamp val = " "; 5793c884b50SAndrew Gallatin len -= sizeof(long); 5803c884b50SAndrew Gallatin p += sizeof(long); 581aa02fb57SPoul-Henning Kamp } 582dbf9b92fSDoug Rabson return (0); 583dbf9b92fSDoug Rabson 584dbf9b92fSDoug Rabson case 'P': 585dbf9b92fSDoug Rabson if (!nflag) 586d0b8aabbSAnton Berezin printf("%s%s", name, sep); 587dbf9b92fSDoug Rabson printf("%p", *(void **)p); 588dbf9b92fSDoug Rabson return (0); 589dbf9b92fSDoug Rabson 5901d86b91cSPoul-Henning Kamp case 'T': 5911d86b91cSPoul-Henning Kamp case 'S': 5921d86b91cSPoul-Henning Kamp i = 0; 593a89ab9bbSDag-Erling Smørgrav if (strcmp(fmt, "S,clockinfo") == 0) 594a89ab9bbSDag-Erling Smørgrav func = S_clockinfo; 595a89ab9bbSDag-Erling Smørgrav else if (strcmp(fmt, "S,timeval") == 0) 596a89ab9bbSDag-Erling Smørgrav func = S_timeval; 597a89ab9bbSDag-Erling Smørgrav else if (strcmp(fmt, "S,loadavg") == 0) 598a89ab9bbSDag-Erling Smørgrav func = S_loadavg; 599f7550ecfSMatthew Dillon else if (strcmp(fmt, "S,vmtotal") == 0) 600f7550ecfSMatthew Dillon func = S_vmtotal; 601a89ab9bbSDag-Erling Smørgrav else if (strcmp(fmt, "T,dev_t") == 0) 602a89ab9bbSDag-Erling Smørgrav func = T_dev_t; 603a89ab9bbSDag-Erling Smørgrav else 604a89ab9bbSDag-Erling Smørgrav func = NULL; 6051d86b91cSPoul-Henning Kamp if (func) { 6061d86b91cSPoul-Henning Kamp if (!nflag) 607d0b8aabbSAnton Berezin printf("%s%s", name, sep); 6081d86b91cSPoul-Henning Kamp return ((*func)(len, p)); 6091d86b91cSPoul-Henning Kamp } 6101d86b91cSPoul-Henning Kamp /* FALLTHROUGH */ 611dea673e9SRodney W. Grimes default: 6129a2402bcSDag-Erling Smørgrav if (!oflag && !xflag) 6131d86b91cSPoul-Henning Kamp return (1); 6141d86b91cSPoul-Henning Kamp if (!nflag) 615d0b8aabbSAnton Berezin printf("%s%s", name, sep); 6161d86b91cSPoul-Henning Kamp printf("Format:%s Length:%d Dump:0x", fmt, len); 617a89ab9bbSDag-Erling Smørgrav while (len-- && (xflag || p < val + 16)) 6181d86b91cSPoul-Henning Kamp printf("%02x", *p++); 619a89ab9bbSDag-Erling Smørgrav if (!xflag && len > 16) 6201d86b91cSPoul-Henning Kamp printf("..."); 6211d86b91cSPoul-Henning Kamp return (0); 6221d86b91cSPoul-Henning Kamp } 6231d86b91cSPoul-Henning Kamp return (1); 624dea673e9SRodney W. Grimes } 625dea673e9SRodney W. Grimes 6261d86b91cSPoul-Henning Kamp static int 6271d86b91cSPoul-Henning Kamp sysctl_all (int *oid, int len) 628dea673e9SRodney W. Grimes { 6291d86b91cSPoul-Henning Kamp int name1[22], name2[22]; 630dbf9b92fSDoug Rabson int i, j; 631dbf9b92fSDoug Rabson size_t l1, l2; 632dea673e9SRodney W. Grimes 6331d86b91cSPoul-Henning Kamp name1[0] = 0; 6341d86b91cSPoul-Henning Kamp name1[1] = 2; 6351d86b91cSPoul-Henning Kamp l1 = 2; 6361d86b91cSPoul-Henning Kamp if (len) { 6371d86b91cSPoul-Henning Kamp memcpy(name1+2, oid, len * sizeof(int)); 6381d86b91cSPoul-Henning Kamp l1 += len; 6391d86b91cSPoul-Henning Kamp } else { 6401d86b91cSPoul-Henning Kamp name1[2] = 1; 6411d86b91cSPoul-Henning Kamp l1++; 6421d86b91cSPoul-Henning Kamp } 643a89ab9bbSDag-Erling Smørgrav for (;;) { 64431fb4661SDima Dorfman l2 = sizeof(name2); 6451d86b91cSPoul-Henning Kamp j = sysctl(name1, l1, name2, &l2, 0, 0); 646c1160fe4SBill Fumerola if (j < 0) { 6471d86b91cSPoul-Henning Kamp if (errno == ENOENT) 6481d86b91cSPoul-Henning Kamp return 0; 6491d86b91cSPoul-Henning Kamp else 650d9b1bc77SPhilippe Charnier err(1, "sysctl(getnext) %d %d", j, l2); 651c1160fe4SBill Fumerola } 6521d86b91cSPoul-Henning Kamp 6531d86b91cSPoul-Henning Kamp l2 /= sizeof(int); 6541d86b91cSPoul-Henning Kamp 6551d86b91cSPoul-Henning Kamp if (l2 < len) 6561d86b91cSPoul-Henning Kamp return 0; 6571d86b91cSPoul-Henning Kamp 6581d86b91cSPoul-Henning Kamp for (i = 0; i < len; i++) 6591d86b91cSPoul-Henning Kamp if (name2[i] != oid[i]) 6601d86b91cSPoul-Henning Kamp return 0; 6611d86b91cSPoul-Henning Kamp 6621d86b91cSPoul-Henning Kamp i = show_var(name2, l2); 6631d86b91cSPoul-Henning Kamp if (!i && !bflag) 6641d86b91cSPoul-Henning Kamp putchar('\n'); 6651d86b91cSPoul-Henning Kamp 6661d86b91cSPoul-Henning Kamp memcpy(name1+2, name2, l2 * sizeof(int)); 6671d86b91cSPoul-Henning Kamp l1 = 2 + l2; 6681d86b91cSPoul-Henning Kamp } 669dea673e9SRodney W. Grimes } 670