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