bootinfo.h revision 1.27 1 1.27 maxv /* $NetBSD: bootinfo.h,v 1.27 2017/10/07 10:26:38 maxv Exp $ */
2 1.1 fvdl
3 1.1 fvdl /*
4 1.1 fvdl * Copyright (c) 1997
5 1.1 fvdl * Matthias Drochner. All rights reserved.
6 1.1 fvdl *
7 1.1 fvdl * Redistribution and use in source and binary forms, with or without
8 1.1 fvdl * modification, are permitted provided that the following conditions
9 1.1 fvdl * are met:
10 1.1 fvdl * 1. Redistributions of source code must retain the above copyright
11 1.1 fvdl * notice, this list of conditions and the following disclaimer.
12 1.1 fvdl * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 fvdl * notice, this list of conditions and the following disclaimer in the
14 1.1 fvdl * documentation and/or other materials provided with the distribution.
15 1.1 fvdl *
16 1.1 fvdl * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
17 1.1 fvdl * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
18 1.1 fvdl * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
19 1.1 fvdl * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
20 1.1 fvdl * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
21 1.1 fvdl * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
22 1.1 fvdl * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
23 1.1 fvdl * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24 1.1 fvdl * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
25 1.1 fvdl * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26 1.1 fvdl *
27 1.1 fvdl */
28 1.1 fvdl
29 1.6 thorpej #define BTINFO_BOOTPATH 0
30 1.11 jmmv #define BTINFO_ROOTDEVICE 1
31 1.6 thorpej #define BTINFO_BOOTDISK 3
32 1.6 thorpej #define BTINFO_NETIF 4
33 1.6 thorpej #define BTINFO_CONSOLE 6
34 1.6 thorpej #define BTINFO_BIOSGEOM 7
35 1.6 thorpej #define BTINFO_SYMTAB 8
36 1.6 thorpej #define BTINFO_MEMMAP 9
37 1.6 thorpej #define BTINFO_BOOTWEDGE 10
38 1.13 ad #define BTINFO_MODULELIST 11
39 1.15 jmcneill #define BTINFO_FRAMEBUFFER 12
40 1.18 uebayasi #define BTINFO_USERCONFCOMMANDS 13
41 1.24 christos #define BTINFO_EFI 14
42 1.25 nonaka #define BTINFO_EFIMEMMAP 15
43 1.27 maxv #define BTINFO_PREKERN 16
44 1.24 christos
45 1.24 christos #define BTINFO_STR "bootpath", "rootdevice", "bootdisk", "netif", \
46 1.24 christos "console", "biosgeom", "symtab", "memmap", "bootwedge", "modulelist", \
47 1.25 nonaka "framebuffer", "userconfcommands", "efi", "efimemmap",
48 1.13 ad
49 1.13 ad #ifndef _LOCORE
50 1.13 ad
51 1.13 ad struct btinfo_common {
52 1.13 ad int len;
53 1.13 ad int type;
54 1.13 ad };
55 1.1 fvdl
56 1.1 fvdl struct btinfo_bootpath {
57 1.1 fvdl struct btinfo_common common;
58 1.1 fvdl char bootpath[80];
59 1.1 fvdl };
60 1.1 fvdl
61 1.11 jmmv struct btinfo_rootdevice {
62 1.11 jmmv struct btinfo_common common;
63 1.11 jmmv char devname[16];
64 1.11 jmmv };
65 1.11 jmmv
66 1.1 fvdl struct btinfo_bootdisk {
67 1.1 fvdl struct btinfo_common common;
68 1.1 fvdl int labelsector; /* label valid if != -1 */
69 1.1 fvdl struct {
70 1.9 junyoung uint16_t type, checksum;
71 1.1 fvdl char packname[16];
72 1.1 fvdl } label;
73 1.1 fvdl int biosdev;
74 1.1 fvdl int partition;
75 1.1 fvdl };
76 1.1 fvdl
77 1.6 thorpej struct btinfo_bootwedge {
78 1.6 thorpej struct btinfo_common common;
79 1.6 thorpej int biosdev;
80 1.6 thorpej daddr_t startblk;
81 1.6 thorpej uint64_t nblks;
82 1.6 thorpej daddr_t matchblk;
83 1.6 thorpej uint64_t matchnblks;
84 1.6 thorpej uint8_t matchhash[16]; /* MD5 hash */
85 1.12 perry } __packed;
86 1.6 thorpej
87 1.1 fvdl struct btinfo_netif {
88 1.1 fvdl struct btinfo_common common;
89 1.1 fvdl char ifname[16];
90 1.1 fvdl int bus;
91 1.1 fvdl #define BI_BUS_ISA 0
92 1.1 fvdl #define BI_BUS_PCI 1
93 1.1 fvdl union {
94 1.1 fvdl unsigned int iobase; /* ISA */
95 1.1 fvdl unsigned int tag; /* PCI, BIOS format */
96 1.1 fvdl } addr;
97 1.1 fvdl };
98 1.1 fvdl
99 1.1 fvdl struct btinfo_console {
100 1.1 fvdl struct btinfo_common common;
101 1.1 fvdl char devname[16];
102 1.1 fvdl int addr;
103 1.1 fvdl int speed;
104 1.1 fvdl };
105 1.1 fvdl
106 1.1 fvdl struct btinfo_symtab {
107 1.1 fvdl struct btinfo_common common;
108 1.1 fvdl int nsym;
109 1.1 fvdl int ssym;
110 1.1 fvdl int esym;
111 1.1 fvdl };
112 1.1 fvdl
113 1.1 fvdl struct bi_memmap_entry {
114 1.9 junyoung uint64_t addr; /* beginning of block */ /* 8 */
115 1.9 junyoung uint64_t size; /* size of block */ /* 8 */
116 1.9 junyoung uint32_t type; /* type of block */ /* 4 */
117 1.12 perry } __packed; /* == 20 */
118 1.1 fvdl
119 1.1 fvdl #define BIM_Memory 1 /* available RAM usable by OS */
120 1.1 fvdl #define BIM_Reserved 2 /* in use or reserved by the system */
121 1.1 fvdl #define BIM_ACPI 3 /* ACPI Reclaim memory */
122 1.1 fvdl #define BIM_NVS 4 /* ACPI NVS memory */
123 1.26 nonaka #define BIM_Unusable 5 /* errors have been detected */
124 1.26 nonaka #define BIM_Disabled 6 /* not enabled */
125 1.26 nonaka #define BIM_PMEM 7 /* Persistent memory */
126 1.26 nonaka #define BIM_PRAM 12 /* legacy NVDIMM (OEM defined) */
127 1.1 fvdl
128 1.1 fvdl struct btinfo_memmap {
129 1.1 fvdl struct btinfo_common common;
130 1.1 fvdl int num;
131 1.1 fvdl struct bi_memmap_entry entry[1]; /* var len */
132 1.1 fvdl };
133 1.1 fvdl
134 1.8 dyoung #if HAVE_NBTOOL_CONFIG_H
135 1.8 dyoung #include <nbinclude/sys/bootblock.h>
136 1.8 dyoung #else
137 1.3 lukem #include <sys/bootblock.h>
138 1.8 dyoung #endif /* HAVE_NBTOOL_CONFIG_H */
139 1.1 fvdl
140 1.1 fvdl /*
141 1.1 fvdl * Structure describing disk info as seen by the BIOS.
142 1.1 fvdl */
143 1.1 fvdl struct bi_biosgeom_entry {
144 1.2 dsl int sec, head, cyl; /* geometry */
145 1.9 junyoung uint64_t totsec; /* LBA sectors from ext int13 */
146 1.2 dsl int flags, dev; /* flags, BIOS device # */
147 1.2 dsl #define BI_GEOM_INVALID 0x000001
148 1.2 dsl #define BI_GEOM_EXTINT13 0x000002
149 1.9 junyoung #ifdef BIOSDISK_EXTINFO_V3
150 1.2 dsl #define BI_GEOM_BADCKSUM 0x000004 /* v3.x checksum invalid */
151 1.2 dsl #define BI_GEOM_BUS_MASK 0x00ff00 /* connecting bus type */
152 1.2 dsl #define BI_GEOM_BUS_ISA 0x000100
153 1.2 dsl #define BI_GEOM_BUS_PCI 0x000200
154 1.2 dsl #define BI_GEOM_BUS_OTHER 0x00ff00
155 1.2 dsl #define BI_GEOM_IFACE_MASK 0xff0000 /* interface type */
156 1.2 dsl #define BI_GEOM_IFACE_ATA 0x010000
157 1.2 dsl #define BI_GEOM_IFACE_ATAPI 0x020000
158 1.2 dsl #define BI_GEOM_IFACE_SCSI 0x030000
159 1.2 dsl #define BI_GEOM_IFACE_USB 0x040000
160 1.2 dsl #define BI_GEOM_IFACE_1394 0x050000 /* Firewire */
161 1.2 dsl #define BI_GEOM_IFACE_FIBRE 0x060000 /* Fibre channel */
162 1.9 junyoung #define BI_GEOM_IFACE_OTHER 0xff0000
163 1.2 dsl unsigned int cksum; /* MBR checksum */
164 1.9 junyoung unsigned int interface_path; /* ISA iobase PCI bus/dev/fun */
165 1.9 junyoung uint64_t device_path;
166 1.2 dsl int res0; /* future expansion; 0 now */
167 1.2 dsl #else
168 1.2 dsl unsigned int cksum; /* MBR checksum */
169 1.2 dsl int res0, res1, res2, res3; /* future expansion; 0 now */
170 1.2 dsl #endif
171 1.20 christos struct mbr_partition mbrparts[MBR_PART_COUNT]; /* MBR itself */
172 1.12 perry } __packed;
173 1.1 fvdl
174 1.1 fvdl struct btinfo_biosgeom {
175 1.1 fvdl struct btinfo_common common;
176 1.1 fvdl int num;
177 1.1 fvdl struct bi_biosgeom_entry disk[1]; /* var len */
178 1.1 fvdl };
179 1.1 fvdl
180 1.13 ad struct bi_modulelist_entry {
181 1.13 ad char path[80];
182 1.13 ad int type;
183 1.13 ad int len;
184 1.13 ad uint32_t base;
185 1.13 ad };
186 1.13 ad #define BI_MODULE_NONE 0x00
187 1.13 ad #define BI_MODULE_ELF 0x01
188 1.17 jmcneill #define BI_MODULE_IMAGE 0x02
189 1.19 tls #define BI_MODULE_RND 0x03
190 1.23 jmcneill #define BI_MODULE_FS 0x04
191 1.13 ad
192 1.13 ad struct btinfo_modulelist {
193 1.13 ad struct btinfo_common common;
194 1.13 ad int num;
195 1.13 ad uint32_t endpa;
196 1.13 ad /* bi_modulelist_entry list follows */
197 1.13 ad };
198 1.13 ad
199 1.15 jmcneill struct btinfo_framebuffer {
200 1.15 jmcneill struct btinfo_common common;
201 1.15 jmcneill uint64_t physaddr;
202 1.15 jmcneill uint32_t flags;
203 1.15 jmcneill uint32_t width;
204 1.15 jmcneill uint32_t height;
205 1.15 jmcneill uint16_t stride;
206 1.15 jmcneill uint8_t depth;
207 1.15 jmcneill uint8_t rnum;
208 1.15 jmcneill uint8_t gnum;
209 1.15 jmcneill uint8_t bnum;
210 1.15 jmcneill uint8_t rpos;
211 1.15 jmcneill uint8_t gpos;
212 1.15 jmcneill uint8_t bpos;
213 1.16 jmcneill uint16_t vbemode;
214 1.16 jmcneill uint8_t reserved[14];
215 1.15 jmcneill };
216 1.15 jmcneill
217 1.18 uebayasi struct bi_userconfcommand {
218 1.18 uebayasi char text[80];
219 1.18 uebayasi };
220 1.18 uebayasi
221 1.18 uebayasi struct btinfo_userconfcommands {
222 1.18 uebayasi struct btinfo_common common;
223 1.18 uebayasi int num;
224 1.18 uebayasi /* bi_userconfcommand list follows */
225 1.18 uebayasi };
226 1.18 uebayasi
227 1.24 christos /* EFI Information */
228 1.24 christos struct btinfo_efi {
229 1.24 christos struct btinfo_common common;
230 1.25 nonaka uint64_t systblpa; /* Physical address of the EFI System Table */
231 1.25 nonaka uint32_t flags;
232 1.25 nonaka #define BI_EFI_32BIT __BIT(0) /* 32bit UEFI */
233 1.25 nonaka uint8_t reserved[12];
234 1.25 nonaka };
235 1.25 nonaka
236 1.27 maxv struct btinfo_prekern {
237 1.27 maxv struct btinfo_common common;
238 1.27 maxv uint32_t kernpa_start;
239 1.27 maxv uint32_t kernpa_end;
240 1.27 maxv };
241 1.27 maxv
242 1.25 nonaka struct btinfo_efimemmap {
243 1.25 nonaka struct btinfo_common common;
244 1.25 nonaka uint32_t num; /* number of memory descriptor */
245 1.25 nonaka uint32_t version; /* version of memory descriptor */
246 1.25 nonaka uint32_t size; /* size of memory descriptor */
247 1.25 nonaka uint8_t memmap[1]; /* whole memory descriptors */
248 1.24 christos };
249 1.24 christos
250 1.10 jmmv #endif /* _LOCORE */
251 1.10 jmmv
252 1.1 fvdl #ifdef _KERNEL
253 1.10 jmmv
254 1.10 jmmv #define BOOTINFO_MAXSIZE 4096
255 1.10 jmmv
256 1.10 jmmv #ifndef _LOCORE
257 1.10 jmmv /*
258 1.10 jmmv * Structure that holds the information passed by the boot loader.
259 1.10 jmmv */
260 1.10 jmmv struct bootinfo {
261 1.10 jmmv /* Number of bootinfo_* entries in bi_data. */
262 1.10 jmmv uint32_t bi_nentries;
263 1.10 jmmv
264 1.10 jmmv /* Raw data of bootinfo entries. The first one (if any) is
265 1.10 jmmv * found at bi_data[0] and can be casted to (bootinfo_common *).
266 1.10 jmmv * Once this is done, the following entry is found at 'len'
267 1.10 jmmv * offset as specified by the previous entry. */
268 1.10 jmmv uint8_t bi_data[BOOTINFO_MAXSIZE - sizeof(uint32_t)];
269 1.10 jmmv };
270 1.10 jmmv
271 1.14 tron extern struct bootinfo bootinfo;
272 1.14 tron
273 1.4 junyoung void *lookup_bootinfo(int);
274 1.24 christos void aprint_bootinfo(void);
275 1.1 fvdl #endif /* _LOCORE */
276 1.1 fvdl
277 1.10 jmmv #endif /* _KERNEL */
278