NetBSD/usr.sbin/sysinst
martin 7ca7eecae1 Make sure all menus have a translatable exit option (or none at all). 2019-11-16 20:26:59 +00:00
..
arch Make the bootblock selection menu more sane, pointed out by maxv 2019-11-16 18:08:59 +00:00
Makefile
Makefile.inc Make tar extraction flags depend on our usage of pax-as-tar or bsdtar. 2019-11-14 13:58:22 +00:00
README.md_defs Provide some documentation for macros / defines used in the machine 2019-08-14 12:49:37 +00:00
SPELLING.en
TODO
aout2elf.c
bsddisklabel.c Make cloning support optional, so we can save some space on very small 2019-11-13 18:57:26 +00:00
checkrc.c Fix memory leak (found by MKSANITIZER=yes build). 2019-08-18 11:11:48 +00:00
configmenu.c Make sure all menus have a translatable exit option (or none at all). 2019-11-16 20:26:59 +00:00
defs.h Make tar extraction flags depend on our usage of pax-as-tar or bsdtar. 2019-11-14 13:58:22 +00:00
defsizes.h
disklabel.c Add options to the various partitioning stages that allow cloning of 2019-11-12 16:33:14 +00:00
disks.c Make sure all menus have a translatable exit option (or none at all). 2019-11-16 20:26:59 +00:00
disks_lfs.c
endian.h
factor.c
geom.c
gpt.c Add options to the various partitioning stages that allow cloning of 2019-11-12 16:33:14 +00:00
gpt_uuid.c
install.c Make cloning support optional, so we can save some space on very small 2019-11-13 18:57:26 +00:00
label.c Make cloning support optional, so we can save some space on very small 2019-11-13 18:57:26 +00:00
main.c Add options to the various partitioning stages that allow cloning of 2019-11-12 16:33:14 +00:00
mbr.c Add options to the various partitioning stages that allow cloning of 2019-11-12 16:33:14 +00:00
mbr.h Add options to the various partitioning stages that allow cloning of 2019-11-12 16:33:14 +00:00
menus.mi Fix the "reinstall sets" action. 2019-07-23 16:02:32 +00:00
menus.pm
msg.mbr.de
msg.mbr.en
msg.mbr.es
msg.mbr.fr
msg.mbr.pl
msg.mi.de Make sure all menus have a translatable exit option (or none at all). 2019-11-16 20:26:59 +00:00
msg.mi.en Make sure all menus have a translatable exit option (or none at all). 2019-11-16 20:26:59 +00:00
msg.mi.es Make sure all menus have a translatable exit option (or none at all). 2019-11-16 20:26:59 +00:00
msg.mi.fr Make sure all menus have a translatable exit option (or none at all). 2019-11-16 20:26:59 +00:00
msg.mi.pl Make sure all menus have a translatable exit option (or none at all). 2019-11-16 20:26:59 +00:00
msg.pm.de
msg.pm.en
msg.pm.es
msg.pm.fr
msg.pm.pl
msg_cmp.sh
msg_xlat.sh
net.c Make sure all menus have a translatable exit option (or none at all). 2019-11-16 20:26:59 +00:00
part_edit.c Drop unused variable. 2019-11-16 15:50:45 +00:00
partitions.c Add options to the various partitioning stages that allow cloning of 2019-11-12 16:33:14 +00:00
partitions.h Add options to the various partitioning stages that allow cloning of 2019-11-12 16:33:14 +00:00
partman.c Make sure all menus have a translatable exit option (or none at all). 2019-11-16 20:26:59 +00:00
run.c Make sure all menus have a translatable exit option (or none at all). 2019-11-16 20:26:59 +00:00
sizemultname.c
target.c Support upgrade of systems using NAME= syntax in /etc/fstab. 2019-08-07 10:08:04 +00:00
txtwalk.c Support upgrade of systems using NAME= syntax in /etc/fstab. 2019-08-07 10:08:04 +00:00
txtwalk.h Support upgrade of systems using NAME= syntax in /etc/fstab. 2019-08-07 10:08:04 +00:00
unif.awk
upgrade.c Do not offer to upgared the "current system" if we are running off a CD 2019-08-27 14:11:00 +00:00
util.c Make sure all menus have a translatable exit option (or none at all). 2019-11-16 20:26:59 +00:00
wskbd.c

README.md_defs

/* $NetBSD: README.md_defs,v 1.1 2019/08/14 12:49:37 martin Exp $ */

The following is trying to document the most important machine dependent
defines used in the sysinst code.


If HAVE_GPT is true, the MD code may limit the space used for the
GPT at the beginning of the disk to allow e.g. a bootloader
being added after it (see evbarm on allwinner SoCs, u-boot is
copied at 8k into the image).

/* Size limit for the initial GPT part, in bytes */
#define	MD_GPT_INITIAL_SIZE		(8*1024)


The default installation description is created as a static array using
lots of conditionals. It may be overriden / replaced in the MD code
(see below), an example for that is arch/i386/md.c when we have been
booted from UEFI firmware.

Name		Value / example		Description
PART_BOOT	(8*MEG) (undefined)	if defined, a boot partition
					of this size (in bytes, rounded)
					will be part of the default partition
					suggestions. Must be compile time
					const! Use MD_PART_DEFAULTS if
					runtime adjustment is needed.
PART_BOOT_MOUNT	"/boot" (undefined)	Add boot partition to fstab for
					this mount point
PART_BOOT_TYPE	FS_BSDFS		Kind of filesystem used
PART_BOOT_SUBT	MBR_PTYPE_FAT12		File system specific sub type


The boot partition is always inserted at the front of the suggested default
partitions, to cope with firmwares that may not be able to load from the
whole disk.

If multiple boot partitions are required (see ofppc, where various schemes
are supported, depending on exact model), the variables above can all be
repeated with _BOOT1_ or _BOOT2_ name instead of _BOOT_.


ATTENTION:
	PART_BOOT	is in BYTE (not MB), while most other sizes
			(DEFROOTSIZE, DEFSWAP, ...) are in MB!


The following macros provide optional MD hooks:

MD_PART_DEFAULTS	may be undefined

used like:

	void MD_PART_DEFAULTS(struct pm_dev*, struct part_usage_info*,
	    size_t num_usage_infos),

Called before any of the partition usage defaults is ever used, can be used
to adjust e.g. partition sizes to actual system requirements (align boot
partition with cylindersize), or (since it is a macro and all params are
by references) to completely swap the defaults (e.g. EFI vs. biosboot).
If swapping, make sure allocation and num_usage_infos stays consistent,
old allocation is done by calloc(3), use free(3) to release.


MD_NEED_BOOTBLOCK	may be undefined

used like:

	bool MD_NEED_BOOTBLOCK(struct install_partition_desc *install)

returns true if this setup needs boot blocks. Used for example on x86
when UEFI installs do not need any bootblocks, but BIOS ones do.


HAVE_PLAIN_DISKLABEL_BOOT	may be undefined, only used on architectures
				that have MBR as primary with disklabel as
				secondary partitioning scheme (RAW_PART != 2)

used like:

	bool HAVE_PLAIN_DISKLABEL_BOOT(const char *disk)

returns true if the disk could be made bootable with only a disklabel
(and no MBR).