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 44bca9bbeaSLuigi Rizzo #ifdef __i386__ 45bca9bbeaSLuigi Rizzo #include <sys/reboot.h> /* used for bootdev parsing */ 46bca9bbeaSLuigi Rizzo #endif 47ce685842SBruce Evans #include <sys/param.h> 48ce685842SBruce Evans #include <sys/time.h> 49ce685842SBruce Evans #include <sys/resource.h> 50dea673e9SRodney W. Grimes #include <sys/stat.h> 51dea673e9SRodney W. Grimes #include <sys/sysctl.h> 52f7550ecfSMatthew Dillon #include <sys/vmmeter.h> 53dea673e9SRodney W. Grimes 54d9b1bc77SPhilippe Charnier #include <ctype.h> 55d9b1bc77SPhilippe Charnier #include <err.h> 56dea673e9SRodney W. Grimes #include <errno.h> 5745817aaaSDag-Erling Smørgrav #include <locale.h> 58dea673e9SRodney W. Grimes #include <stdio.h> 59dea673e9SRodney W. Grimes #include <stdlib.h> 60dea673e9SRodney W. Grimes #include <string.h> 61d9b1bc77SPhilippe Charnier #include <unistd.h> 62dea673e9SRodney W. Grimes 6345817aaaSDag-Erling Smørgrav static int aflag, bflag, dflag, eflag, hflag, Nflag, nflag, oflag, xflag; 64dea673e9SRodney W. Grimes 651d86b91cSPoul-Henning Kamp static int oidfmt(int *, int, char *, u_int *); 661d86b91cSPoul-Henning Kamp static void parse(char *); 671d86b91cSPoul-Henning Kamp static int show_var(int *, int); 681d86b91cSPoul-Henning Kamp static int sysctl_all (int *oid, int len); 691d86b91cSPoul-Henning Kamp static int name2oid(char *, int *); 70dea673e9SRodney W. Grimes 717e9c84c7SPeter Wemm static void set_T_dev_t (char *, void **, size_t *); 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", 7845817aaaSDag-Erling Smørgrav "usage: sysctl [-bdehNnox] variable[=value] ...", 7945817aaaSDag-Erling Smørgrav " sysctl [-bdehNnox] -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 9245817aaaSDag-Erling Smørgrav while ((ch = getopt(argc, argv, "AabdehNnowxX")) != -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; 122ca5fac55SDag-Erling Smørgrav case 'w': 1239a2402bcSDag-Erling Smørgrav /* compatibility */ 1249a2402bcSDag-Erling Smørgrav /* ignored */ 125ca5fac55SDag-Erling Smørgrav break; 126ca5fac55SDag-Erling Smørgrav case 'X': 1279a2402bcSDag-Erling Smørgrav /* compatibility */ 1289a2402bcSDag-Erling Smørgrav aflag = xflag = 1; 1299a2402bcSDag-Erling Smørgrav break; 1309a2402bcSDag-Erling Smørgrav case 'x': 1319a2402bcSDag-Erling Smørgrav xflag = 1; 132ca5fac55SDag-Erling Smørgrav break; 133ca5fac55SDag-Erling Smørgrav default: 134ca5fac55SDag-Erling Smørgrav usage(); 135dea673e9SRodney W. Grimes } 136dea673e9SRodney W. Grimes } 137dea673e9SRodney W. Grimes argc -= optind; 138dea673e9SRodney W. Grimes argv += optind; 139dea673e9SRodney W. Grimes 1409a2402bcSDag-Erling Smørgrav if (Nflag && nflag) 14181e7454aSDag-Erling Smørgrav usage(); 1429a2402bcSDag-Erling Smørgrav if (aflag && argc == 0) 1431d86b91cSPoul-Henning Kamp exit(sysctl_all(0, 0)); 144dea673e9SRodney W. Grimes if (argc == 0) 145dea673e9SRodney W. Grimes usage(); 146dea673e9SRodney W. Grimes while (argc-- > 0) 1471d86b91cSPoul-Henning Kamp parse(*argv++); 148dea673e9SRodney W. Grimes exit(0); 149dea673e9SRodney W. Grimes } 150dea673e9SRodney W. Grimes 151dea673e9SRodney W. Grimes /* 152dea673e9SRodney W. Grimes * Parse a name into a MIB entry. 153dea673e9SRodney W. Grimes * Lookup and print out the MIB entry if it exists. 154dea673e9SRodney W. Grimes * Set a new value if requested. 155dea673e9SRodney W. Grimes */ 1561d86b91cSPoul-Henning Kamp static void 1571d86b91cSPoul-Henning Kamp parse(char *string) 158dea673e9SRodney W. Grimes { 1591d86b91cSPoul-Henning Kamp int len, i, j; 160dea673e9SRodney W. Grimes void *newval = 0; 1611ce1a53dSJim Pirzyk int intval; 1621ce1a53dSJim Pirzyk unsigned int uintval; 1631ce1a53dSJim Pirzyk long longval; 1641ce1a53dSJim Pirzyk unsigned long ulongval; 1651ce1a53dSJim Pirzyk size_t newsize = 0; 166dea673e9SRodney W. Grimes quad_t quadval; 167dea673e9SRodney W. Grimes int mib[CTL_MAXNAME]; 168a78d3eafSRobert Watson char *cp, *bufp, buf[BUFSIZ], *endptr, fmt[BUFSIZ]; 1691d86b91cSPoul-Henning Kamp u_int kind; 170dea673e9SRodney W. Grimes 171dea673e9SRodney W. Grimes bufp = buf; 172dea673e9SRodney W. Grimes snprintf(buf, BUFSIZ, "%s", string); 173dea673e9SRodney W. Grimes if ((cp = strchr(string, '=')) != NULL) { 174dea673e9SRodney W. Grimes *strchr(buf, '=') = '\0'; 175dea673e9SRodney W. Grimes *cp++ = '\0'; 176dea673e9SRodney W. Grimes while (isspace(*cp)) 177dea673e9SRodney W. Grimes cp++; 178dea673e9SRodney W. Grimes newval = cp; 179dea673e9SRodney W. Grimes newsize = strlen(cp); 180dea673e9SRodney W. Grimes } 1811d86b91cSPoul-Henning Kamp len = name2oid(bufp, mib); 1821d86b91cSPoul-Henning Kamp 1831d86b91cSPoul-Henning Kamp if (len < 0) 184d9b1bc77SPhilippe Charnier errx(1, "unknown oid '%s'", bufp); 1851d86b91cSPoul-Henning Kamp 186d58f0054SPoul-Henning Kamp if (oidfmt(mib, len, fmt, &kind)) 187d9b1bc77SPhilippe Charnier err(1, "couldn't find format of oid '%s'", bufp); 1881d86b91cSPoul-Henning Kamp 1899a2402bcSDag-Erling Smørgrav if (newval == NULL) { 1901d86b91cSPoul-Henning Kamp if ((kind & CTLTYPE) == CTLTYPE_NODE) { 1911d86b91cSPoul-Henning Kamp sysctl_all(mib, len); 1921d86b91cSPoul-Henning Kamp } else { 1931d86b91cSPoul-Henning Kamp i = show_var(mib, len); 1941d86b91cSPoul-Henning Kamp if (!i && !bflag) 1951d86b91cSPoul-Henning Kamp putchar('\n'); 196dea673e9SRodney W. Grimes } 1971d86b91cSPoul-Henning Kamp } else { 1981d86b91cSPoul-Henning Kamp if ((kind & CTLTYPE) == CTLTYPE_NODE) 1991d86b91cSPoul-Henning Kamp errx(1, "oid '%s' isn't a leaf node", bufp); 200dea673e9SRodney W. Grimes 201ac8711d2SMike Silbersack if (!(kind & CTLFLAG_WR)) { 2029b4b73b7SMike Silbersack if (kind & CTLFLAG_TUN) { 203ac8711d2SMike Silbersack warnx("oid '%s' is a read only tunable", bufp); 204ac8711d2SMike Silbersack errx(1, "Tunable values are set in /boot/loader.conf"); 2059b4b73b7SMike Silbersack } else { 2061d86b91cSPoul-Henning Kamp errx(1, "oid '%s' is read only", bufp); 2079b4b73b7SMike Silbersack } 208ac8711d2SMike Silbersack } 209dea673e9SRodney W. Grimes 210a78d3eafSRobert Watson if ((kind & CTLTYPE) == CTLTYPE_INT || 211a78d3eafSRobert Watson (kind & CTLTYPE) == CTLTYPE_UINT || 212a78d3eafSRobert Watson (kind & CTLTYPE) == CTLTYPE_LONG || 2134d90830fSDima Dorfman (kind & CTLTYPE) == CTLTYPE_ULONG || 2144d90830fSDima Dorfman (kind & CTLTYPE) == CTLTYPE_QUAD) { 215a78d3eafSRobert Watson if (strlen(newval) == 0) 216a78d3eafSRobert Watson errx(1, "empty numeric value"); 217a78d3eafSRobert Watson } 218a78d3eafSRobert Watson 2191d86b91cSPoul-Henning Kamp switch (kind & CTLTYPE) { 220dea673e9SRodney W. Grimes case CTLTYPE_INT: 221a78d3eafSRobert Watson intval = (int)strtol(newval, &endptr, 0); 222a78d3eafSRobert Watson if (endptr == newval || *endptr != '\0') 223a78d3eafSRobert Watson errx(1, "invalid integer '%s'", 224a78d3eafSRobert Watson newval); 225dea673e9SRodney W. Grimes newval = &intval; 22631fb4661SDima Dorfman newsize = sizeof(intval); 227dea673e9SRodney W. Grimes break; 2281ce1a53dSJim Pirzyk case CTLTYPE_UINT: 229a78d3eafSRobert Watson uintval = (int) strtoul(newval, &endptr, 0); 230a78d3eafSRobert Watson if (endptr == newval || *endptr != '\0') 231a78d3eafSRobert Watson errx(1, "invalid unsigned integer '%s'", 232a78d3eafSRobert Watson newval); 2331ce1a53dSJim Pirzyk newval = &uintval; 2341ce1a53dSJim Pirzyk newsize = sizeof uintval; 2351ce1a53dSJim Pirzyk break; 2361ce1a53dSJim Pirzyk case CTLTYPE_LONG: 237a78d3eafSRobert Watson longval = strtol(newval, &endptr, 0); 238a78d3eafSRobert Watson if (endptr == newval || *endptr != '\0') 239a78d3eafSRobert Watson errx(1, "invalid long integer '%s'", 240a78d3eafSRobert Watson newval); 2411ce1a53dSJim Pirzyk newval = &longval; 2421ce1a53dSJim Pirzyk newsize = sizeof longval; 2431ce1a53dSJim Pirzyk break; 2441ce1a53dSJim Pirzyk case CTLTYPE_ULONG: 245a78d3eafSRobert Watson ulongval = strtoul(newval, &endptr, 0); 246a78d3eafSRobert Watson if (endptr == newval || *endptr != '\0') 247a78d3eafSRobert Watson errx(1, "invalid unsigned long integer" 248a78d3eafSRobert Watson " '%s'", newval); 2491ce1a53dSJim Pirzyk newval = &ulongval; 2501ce1a53dSJim Pirzyk newsize = sizeof ulongval; 2511d86b91cSPoul-Henning Kamp break; 2521d86b91cSPoul-Henning Kamp case CTLTYPE_STRING: 2531d86b91cSPoul-Henning Kamp break; 254dea673e9SRodney W. Grimes case CTLTYPE_QUAD: 255dea673e9SRodney W. Grimes sscanf(newval, "%qd", &quadval); 256dea673e9SRodney W. Grimes newval = &quadval; 25731fb4661SDima Dorfman newsize = sizeof(quadval); 258dea673e9SRodney W. Grimes break; 259d58f0054SPoul-Henning Kamp case CTLTYPE_OPAQUE: 260d58f0054SPoul-Henning Kamp if (strcmp(fmt, "T,dev_t") == 0) { 261d58f0054SPoul-Henning Kamp set_T_dev_t ((char*)newval, &newval, &newsize); 262d58f0054SPoul-Henning Kamp break; 263d58f0054SPoul-Henning Kamp } 264d58f0054SPoul-Henning Kamp /* FALLTHROUGH */ 2651d86b91cSPoul-Henning Kamp default: 2661d86b91cSPoul-Henning Kamp errx(1, "oid '%s' is type %d," 26714b94d04SJohn Polstra " cannot set that", bufp, 26814b94d04SJohn Polstra kind & CTLTYPE); 269dea673e9SRodney W. Grimes } 2701d86b91cSPoul-Henning Kamp 2711d86b91cSPoul-Henning Kamp i = show_var(mib, len); 2721d86b91cSPoul-Henning Kamp if (sysctl(mib, len, 0, 0, newval, newsize) == -1) { 2731d86b91cSPoul-Henning Kamp if (!i && !bflag) 2741d86b91cSPoul-Henning Kamp putchar('\n'); 275dea673e9SRodney W. Grimes switch (errno) { 276dea673e9SRodney W. Grimes case EOPNOTSUPP: 277d9b1bc77SPhilippe Charnier errx(1, "%s: value is not available", 2781d86b91cSPoul-Henning Kamp string); 279dea673e9SRodney W. Grimes case ENOTDIR: 280d9b1bc77SPhilippe Charnier errx(1, "%s: specification is incomplete", 281dea673e9SRodney W. Grimes string); 282dea673e9SRodney W. Grimes case ENOMEM: 283d9b1bc77SPhilippe Charnier errx(1, "%s: type is unknown to this program", 284dea673e9SRodney W. Grimes string); 285dea673e9SRodney W. Grimes default: 286d9b1bc77SPhilippe Charnier warn("%s", string); 287dea673e9SRodney W. Grimes return; 288dea673e9SRodney W. Grimes } 289dea673e9SRodney W. Grimes } 2901d86b91cSPoul-Henning Kamp if (!bflag) 2911d86b91cSPoul-Henning Kamp printf(" -> "); 2921d86b91cSPoul-Henning Kamp i = nflag; 2931d86b91cSPoul-Henning Kamp nflag = 1; 2941d86b91cSPoul-Henning Kamp j = show_var(mib, len); 2951d86b91cSPoul-Henning Kamp if (!j && !bflag) 2961d86b91cSPoul-Henning Kamp putchar('\n'); 2971d86b91cSPoul-Henning Kamp nflag = i; 298dea673e9SRodney W. Grimes } 299dea673e9SRodney W. Grimes } 300dea673e9SRodney W. Grimes 3011d86b91cSPoul-Henning Kamp /* These functions will dump out various interesting structures. */ 302dea673e9SRodney W. Grimes 3031d86b91cSPoul-Henning Kamp static int 3041d86b91cSPoul-Henning Kamp S_clockinfo(int l2, void *p) 3051d86b91cSPoul-Henning Kamp { 3061d86b91cSPoul-Henning Kamp struct clockinfo *ci = (struct clockinfo*)p; 307996076bbSAlfred Perlstein if (l2 != sizeof(*ci)) { 308996076bbSAlfred Perlstein warnx("S_clockinfo %d != %d", l2, sizeof(*ci)); 309996076bbSAlfred Perlstein return (0); 310996076bbSAlfred Perlstein } 31145817aaaSDag-Erling Smørgrav printf(hflag ? "{ hz = %'d, tick = %'d, profhz = %'d, stathz = %'d }" : 31245817aaaSDag-Erling Smørgrav "{ hz = %d, tick = %d, profhz = %d, stathz = %d }", 313b35c8f28SPoul-Henning Kamp ci->hz, ci->tick, ci->profhz, ci->stathz); 3141d86b91cSPoul-Henning Kamp return (0); 315dea673e9SRodney W. Grimes } 316dea673e9SRodney W. Grimes 3171d86b91cSPoul-Henning Kamp static int 3181d86b91cSPoul-Henning Kamp S_loadavg(int l2, void *p) 3191d86b91cSPoul-Henning Kamp { 3201d86b91cSPoul-Henning Kamp struct loadavg *tv = (struct loadavg*)p; 3211d86b91cSPoul-Henning Kamp 322996076bbSAlfred Perlstein if (l2 != sizeof(*tv)) { 323996076bbSAlfred Perlstein warnx("S_loadavg %d != %d", l2, sizeof(*tv)); 324996076bbSAlfred Perlstein return (0); 325996076bbSAlfred Perlstein } 32645817aaaSDag-Erling Smørgrav printf(hflag ? "{ %'.2f %'.2f %'.2f }" : "{ %.2f %.2f %.2f }", 3271d86b91cSPoul-Henning Kamp (double)tv->ldavg[0]/(double)tv->fscale, 3281d86b91cSPoul-Henning Kamp (double)tv->ldavg[1]/(double)tv->fscale, 3291d86b91cSPoul-Henning Kamp (double)tv->ldavg[2]/(double)tv->fscale); 3301d86b91cSPoul-Henning Kamp return (0); 331dea673e9SRodney W. Grimes } 332dea673e9SRodney W. Grimes 3331d86b91cSPoul-Henning Kamp static int 3341d86b91cSPoul-Henning Kamp S_timeval(int l2, void *p) 3351d86b91cSPoul-Henning Kamp { 3361d86b91cSPoul-Henning Kamp struct timeval *tv = (struct timeval*)p; 337c2deb608SBruce Evans time_t tv_sec; 3381d86b91cSPoul-Henning Kamp char *p1, *p2; 339dea673e9SRodney W. Grimes 340996076bbSAlfred Perlstein if (l2 != sizeof(*tv)) { 341996076bbSAlfred Perlstein warnx("S_timeval %d != %d", l2, sizeof(*tv)); 342996076bbSAlfred Perlstein return (0); 343996076bbSAlfred Perlstein } 34445817aaaSDag-Erling Smørgrav printf(hflag ? "{ sec = %'ld, usec = %'ld } " : 34545817aaaSDag-Erling Smørgrav "{ sec = %ld, usec = %ld } ", 3461d86b91cSPoul-Henning Kamp tv->tv_sec, tv->tv_usec); 347c2deb608SBruce Evans tv_sec = tv->tv_sec; 348c2deb608SBruce Evans p1 = strdup(ctime(&tv_sec)); 3491d86b91cSPoul-Henning Kamp for (p2=p1; *p2 ; p2++) 3501d86b91cSPoul-Henning Kamp if (*p2 == '\n') 3511d86b91cSPoul-Henning Kamp *p2 = '\0'; 3521d86b91cSPoul-Henning Kamp fputs(p1, stdout); 3531d86b91cSPoul-Henning Kamp return (0); 3541d86b91cSPoul-Henning Kamp } 3551d86b91cSPoul-Henning Kamp 3561d86b91cSPoul-Henning Kamp static int 357f7550ecfSMatthew Dillon S_vmtotal(int l2, void *p) 358f7550ecfSMatthew Dillon { 359f7550ecfSMatthew Dillon struct vmtotal *v = (struct vmtotal *)p; 360654e22e7SMatthew Dillon int pageKilo = getpagesize() / 1024; 361f7550ecfSMatthew Dillon 362f7550ecfSMatthew Dillon if (l2 != sizeof(*v)) { 363f7550ecfSMatthew Dillon warnx("S_vmtotal %d != %d", l2, sizeof(*v)); 364f7550ecfSMatthew Dillon return (0); 365f7550ecfSMatthew Dillon } 366f7550ecfSMatthew Dillon 367654e22e7SMatthew Dillon printf( 368654e22e7SMatthew Dillon "\nSystem wide totals computed every five seconds:" 369654e22e7SMatthew Dillon " (values in kilobytes)\n"); 370f7550ecfSMatthew Dillon printf("===============================================\n"); 371654e22e7SMatthew Dillon printf( 372654e22e7SMatthew Dillon "Processes:\t\t(RUNQ: %hu Disk Wait: %hu Page Wait: " 373654e22e7SMatthew Dillon "%hu Sleep: %hu)\n", 374f7550ecfSMatthew Dillon v->t_rq, v->t_dw, v->t_pw, v->t_sl); 375654e22e7SMatthew Dillon printf( 376654e22e7SMatthew Dillon "Virtual Memory:\t\t(Total: %luK, Active %lldK)\n", 377654e22e7SMatthew Dillon (unsigned long)v->t_vm / 1024, 378654e22e7SMatthew Dillon (long long)v->t_avm * pageKilo); 379654e22e7SMatthew Dillon printf("Real Memory:\t\t(Total: %lldK Active %lldK)\n", 380654e22e7SMatthew Dillon (long long)v->t_rm * pageKilo, (long long)v->t_arm * pageKilo); 381654e22e7SMatthew Dillon printf("Shared Virtual Memory:\t(Total: %lldK Active: %lldK)\n", 382654e22e7SMatthew Dillon (long long)v->t_vmshr * pageKilo, 383654e22e7SMatthew Dillon (long long)v->t_avmshr * pageKilo); 384654e22e7SMatthew Dillon printf("Shared Real Memory:\t(Total: %lldK Active: %lldK)\n", 385654e22e7SMatthew Dillon (long long)v->t_rmshr * pageKilo, 386654e22e7SMatthew Dillon (long long)v->t_armshr * pageKilo); 387654e22e7SMatthew Dillon printf("Free Memory Pages:\t%ldK\n", (long long)v->t_free * pageKilo); 388f7550ecfSMatthew Dillon 389f7550ecfSMatthew Dillon return (0); 390f7550ecfSMatthew Dillon } 391f7550ecfSMatthew Dillon 392f7550ecfSMatthew Dillon static int 3931d86b91cSPoul-Henning Kamp T_dev_t(int l2, void *p) 3941d86b91cSPoul-Henning Kamp { 3951d86b91cSPoul-Henning Kamp dev_t *d = (dev_t *)p; 396996076bbSAlfred Perlstein if (l2 != sizeof(*d)) { 397996076bbSAlfred Perlstein warnx("T_dev_T %d != %d", l2, sizeof(*d)); 398996076bbSAlfred Perlstein return (0); 399996076bbSAlfred Perlstein } 4006ed3a297SPoul-Henning Kamp if ((int)(*d) != -1) { 4016ed3a297SPoul-Henning Kamp if (minor(*d) > 255 || minor(*d) < 0) 4026ed3a297SPoul-Henning Kamp printf("{ major = %d, minor = 0x%x }", 4036ed3a297SPoul-Henning Kamp major(*d), minor(*d)); 4046ed3a297SPoul-Henning Kamp else 4051d86b91cSPoul-Henning Kamp printf("{ major = %d, minor = %d }", 4061d86b91cSPoul-Henning Kamp major(*d), minor(*d)); 4076ed3a297SPoul-Henning Kamp } 4081d86b91cSPoul-Henning Kamp return (0); 4091d86b91cSPoul-Henning Kamp } 4101d86b91cSPoul-Henning Kamp 411d58f0054SPoul-Henning Kamp static void 4127e9c84c7SPeter Wemm set_T_dev_t (char *path, void **val, size_t *size) 413d58f0054SPoul-Henning Kamp { 414d58f0054SPoul-Henning Kamp static struct stat statb; 415d58f0054SPoul-Henning Kamp 416d58f0054SPoul-Henning Kamp if (strcmp(path, "none") && strcmp(path, "off")) { 417d58f0054SPoul-Henning Kamp int rc = stat (path, &statb); 418d58f0054SPoul-Henning Kamp if (rc) { 419d58f0054SPoul-Henning Kamp err(1, "cannot stat %s", path); 420d58f0054SPoul-Henning Kamp } 421d58f0054SPoul-Henning Kamp 422d58f0054SPoul-Henning Kamp if (!S_ISCHR(statb.st_mode)) { 423d58f0054SPoul-Henning Kamp errx(1, "must specify a device special file."); 424d58f0054SPoul-Henning Kamp } 425d58f0054SPoul-Henning Kamp } else { 426d58f0054SPoul-Henning Kamp statb.st_rdev = NODEV; 427d58f0054SPoul-Henning Kamp } 428d58f0054SPoul-Henning Kamp *val = (char*) &statb.st_rdev; 429d58f0054SPoul-Henning Kamp *size = sizeof statb.st_rdev; 430d58f0054SPoul-Henning Kamp } 431d58f0054SPoul-Henning Kamp 4321d86b91cSPoul-Henning Kamp /* 4331d86b91cSPoul-Henning Kamp * These functions uses a presently undocumented interface to the kernel 4341d86b91cSPoul-Henning Kamp * to walk the tree and get the type so it can print the value. 4351d86b91cSPoul-Henning Kamp * This interface is under work and consideration, and should probably 4361d86b91cSPoul-Henning Kamp * be killed with a big axe by the first person who can find the time. 4371d86b91cSPoul-Henning Kamp * (be aware though, that the proper interface isn't as obvious as it 4381d86b91cSPoul-Henning Kamp * may seem, there are various conflicting requirements. 4391d86b91cSPoul-Henning Kamp */ 4401d86b91cSPoul-Henning Kamp 4411d86b91cSPoul-Henning Kamp static int 4421d86b91cSPoul-Henning Kamp name2oid(char *name, int *oidp) 4431d86b91cSPoul-Henning Kamp { 4441d86b91cSPoul-Henning Kamp int oid[2]; 445dbf9b92fSDoug Rabson int i; 446dbf9b92fSDoug Rabson size_t j; 4471d86b91cSPoul-Henning Kamp 4481d86b91cSPoul-Henning Kamp oid[0] = 0; 4491d86b91cSPoul-Henning Kamp oid[1] = 3; 4501d86b91cSPoul-Henning Kamp 4511d86b91cSPoul-Henning Kamp j = CTL_MAXNAME * sizeof(int); 4521d86b91cSPoul-Henning Kamp i = sysctl(oid, 2, oidp, &j, name, strlen(name)); 4531d86b91cSPoul-Henning Kamp if (i < 0) 4541d86b91cSPoul-Henning Kamp return i; 4551d86b91cSPoul-Henning Kamp j /= sizeof(int); 4561d86b91cSPoul-Henning Kamp return (j); 4571d86b91cSPoul-Henning Kamp } 4581d86b91cSPoul-Henning Kamp 4591d86b91cSPoul-Henning Kamp static int 4601d86b91cSPoul-Henning Kamp oidfmt(int *oid, int len, char *fmt, u_int *kind) 4611d86b91cSPoul-Henning Kamp { 4621d86b91cSPoul-Henning Kamp int qoid[CTL_MAXNAME+2]; 4631d86b91cSPoul-Henning Kamp u_char buf[BUFSIZ]; 464dbf9b92fSDoug Rabson int i; 465dbf9b92fSDoug Rabson size_t j; 4661d86b91cSPoul-Henning Kamp 4671d86b91cSPoul-Henning Kamp qoid[0] = 0; 4681d86b91cSPoul-Henning Kamp qoid[1] = 4; 4691d86b91cSPoul-Henning Kamp memcpy(qoid + 2, oid, len * sizeof(int)); 4701d86b91cSPoul-Henning Kamp 47131fb4661SDima Dorfman j = sizeof(buf); 4721d86b91cSPoul-Henning Kamp i = sysctl(qoid, len + 2, buf, &j, 0, 0); 4731d86b91cSPoul-Henning Kamp if (i) 474d9b1bc77SPhilippe Charnier err(1, "sysctl fmt %d %d %d", i, j, errno); 4751d86b91cSPoul-Henning Kamp 4761d86b91cSPoul-Henning Kamp if (kind) 4771d86b91cSPoul-Henning Kamp *kind = *(u_int *)buf; 4781d86b91cSPoul-Henning Kamp 4791d86b91cSPoul-Henning Kamp if (fmt) 4801d86b91cSPoul-Henning Kamp strcpy(fmt, (char *)(buf + sizeof(u_int))); 4811d86b91cSPoul-Henning Kamp return 0; 4821d86b91cSPoul-Henning Kamp } 4831d86b91cSPoul-Henning Kamp 48460cf2c12SLuigi Rizzo /* 4851d86b91cSPoul-Henning Kamp * This formats and outputs the value of one variable 4861d86b91cSPoul-Henning Kamp * 4871d86b91cSPoul-Henning Kamp * Returns zero if anything was actually output. 4881d86b91cSPoul-Henning Kamp * Returns one if didn't know what to do with this. 4891d86b91cSPoul-Henning Kamp * Return minus one if we had errors. 4901d86b91cSPoul-Henning Kamp */ 4911d86b91cSPoul-Henning Kamp 4921d86b91cSPoul-Henning Kamp static int 4931d86b91cSPoul-Henning Kamp show_var(int *oid, int nlen) 4941d86b91cSPoul-Henning Kamp { 4951d86b91cSPoul-Henning Kamp u_char buf[BUFSIZ], *val, *p; 496d0b8aabbSAnton Berezin char name[BUFSIZ], *fmt, *sep; 4971d86b91cSPoul-Henning Kamp int qoid[CTL_MAXNAME+2]; 498dbf9b92fSDoug Rabson int i; 499dbf9b92fSDoug Rabson size_t j, len; 5001d86b91cSPoul-Henning Kamp u_int kind; 501a89ab9bbSDag-Erling Smørgrav int (*func)(int, void *); 5021d86b91cSPoul-Henning Kamp 50381e7454aSDag-Erling Smørgrav qoid[0] = 0; 50481e7454aSDag-Erling Smørgrav memcpy(qoid + 2, oid, nlen * sizeof(int)); 50581e7454aSDag-Erling Smørgrav 50681e7454aSDag-Erling Smørgrav qoid[1] = 1; 50731fb4661SDima Dorfman j = sizeof(name); 50881e7454aSDag-Erling Smørgrav i = sysctl(qoid, nlen + 2, name, &j, 0, 0); 50981e7454aSDag-Erling Smørgrav if (i || !j) 51081e7454aSDag-Erling Smørgrav err(1, "sysctl name %d %d %d", i, j, errno); 51181e7454aSDag-Erling Smørgrav 512ca5fac55SDag-Erling Smørgrav if (Nflag) { 513ca5fac55SDag-Erling Smørgrav printf("%s", name); 514ca5fac55SDag-Erling Smørgrav return (0); 515ca5fac55SDag-Erling Smørgrav } 516ca5fac55SDag-Erling Smørgrav 517d0b8aabbSAnton Berezin if (eflag) 518d0b8aabbSAnton Berezin sep = "="; 519d0b8aabbSAnton Berezin else 520d0b8aabbSAnton Berezin sep = ": "; 521d0b8aabbSAnton Berezin 5226105f815SLuigi Rizzo if (dflag) { /* just print description */ 5236105f815SLuigi Rizzo qoid[1] = 5; 5246105f815SLuigi Rizzo j = sizeof(buf); 5256105f815SLuigi Rizzo i = sysctl(qoid, nlen + 2, buf, &j, 0, 0); 5266105f815SLuigi Rizzo if (!nflag) 5276105f815SLuigi Rizzo printf("%s%s", name, sep); 5286105f815SLuigi Rizzo printf("%s", buf); 5296105f815SLuigi Rizzo return (0); 5306105f815SLuigi Rizzo } 5311d86b91cSPoul-Henning Kamp /* find an estimate of how much we need for this var */ 5321d86b91cSPoul-Henning Kamp j = 0; 5331d86b91cSPoul-Henning Kamp i = sysctl(oid, nlen, 0, &j, 0, 0); 5341d86b91cSPoul-Henning Kamp j += j; /* we want to be sure :-) */ 5351d86b91cSPoul-Henning Kamp 536661b2c16SPeter Wemm val = alloca(j + 1); 5371d86b91cSPoul-Henning Kamp len = j; 5381d86b91cSPoul-Henning Kamp i = sysctl(oid, nlen, val, &len, 0, 0); 5391d86b91cSPoul-Henning Kamp if (i || !len) 5401d86b91cSPoul-Henning Kamp return (1); 5411d86b91cSPoul-Henning Kamp 5421d86b91cSPoul-Henning Kamp if (bflag) { 5431d86b91cSPoul-Henning Kamp fwrite(val, 1, len, stdout); 5441d86b91cSPoul-Henning Kamp return (0); 5451d86b91cSPoul-Henning Kamp } 54676d3dc52SAndrey A. Chernov val[len] = '\0'; 547d58f0054SPoul-Henning Kamp fmt = buf; 548d58f0054SPoul-Henning Kamp oidfmt(oid, nlen, fmt, &kind); 5491d86b91cSPoul-Henning Kamp p = val; 5501d86b91cSPoul-Henning Kamp switch (*fmt) { 5511d86b91cSPoul-Henning Kamp case 'A': 5521d86b91cSPoul-Henning Kamp if (!nflag) 553d0b8aabbSAnton Berezin printf("%s%s", name, sep); 5549866352eSPeter Wemm printf("%.*s", len, p); 5551d86b91cSPoul-Henning Kamp return (0); 5561d86b91cSPoul-Henning Kamp 5571d86b91cSPoul-Henning Kamp case 'I': 5581d86b91cSPoul-Henning Kamp if (!nflag) 559d0b8aabbSAnton Berezin printf("%s%s", name, sep); 5609701cd40SJohn Baldwin fmt++; 5612b4c0a3bSPoul-Henning Kamp val = ""; 5622b4c0a3bSPoul-Henning Kamp while (len >= sizeof(int)) { 56345817aaaSDag-Erling Smørgrav fputs(val, stdout); 5649701cd40SJohn Baldwin if(*fmt == 'U') 56545817aaaSDag-Erling Smørgrav printf(hflag ? "%'u" : "%u", *(unsigned int *)p); 566c591d41fSPeter Wemm else if (*fmt == 'K') { 567c591d41fSPeter Wemm if (*(int *)p < 0) 568c591d41fSPeter Wemm printf("%d", *(int *)p); 5699701cd40SJohn Baldwin else 570c591d41fSPeter Wemm printf("%d.%dC", (*(int *)p - 2732) / 10, (*(int *)p - 2732) % 10); 571c591d41fSPeter Wemm } else 57245817aaaSDag-Erling Smørgrav printf(hflag ? "%'d" : "%d", *(int *)p); 5732b4c0a3bSPoul-Henning Kamp val = " "; 5742b4c0a3bSPoul-Henning Kamp len -= sizeof(int); 5752b4c0a3bSPoul-Henning Kamp p += sizeof(int); 5762b4c0a3bSPoul-Henning Kamp } 5771d86b91cSPoul-Henning Kamp return (0); 5781d86b91cSPoul-Henning Kamp 579dbf9b92fSDoug Rabson case 'L': 580dbf9b92fSDoug Rabson if (!nflag) 581d0b8aabbSAnton Berezin printf("%s%s", name, sep); 5829701cd40SJohn Baldwin fmt++; 583aa02fb57SPoul-Henning Kamp val = ""; 584aa02fb57SPoul-Henning Kamp while (len >= sizeof(long)) { 58545817aaaSDag-Erling Smørgrav fputs(val, stdout); 5869701cd40SJohn Baldwin if(*fmt == 'U') 58745817aaaSDag-Erling Smørgrav printf(hflag ? "%'lu" : "%lu", *(unsigned long *)p); 588c591d41fSPeter Wemm else if (*fmt == 'K') { 589c591d41fSPeter Wemm if (*(long *)p < 0) 590c591d41fSPeter Wemm printf("%ld", *(long *)p); 5919701cd40SJohn Baldwin else 592c591d41fSPeter Wemm printf("%ld.%ldC", (*(long *)p - 2732) / 10, (*(long *)p - 2732) % 10); 593c591d41fSPeter Wemm } else 59445817aaaSDag-Erling Smørgrav printf(hflag ? "%'ld" : "%ld", *(long *)p); 595aa02fb57SPoul-Henning Kamp val = " "; 5963c884b50SAndrew Gallatin len -= sizeof(long); 5973c884b50SAndrew Gallatin p += sizeof(long); 598aa02fb57SPoul-Henning Kamp } 599dbf9b92fSDoug Rabson return (0); 600dbf9b92fSDoug Rabson 601dbf9b92fSDoug Rabson case 'P': 602dbf9b92fSDoug Rabson if (!nflag) 603d0b8aabbSAnton Berezin printf("%s%s", name, sep); 604dbf9b92fSDoug Rabson printf("%p", *(void **)p); 605dbf9b92fSDoug Rabson return (0); 606dbf9b92fSDoug Rabson 6071d86b91cSPoul-Henning Kamp case 'T': 6081d86b91cSPoul-Henning Kamp case 'S': 6091d86b91cSPoul-Henning Kamp i = 0; 610a89ab9bbSDag-Erling Smørgrav if (strcmp(fmt, "S,clockinfo") == 0) 611a89ab9bbSDag-Erling Smørgrav func = S_clockinfo; 612a89ab9bbSDag-Erling Smørgrav else if (strcmp(fmt, "S,timeval") == 0) 613a89ab9bbSDag-Erling Smørgrav func = S_timeval; 614a89ab9bbSDag-Erling Smørgrav else if (strcmp(fmt, "S,loadavg") == 0) 615a89ab9bbSDag-Erling Smørgrav func = S_loadavg; 616f7550ecfSMatthew Dillon else if (strcmp(fmt, "S,vmtotal") == 0) 617f7550ecfSMatthew Dillon func = S_vmtotal; 618a89ab9bbSDag-Erling Smørgrav else if (strcmp(fmt, "T,dev_t") == 0) 619a89ab9bbSDag-Erling Smørgrav func = T_dev_t; 620a89ab9bbSDag-Erling Smørgrav else 621a89ab9bbSDag-Erling Smørgrav func = NULL; 6221d86b91cSPoul-Henning Kamp if (func) { 6231d86b91cSPoul-Henning Kamp if (!nflag) 624d0b8aabbSAnton Berezin printf("%s%s", name, sep); 6251d86b91cSPoul-Henning Kamp return ((*func)(len, p)); 6261d86b91cSPoul-Henning Kamp } 6271d86b91cSPoul-Henning Kamp /* FALLTHROUGH */ 628dea673e9SRodney W. Grimes default: 6299a2402bcSDag-Erling Smørgrav if (!oflag && !xflag) 6301d86b91cSPoul-Henning Kamp return (1); 6311d86b91cSPoul-Henning Kamp if (!nflag) 632d0b8aabbSAnton Berezin printf("%s%s", name, sep); 6331d86b91cSPoul-Henning Kamp printf("Format:%s Length:%d Dump:0x", fmt, len); 634a89ab9bbSDag-Erling Smørgrav while (len-- && (xflag || p < val + 16)) 6351d86b91cSPoul-Henning Kamp printf("%02x", *p++); 636a89ab9bbSDag-Erling Smørgrav if (!xflag && len > 16) 6371d86b91cSPoul-Henning Kamp printf("..."); 6381d86b91cSPoul-Henning Kamp return (0); 6391d86b91cSPoul-Henning Kamp } 6401d86b91cSPoul-Henning Kamp return (1); 641dea673e9SRodney W. Grimes } 642dea673e9SRodney W. Grimes 6431d86b91cSPoul-Henning Kamp static int 6441d86b91cSPoul-Henning Kamp sysctl_all (int *oid, int len) 645dea673e9SRodney W. Grimes { 6461d86b91cSPoul-Henning Kamp int name1[22], name2[22]; 647dbf9b92fSDoug Rabson int i, j; 648dbf9b92fSDoug Rabson size_t l1, l2; 649dea673e9SRodney W. Grimes 6501d86b91cSPoul-Henning Kamp name1[0] = 0; 6511d86b91cSPoul-Henning Kamp name1[1] = 2; 6521d86b91cSPoul-Henning Kamp l1 = 2; 6531d86b91cSPoul-Henning Kamp if (len) { 6541d86b91cSPoul-Henning Kamp memcpy(name1+2, oid, len * sizeof(int)); 6551d86b91cSPoul-Henning Kamp l1 += len; 6561d86b91cSPoul-Henning Kamp } else { 6571d86b91cSPoul-Henning Kamp name1[2] = 1; 6581d86b91cSPoul-Henning Kamp l1++; 6591d86b91cSPoul-Henning Kamp } 660a89ab9bbSDag-Erling Smørgrav for (;;) { 66131fb4661SDima Dorfman l2 = sizeof(name2); 6621d86b91cSPoul-Henning Kamp j = sysctl(name1, l1, name2, &l2, 0, 0); 663c1160fe4SBill Fumerola if (j < 0) { 6641d86b91cSPoul-Henning Kamp if (errno == ENOENT) 6651d86b91cSPoul-Henning Kamp return 0; 6661d86b91cSPoul-Henning Kamp else 667d9b1bc77SPhilippe Charnier err(1, "sysctl(getnext) %d %d", j, l2); 668c1160fe4SBill Fumerola } 6691d86b91cSPoul-Henning Kamp 6701d86b91cSPoul-Henning Kamp l2 /= sizeof(int); 6711d86b91cSPoul-Henning Kamp 6721d86b91cSPoul-Henning Kamp if (l2 < len) 6731d86b91cSPoul-Henning Kamp return 0; 6741d86b91cSPoul-Henning Kamp 6751d86b91cSPoul-Henning Kamp for (i = 0; i < len; i++) 6761d86b91cSPoul-Henning Kamp if (name2[i] != oid[i]) 6771d86b91cSPoul-Henning Kamp return 0; 6781d86b91cSPoul-Henning Kamp 6791d86b91cSPoul-Henning Kamp i = show_var(name2, l2); 6801d86b91cSPoul-Henning Kamp if (!i && !bflag) 6811d86b91cSPoul-Henning Kamp putchar('\n'); 6821d86b91cSPoul-Henning Kamp 6831d86b91cSPoul-Henning Kamp memcpy(name1+2, name2, l2 * sizeof(int)); 6841d86b91cSPoul-Henning Kamp l1 = 2 + l2; 6851d86b91cSPoul-Henning Kamp } 686dea673e9SRodney W. Grimes } 687