Marcel Moolenaar 4d32fcb42b Add the bootcode verb for installing boot code. Boot code
is supported for the MBR, GPT and PC98 schemes, where GPT
installs boot code into the PMBR.
2008-04-13 19:54:54 +00:00

174 lines
5.9 KiB
C

/*-
* Copyright (c) 2006, 2007 Marcel Moolenaar
* 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.
*
* $FreeBSD$
*/
#ifndef _GEOM_PART_H_
#define _GEOM_PART_H_
#define G_PART_TRACE(args) g_trace args
#define G_PART_PROBE_PRI_LOW -10
#define G_PART_PROBE_PRI_NORM -5
#define G_PART_PROBE_PRI_HIGH 0
enum g_part_alias {
G_PART_ALIAS_EFI, /* A EFI system partition entry. */
G_PART_ALIAS_FREEBSD, /* A BSD labeled partition entry. */
G_PART_ALIAS_FREEBSD_BOOT, /* A FreeBSD boot partition entry. */
G_PART_ALIAS_FREEBSD_SWAP, /* A swap partition entry. */
G_PART_ALIAS_FREEBSD_UFS, /* A UFS/UFS2 file system entry. */
G_PART_ALIAS_FREEBSD_VINUM, /* A Vinum partition entry. */
G_PART_ALIAS_FREEBSD_ZFS, /* A ZFS file system entry. */
G_PART_ALIAS_MBR, /* A MBR (extended) partition entry. */
/* Keep the following last */
G_PART_ALIAS_COUNT
};
const char *g_part_alias_name(enum g_part_alias);
/* G_PART scheme (KOBJ class). */
struct g_part_scheme {
KOBJ_CLASS_FIELDS;
size_t gps_entrysz;
int gps_minent;
int gps_maxent;
int gps_bootcodesz;
TAILQ_ENTRY(g_part_scheme) scheme_list;
};
struct g_part_entry {
LIST_ENTRY(g_part_entry) gpe_entry;
struct g_provider *gpe_pp; /* Corresponding provider. */
off_t gpe_offset; /* Byte offset. */
quad_t gpe_start; /* First LBA of partition. */
quad_t gpe_end; /* Last LBA of partition. */
int gpe_index;
int gpe_created:1; /* Entry is newly created. */
int gpe_deleted:1; /* Entry has been deleted. */
int gpe_modified:1; /* Entry has been modified. */
int gpe_internal:1; /* Entry is not a used entry. */
};
/* G_PART table (KOBJ instance). */
struct g_part_table {
KOBJ_FIELDS;
struct g_part_scheme *gpt_scheme;
struct g_geom *gpt_gp;
LIST_HEAD(, g_part_entry) gpt_entry;
quad_t gpt_first; /* First allocatable LBA */
quad_t gpt_last; /* Last allocatable LBA */
int gpt_entries;
/*
* gpt_smhead and gpt_smtail are bitmaps representing the first
* 32 sectors on the disk (gpt_smhead) and the last 32 sectors
* on the disk (gpt_smtail). These maps are used by the commit
* verb to clear sectors previously used by a scheme after the
* partitioning scheme has been destroyed.
*/
uint32_t gpt_smhead;
uint32_t gpt_smtail;
/*
* gpt_sectors and gpt_heads are the fixed or synchesized number
* of sectors per track and heads (resp) that make up a disks
* geometry. This is to support partitioning schemes as well as
* file systems that work on a geometry. The MBR scheme and the
* MS-DOS (FAT) file system come to mind.
* We keep track of whether the geometry is fixed or synchesized
* so that a partitioning scheme can correct the synthesized
* geometry, based on the on-disk metadata.
*/
uint32_t gpt_sectors;
uint32_t gpt_heads;
/*
* gpt_offset holds the absolute block address of the scheme
* on disk. Some partitioning schemes (historically) use
* absolute addressing. Relative addresses are obtained by
* subtracting gpt_offset from the absolute addresses.
*/
uint64_t gpt_offset;
int gpt_depth; /* Sub-partitioning level. */
int gpt_isleaf:1; /* Cannot be sub-partitioned. */
int gpt_created:1; /* Newly created. */
int gpt_modified:1; /* Table changes have been made. */
int gpt_opened:1; /* Permissions obtained. */
int gpt_fixgeom:1; /* Geometry is fixed. */
};
struct g_part_entry *g_part_new_entry(struct g_part_table *, int, quad_t,
quad_t);
/* G_PART ctlreq parameters. */
#define G_PART_PARM_ENTRIES 0x0001
#define G_PART_PARM_FLAGS 0x0002
#define G_PART_PARM_GEOM 0x0004
#define G_PART_PARM_INDEX 0x0008
#define G_PART_PARM_LABEL 0x0010
#define G_PART_PARM_OUTPUT 0x0020
#define G_PART_PARM_PROVIDER 0x0040
#define G_PART_PARM_SCHEME 0x0080
#define G_PART_PARM_SIZE 0x0100
#define G_PART_PARM_START 0x0200
#define G_PART_PARM_TYPE 0x0400
#define G_PART_PARM_VERSION 0x0800
#define G_PART_PARM_BOOTCODE 0x1000
struct g_part_parms {
unsigned int gpp_parms;
unsigned int gpp_entries;
const char *gpp_flags;
struct g_geom *gpp_geom;
unsigned int gpp_index;
const char *gpp_label;
struct g_provider *gpp_provider;
struct g_part_scheme *gpp_scheme;
quad_t gpp_size;
quad_t gpp_start;
const char *gpp_type;
unsigned int gpp_version;
const void *gpp_codeptr;
unsigned int gpp_codesize;
};
void g_part_geometry_heads(off_t, u_int, off_t *, u_int *);
int g_part_modevent(module_t, int, struct g_part_scheme *);
#define G_PART_SCHEME_DECLARE(name) \
static int name##_modevent(module_t mod, int tp, void *d) \
{ \
return (g_part_modevent(mod, tp, d)); \
} \
static moduledata_t name##_mod = { \
#name, \
name##_modevent, \
&name##_scheme \
}; \
DECLARE_MODULE(name, name##_mod, SI_SUB_DRIVERS, SI_ORDER_ANY)
#endif /* !_GEOM_PART_H_ */