183f9dfabSGarrett Wollman /* 283f9dfabSGarrett Wollman * Copyright (c) 1980, 1993 383f9dfabSGarrett Wollman * The Regents of the University of California. All rights reserved. 483f9dfabSGarrett Wollman * 583f9dfabSGarrett Wollman * Redistribution and use in source and binary forms, with or without 683f9dfabSGarrett Wollman * modification, are permitted provided that the following conditions 783f9dfabSGarrett Wollman * are met: 883f9dfabSGarrett Wollman * 1. Redistributions of source code must retain the above copyright 983f9dfabSGarrett Wollman * notice, this list of conditions and the following disclaimer. 1083f9dfabSGarrett Wollman * 2. Redistributions in binary form must reproduce the above copyright 1183f9dfabSGarrett Wollman * notice, this list of conditions and the following disclaimer in the 1283f9dfabSGarrett Wollman * documentation and/or other materials provided with the distribution. 1383f9dfabSGarrett Wollman * 4. Neither the name of the University nor the names of its contributors 1483f9dfabSGarrett Wollman * may be used to endorse or promote products derived from this software 1583f9dfabSGarrett Wollman * without specific prior written permission. 1683f9dfabSGarrett Wollman * 1783f9dfabSGarrett Wollman * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 1883f9dfabSGarrett Wollman * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 1983f9dfabSGarrett Wollman * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 2083f9dfabSGarrett Wollman * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 2183f9dfabSGarrett Wollman * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 2283f9dfabSGarrett Wollman * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 2383f9dfabSGarrett Wollman * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 2483f9dfabSGarrett Wollman * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 2583f9dfabSGarrett Wollman * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 2683f9dfabSGarrett Wollman * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 2783f9dfabSGarrett Wollman * SUCH DAMAGE. 2883f9dfabSGarrett Wollman */ 2983f9dfabSGarrett Wollman 30c69284caSDavid E. O'Brien #if 0 3183f9dfabSGarrett Wollman #ifndef lint 328f034b11SPhilippe Charnier static const char copyright[] = 3383f9dfabSGarrett Wollman "@(#) Copyright (c) 1980, 1993\n\ 3483f9dfabSGarrett Wollman The Regents of the University of California. All rights reserved.\n"; 3583f9dfabSGarrett Wollman #endif /* not lint */ 3683f9dfabSGarrett Wollman 3783f9dfabSGarrett Wollman #ifndef lint 388f034b11SPhilippe Charnier static char sccsid[] = "From: @(#)swapon.c 8.1 (Berkeley) 6/5/93"; 3983f9dfabSGarrett Wollman #endif /* not lint */ 40c69284caSDavid E. O'Brien #endif 41c69284caSDavid E. O'Brien #include <sys/cdefs.h> 42c69284caSDavid E. O'Brien __FBSDID("$FreeBSD$"); 4383f9dfabSGarrett Wollman 4483f9dfabSGarrett Wollman #include <sys/param.h> 452dd527b3SPoul-Henning Kamp #include <sys/disk.h> 46c0046e26SDag-Erling Smørgrav #include <sys/sysctl.h> 4783f9dfabSGarrett Wollman 48c0046e26SDag-Erling Smørgrav #include <err.h> 49f6848434SAlfred Perlstein #include <errno.h> 50c0046e26SDag-Erling Smørgrav #include <fcntl.h> 51c0046e26SDag-Erling Smørgrav #include <paths.h> 52c0046e26SDag-Erling Smørgrav #include <stdint.h> 53c0046e26SDag-Erling Smørgrav #include <stdio.h> 54c0046e26SDag-Erling Smørgrav #include <stdlib.h> 55c0046e26SDag-Erling Smørgrav #include <string.h> 56c0046e26SDag-Erling Smørgrav #include <sysexits.h> 57c0046e26SDag-Erling Smørgrav #include <unistd.h> 58c0046e26SDag-Erling Smørgrav 59c0046e26SDag-Erling Smørgrav static int verbose; 60c0046e26SDag-Erling Smørgrav 61c0046e26SDag-Erling Smørgrav static void 62c0046e26SDag-Erling Smørgrav usage(void) 63c0046e26SDag-Erling Smørgrav { 64f6848434SAlfred Perlstein fprintf(stderr, "%s\n%s\n%s\n", 65c0046e26SDag-Erling Smørgrav "usage: dumpon [-v] special_file", 66f6848434SAlfred Perlstein " dumpon [-v] off", 674a790eddSAlfred Perlstein " dumpon [-v] -l"); 68c0046e26SDag-Erling Smørgrav exit(EX_USAGE); 69c0046e26SDag-Erling Smørgrav } 70c0046e26SDag-Erling Smørgrav 71c0046e26SDag-Erling Smørgrav static void 72c0046e26SDag-Erling Smørgrav check_size(int fd, const char *fn) 73c0046e26SDag-Erling Smørgrav { 74c0046e26SDag-Erling Smørgrav int name[] = { CTL_HW, HW_PHYSMEM }; 75*0bfc2a12SMarcelo Araujo size_t namelen = nitems(name); 76c0046e26SDag-Erling Smørgrav unsigned long physmem; 77ce893772SPaul Saab size_t len; 78c0046e26SDag-Erling Smørgrav off_t mediasize; 79ce893772SPaul Saab int minidump; 80c0046e26SDag-Erling Smørgrav 81b54a17cdSJohn Baldwin len = sizeof(minidump); 82ce893772SPaul Saab if (sysctlbyname("debug.minidump", &minidump, &len, NULL, 0) == 0 && 83ce893772SPaul Saab minidump == 1) 84ce893772SPaul Saab return; 85b54a17cdSJohn Baldwin len = sizeof(physmem); 86c0046e26SDag-Erling Smørgrav if (sysctl(name, namelen, &physmem, &len, NULL, 0) != 0) 87c0046e26SDag-Erling Smørgrav err(EX_OSERR, "can't get memory size"); 88c0046e26SDag-Erling Smørgrav if (ioctl(fd, DIOCGMEDIASIZE, &mediasize) != 0) 89c0046e26SDag-Erling Smørgrav err(EX_OSERR, "%s: can't get size", fn); 909872f15dSDag-Erling Smørgrav if ((uintmax_t)mediasize < (uintmax_t)physmem) { 91c0046e26SDag-Erling Smørgrav if (verbose) 92c0046e26SDag-Erling Smørgrav printf("%s is smaller than physical memory\n", fn); 93c0046e26SDag-Erling Smørgrav exit(EX_IOERR); 94c0046e26SDag-Erling Smørgrav } 95c0046e26SDag-Erling Smørgrav } 9683f9dfabSGarrett Wollman 97f6848434SAlfred Perlstein static void 98f6848434SAlfred Perlstein listdumpdev(void) 99f6848434SAlfred Perlstein { 100f6848434SAlfred Perlstein char dumpdev[PATH_MAX]; 101f6848434SAlfred Perlstein size_t len; 102f6848434SAlfred Perlstein const char *sysctlname = "kern.shutdown.dumpdevname"; 103f6848434SAlfred Perlstein 104f6848434SAlfred Perlstein len = sizeof(dumpdev); 105f6848434SAlfred Perlstein if (sysctlbyname(sysctlname, &dumpdev, &len, NULL, 0) != 0) { 106f6848434SAlfred Perlstein if (errno == ENOMEM) { 107f6848434SAlfred Perlstein err(EX_OSERR, "Kernel returned too large of a buffer for '%s'\n", 108f6848434SAlfred Perlstein sysctlname); 109f6848434SAlfred Perlstein } else { 110f6848434SAlfred Perlstein err(EX_OSERR, "Sysctl get '%s'\n", sysctlname); 111f6848434SAlfred Perlstein } 112f6848434SAlfred Perlstein } 113f6848434SAlfred Perlstein if (verbose) { 114f6848434SAlfred Perlstein printf("kernel dumps on "); 115f6848434SAlfred Perlstein } 116f6848434SAlfred Perlstein if (strlen(dumpdev) == 0) { 117f6848434SAlfred Perlstein printf("%s\n", _PATH_DEVNULL); 118f6848434SAlfred Perlstein } else { 119f6848434SAlfred Perlstein printf("%s\n", dumpdev); 120f6848434SAlfred Perlstein } 121f6848434SAlfred Perlstein } 122f6848434SAlfred Perlstein 12383f9dfabSGarrett Wollman int 124d1a939c1SWarner Losh main(int argc, char *argv[]) 12583f9dfabSGarrett Wollman { 126c0046e26SDag-Erling Smørgrav int ch; 1279e9c1cadSPoul-Henning Kamp int i, fd; 1289e9c1cadSPoul-Henning Kamp u_int u; 129f6848434SAlfred Perlstein int do_listdumpdev = 0; 13083f9dfabSGarrett Wollman 131f6848434SAlfred Perlstein while ((ch = getopt(argc, argv, "lv")) != -1) 13283f9dfabSGarrett Wollman switch((char)ch) { 133f6848434SAlfred Perlstein case 'l': 134f6848434SAlfred Perlstein do_listdumpdev = 1; 135f6848434SAlfred Perlstein break; 13683f9dfabSGarrett Wollman case 'v': 13783f9dfabSGarrett Wollman verbose = 1; 13883f9dfabSGarrett Wollman break; 13983f9dfabSGarrett Wollman default: 14083f9dfabSGarrett Wollman usage(); 14183f9dfabSGarrett Wollman } 142c0046e26SDag-Erling Smørgrav 143c0046e26SDag-Erling Smørgrav argc -= optind; 14483f9dfabSGarrett Wollman argv += optind; 14583f9dfabSGarrett Wollman 146f6848434SAlfred Perlstein if (do_listdumpdev) { 147f6848434SAlfred Perlstein listdumpdev(); 148f6848434SAlfred Perlstein exit(EX_OK); 149f6848434SAlfred Perlstein } 150f6848434SAlfred Perlstein 151c0046e26SDag-Erling Smørgrav if (argc != 1) 15283f9dfabSGarrett Wollman usage(); 15383f9dfabSGarrett Wollman 154c0046e26SDag-Erling Smørgrav if (strcmp(argv[0], "off") != 0) { 15545a9027dSSteven Hartland char tmp[PATH_MAX]; 15645a9027dSSteven Hartland char *dumpdev; 15745a9027dSSteven Hartland 15845a9027dSSteven Hartland if (strncmp(argv[0], _PATH_DEV, sizeof(_PATH_DEV) - 1) == 0) { 15945a9027dSSteven Hartland dumpdev = argv[0]; 16045a9027dSSteven Hartland } else { 16145a9027dSSteven Hartland i = snprintf(tmp, PATH_MAX, "%s%s", _PATH_DEV, argv[0]); 16245a9027dSSteven Hartland if (i < 0) { 16345a9027dSSteven Hartland err(EX_OSERR, "%s", argv[0]); 16445a9027dSSteven Hartland } else if (i >= PATH_MAX) { 16545a9027dSSteven Hartland errno = EINVAL; 16645a9027dSSteven Hartland err(EX_DATAERR, "%s", argv[0]); 16745a9027dSSteven Hartland } 16845a9027dSSteven Hartland dumpdev = tmp; 16945a9027dSSteven Hartland } 17045a9027dSSteven Hartland fd = open(dumpdev, O_RDONLY); 1719e9c1cadSPoul-Henning Kamp if (fd < 0) 17245a9027dSSteven Hartland err(EX_OSFILE, "%s", dumpdev); 17345a9027dSSteven Hartland check_size(fd, dumpdev); 1749e9c1cadSPoul-Henning Kamp u = 0; 1757f086a08SPoul-Henning Kamp i = ioctl(fd, DIOCSKERNELDUMP, &u); 1769e9c1cadSPoul-Henning Kamp u = 1; 1777f086a08SPoul-Henning Kamp i = ioctl(fd, DIOCSKERNELDUMP, &u); 1789e9c1cadSPoul-Henning Kamp if (i == 0 && verbose) 17945a9027dSSteven Hartland printf("kernel dumps on %s\n", dumpdev); 18083f9dfabSGarrett Wollman } else { 1819e9c1cadSPoul-Henning Kamp fd = open(_PATH_DEVNULL, O_RDONLY); 1829e9c1cadSPoul-Henning Kamp if (fd < 0) 1839e9c1cadSPoul-Henning Kamp err(EX_OSFILE, "%s", _PATH_DEVNULL); 1849e9c1cadSPoul-Henning Kamp u = 0; 1857f086a08SPoul-Henning Kamp i = ioctl(fd, DIOCSKERNELDUMP, &u); 1869e9c1cadSPoul-Henning Kamp if (i == 0 && verbose) 1879e9c1cadSPoul-Henning Kamp printf("kernel dumps disabled\n"); 18883f9dfabSGarrett Wollman } 1899e9c1cadSPoul-Henning Kamp if (i < 0) 1907f086a08SPoul-Henning Kamp err(EX_OSERR, "ioctl(DIOCSKERNELDUMP)"); 19183f9dfabSGarrett Wollman 1929e9c1cadSPoul-Henning Kamp exit (0); 19383f9dfabSGarrett Wollman } 194