installboot.h revision 1.45 1 1.45 tsutsui /* $NetBSD: installboot.h,v 1.45 2024/05/19 15:48:57 tsutsui Exp $ */
2 1.1 lukem
3 1.1 lukem /*-
4 1.1 lukem * Copyright (c) 2002 The NetBSD Foundation, Inc.
5 1.1 lukem * All rights reserved.
6 1.1 lukem *
7 1.1 lukem * This code is derived from software contributed to The NetBSD Foundation
8 1.1 lukem * by Luke Mewburn of Wasabi Systems.
9 1.1 lukem *
10 1.1 lukem * Redistribution and use in source and binary forms, with or without
11 1.1 lukem * modification, are permitted provided that the following conditions
12 1.1 lukem * are met:
13 1.1 lukem * 1. Redistributions of source code must retain the above copyright
14 1.1 lukem * notice, this list of conditions and the following disclaimer.
15 1.1 lukem * 2. Redistributions in binary form must reproduce the above copyright
16 1.1 lukem * notice, this list of conditions and the following disclaimer in the
17 1.1 lukem * documentation and/or other materials provided with the distribution.
18 1.1 lukem *
19 1.1 lukem * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20 1.1 lukem * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21 1.1 lukem * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22 1.1 lukem * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23 1.1 lukem * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24 1.1 lukem * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25 1.1 lukem * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26 1.1 lukem * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27 1.1 lukem * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28 1.1 lukem * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29 1.1 lukem * POSSIBILITY OF SUCH DAMAGE.
30 1.1 lukem */
31 1.1 lukem
32 1.1 lukem #ifndef _INSTALLBOOT_H
33 1.1 lukem #define _INSTALLBOOT_H
34 1.2 bjh21
35 1.21 lukem #if HAVE_NBTOOL_CONFIG_H
36 1.21 lukem #include "nbtool_config.h"
37 1.10 lukem #include "../../sys/sys/bootblock.h"
38 1.10 lukem #else
39 1.10 lukem #include <sys/bootblock.h>
40 1.20 lukem #include <sys/endian.h>
41 1.2 bjh21 #endif
42 1.1 lukem
43 1.11 lukem #include <sys/stat.h>
44 1.11 lukem #include <stdint.h>
45 1.11 lukem
46 1.1 lukem typedef enum {
47 1.1 lukem /* flags from global options */
48 1.1 lukem IB_VERBOSE = 1<<0, /* verbose operation */
49 1.1 lukem IB_NOWRITE = 1<<1, /* don't write */
50 1.1 lukem IB_CLEAR = 1<<2, /* clear boot block */
51 1.27 dsl IB_EDIT = 1<<3, /* edit boot parameters */
52 1.33 dsl IB_FORCE = 1<<4, /* Ignore some consistency checks */
53 1.1 lukem
54 1.1 lukem /* flags from -o options */
55 1.1 lukem IB_ALPHASUM = 1<<8, /* set Alpha checksum */
56 1.15 lukem IB_APPEND = 1<<9, /* append stage 1 to EO(regular)F */
57 1.1 lukem IB_SUNSUM = 1<<10, /* set Sun checksum */
58 1.9 lukem IB_STAGE1START= 1<<11, /* start block for stage 1 provided */
59 1.9 lukem IB_STAGE2START= 1<<12, /* start block for stage 2 provided */
60 1.16 mhitch IB_COMMAND = 1<<13, /* Amiga commandline option */
61 1.19 dsl IB_RESETVIDEO = 1<<14, /* i386 reset video */
62 1.19 dsl IB_CONSOLE = 1<<15, /* i386 console */
63 1.19 dsl IB_CONSPEED = 1<<16, /* i386 console baud rate */
64 1.19 dsl IB_TIMEOUT = 1<<17, /* i386 boot timeout */
65 1.19 dsl IB_PASSWORD = 1<<18, /* i386 boot password */
66 1.24 dsl IB_KEYMAP = 1<<19, /* i386 console keymap */
67 1.25 dsl IB_CONSADDR = 1<<20, /* i386 console io address */
68 1.37 drochner IB_MODULES = 1<<21, /* i386: load modules */
69 1.37 drochner IB_BOOTCONF = 1<<22, /* i386: read boot.conf */
70 1.40 thorpej
71 1.40 thorpej IB_BOARD = 1<<23, /* evb*: board specification */
72 1.40 thorpej IB_DTB= 1<<24, /* evb*: device tree blob */
73 1.40 thorpej
74 1.40 thorpej /* IB_MEDIA is required for some evb*, but not all. */
75 1.40 thorpej IB_MEDIA = 1<<25, /* evb*: boot media type */
76 1.1 lukem } ib_flags;
77 1.1 lukem
78 1.40 thorpej typedef enum {
79 1.40 thorpej
80 1.40 thorpej MF_UBOOT = 1<<0, /* platform (maybe) uses u-boot */
81 1.40 thorpej } m_flags;
82 1.40 thorpej
83 1.1 lukem typedef struct {
84 1.9 lukem ib_flags flags; /* flags (see above) */
85 1.9 lukem struct ib_mach *machine; /* machine details (see below) */
86 1.9 lukem struct ib_fs *fstype; /* file system details (see below) */
87 1.9 lukem const char *filesystem; /* name of target file system */
88 1.9 lukem int fsfd; /* open fd to filesystem */
89 1.11 lukem struct stat fsstat; /* fstat(2) of fsfd */
90 1.9 lukem const char *stage1; /* name of stage1 bootstrap */
91 1.9 lukem int s1fd; /* open fd to stage1 */
92 1.11 lukem struct stat s1stat; /* fstat(2) of s1fd */
93 1.17 fvdl uint64_t s1start; /* start block of stage1 */
94 1.9 lukem const char *stage2; /* name of stage2 bootstrap */
95 1.17 fvdl uint64_t s2start; /* start block of stage2 */
96 1.36 tsutsui uint32_t sectorsize; /* sector size of target fs */
97 1.43 brook const char *uboot_paths; /* u-boot paths */
98 1.19 dsl /* parsed -o option=value data */
99 1.19 dsl const char *command; /* name of command string */
100 1.19 dsl const char *console; /* name of console */
101 1.19 dsl int conspeed; /* console baud rate */
102 1.25 dsl int consaddr; /* console io address */
103 1.19 dsl const char *password; /* boot password */
104 1.19 dsl int timeout; /* interactive boot timeout */
105 1.24 dsl const char *keymap; /* keyboard translations */
106 1.40 thorpej const char *board; /* board specification */
107 1.40 thorpej const char *dtb; /* dtb specification */
108 1.40 thorpej const char *media; /* boot media type */
109 1.40 thorpej
110 1.40 thorpej /* temporary working data */
111 1.40 thorpej void *mach_data; /* platform-specific data */
112 1.1 lukem } ib_params;
113 1.1 lukem
114 1.5 lukem typedef struct {
115 1.17 fvdl uint64_t block;
116 1.5 lukem uint32_t blocksize;
117 1.5 lukem } ib_block;
118 1.5 lukem
119 1.1 lukem struct ib_mach {
120 1.1 lukem const char *name;
121 1.1 lukem int (*setboot) (ib_params *);
122 1.1 lukem int (*clearboot) (ib_params *);
123 1.27 dsl int (*editboot) (ib_params *);
124 1.40 thorpej void (*usage) (ib_params *);
125 1.19 dsl ib_flags valid_flags;
126 1.40 thorpej m_flags mach_flags;
127 1.1 lukem };
128 1.1 lukem
129 1.5 lukem struct ib_fs {
130 1.9 lukem /* compile time parameters */
131 1.5 lukem const char *name;
132 1.5 lukem int (*match) (ib_params *);
133 1.5 lukem int (*findstage2) (ib_params *, uint32_t *, ib_block *);
134 1.9 lukem /* run time fs specific parameters */
135 1.9 lukem uint32_t blocksize;
136 1.9 lukem uint32_t needswap;
137 1.17 fvdl off_t sblockloc; /* location of superblock */
138 1.31 jdc off_t offset; /* file system offset (e.g. RAID) */
139 1.5 lukem };
140 1.1 lukem
141 1.13 lukem typedef enum {
142 1.13 lukem BBINFO_BIG_ENDIAN = 0,
143 1.13 lukem BBINFO_LITTLE_ENDIAN = 1,
144 1.13 lukem } bbinfo_endian;
145 1.13 lukem
146 1.12 lukem struct bbinfo_params {
147 1.13 lukem const char *magic; /* magic string to look for */
148 1.13 lukem uint32_t offset; /* offset to write start of stage1 */
149 1.13 lukem uint32_t blocksize; /* blocksize of stage1 */
150 1.13 lukem uint32_t maxsize; /* max size of stage1 */
151 1.13 lukem uint32_t headeroffset; /*
152 1.13 lukem * header offset (relative to offset)
153 1.13 lukem * to read stage1 into
154 1.13 lukem */
155 1.13 lukem bbinfo_endian endian;
156 1.12 lukem };
157 1.12 lukem
158 1.38 matt extern struct ib_mach * const machines[];
159 1.5 lukem extern struct ib_fs fstypes[];
160 1.1 lukem
161 1.5 lukem /* installboot.c */
162 1.5 lukem uint16_t compute_sunsum(const uint16_t *);
163 1.5 lukem int set_sunsum(ib_params *, uint16_t *, uint16_t);
164 1.3 lukem int no_setboot(ib_params *);
165 1.3 lukem int no_clearboot(ib_params *);
166 1.27 dsl int no_editboot(ib_params *);
167 1.12 lukem
168 1.12 lukem /* bbinfo.c */
169 1.13 lukem int shared_bbinfo_clearboot(ib_params *, struct bbinfo_params *,
170 1.13 lukem int (*)(ib_params *, struct bbinfo_params *, uint8_t *));
171 1.12 lukem int shared_bbinfo_setboot(ib_params *, struct bbinfo_params *,
172 1.13 lukem int (*)(ib_params *, struct bbinfo_params *, uint8_t *));
173 1.5 lukem
174 1.45 tsutsui /* cd9660.c */
175 1.45 tsutsui int cd9660_match(ib_params *);
176 1.45 tsutsui int cd9660_findstage2(ib_params *, uint32_t *, ib_block *);
177 1.45 tsutsui
178 1.44 tsutsui /* ext2fs.c */
179 1.44 tsutsui int ext2fs_match(ib_params *);
180 1.44 tsutsui int ext2fs_findstage2(ib_params *, uint32_t *, ib_block *);
181 1.44 tsutsui
182 1.44 tsutsui /* ffs.c */
183 1.5 lukem int ffs_match(ib_params *);
184 1.5 lukem int ffs_findstage2(ib_params *, uint32_t *, ib_block *);
185 1.31 jdc int raid_match(ib_params *);
186 1.44 tsutsui
187 1.44 tsutsui /* fstypes.c */
188 1.44 tsutsui int hardcode_stage2(ib_params *, uint32_t *, ib_block *);
189 1.7 lukem int raw_match(ib_params *);
190 1.7 lukem int raw_findstage2(ib_params *, uint32_t *, ib_block *);
191 1.5 lukem
192 1.5 lukem /* machines.c */
193 1.30 dsl extern struct ib_mach ib_mach_alpha;
194 1.30 dsl extern struct ib_mach ib_mach_amd64;
195 1.30 dsl extern struct ib_mach ib_mach_amiga;
196 1.41 kamil extern struct ib_mach ib_mach_emips;
197 1.40 thorpej extern struct ib_mach ib_mach_evbarm;
198 1.42 thorpej extern struct ib_mach ib_mach_evbmips;
199 1.30 dsl extern struct ib_mach ib_mach_ews4800mips;
200 1.30 dsl extern struct ib_mach ib_mach_hp300;
201 1.39 skrll extern struct ib_mach ib_mach_hppa;
202 1.30 dsl extern struct ib_mach ib_mach_i386;
203 1.32 uwe extern struct ib_mach ib_mach_landisk;
204 1.30 dsl extern struct ib_mach ib_mach_macppc;
205 1.30 dsl extern struct ib_mach ib_mach_news68k;
206 1.30 dsl extern struct ib_mach ib_mach_newsmips;
207 1.30 dsl extern struct ib_mach ib_mach_next68k;
208 1.30 dsl extern struct ib_mach ib_mach_pmax;
209 1.30 dsl extern struct ib_mach ib_mach_sparc;
210 1.30 dsl extern struct ib_mach ib_mach_sparc64;
211 1.30 dsl extern struct ib_mach ib_mach_sun2;
212 1.30 dsl extern struct ib_mach ib_mach_sun3;
213 1.30 dsl extern struct ib_mach ib_mach_vax;
214 1.30 dsl extern struct ib_mach ib_mach_x68k;
215 1.1 lukem
216 1.1 lukem #endif /* _INSTALLBOOT_H */
217