Home | History | Annotate | Line # | Download | only in include
bootinfo.h revision 1.26
      1  1.26    nonaka /*	$NetBSD: bootinfo.h,v 1.26 2017/02/14 13:25:22 nonaka 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.24  christos 
     44  1.24  christos #define BTINFO_STR "bootpath", "rootdevice", "bootdisk", "netif", \
     45  1.24  christos     "console", "biosgeom", "symtab", "memmap", "bootwedge", "modulelist", \
     46  1.25    nonaka     "framebuffer", "userconfcommands", "efi", "efimemmap",
     47  1.13        ad 
     48  1.13        ad #ifndef _LOCORE
     49  1.13        ad 
     50  1.13        ad struct btinfo_common {
     51  1.13        ad 	int len;
     52  1.13        ad 	int type;
     53  1.13        ad };
     54   1.1      fvdl 
     55   1.1      fvdl struct btinfo_bootpath {
     56   1.1      fvdl 	struct btinfo_common common;
     57   1.1      fvdl 	char bootpath[80];
     58   1.1      fvdl };
     59   1.1      fvdl 
     60  1.11      jmmv struct btinfo_rootdevice {
     61  1.11      jmmv 	struct btinfo_common common;
     62  1.11      jmmv 	char devname[16];
     63  1.11      jmmv };
     64  1.11      jmmv 
     65   1.1      fvdl struct btinfo_bootdisk {
     66   1.1      fvdl 	struct btinfo_common common;
     67   1.1      fvdl 	int labelsector; /* label valid if != -1 */
     68   1.1      fvdl 	struct {
     69   1.9  junyoung 		uint16_t type, checksum;
     70   1.1      fvdl 		char packname[16];
     71   1.1      fvdl 	} label;
     72   1.1      fvdl 	int biosdev;
     73   1.1      fvdl 	int partition;
     74   1.1      fvdl };
     75   1.1      fvdl 
     76   1.6   thorpej struct btinfo_bootwedge {
     77   1.6   thorpej 	struct btinfo_common common;
     78   1.6   thorpej 	int biosdev;
     79   1.6   thorpej 	daddr_t startblk;
     80   1.6   thorpej 	uint64_t nblks;
     81   1.6   thorpej 	daddr_t matchblk;
     82   1.6   thorpej 	uint64_t matchnblks;
     83   1.6   thorpej 	uint8_t matchhash[16];	/* MD5 hash */
     84  1.12     perry } __packed;
     85   1.6   thorpej 
     86   1.1      fvdl struct btinfo_netif {
     87   1.1      fvdl 	struct btinfo_common common;
     88   1.1      fvdl 	char ifname[16];
     89   1.1      fvdl 	int bus;
     90   1.1      fvdl #define BI_BUS_ISA 0
     91   1.1      fvdl #define BI_BUS_PCI 1
     92   1.1      fvdl 	union {
     93   1.1      fvdl 		unsigned int iobase; /* ISA */
     94   1.1      fvdl 		unsigned int tag; /* PCI, BIOS format */
     95   1.1      fvdl 	} addr;
     96   1.1      fvdl };
     97   1.1      fvdl 
     98   1.1      fvdl struct btinfo_console {
     99   1.1      fvdl 	struct btinfo_common common;
    100   1.1      fvdl 	char devname[16];
    101   1.1      fvdl 	int addr;
    102   1.1      fvdl 	int speed;
    103   1.1      fvdl };
    104   1.1      fvdl 
    105   1.1      fvdl struct btinfo_symtab {
    106   1.1      fvdl 	struct btinfo_common common;
    107   1.1      fvdl 	int nsym;
    108   1.1      fvdl 	int ssym;
    109   1.1      fvdl 	int esym;
    110   1.1      fvdl };
    111   1.1      fvdl 
    112   1.1      fvdl struct bi_memmap_entry {
    113   1.9  junyoung 	uint64_t addr;		/* beginning of block */	/* 8 */
    114   1.9  junyoung 	uint64_t size;		/* size of block */		/* 8 */
    115   1.9  junyoung 	uint32_t type;		/* type of block */		/* 4 */
    116  1.12     perry } __packed;				/*	== 20 */
    117   1.1      fvdl 
    118   1.1      fvdl #define	BIM_Memory	1	/* available RAM usable by OS */
    119   1.1      fvdl #define	BIM_Reserved	2	/* in use or reserved by the system */
    120   1.1      fvdl #define	BIM_ACPI	3	/* ACPI Reclaim memory */
    121   1.1      fvdl #define	BIM_NVS		4	/* ACPI NVS memory */
    122  1.26    nonaka #define	BIM_Unusable	5	/* errors have been detected */
    123  1.26    nonaka #define	BIM_Disabled	6	/* not enabled */
    124  1.26    nonaka #define	BIM_PMEM	7	/* Persistent memory */
    125  1.26    nonaka #define	BIM_PRAM	12	/* legacy NVDIMM (OEM defined) */
    126   1.1      fvdl 
    127   1.1      fvdl struct btinfo_memmap {
    128   1.1      fvdl 	struct btinfo_common common;
    129   1.1      fvdl 	int num;
    130   1.1      fvdl 	struct bi_memmap_entry entry[1]; /* var len */
    131   1.1      fvdl };
    132   1.1      fvdl 
    133   1.8    dyoung #if HAVE_NBTOOL_CONFIG_H
    134   1.8    dyoung #include <nbinclude/sys/bootblock.h>
    135   1.8    dyoung #else
    136   1.3     lukem #include <sys/bootblock.h>
    137   1.8    dyoung #endif /* HAVE_NBTOOL_CONFIG_H */
    138   1.1      fvdl 
    139   1.1      fvdl /*
    140   1.1      fvdl  * Structure describing disk info as seen by the BIOS.
    141   1.1      fvdl  */
    142   1.1      fvdl struct bi_biosgeom_entry {
    143   1.2       dsl 	int		sec, head, cyl;		/* geometry */
    144   1.9  junyoung 	uint64_t	totsec;			/* LBA sectors from ext int13 */
    145   1.2       dsl 	int		flags, dev;		/* flags, BIOS device # */
    146   1.2       dsl #define BI_GEOM_INVALID		0x000001
    147   1.2       dsl #define BI_GEOM_EXTINT13	0x000002
    148   1.9  junyoung #ifdef BIOSDISK_EXTINFO_V3
    149   1.2       dsl #define BI_GEOM_BADCKSUM	0x000004	/* v3.x checksum invalid */
    150   1.2       dsl #define BI_GEOM_BUS_MASK	0x00ff00	/* connecting bus type */
    151   1.2       dsl #define BI_GEOM_BUS_ISA		0x000100
    152   1.2       dsl #define BI_GEOM_BUS_PCI		0x000200
    153   1.2       dsl #define BI_GEOM_BUS_OTHER	0x00ff00
    154   1.2       dsl #define BI_GEOM_IFACE_MASK	0xff0000	/* interface type */
    155   1.2       dsl #define BI_GEOM_IFACE_ATA	0x010000
    156   1.2       dsl #define BI_GEOM_IFACE_ATAPI	0x020000
    157   1.2       dsl #define BI_GEOM_IFACE_SCSI	0x030000
    158   1.2       dsl #define BI_GEOM_IFACE_USB	0x040000
    159   1.2       dsl #define BI_GEOM_IFACE_1394	0x050000	/* Firewire */
    160   1.2       dsl #define BI_GEOM_IFACE_FIBRE	0x060000	/* Fibre channel */
    161   1.9  junyoung #define BI_GEOM_IFACE_OTHER	0xff0000
    162   1.2       dsl 	unsigned int	cksum;			/* MBR checksum */
    163   1.9  junyoung 	unsigned int	interface_path;		/* ISA iobase PCI bus/dev/fun */
    164   1.9  junyoung 	uint64_t	device_path;
    165   1.2       dsl 	int		res0;			/* future expansion; 0 now */
    166   1.2       dsl #else
    167   1.2       dsl 	unsigned int	cksum;			/* MBR checksum */
    168   1.2       dsl 	int		res0, res1, res2, res3;	/* future expansion; 0 now */
    169   1.2       dsl #endif
    170  1.20  christos 	struct mbr_partition mbrparts[MBR_PART_COUNT]; /* MBR itself */
    171  1.12     perry } __packed;
    172   1.1      fvdl 
    173   1.1      fvdl struct btinfo_biosgeom {
    174   1.1      fvdl 	struct btinfo_common common;
    175   1.1      fvdl 	int num;
    176   1.1      fvdl 	struct bi_biosgeom_entry disk[1]; /* var len */
    177   1.1      fvdl };
    178   1.1      fvdl 
    179  1.13        ad struct bi_modulelist_entry {
    180  1.13        ad 	char path[80];
    181  1.13        ad 	int type;
    182  1.13        ad 	int len;
    183  1.13        ad 	uint32_t base;
    184  1.13        ad };
    185  1.13        ad #define	BI_MODULE_NONE		0x00
    186  1.13        ad #define	BI_MODULE_ELF		0x01
    187  1.17  jmcneill #define	BI_MODULE_IMAGE		0x02
    188  1.19       tls #define BI_MODULE_RND		0x03
    189  1.23  jmcneill #define BI_MODULE_FS		0x04
    190  1.13        ad 
    191  1.13        ad struct btinfo_modulelist {
    192  1.13        ad 	struct btinfo_common common;
    193  1.13        ad 	int num;
    194  1.13        ad 	uint32_t endpa;
    195  1.13        ad 	/* bi_modulelist_entry list follows */
    196  1.13        ad };
    197  1.13        ad 
    198  1.15  jmcneill struct btinfo_framebuffer {
    199  1.15  jmcneill 	struct btinfo_common common;
    200  1.15  jmcneill 	uint64_t physaddr;
    201  1.15  jmcneill 	uint32_t flags;
    202  1.15  jmcneill 	uint32_t width;
    203  1.15  jmcneill 	uint32_t height;
    204  1.15  jmcneill 	uint16_t stride;
    205  1.15  jmcneill 	uint8_t depth;
    206  1.15  jmcneill 	uint8_t rnum;
    207  1.15  jmcneill 	uint8_t gnum;
    208  1.15  jmcneill 	uint8_t bnum;
    209  1.15  jmcneill 	uint8_t rpos;
    210  1.15  jmcneill 	uint8_t gpos;
    211  1.15  jmcneill 	uint8_t bpos;
    212  1.16  jmcneill 	uint16_t vbemode;
    213  1.16  jmcneill 	uint8_t reserved[14];
    214  1.15  jmcneill };
    215  1.15  jmcneill 
    216  1.18  uebayasi struct bi_userconfcommand {
    217  1.18  uebayasi 	char text[80];
    218  1.18  uebayasi };
    219  1.18  uebayasi 
    220  1.18  uebayasi struct btinfo_userconfcommands {
    221  1.18  uebayasi 	struct btinfo_common common;
    222  1.18  uebayasi 	int num;
    223  1.18  uebayasi 	/* bi_userconfcommand list follows */
    224  1.18  uebayasi };
    225  1.18  uebayasi 
    226  1.24  christos /* EFI Information */
    227  1.24  christos struct btinfo_efi {
    228  1.24  christos 	struct btinfo_common common;
    229  1.25    nonaka 	uint64_t systblpa;	/* Physical address of the EFI System Table */
    230  1.25    nonaka 	uint32_t flags;
    231  1.25    nonaka #define BI_EFI_32BIT	__BIT(0)	/* 32bit UEFI */
    232  1.25    nonaka 	uint8_t reserved[12];
    233  1.25    nonaka };
    234  1.25    nonaka 
    235  1.25    nonaka struct btinfo_efimemmap {
    236  1.25    nonaka 	struct btinfo_common common;
    237  1.25    nonaka 	uint32_t num;		/* number of memory descriptor */
    238  1.25    nonaka 	uint32_t version;	/* version of memory descriptor */
    239  1.25    nonaka 	uint32_t size;		/* size of memory descriptor */
    240  1.25    nonaka 	uint8_t memmap[1];	/* whole memory descriptors */
    241  1.24  christos };
    242  1.24  christos 
    243  1.10      jmmv #endif /* _LOCORE */
    244  1.10      jmmv 
    245   1.1      fvdl #ifdef _KERNEL
    246  1.10      jmmv 
    247  1.10      jmmv #define BOOTINFO_MAXSIZE 4096
    248  1.10      jmmv 
    249  1.10      jmmv #ifndef _LOCORE
    250  1.10      jmmv /*
    251  1.10      jmmv  * Structure that holds the information passed by the boot loader.
    252  1.10      jmmv  */
    253  1.10      jmmv struct bootinfo {
    254  1.10      jmmv 	/* Number of bootinfo_* entries in bi_data. */
    255  1.10      jmmv 	uint32_t	bi_nentries;
    256  1.10      jmmv 
    257  1.10      jmmv 	/* Raw data of bootinfo entries.  The first one (if any) is
    258  1.10      jmmv 	 * found at bi_data[0] and can be casted to (bootinfo_common *).
    259  1.10      jmmv 	 * Once this is done, the following entry is found at 'len'
    260  1.10      jmmv 	 * offset as specified by the previous entry. */
    261  1.10      jmmv 	uint8_t		bi_data[BOOTINFO_MAXSIZE - sizeof(uint32_t)];
    262  1.10      jmmv };
    263  1.10      jmmv 
    264  1.14      tron extern struct bootinfo bootinfo;
    265  1.14      tron 
    266   1.4  junyoung void *lookup_bootinfo(int);
    267  1.24  christos void  aprint_bootinfo(void);
    268   1.1      fvdl #endif /* _LOCORE */
    269   1.1      fvdl 
    270  1.10      jmmv #endif /* _KERNEL */
    271