Home | History | Annotate | Line # | Download | only in include
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