Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 15 Dec 2017 06:34:27 +0000 (UTC)
From:      Warner Losh <imp@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-head@freebsd.org
Subject:   svn commit: r326874 - head/tools/boot
Message-ID:  <201712150634.vBF6YRGc023997@repo.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: imp
Date: Fri Dec 15 06:34:27 2017
New Revision: 326874
URL: https://svnweb.freebsd.org/changeset/base/326874

Log:
  Script to generate minimal boot images for each of the 24 supported
  boot images for x86. This will be enhanced to generate all the other
  images (u-boot, powerpc CHRP, etc).
  
  At the moment, it's only generating three of them. zfs+gpt+legacy
  works with qemu:
  	qemu-system-x86_64 --drive file=${file},format=raw -serial telnet::4444,server
  but the ufs ones still have issues I'm tracking down.
  
  These images are the boot blocks, /boot/loader, a kernel, maybe a
  couple of modules, /sbin/init, /bin/sh, /libexec/ld-elf.so, libc.so,
  libedit and libncursesw. This is just enough to get to single user. At
  the moment, these come from the host system, but should come from
  OBJTOP.
  
  At the moment, this requires root to build since the zfs tools require
  it (and GELI will too when we add support for that).
  
  Sponsored by: Netflix

Added:
  head/tools/boot/rootgen.sh   (contents, props changed)

