swapctl.c revision 1.26 1 1.26 cjep /* $NetBSD: swapctl.c,v 1.26 2004/06/08 08:13:16 cjep Exp $ */
2 1.1 mrg
3 1.1 mrg /*
4 1.11 mrg * Copyright (c) 1996, 1997, 1999 Matthew R. Green
5 1.1 mrg * All rights reserved.
6 1.1 mrg *
7 1.1 mrg * Redistribution and use in source and binary forms, with or without
8 1.1 mrg * modification, are permitted provided that the following conditions
9 1.1 mrg * are met:
10 1.1 mrg * 1. Redistributions of source code must retain the above copyright
11 1.1 mrg * notice, this list of conditions and the following disclaimer.
12 1.1 mrg * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 mrg * notice, this list of conditions and the following disclaimer in the
14 1.1 mrg * documentation and/or other materials provided with the distribution.
15 1.7 mrg * 3. The name of the author may not be used to endorse or promote products
16 1.1 mrg * derived from this software without specific prior written permission.
17 1.1 mrg *
18 1.1 mrg * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
19 1.1 mrg * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
20 1.1 mrg * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
21 1.1 mrg * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
22 1.1 mrg * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
23 1.1 mrg * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
24 1.1 mrg * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
25 1.1 mrg * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
26 1.1 mrg * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
27 1.1 mrg * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
28 1.1 mrg * SUCH DAMAGE.
29 1.1 mrg */
30 1.1 mrg
31 1.1 mrg /*
32 1.1 mrg * swapctl command:
33 1.10 mrg * -A add all devices listed as `sw' in /etc/fstab (also
34 1.13 soren * (sets the dump device, if listed in fstab)
35 1.10 mrg * -D <dev> set dumpdev to <dev>
36 1.16 mrg * -z show dumpdev
37 1.12 lukem * -U remove all devices listed as `sw' in /etc/fstab.
38 1.12 lukem * -t [blk|noblk] if -A or -U , add (remove) either all block device
39 1.12 lukem * or all non-block devices
40 1.1 mrg * -a <dev> add this device
41 1.17 lukem * -d <dev> remove this swap device
42 1.25 mrg * -g use gigabytes
43 1.24 mrg * -h use humanize_number(3) for listing
44 1.1 mrg * -l list swap devices
45 1.25 mrg * -m use megabytes
46 1.1 mrg * -s short listing of swap devices
47 1.1 mrg * -k use kilobytes
48 1.1 mrg * -p <pri> use this priority
49 1.1 mrg * -c change priority
50 1.2 thorpej *
51 1.2 thorpej * or, if invoked as "swapon" (compatibility mode):
52 1.2 thorpej *
53 1.2 thorpej * -a all devices listed as `sw' in /etc/fstab
54 1.4 thorpej * -t same as -t above (feature not present in old
55 1.4 thorpej * swapon(8) command)
56 1.2 thorpej * <dev> add this device
57 1.1 mrg */
58 1.22 agc #include <sys/cdefs.h>
59 1.22 agc
60 1.22 agc #ifndef lint
61 1.26 cjep __RCSID("$NetBSD: swapctl.c,v 1.26 2004/06/08 08:13:16 cjep Exp $");
62 1.22 agc #endif
63 1.22 agc
64 1.1 mrg
65 1.1 mrg #include <sys/param.h>
66 1.4 thorpej #include <sys/stat.h>
67 1.14 mrg #include <sys/swap.h>
68 1.1 mrg
69 1.1 mrg #include <unistd.h>
70 1.3 mikel #include <err.h>
71 1.1 mrg #include <errno.h>
72 1.1 mrg #include <stdio.h>
73 1.1 mrg #include <stdlib.h>
74 1.1 mrg #include <string.h>
75 1.1 mrg #include <fstab.h>
76 1.1 mrg
77 1.1 mrg #include "swapctl.h"
78 1.1 mrg
79 1.2 thorpej int command;
80 1.2 thorpej
81 1.2 thorpej /*
82 1.2 thorpej * Commands for swapctl(8). These are mutually exclusive.
83 1.2 thorpej */
84 1.12 lukem #define CMD_A 0x01 /* process /etc/fstab for adding */
85 1.10 mrg #define CMD_D 0x02 /* set dumpdev */
86 1.12 lukem #define CMD_U 0x04 /* process /etc/fstab for removing */
87 1.12 lukem #define CMD_a 0x08 /* add a swap file/device */
88 1.12 lukem #define CMD_c 0x10 /* change priority of a swap file/device */
89 1.12 lukem #define CMD_d 0x20 /* delete a swap file/device */
90 1.12 lukem #define CMD_l 0x40 /* list swap files/devices */
91 1.12 lukem #define CMD_s 0x80 /* summary of swap files/devices */
92 1.16 mrg #define CMD_z 0x100 /* show dump device */
93 1.2 thorpej
94 1.2 thorpej #define SET_COMMAND(cmd) \
95 1.2 thorpej do { \
96 1.2 thorpej if (command) \
97 1.2 thorpej usage(); \
98 1.2 thorpej command = (cmd); \
99 1.2 thorpej } while (0)
100 1.2 thorpej
101 1.2 thorpej /*
102 1.2 thorpej * Commands that require a "path" argument at the end of the command
103 1.2 thorpej * line, and the ones which require that none exist.
104 1.2 thorpej */
105 1.10 mrg #define REQUIRE_PATH (CMD_D | CMD_a | CMD_c | CMD_d)
106 1.16 mrg #define REQUIRE_NOPATH (CMD_A | CMD_U | CMD_l | CMD_s | CMD_z)
107 1.2 thorpej
108 1.2 thorpej /*
109 1.2 thorpej * Option flags, and the commands with which they are valid.
110 1.2 thorpej */
111 1.25 mrg int kflag; /* display in 1K^x blocks */
112 1.2 thorpej #define KFLAG_CMDS (CMD_l | CMD_s)
113 1.25 mrg #define MFLAG_CMDS (CMD_l | CMD_s)
114 1.25 mrg #define GFLAG_CMDS (CMD_l | CMD_s)
115 1.2 thorpej
116 1.24 mrg int hflag; /* display with humanize_number */
117 1.24 mrg #define HFLAG_CMDS (CMD_l | CMD_s)
118 1.24 mrg
119 1.2 thorpej int pflag; /* priority was specified */
120 1.2 thorpej #define PFLAG_CMDS (CMD_A | CMD_a | CMD_c)
121 1.2 thorpej
122 1.4 thorpej char *tflag; /* swap device type (blk or noblk) */
123 1.16 mrg #define TFLAG_CMDS (CMD_A | CMD_U)
124 1.4 thorpej
125 1.1 mrg int pri; /* uses 0 as default pri */
126 1.1 mrg
127 1.10 mrg static void change_priority __P((const char *));
128 1.12 lukem static int add_swap __P((const char *, int));
129 1.12 lukem static int delete_swap __P((const char *));
130 1.10 mrg static void set_dumpdev __P((const char *));
131 1.16 mrg static void get_dumpdev __P((void));
132 1.6 lukem int main __P((int, char *[]));
133 1.12 lukem static void do_fstab __P((int));
134 1.1 mrg static void usage __P((void));
135 1.2 thorpej static void swapon_command __P((int, char **));
136 1.2 thorpej #if 0
137 1.2 thorpej static void swapoff_command __P((int, char **));
138 1.2 thorpej #endif
139 1.2 thorpej
140 1.1 mrg int
141 1.1 mrg main(argc, argv)
142 1.1 mrg int argc;
143 1.1 mrg char *argv[];
144 1.1 mrg {
145 1.1 mrg int c;
146 1.2 thorpej
147 1.18 cgd if (strcmp(getprogname(), "swapon") == 0) {
148 1.2 thorpej swapon_command(argc, argv);
149 1.2 thorpej /* NOTREACHED */
150 1.2 thorpej }
151 1.2 thorpej
152 1.2 thorpej #if 0
153 1.18 cgd if (strcmp(getprogname(), "swapoff") == 0) {
154 1.2 thorpej swapoff_command(argc, argv);
155 1.2 thorpej /* NOTREACHED */
156 1.2 thorpej }
157 1.2 thorpej #endif
158 1.2 thorpej
159 1.25 mrg while ((c = getopt(argc, argv, "ADUacdghklmp:st:z")) != -1) {
160 1.2 thorpej switch (c) {
161 1.1 mrg case 'A':
162 1.2 thorpej SET_COMMAND(CMD_A);
163 1.1 mrg break;
164 1.2 thorpej
165 1.10 mrg case 'D':
166 1.10 mrg SET_COMMAND(CMD_D);
167 1.10 mrg break;
168 1.10 mrg
169 1.12 lukem case 'U':
170 1.12 lukem SET_COMMAND(CMD_U);
171 1.12 lukem break;
172 1.12 lukem
173 1.1 mrg case 'a':
174 1.2 thorpej SET_COMMAND(CMD_a);
175 1.1 mrg break;
176 1.2 thorpej
177 1.1 mrg case 'c':
178 1.2 thorpej SET_COMMAND(CMD_c);
179 1.1 mrg break;
180 1.2 thorpej
181 1.1 mrg case 'd':
182 1.2 thorpej SET_COMMAND(CMD_d);
183 1.1 mrg break;
184 1.2 thorpej
185 1.25 mrg case 'g':
186 1.25 mrg kflag = 3; /* 1k ^ 3 */
187 1.25 mrg break;
188 1.25 mrg
189 1.24 mrg case 'h':
190 1.24 mrg hflag = 1;
191 1.24 mrg break;
192 1.24 mrg
193 1.25 mrg case 'k':
194 1.25 mrg kflag = 1;
195 1.25 mrg break;
196 1.25 mrg
197 1.1 mrg case 'l':
198 1.2 thorpej SET_COMMAND(CMD_l);
199 1.1 mrg break;
200 1.2 thorpej
201 1.25 mrg case 'm':
202 1.25 mrg kflag = 2; /* 1k ^ 2 */
203 1.1 mrg break;
204 1.2 thorpej
205 1.1 mrg case 'p':
206 1.1 mrg pflag = 1;
207 1.2 thorpej /* XXX strtol() */
208 1.1 mrg pri = atoi(optarg);
209 1.1 mrg break;
210 1.2 thorpej
211 1.1 mrg case 's':
212 1.2 thorpej SET_COMMAND(CMD_s);
213 1.1 mrg break;
214 1.2 thorpej
215 1.4 thorpej case 't':
216 1.4 thorpej if (tflag != NULL)
217 1.4 thorpej usage();
218 1.4 thorpej tflag = optarg;
219 1.4 thorpej break;
220 1.4 thorpej
221 1.16 mrg case 'z':
222 1.16 mrg SET_COMMAND(CMD_z);
223 1.16 mrg break;
224 1.16 mrg
225 1.2 thorpej default:
226 1.2 thorpej usage();
227 1.2 thorpej /* NOTREACHED */
228 1.1 mrg }
229 1.1 mrg }
230 1.2 thorpej
231 1.2 thorpej /* Did the user specify a command? */
232 1.2 thorpej if (command == 0)
233 1.1 mrg usage();
234 1.1 mrg
235 1.1 mrg argv += optind;
236 1.2 thorpej argc -= optind;
237 1.2 thorpej
238 1.2 thorpej switch (argc) {
239 1.2 thorpej case 0:
240 1.2 thorpej if (command & REQUIRE_PATH)
241 1.2 thorpej usage();
242 1.2 thorpej break;
243 1.2 thorpej
244 1.2 thorpej case 1:
245 1.2 thorpej if (command & REQUIRE_NOPATH)
246 1.2 thorpej usage();
247 1.2 thorpej break;
248 1.2 thorpej
249 1.2 thorpej default:
250 1.1 mrg usage();
251 1.2 thorpej }
252 1.2 thorpej
253 1.2 thorpej /* To change priority, you have to specify one. */
254 1.2 thorpej if ((command == CMD_c) && pflag == 0)
255 1.1 mrg usage();
256 1.1 mrg
257 1.4 thorpej /* Sanity-check -t */
258 1.4 thorpej if (tflag != NULL) {
259 1.12 lukem if (command != CMD_A && command != CMD_U)
260 1.4 thorpej usage();
261 1.4 thorpej if (strcmp(tflag, "blk") != 0 &&
262 1.4 thorpej strcmp(tflag, "noblk") != 0)
263 1.4 thorpej usage();
264 1.4 thorpej }
265 1.4 thorpej
266 1.2 thorpej /* Dispatch the command. */
267 1.2 thorpej switch (command) {
268 1.2 thorpej case CMD_l:
269 1.24 mrg list_swap(pri, kflag, pflag, 0, 1, hflag);
270 1.2 thorpej break;
271 1.2 thorpej
272 1.2 thorpej case CMD_s:
273 1.24 mrg list_swap(pri, kflag, pflag, 0, 0, hflag);
274 1.2 thorpej break;
275 1.2 thorpej
276 1.2 thorpej case CMD_c:
277 1.1 mrg change_priority(argv[0]);
278 1.2 thorpej break;
279 1.2 thorpej
280 1.2 thorpej case CMD_a:
281 1.12 lukem if (! add_swap(argv[0], pri))
282 1.12 lukem exit(1);
283 1.2 thorpej break;
284 1.2 thorpej
285 1.2 thorpej case CMD_d:
286 1.12 lukem if (! delete_swap(argv[0]))
287 1.12 lukem exit(1);
288 1.2 thorpej break;
289 1.2 thorpej
290 1.2 thorpej case CMD_A:
291 1.12 lukem do_fstab(1);
292 1.2 thorpej break;
293 1.10 mrg
294 1.10 mrg case CMD_D:
295 1.10 mrg set_dumpdev(argv[0]);
296 1.10 mrg break;
297 1.12 lukem
298 1.16 mrg case CMD_z:
299 1.16 mrg get_dumpdev();
300 1.16 mrg break;
301 1.16 mrg
302 1.12 lukem case CMD_U:
303 1.12 lukem do_fstab(0);
304 1.12 lukem break;
305 1.2 thorpej }
306 1.2 thorpej
307 1.2 thorpej exit(0);
308 1.2 thorpej }
309 1.2 thorpej
310 1.2 thorpej /*
311 1.2 thorpej * swapon_command: emulate the old swapon(8) program.
312 1.2 thorpej */
313 1.12 lukem static void
314 1.2 thorpej swapon_command(argc, argv)
315 1.2 thorpej int argc;
316 1.2 thorpej char **argv;
317 1.2 thorpej {
318 1.2 thorpej int ch, fiztab = 0;
319 1.2 thorpej
320 1.4 thorpej while ((ch = getopt(argc, argv, "at:")) != -1) {
321 1.2 thorpej switch (ch) {
322 1.2 thorpej case 'a':
323 1.2 thorpej fiztab = 1;
324 1.2 thorpej break;
325 1.4 thorpej case 't':
326 1.4 thorpej if (tflag != NULL)
327 1.4 thorpej usage();
328 1.4 thorpej tflag = optarg;
329 1.4 thorpej break;
330 1.2 thorpej default:
331 1.2 thorpej goto swapon_usage;
332 1.2 thorpej }
333 1.2 thorpej }
334 1.2 thorpej argc -= optind;
335 1.2 thorpej argv += optind;
336 1.2 thorpej
337 1.2 thorpej if (fiztab) {
338 1.2 thorpej if (argc)
339 1.2 thorpej goto swapon_usage;
340 1.4 thorpej /* Sanity-check -t */
341 1.4 thorpej if (tflag != NULL) {
342 1.4 thorpej if (strcmp(tflag, "blk") != 0 &&
343 1.4 thorpej strcmp(tflag, "noblk") != 0)
344 1.4 thorpej usage();
345 1.4 thorpej }
346 1.12 lukem do_fstab(1);
347 1.2 thorpej exit(0);
348 1.4 thorpej } else if (argc == 0 || tflag != NULL)
349 1.2 thorpej goto swapon_usage;
350 1.2 thorpej
351 1.2 thorpej while (argc) {
352 1.12 lukem if (! add_swap(argv[0], pri))
353 1.12 lukem exit(1);
354 1.2 thorpej argc--;
355 1.2 thorpej argv++;
356 1.2 thorpej }
357 1.1 mrg exit(0);
358 1.2 thorpej /* NOTREACHED */
359 1.2 thorpej
360 1.2 thorpej swapon_usage:
361 1.18 cgd fprintf(stderr, "usage: %s -a [-t blk|noblk]\n", getprogname());
362 1.18 cgd fprintf(stderr, " %s <path> ...\n", getprogname());
363 1.2 thorpej exit(1);
364 1.1 mrg }
365 1.1 mrg
366 1.1 mrg /*
367 1.1 mrg * change_priority: change the priority of a swap device.
368 1.1 mrg */
369 1.12 lukem static void
370 1.1 mrg change_priority(path)
371 1.10 mrg const char *path;
372 1.1 mrg {
373 1.1 mrg
374 1.1 mrg if (swapctl(SWAP_CTL, path, pri) < 0)
375 1.1 mrg warn("%s", path);
376 1.1 mrg }
377 1.1 mrg
378 1.1 mrg /*
379 1.1 mrg * add_swap: add the pathname to the list of swap devices.
380 1.1 mrg */
381 1.12 lukem static int
382 1.12 lukem add_swap(path, priority)
383 1.10 mrg const char *path;
384 1.12 lukem int priority;
385 1.1 mrg {
386 1.10 mrg struct stat sb;
387 1.10 mrg
388 1.10 mrg if (stat(path, &sb) < 0)
389 1.10 mrg goto oops;
390 1.10 mrg
391 1.10 mrg if (sb.st_mode & S_IROTH)
392 1.19 pooka warnx("WARNING: %s is readable by the world", path);
393 1.10 mrg if (sb.st_mode & S_IWOTH)
394 1.19 pooka warnx("WARNING: %s is writable by the world", path);
395 1.1 mrg
396 1.12 lukem if (swapctl(SWAP_ON, path, priority) < 0) {
397 1.10 mrg oops:
398 1.12 lukem warn("%s", path);
399 1.12 lukem return (0);
400 1.12 lukem }
401 1.12 lukem return (1);
402 1.1 mrg }
403 1.1 mrg
404 1.1 mrg /*
405 1.11 mrg * delete_swap: remove the pathname to the list of swap devices.
406 1.1 mrg */
407 1.12 lukem static int
408 1.11 mrg delete_swap(path)
409 1.10 mrg const char *path;
410 1.1 mrg {
411 1.1 mrg
412 1.12 lukem if (swapctl(SWAP_OFF, path, pri) < 0) {
413 1.12 lukem warn("%s", path);
414 1.12 lukem return (0);
415 1.12 lukem }
416 1.12 lukem return (1);
417 1.1 mrg }
418 1.1 mrg
419 1.12 lukem static void
420 1.10 mrg set_dumpdev(path)
421 1.10 mrg const char *path;
422 1.10 mrg {
423 1.10 mrg
424 1.23 fvdl if (swapctl(SWAP_DUMPDEV, path, 0) == -1)
425 1.10 mrg warn("could not set dump device to %s", path);
426 1.10 mrg else
427 1.18 cgd printf("%s: setting dump device to %s\n", getprogname(), path);
428 1.16 mrg }
429 1.16 mrg
430 1.16 mrg static void
431 1.16 mrg get_dumpdev()
432 1.16 mrg {
433 1.16 mrg dev_t dev;
434 1.16 mrg char *name;
435 1.16 mrg
436 1.23 fvdl if (swapctl(SWAP_GETDUMPDEV, &dev, 0) == -1)
437 1.16 mrg warn("could not get dump device");
438 1.21 drochner else if (dev == NODEV)
439 1.21 drochner printf("no dump device set\n");
440 1.16 mrg else {
441 1.16 mrg name = devname(dev, S_IFBLK);
442 1.16 mrg printf("dump device is ");
443 1.16 mrg if (name)
444 1.16 mrg printf("%s\n", name);
445 1.16 mrg else
446 1.16 mrg printf("major %d minor %d\n", major(dev), minor(dev));
447 1.16 mrg }
448 1.10 mrg }
449 1.10 mrg
450 1.12 lukem static void
451 1.12 lukem do_fstab(add)
452 1.12 lukem int add;
453 1.1 mrg {
454 1.1 mrg struct fstab *fp;
455 1.1 mrg char *s;
456 1.1 mrg long priority;
457 1.4 thorpej struct stat st;
458 1.4 thorpej int isblk;
459 1.8 mrg int gotone = 0;
460 1.12 lukem #define PATH_MOUNT "/sbin/mount_nfs"
461 1.12 lukem #define PATH_UMOUNT "/sbin/umount"
462 1.12 lukem char cmd[2*PATH_MAX+sizeof(PATH_MOUNT)+2];
463 1.1 mrg
464 1.1 mrg #define PRIORITYEQ "priority="
465 1.1 mrg #define NFSMNTPT "nfsmntpt="
466 1.5 mikel while ((fp = getfsent()) != NULL) {
467 1.9 mycroft const char *spec;
468 1.1 mrg
469 1.10 mrg spec = fp->fs_spec;
470 1.12 lukem cmd[0] = '\0';
471 1.10 mrg
472 1.12 lukem if (strcmp(fp->fs_type, "dp") == 0 && add) {
473 1.10 mrg set_dumpdev(spec);
474 1.10 mrg continue;
475 1.10 mrg }
476 1.10 mrg
477 1.1 mrg if (strcmp(fp->fs_type, "sw") != 0)
478 1.1 mrg continue;
479 1.20 jdolecek
480 1.20 jdolecek /* handle dp as mnt option */
481 1.20 jdolecek if (strstr(fp->fs_mntops, "dp") && add)
482 1.20 jdolecek set_dumpdev(spec);
483 1.20 jdolecek
484 1.4 thorpej isblk = 0;
485 1.1 mrg
486 1.5 mikel if ((s = strstr(fp->fs_mntops, PRIORITYEQ)) != NULL) {
487 1.1 mrg s += sizeof(PRIORITYEQ) - 1;
488 1.1 mrg priority = atol(s);
489 1.1 mrg } else
490 1.1 mrg priority = pri;
491 1.1 mrg
492 1.5 mikel if ((s = strstr(fp->fs_mntops, NFSMNTPT)) != NULL) {
493 1.12 lukem char *t;
494 1.1 mrg
495 1.4 thorpej /*
496 1.4 thorpej * Skip this song and dance if we're only
497 1.4 thorpej * doing block devices.
498 1.4 thorpej */
499 1.12 lukem if (tflag != NULL && strcmp(tflag, "blk") == 0)
500 1.4 thorpej continue;
501 1.4 thorpej
502 1.1 mrg t = strpbrk(s, ",");
503 1.1 mrg if (t != 0)
504 1.1 mrg *t = '\0';
505 1.1 mrg spec = strdup(s + strlen(NFSMNTPT));
506 1.1 mrg if (t != 0)
507 1.1 mrg *t = ',';
508 1.1 mrg
509 1.1 mrg if (spec == NULL)
510 1.1 mrg errx(1, "Out of memory");
511 1.1 mrg
512 1.1 mrg if (strlen(spec) == 0) {
513 1.1 mrg warnx("empty mountpoint");
514 1.9 mycroft free((char *)spec);
515 1.1 mrg continue;
516 1.1 mrg }
517 1.12 lukem if (add) {
518 1.12 lukem snprintf(cmd, sizeof(cmd), "%s %s %s",
519 1.12 lukem PATH_MOUNT, fp->fs_spec, spec);
520 1.12 lukem if (system(cmd) != 0) {
521 1.12 lukem warnx("%s: mount failed", fp->fs_spec);
522 1.12 lukem continue;
523 1.12 lukem }
524 1.12 lukem } else {
525 1.12 lukem snprintf(cmd, sizeof(cmd), "%s %s",
526 1.12 lukem PATH_UMOUNT, fp->fs_spec);
527 1.1 mrg }
528 1.4 thorpej } else {
529 1.4 thorpej /*
530 1.4 thorpej * Determine blk-ness.
531 1.4 thorpej */
532 1.4 thorpej if (stat(spec, &st) < 0) {
533 1.15 itojun warn("%s", spec);
534 1.4 thorpej continue;
535 1.4 thorpej }
536 1.4 thorpej if (S_ISBLK(st.st_mode))
537 1.4 thorpej isblk = 1;
538 1.4 thorpej }
539 1.4 thorpej
540 1.4 thorpej /*
541 1.4 thorpej * Skip this type if we're told to.
542 1.4 thorpej */
543 1.4 thorpej if (tflag != NULL) {
544 1.4 thorpej if (strcmp(tflag, "blk") == 0 && isblk == 0)
545 1.4 thorpej continue;
546 1.4 thorpej if (strcmp(tflag, "noblk") == 0 && isblk == 1)
547 1.4 thorpej continue;
548 1.1 mrg }
549 1.1 mrg
550 1.12 lukem if (add) {
551 1.12 lukem if (add_swap(spec, (int)priority)) {
552 1.12 lukem gotone = 1;
553 1.12 lukem printf(
554 1.12 lukem "%s: adding %s as swap device at priority %d\n",
555 1.18 cgd getprogname(), fp->fs_spec, (int)priority);
556 1.12 lukem }
557 1.12 lukem } else {
558 1.12 lukem if (delete_swap(spec)) {
559 1.12 lukem gotone = 1;
560 1.12 lukem printf(
561 1.12 lukem "%s: removing %s as swap device\n",
562 1.18 cgd getprogname(), fp->fs_spec);
563 1.12 lukem }
564 1.12 lukem if (cmd[0]) {
565 1.12 lukem if (system(cmd) != 0) {
566 1.12 lukem warnx("%s: umount failed", fp->fs_spec);
567 1.12 lukem continue;
568 1.12 lukem }
569 1.12 lukem }
570 1.8 mrg }
571 1.1 mrg
572 1.1 mrg if (spec != fp->fs_spec)
573 1.9 mycroft free((char *)spec);
574 1.1 mrg }
575 1.8 mrg if (gotone == 0)
576 1.8 mrg exit(1);
577 1.1 mrg }
578 1.1 mrg
579 1.12 lukem static void
580 1.1 mrg usage()
581 1.1 mrg {
582 1.18 cgd const char *progname = getprogname();
583 1.1 mrg
584 1.4 thorpej fprintf(stderr, "usage: %s -A [-p priority] [-t blk|noblk]\n",
585 1.18 cgd progname);
586 1.18 cgd fprintf(stderr, " %s -D dumppath\n", progname);
587 1.18 cgd fprintf(stderr, " %s -U [-t blk|noblk]\n", progname);
588 1.18 cgd fprintf(stderr, " %s -a [-p priority] path\n", progname);
589 1.18 cgd fprintf(stderr, " %s -c -p priority path\n", progname);
590 1.18 cgd fprintf(stderr, " %s -d path\n", progname);
591 1.25 mrg fprintf(stderr, " %s -l | -s [-k|-m|-g|-h]\n", progname);
592 1.26 cjep fprintf(stderr, " %s -z\n", progname);
593 1.1 mrg exit(1);
594 1.1 mrg }
595