reboot.h revision 1.26 1 1.26 thorpej /* $NetBSD: reboot.h,v 1.26 2020/01/01 22:57:17 thorpej Exp $ */
2 1.6 cgd
3 1.1 cgd /*
4 1.7 mycroft * Copyright (c) 1982, 1986, 1988, 1993, 1994
5 1.4 cgd * The Regents of the University of California. All rights reserved.
6 1.1 cgd *
7 1.1 cgd * Redistribution and use in source and binary forms, with or without
8 1.1 cgd * modification, are permitted provided that the following conditions
9 1.1 cgd * are met:
10 1.1 cgd * 1. Redistributions of source code must retain the above copyright
11 1.1 cgd * notice, this list of conditions and the following disclaimer.
12 1.1 cgd * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 cgd * notice, this list of conditions and the following disclaimer in the
14 1.1 cgd * documentation and/or other materials provided with the distribution.
15 1.21 agc * 3. Neither the name of the University nor the names of its contributors
16 1.1 cgd * may be used to endorse or promote products derived from this software
17 1.1 cgd * without specific prior written permission.
18 1.1 cgd *
19 1.1 cgd * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
20 1.1 cgd * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21 1.1 cgd * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22 1.1 cgd * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
23 1.1 cgd * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
24 1.1 cgd * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
25 1.1 cgd * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
26 1.1 cgd * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27 1.1 cgd * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
28 1.1 cgd * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
29 1.1 cgd * SUCH DAMAGE.
30 1.1 cgd *
31 1.14 fvdl * @(#)reboot.h 8.3 (Berkeley) 12/13/94
32 1.1 cgd */
33 1.1 cgd
34 1.12 mikel #ifndef _SYS_REBOOT_H_
35 1.12 mikel #define _SYS_REBOOT_H_
36 1.12 mikel
37 1.1 cgd /*
38 1.8 scottr * Arguments to reboot system call. These are passed to the boot program,
39 1.8 scottr * and then on to init.
40 1.1 cgd */
41 1.1 cgd #define RB_AUTOBOOT 0 /* flags for system auto-booting itself */
42 1.1 cgd
43 1.24 ad #define RB_ASKNAME 0x00000001 /* ask for file name to reboot from */
44 1.24 ad #define RB_SINGLE 0x00000002 /* reboot to single user only */
45 1.24 ad #define RB_NOSYNC 0x00000004 /* dont sync before reboot */
46 1.24 ad #define RB_HALT 0x00000008 /* don't reboot, just halt */
47 1.24 ad #define RB_INITNAME 0x00000010 /* name given for /etc/init (unused) */
48 1.24 ad #define __RB_UNUSED1 0x00000020 /* was RB_DFLTROOT, obsolete */
49 1.24 ad #define RB_KDB 0x00000040 /* give control to kernel debugger */
50 1.24 ad #define RB_RDONLY 0x00000080 /* mount root fs read-only */
51 1.24 ad #define RB_DUMP 0x00000100 /* dump kernel memory before reboot */
52 1.24 ad #define RB_MINIROOT 0x00000200 /* mini-root present in memory */
53 1.24 ad #define RB_STRING 0x00000400 /* use provided bootstr */
54 1.16 thorpej #define RB_POWERDOWN (RB_HALT|0x800) /* turn power off (or at least halt) */
55 1.24 ad #define RB_USERCONF 0x00001000 /* change configured devices */
56 1.18 jdolecek
57 1.18 jdolecek /*
58 1.18 jdolecek * Extra autoboot flags (passed by boot prog to kernel). See also
59 1.18 jdolecek * macros bootverbose, bootquiet in <sys/systm.h>.
60 1.18 jdolecek */
61 1.24 ad #define AB_NORMAL 0x00000000 /* boot normally (default) */
62 1.24 ad #define AB_QUIET 0x00010000 /* boot quietly */
63 1.24 ad #define AB_VERBOSE 0x00020000 /* boot verbosely */
64 1.24 ad #define AB_SILENT 0x00040000 /* boot silently */
65 1.24 ad #define AB_DEBUG 0x00080000 /* boot with debug messages */
66 1.24 ad
67 1.24 ad /*
68 1.24 ad * The top 4 bits are architecture specific and are used to
69 1.24 ad * pass information between the bootblocks and the machine
70 1.24 ad * initialization code.
71 1.24 ad */
72 1.24 ad #define RB_MD1 0x10000000
73 1.24 ad #define RB_MD2 0x20000000
74 1.24 ad #define RB_MD3 0x40000000
75 1.24 ad #define RB_MD4 0x80000000
76 1.1 cgd
77 1.1 cgd /*
78 1.1 cgd * Constants for converting boot-style device number to type,
79 1.1 cgd * adaptor (uba, mba, etc), unit number and partition number.
80 1.1 cgd * Type (== major device number) is in the low byte
81 1.1 cgd * for backward compatibility. Except for that of the "magic
82 1.1 cgd * number", each mask applies to the shifted value.
83 1.1 cgd * Format:
84 1.1 cgd * (4) (4) (4) (4) (8) (8)
85 1.1 cgd * --------------------------------
86 1.1 cgd * |MA | AD| CT| UN| PART | TYPE |
87 1.1 cgd * --------------------------------
88 1.1 cgd */
89 1.1 cgd #define B_ADAPTORSHIFT 24
90 1.1 cgd #define B_ADAPTORMASK 0x0f
91 1.1 cgd #define B_ADAPTOR(val) (((val) >> B_ADAPTORSHIFT) & B_ADAPTORMASK)
92 1.1 cgd #define B_CONTROLLERSHIFT 20
93 1.1 cgd #define B_CONTROLLERMASK 0xf
94 1.1 cgd #define B_CONTROLLER(val) (((val)>>B_CONTROLLERSHIFT) & B_CONTROLLERMASK)
95 1.1 cgd #define B_UNITSHIFT 16
96 1.1 cgd #define B_UNITMASK 0xf
97 1.1 cgd #define B_UNIT(val) (((val) >> B_UNITSHIFT) & B_UNITMASK)
98 1.1 cgd #define B_PARTITIONSHIFT 8
99 1.1 cgd #define B_PARTITIONMASK 0xff
100 1.1 cgd #define B_PARTITION(val) (((val) >> B_PARTITIONSHIFT) & B_PARTITIONMASK)
101 1.1 cgd #define B_TYPESHIFT 0
102 1.1 cgd #define B_TYPEMASK 0xff
103 1.1 cgd #define B_TYPE(val) (((val) >> B_TYPESHIFT) & B_TYPEMASK)
104 1.1 cgd
105 1.7 mycroft #define B_MAGICMASK 0xf0000000
106 1.7 mycroft #define B_DEVMAGIC 0xa0000000
107 1.1 cgd
108 1.1 cgd #define MAKEBOOTDEV(type, adaptor, controller, unit, partition) \
109 1.1 cgd (((type) << B_TYPESHIFT) | ((adaptor) << B_ADAPTORSHIFT) | \
110 1.1 cgd ((controller) << B_CONTROLLERSHIFT) | ((unit) << B_UNITSHIFT) | \
111 1.1 cgd ((partition) << B_PARTITIONSHIFT) | B_DEVMAGIC)
112 1.9 christos
113 1.9 christos #ifdef _KERNEL
114 1.9 christos
115 1.9 christos __BEGIN_DECLS
116 1.9 christos
117 1.26 thorpej void kern_reboot(int, char *) __dead;
118 1.26 thorpej void cpu_reboot(int, char *) __dead;
119 1.9 christos
120 1.9 christos __END_DECLS
121 1.9 christos
122 1.9 christos #endif /* _KERNEL */
123 1.9 christos
124 1.12 mikel #endif /* !_SYS_REBOOT_H_ */
125