Added: head/tools/boot/rootgen.sh
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ head/tools/boot/rootgen.sh	Fri Dec 15 06:34:27 2017	(r326874)
@@ -0,0 +1,213 @@
+#!/bin/sh
+
+# $FreeBSD$
+
+#
+# Builds all the bat-shit crazy combinations we support booting from,
+# at least for amd64. It assume you have a ~sane kernel in /boot/kernel
+# and copies that into the ~150MB root images we create (we create the du
+# size of the kernel + 20MB
+#
+# Sad panda sez: this runs as root, but could be userland if someone
+# creates userland geli and zfs tools.
+#
+# This assumes an external prograam install-boot.sh which will install
+# the appropriate boot files in the appropriate locations.
+#
+# These images assume ada0 will be the root image. We should likely
+# use labels, but we don't.
+#
+# ASsumes you've already rebuilt... maybe bad? Also maybe bad: the env
+# vars should likely be conditionally set to allow better automation.
+#
+
+cpsys() {
+    src=$1
+    dst=$2
+
+    # Copy kernel + boot loader
+    (cd $src ; tar cf - .) | (cd $dst; tar xf -)
+}
+
+mk_nogeli_gpt_ufs_legacy() {
+    src=$1
+    img=$2
+
+    rm -f ${img} ${img}.p2
+    makefs -t ffs -B little -s 200m ${img}.p2 ${src}
+    mkimg -s gpt -b ${src}/boot/pmbr \
+	  -p freebsd-boot:=${src}/boot/gptboot \
+	  -p freebsd-ufs:=${img}.p2 -o ${img}
+}
+
+mk_nogeli_gpt_ufs_uefi() {
+    src=$1
+    img=$2
+
+    rm -f ${img} ${img}.p2
+    makefs -t ffs -B little -s 200m ${img}.p2 ${src}
+    mkimg -s gpt -b ${src}/boot/pmbr \
+	  -p freebsd-boot:=${src}/boot/gptboot \
+	  -p freebsd-ufs:=${img}.p2 -o ${img}
+}
+
+mk_nogeli_gpt_ufs_both() {
+    src=$1
+    img=$2
+
+    makefs -t ffs -B little -s 200m ${img}.p3 ${src}
+    # p1 is boot for uefi, p2 is boot for gpt, p3 is /
+    mkimg -b ${src}/boot/pmbr -s gpt \
+	  -p efi:=${src}/boot/boot1.efifat \
+	  -p freebsd-boot:=${src}/boot/gptboot \
+	  -p freebsd-ufs:=${img}.p3 \
+	  -o ${img}
+}
+
+mk_nogeli_gpt_zfs_legacy() {
+    src=$1
+    img=$2
+    mntpt=$3
+    geli=$4
+    scheme=$5
+    fs=$6
+    bios=$7
+    pool=nogeli-gpt-zfs-legacy
+
+    rm -f ${img}
+    dd if=/dev/zero of=${img} count=1 seek=$((200 * 1024 * 1024 / 512))
+    md=$(mdconfig -f ${img})
+    gpart create -s gpt ${md}
+    gpart add -t freebsd-boot -s 400k -a 4k	${md}	# <= ~540k
+    gpart add -t freebsd-zfs -l root $md
+    # install-boot will make this bootable
+    zpool create -O mountpoint=none -R ${mntpt} ${pool} ${md}p2
+    zpool set bootfs=${pool} ${pool}
+    zfs create -o mountpoint=/ ${pool}/ROOT
+    # NB: The online guides go nuts customizing /var and other mountpoints here, no need
+    cpsys ${src} ${mntpt}
+    df
+    # need to make a couple of tweaks
+    cat > ${mntpt}/boot/loader.conf <<EOF
+zfs_load=YES
+opensolaris_load=YES
+EOF
+    cp /boot/kernel/zfs.ko ${mntpt}/boot/kernel/zfs.ko
+    cp /boot/kernel/opensolaris.ko ${mntpt}/boot/kernel/opensolaris.ko
+    # end tweaks
+    zfs umount -f ${pool}/ROOT
+    zfs set mountpoint=none ${pool}/ROOT
+    zpool set bootfs=${pool}/ROOT ${pool}
+    zpool set autoexpand=on ${pool}
+    zpool export ${pool}
+    ${SRCTOP}/tools/boot/install-boot.sh -g ${geli} -s ${scheme} -f ${fs} -b ${bios} -d ${src} ${md}
+    mdconfig -d -u ${md}
+}
+
+mk_nogeli_gpt_zfs_uefi() {
+}
+
+mk_nogeli_gpt_zfs_both() {
+}
+
+mk_nogeli_mbr_ufs_legacy() {
+}
+
+mk_nogeli_mbr_ufs_uefi() {
+}
+
+mk_nogeli_mbr_ufs_both() {
+}
+
+mk_nogeli_mbr_zfs_legacy() {
+}
+
+mk_nogeli_mbr_zfs_uefi() {
+}
+
+mk_nogeli_mbr_zfs_both() {
+}
+
+mk_geli_gpt_ufs_legacy() {
+}
+
+mk_geli_gpt_ufs_uefi() {
+}
+
+mk_geli_gpt_ufs_both() {
+}
+
+mk_geli_gpt_zfs_legacy() {
+}
+
+mk_geli_gpt_zfs_uefi() {
+}
+
+mk_geli_gpt_zfs_both() {
+}
+
+mk_geli_mbr_ufs_legacy() {
+}
+
+mk_geli_mbr_ufs_uefi() {
+}
+
+mk_geli_mbr_ufs_both() {
+}
+
+mk_geli_mbr_zfs_legacy() {
+}
+
+mk_geli_mbr_zfs_uefi() {
+}
+
+mk_geli_mbr_zfs_both() {
+}
+
+# iso
+# pxeldr
+# u-boot
+
+# Misc variables
+SRCTOP=$(make -v SRCTOP)
+cd ${SRCTOP}/stand
+OBJDIR=$(make -v .OBJDIR)
+IMGDIR=${OBJDIR}/boot-images
+mkdir -p ${IMGDIR}
+MNTPT=$(mktemp -d /tmp/stand-test.XXXXXX)
+
+# Setup the installed tree...
+DESTDIR=${OBJDIR}/boot-tree
+rm -rf ${DESTDIR}
+mkdir -p ${DESTDIR}/boot/defaults
+mkdir -p ${DESTDIR}/boot/kernel
+cp /boot/kernel/kernel ${DESTDIR}/boot/kernel
+echo -D -S115200 > ${DESTDIR}/boot.config
+# XXX
+cp /boot/device.hints ${DESTDIR}/boot/device.hints
+# Assume we're already built
+make install DESTDIR=${DESTDIR} MK_MAN=no MK_INSTALL_AS_USER=yes
+# Copy init, /bin/sh and minimal libraries
+mkdir -p ${DESTDIR}/sbin ${DESTDIR}/bin ${DESTDIR}/lib ${DESTDIR}/libexec
+for f in /sbin/init /bin/sh $(ldd /bin/sh | awk 'NF == 4 { print $3; }') /libexec/ld-elf.so.1; do
+    cp $f ${DESTDIR}/$f
+done
+mkdir ${DESTDIR}/dev
+
+# OK. Let the games begin
+
+for geli in nogeli geli; do
+    for scheme in gpt mbr; do
+	for fs in ufs zfs; do
+	    for bios in legacy uefi both; do
+		# Create sparse file and mount newly created filesystem(s) on it
+		img=${IMGDIR}/${geli}-${scheme}-${fs}-${bios}.img
+		echo "vvvvvvvvvvvvvvvvvvvvvv   Creating $img  vvvvvvvvvvvvvvvvvvvvvvv"
+		eval mk_${geli}_${scheme}_${fs}_${bios} ${DESTDIR} ${img} ${MNTPT} ${geli} ${scheme} ${fs} ${bios}
+		echo "^^^^^^^^^^^^^^^^^^^^^^   Creating $img  ^^^^^^^^^^^^^^^^^^^^^^^"
+	    done
+	done
+    done
+done
+
+rmdir ${MNTPT}



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201712150634.vBF6YRGc023997>