xref: /illumos-gate/usr/src/cmd/boot/bootadm/bootadm.h (revision 4c28a617e3922d92a58e813a5b955eb526b9c386)
1 /*
2  * CDDL HEADER START
3  *
4  * The contents of this file are subject to the terms of the
5  * Common Development and Distribution License (the "License").
6  * You may not use this file except in compliance with the License.
7  *
8  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9  * or http://www.opensolaris.org/os/licensing.
10  * See the License for the specific language governing permissions
11  * and limitations under the License.
12  *
13  * When distributing Covered Code, include this CDDL HEADER in each
14  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15  * If applicable, add the following below this CDDL HEADER, with the
16  * fields enclosed by brackets "[]" replaced with your own identifying
17  * information: Portions Copyright [yyyy] [name of copyright owner]
18  *
19  * CDDL HEADER END
20  */
21 /*
22  * Copyright 2009 Sun Microsystems, Inc.  All rights reserved.
23  * Use is subject to license terms.
24  *
25  * Copyright 2016 Toomas Soome <tsoome@me.com>.
26  */
27 
28 #ifndef _BOOTADM_H
29 #define	_BOOTADM_H
30 
31 #ifdef	__cplusplus
32 extern "C" {
33 #endif
34 
35 #include <assert.h>
36 #include <libintl.h>
37 
38 #ifndef	TEXT_DOMAIN
39 #define	TEXT_DOMAIN	"SUNW_OST_OSCMD"
40 #endif  /* TEXT_DOMAIN */
41 
42 #ifndef	lint
43 #define	_(x) gettext(x)
44 #else
45 #define	_(x) (x)
46 #endif
47 
48 /* Type definitions */
49 
50 /* GRUB menu per-line classification */
51 typedef enum {
52 	BAM_INVALID = 0,
53 	BAM_EMPTY,
54 	BAM_COMMENT,
55 	BAM_GLOBAL,
56 	BAM_ENTRY,
57 	BAM_TITLE
58 } menu_flag_t;
59 
60 /* struct for menu.lst contents */
61 typedef struct line {
62 	int  lineNum;	/* Line number in menu.lst */
63 	int  entryNum;	/* menu boot entry #. ENTRY_INIT if not applicable */
64 	char *cmd;
65 	char *sep;
66 	char *arg;
67 	char *line;
68 	menu_flag_t flags;
69 	struct line *next;
70 	struct line *prev;
71 } line_t;
72 
73 typedef struct entry {
74 	struct entry *next;
75 	struct entry *prev;
76 	line_t *start;
77 	line_t *end;
78 	int	entryNum;
79 	uint_t	flags;
80 } entry_t;
81 
82 /* For flags value in entry_t */
83 #define	BAM_ENTRY_BOOTADM	0x01	/* entry created by bootadm */
84 #define	BAM_ENTRY_LU		0x02	/* entry created by Live Upgrade */
85 #define	BAM_ENTRY_CHAINLOADER	0x04	/* chainloader entry; do not disturb */
86 #define	BAM_ENTRY_ROOT		0x08	/* entry has a root line */
87 #define	BAM_ENTRY_FAILSAFE	0x10	/* failsafe entry  */
88 #define	BAM_ENTRY_DBOOT		0x20	/* Is dboot (normal or failsafe) */
89 #define	BAM_ENTRY_32BIT		0x40	/* Is a 32-bit entry */
90 #define	BAM_ENTRY_HV		0x80	/* Is a hypervisor entry */
91 #define	BAM_ENTRY_FINDROOT	0x100	/* entry has a findroot line */
92 #define	BAM_ENTRY_MULTIBOOT	0x200	/* is multiboot (normal or failsafe) */
93 #define	BAM_ENTRY_64BIT		0x400	/* Is a 64-bit entry */
94 
95 #define	BAM_ENTRY_UPGFSKERNEL	0x800	/* Upgrade failsafe kernel entry */
96 #define	BAM_ENTRY_UPGFSMODULE	0x1000  /* Upgrade failsafe module entry */
97 
98 #define	BAM_ENTRY_LIBBE		0x2000	/* entry created by libbe */
99 
100 typedef struct {
101 	line_t	*start;
102 	line_t	*end;
103 	line_t	*curdefault;	/* line containing default */
104 	line_t	*olddefault;	/* old default line (commented) */
105 	line_t	*old_rc_default;	/* old default line for bootenv.rc */
106 	entry_t	*entries;	/* os entries */
107 } menu_t;
108 
109 typedef enum {
110 	BAM_ERROR = -1,	/* Must be negative. add_boot_entry() depends on it */
111 	BAM_SUCCESS = 0,
112 	BAM_WRITE = 2,
113 	BAM_MSG,	/* Used by upgrade_menu() */
114 	BAM_NOCHANGE	/* Used by cvt_to_hyper()/cvt_to_metal() */
115 } error_t;
116 
117 /*
118  * Menu related
119  * menu_cmd_t and menu_cmds must be kept in sync
120  *
121  * The *_DOLLAR_CMD values must be 1 greater than the
122  * respective [KERNEL|MODULE]_CMD values.
123  */
124 typedef enum {
125 	DEFAULT_CMD = 0,
126 	TIMEOUT_CMD,
127 	TITLE_CMD,
128 	ROOT_CMD,
129 	KERNEL_CMD,
130 	KERNEL_DOLLAR_CMD,	/* Must be KERNEL_CMD + 1 */
131 	MODULE_CMD,
132 	MODULE_DOLLAR_CMD,	/* Must be MODULE_CMD + 1 */
133 	SEP_CMD,
134 	COMMENT_CMD,
135 	CHAINLOADER_CMD,
136 	ARGS_CMD,
137 	FINDROOT_CMD,
138 	BOOTFS_CMD
139 } menu_cmd_t;
140 
141 extern char *menu_cmds[];
142 
143 /* For multi- or direct-boot */
144 typedef enum {
145 	BAM_DIRECT_NOT_SET,
146 	BAM_DIRECT_MULTIBOOT,
147 	BAM_DIRECT_DBOOT
148 } direct_or_multi_t;
149 
150 /* Is there a hypervisor present? */
151 typedef enum {
152 	BAM_HV_UNKNOWN,
153 	BAM_HV_NO,
154 	BAM_HV_PRESENT
155 } hv_t;
156 
157 /* Is there findroot capability present ? */
158 typedef enum {
159 	BAM_FINDROOT_UNKNOWN,
160 	BAM_FINDROOT_ABSENT,
161 	BAM_FINDROOT_PRESENT
162 } findroot_t;
163 
164 typedef enum {
165 	OPT_ABSENT = 0,		/* No option */
166 	OPT_REQ,		/* option required */
167 	OPT_OPTIONAL		/* option may or may not be present */
168 } option_t;
169 
170 typedef struct {
171 	char	*subcmd;
172 	option_t option;
173 	error_t	(*handler)();
174 	int	unpriv;			/* is this an unprivileged command */
175 } subcmd_defn_t;
176 
177 typedef enum zfs_mnted {
178 	ZFS_MNT_ERROR = -1,
179 	LEGACY_MOUNTED = 1,
180 	LEGACY_ALREADY,
181 	ZFS_MOUNTED,
182 	ZFS_ALREADY
183 } zfs_mnted_t;
184 
185 extern int bam_verbose;
186 extern int bam_force;
187 extern direct_or_multi_t bam_direct;
188 extern hv_t bam_is_hv;
189 extern findroot_t bam_is_findroot;
190 extern int bam_debug;
191 
192 extern void bam_add_line(menu_t *mp, entry_t *entry, line_t *prev, line_t *lp);
193 extern void update_numbering(menu_t *mp);
194 extern error_t set_global(menu_t *, char *, int);
195 extern error_t upgrade_menu(menu_t *, char *, char *);
196 extern error_t cvt_to_hyper(menu_t *, char *, char *);
197 extern error_t cvt_to_metal(menu_t *, char *, char *);
198 extern error_t check_subcmd_and_options(char *, char *, subcmd_defn_t *,
199     error_t (**fp)());
200 extern char *mount_top_dataset(char *pool, zfs_mnted_t *mnted);
201 extern void elide_trailing_slash(const char *, char *, size_t);
202 extern int umount_top_dataset(char *, zfs_mnted_t, char *);
203 extern void *s_calloc(size_t, size_t);
204 extern void *s_realloc(void *, size_t);
205 extern char *s_fgets(char *buf, int n, FILE *fp);
206 extern void bam_error(char *format, ...);
207 extern void bam_exit(int);
208 extern void bam_print(char *, ...);
209 extern void bam_print_stderr(char *format, ...);
210 extern void bam_derror(char *format, ...);
211 extern error_t bam_loader_menu(char *, char *, int, char *[]);
212 extern error_t get_boot_cap(const char *osroot);
213 extern char *get_special(char *);
214 extern char *os_to_grubdisk(char *, int);
215 extern void update_line(line_t *);
216 extern int add_boot_entry(menu_t *, char *, char *, char *, char *, char *,
217     char *);
218 extern error_t delete_boot_entry(menu_t *, int, int);
219 extern int is_grub(const char *);
220 extern char *get_grubsign(char *osroot, char *osdev);
221 extern char *get_grubroot(char *osroot, char *osdev, char *menu_root);
222 extern int root_optional(char *osroot, char *menu_root);
223 extern void unlink_line(menu_t *mp, line_t *lp);
224 extern void line_free(line_t *lp);
225 extern char *s_strdup(char *);
226 extern int is_sparc(void);
227 extern int is_pcfs(char *);
228 extern int is_zfs(char *);
229 extern int bootadm_digest(const char *, char **);
230 
231 #define	BAM_MAXLINE	8192
232 
233 /* menu.lst comments created by bootadm */
234 #define	BAM_BOOTADM_HDR	"---------- ADDED BY BOOTADM - DO NOT EDIT ----------"
235 #define	BAM_BOOTADM_FTR	"---------------------END BOOTADM--------------------"
236 
237 /*
238  * menu.lst comments create by Live Upgrade.  Note that these are the end of
239  * the comment strings - there will be other text before them.
240  */
241 #define	BAM_LU_HDR	" - ADDED BY LIVE UPGRADE - DO NOT EDIT  -----"
242 #define	BAM_LU_FTR	" -------------- END LIVE UPGRADE ------------"
243 
244 #define	BAM_OLDDEF	"BOOTADM SAVED DEFAULT: "
245 #define	BAM_OLD_RC_DEF	"BOOTADM RC SAVED DEFAULT: "
246 
247 /*
248  * menu.lst comment created by libbe
249  */
250 #define	BAM_LIBBE_FTR	"============ End of LIBBE entry ============="
251 
252 /* Title used for failsafe entries */
253 #define	FAILSAFE_TITLE	"Solaris failsafe"
254 
255 /* Title used for hv entries */
256 #define	NEW_HV_ENTRY	"Solaris xVM"
257 
258 /* ZFS boot option */
259 #define	ZFS_BOOT	"-B $ZFS-BOOTFS"
260 
261 /* multiboot */
262 #define	MULTI_BOOT	"/platform/i86pc/multiboot"
263 #define	MULTI_BOOT_FAILSAFE	"/boot/multiboot"
264 #define	MULTI_BOOT_FAILSAFE_UNIX	"kernel/unix"
265 #define	MULTI_BOOT_FAILSAFE_LINE	"/boot/multiboot kernel/unix -s"
266 
267 /* directboot kernels */
268 #define	DIRECT_BOOT_32	"/platform/i86pc/kernel/unix"
269 #define	DIRECT_BOOT_64	"/platform/i86pc/kernel/amd64/unix"
270 #define	DIRECT_BOOT_KERNEL	"/platform/i86pc/kernel/$ISADIR/unix"
271 #define	DIRECT_BOOT_FAILSAFE_32	"/boot/platform/i86pc/kernel/unix"
272 #define	DIRECT_BOOT_FAILSAFE_64	"/boot/platform/i86pc/kernel/amd64/unix"
273 #define	DIRECT_BOOT_FAILSAFE_KERNEL \
274 	"/boot/platform/i86pc/kernel/$ISADIR/unix"
275 #define	DIRECT_BOOT_FAILSAFE_LINE	DIRECT_BOOT_FAILSAFE_KERNEL " -s"
276 #define	DIRECT_BOOT_KERNEL_ZFS	DIRECT_BOOT_KERNEL " " ZFS_BOOT
277 #define	DIRECT_BOOT_PREFIX	"/platform/i86pc/"
278 #define	KERNEL_PREFIX	"/platform/i86pc/"
279 #define	AMD_UNIX_SPACE	"/amd64/unix "
280 #define	UNIX_SPACE	"/unix "
281 
282 /* xVM kernels */
283 #define	XEN_KERNEL_SUBSTR "xen.gz"
284 
285 /* Boot archives */
286 #define	ARCHIVE_PREFIX		"/platform/"
287 #define	ARCHIVE_SUFFIX		"/boot_archive"
288 #define	CACHEDIR_SUFFIX		"/archive_cache"
289 #define	UPDATEDIR_SUFFIX	"/updates"
290 #define	DIRECT_BOOT_ARCHIVE	"/platform/i86pc/$ISADIR/boot_archive"
291 #define	DIRECT_BOOT_ARCHIVE_32	"/platform/i86pc/boot_archive"
292 #define	DIRECT_BOOT_ARCHIVE_64	"/platform/i86pc/amd64/boot_archive"
293 #define	MULTIBOOT_ARCHIVE	DIRECT_BOOT_ARCHIVE_32
294 #define	FAILSAFE_ARCHIVE	"/boot/$ISADIR/x86.miniroot-safe"
295 #define	FAILSAFE_ARCHIVE_32	"/boot/x86.miniroot-safe"
296 #define	FAILSAFE_ARCHIVE_64	"/boot/amd64/x86.miniroot-safe"
297 #define	CACHEDIR_32		"/platform/i86pc/archive_cache"
298 #define	CACHEDIR_64		"/platform/i86pc/amd64/archive_cache"
299 #define	UPDATEDIR_32		"/platform/i86pc/updates"
300 #define	UPDATEDIR_64		"/platform/i86pc/amd64/updates"
301 
302 /* Hypervisors */
303 #define	XEN_64			"/boot/amd64/xen.gz"
304 #define	XEN_MENU		"/boot/$ISADIR/xen.gz"
305 #define	HYPERVISOR_KERNEL	"/platform/i86xpv/kernel/$ISADIR/unix"
306 #define	XEN_KERNEL_MODULE_LINE	HYPERVISOR_KERNEL " " HYPERVISOR_KERNEL
307 #define	XEN_KERNEL_MODULE_LINE_ZFS	\
308 	HYPERVISOR_KERNEL " " HYPERVISOR_KERNEL " " ZFS_BOOT
309 
310 /* Helpers */
311 #define	MKISOFS_PATH		"/usr/bin/mkisofs"
312 #define	DD_PATH_USR		"/usr/bin/dd"
313 #define	LOCKFS_PATH		"/usr/sbin/lockfs"
314 
315 /* A first guess at the number of entries in a menu */
316 #define	BAM_ENTRY_NUM		10
317 
318 /* toggle for whether delete_boot_entry prints an error message or not */
319 #define	DBE_PRINTERR		0
320 #define	DBE_QUIET		1
321 
322 /*
323  * Debugging defines
324  */
325 #define	INJECT_ERROR1(x, y)	\
326 { \
327 	if (bam_debug) { \
328 		char *inj = getenv("_BOOTADM_INJECT"); \
329 		if (inj && strcmp(inj, (x)) == 0) {  \
330 			y;	\
331 		} \
332 	} \
333 }
334 
335 #define	INJECT_ERROR2(x, y, z)	\
336 { \
337 	if (bam_debug) { \
338 		char *inj = getenv("_BOOTADM_INJECT"); \
339 		if (inj && strcmp(inj, (x)) == 0) {  \
340 			y;	\
341 			z;	\
342 		} \
343 	} \
344 }
345 
346 #define	BAM_DPRINTF(x)	{if (bam_debug)  bam_derror x; }
347 
348 #ifdef __cplusplus
349 }
350 #endif
351 
352 #endif	/* _BOOTADM_H */
353