Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 22 Mar 2011 01:14:53 +0000 (UTC)
From:      Nathan Whitehorn <nwhitehorn@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-head@freebsd.org
Subject:   svn commit: r219856 - in head/release: . amd64 i386 ia64 powerpc sparc64
Message-ID:  <201103220114.p2M1Ermk035805@svn.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: nwhitehorn
Date: Tue Mar 22 01:14:53 2011
New Revision: 219856
URL: http://svn.freebsd.org/changeset/base/219856

Log:
  Use labels to find release media instead of hard-coded device paths. This
  makes booting more reliable (and working at all on USB sticks). While here,
  move responsibility for setting up fstab into the various platform mk-*.sh
  scripts.
  
  Suggested by:	many

Modified:
  head/release/Makefile
  head/release/amd64/make-memstick.sh
  head/release/amd64/mkisoimages.sh
  head/release/i386/make-memstick.sh
  head/release/i386/mkisoimages.sh
  head/release/ia64/mkisoimages.sh
  head/release/powerpc/mkisoimages.sh
  head/release/sparc64/mkisoimages.sh

Modified: head/release/Makefile
==============================================================================
--- head/release/Makefile	Tue Mar 22 00:52:44 2011	(r219855)
+++ head/release/Makefile	Tue Mar 22 01:14:53 2011	(r219856)
@@ -127,9 +127,7 @@ system: packagesystem
 	touch ${.OBJDIR}/${.TARGET}
 
 release.iso: system
-	echo kernel_options=\"-C\" > ${.OBJDIR}/release/boot/loader.conf
 	sh ${.CURDIR}/${TARGET}/mkisoimages.sh -b FreeBSD_Install ${.OBJDIR}/release.iso ${.OBJDIR}/release
-	rm ${.OBJDIR}/release/boot/loader.conf
 
 memstick: system
 	sh ${.CURDIR}/${TARGET}/make-memstick.sh ${.OBJDIR}/release ${.OBJDIR}/memstick

Modified: head/release/amd64/make-memstick.sh
==============================================================================
--- head/release/amd64/make-memstick.sh	Tue Mar 22 00:52:44 2011	(r219855)
+++ head/release/amd64/make-memstick.sh	Tue Mar 22 01:14:53 2011	(r219856)
@@ -32,12 +32,14 @@ if [ -e ${2} ]; then
   exit 1
 fi
 
+echo '/dev/gpt/FreeBSD_Install / ufs rw,noatime 1 1' > ${1}/etc/fstab
 rm -f ${tempfile}
-makefs ${tempfile} ${1}
+makefs -B little ${tempfile} ${1}
 if [ $? -ne 0 ]; then
   echo "makefs failed"
   exit 1
 fi
+rm ${1}/etc/fstab
 
 #
 # Use $BLOCKSIZE for transfers to improve efficiency.  When calculating
@@ -46,7 +48,7 @@ fi
 #
 
 filesize=`stat -f "%z" ${tempfile}`
-blocks=$(($filesize / ${BLOCKSIZE} + 2))
+blocks=$(($filesize / ${BLOCKSIZE} + 256))
 dd if=/dev/zero of=${2} bs=${BLOCKSIZE} count=${blocks}
 if [ $? -ne 0 ]; then
   echo "creation of image file failed"
@@ -59,19 +61,12 @@ if [ $? -ne 0 ]; then
   exit 1
 fi
 
-fdisk -BIq /dev/${unit}
-if [ $? -ne 0 ]; then
-  echo "fdisk failed"
-  exit 1
-fi
-
-bsdlabel -B -w /dev/${unit}
-if [ $? -ne 0 ]; then
-  echo "bsdlabel failed"
-  exit 1
-fi
+gpart create -s GPT ${unit}
+gpart add -t freebsd-boot -s 64K ${unit}
+gpart bootcode -b ${1}/boot/pmbr -p ${1}/boot/gptboot -i 1 ${unit}
+gpart add -t freebsd-ufs -l FreeBSD_Install ${unit}
 
-dd if=${tempfile} of=/dev/${unit}a bs=$BLOCKSIZE conv=sync
+dd if=${tempfile} of=/dev/${unit}p2 bs=$BLOCKSIZE conv=sync
 if [ $? -ne 0 ]; then
   echo "copying filesystem into image file failed"
   exit 1

Modified: head/release/amd64/mkisoimages.sh
==============================================================================
--- head/release/amd64/mkisoimages.sh	Tue Mar 22 00:52:44 2011	(r219855)
+++ head/release/amd64/mkisoimages.sh	Tue Mar 22 01:14:53 2011	(r219856)
@@ -54,4 +54,7 @@ fi
 LABEL=$1; shift
 NAME=$1; shift
 
+echo "/dev/iso9660/$LABEL / cd9660 ro 0 0" > $1/etc/fstab
 mkisofs $bootable -r -J -V $LABEL -publisher "$publisher" -o $NAME $*
+rm $1/etc/fstab
+

Modified: head/release/i386/make-memstick.sh
==============================================================================
--- head/release/i386/make-memstick.sh	Tue Mar 22 00:52:44 2011	(r219855)
+++ head/release/i386/make-memstick.sh	Tue Mar 22 01:14:53 2011	(r219856)
@@ -32,12 +32,14 @@ if [ -e ${2} ]; then
   exit 1
 fi
 
+echo '/dev/gpt/FreeBSD_Install / ufs rw,noatime 1 1' > ${1}/etc/fstab
 rm -f ${tempfile}
-makefs ${tempfile} ${1}
+makefs -B little ${tempfile} ${1}
 if [ $? -ne 0 ]; then
   echo "makefs failed"
   exit 1
 fi
+rm ${1}/etc/fstab
 
 #
 # Use $BLOCKSIZE for transfers to improve efficiency.  When calculating
@@ -46,7 +48,7 @@ fi
 #
 
 filesize=`stat -f "%z" ${tempfile}`
-blocks=$(($filesize / ${BLOCKSIZE} + 2))
+blocks=$(($filesize / ${BLOCKSIZE} + 256))
 dd if=/dev/zero of=${2} bs=${BLOCKSIZE} count=${blocks}
 if [ $? -ne 0 ]; then
   echo "creation of image file failed"
@@ -59,19 +61,12 @@ if [ $? -ne 0 ]; then
   exit 1
 fi
 
-fdisk -BIq /dev/${unit}
-if [ $? -ne 0 ]; then
-  echo "fdisk failed"
-  exit 1
-fi
-
-bsdlabel -B -w /dev/${unit}
-if [ $? -ne 0 ]; then
-  echo "bsdlabel failed"
-  exit 1
-fi
+gpart create -s GPT ${unit}
+gpart add -t freebsd-boot -s 64K ${unit}
+gpart bootcode -b ${1}/boot/pmbr -p ${1}/boot/gptboot -i 1 ${unit}
+gpart add -t freebsd-ufs -l FreeBSD_Install ${unit}
 
-dd if=${tempfile} of=/dev/${unit}a bs=$BLOCKSIZE conv=sync
+dd if=${tempfile} of=/dev/${unit}p2 bs=$BLOCKSIZE conv=sync
 if [ $? -ne 0 ]; then
   echo "copying filesystem into image file failed"
   exit 1

Modified: head/release/i386/mkisoimages.sh
==============================================================================
--- head/release/i386/mkisoimages.sh	Tue Mar 22 00:52:44 2011	(r219855)
+++ head/release/i386/mkisoimages.sh	Tue Mar 22 01:14:53 2011	(r219856)
@@ -57,4 +57,7 @@ fi
 LABEL=$1; shift
 NAME=$1; shift
 
+echo "/dev/iso9660/$LABEL / cd9660 ro 0 0" > $1/etc/fstab
 mkisofs $bootable -r -J -V $LABEL -publisher "$publisher" -o $NAME $*
+rm $1/etc/fstab
+

Modified: head/release/ia64/mkisoimages.sh
==============================================================================
--- head/release/ia64/mkisoimages.sh	Tue Mar 22 00:52:44 2011	(r219855)
+++ head/release/ia64/mkisoimages.sh	Tue Mar 22 01:14:53 2011	(r219856)
@@ -91,6 +91,8 @@ fi
 
 publisher="The FreeBSD Project.  http://www.freebsd.org/"
 
+echo "/dev/iso9660/$LABEL / cd9660 ro 0 0" > $1/etc/fstab
 $MKISOFS $BOOTOPTS -r -J -V $LABEL -publisher "$publisher" -o $NAME $BASE $*
 rm -f $BASE/$EFIPART
+rm $1/etc/fstab
 exit 0

Modified: head/release/powerpc/mkisoimages.sh
==============================================================================
--- head/release/powerpc/mkisoimages.sh	Tue Mar 22 00:52:44 2011	(r219855)
+++ head/release/powerpc/mkisoimages.sh	Tue Mar 22 01:14:53 2011	(r219856)
@@ -54,4 +54,7 @@ fi
 LABEL=$1; shift
 NAME=$1; shift
 
+echo "/dev/iso9660/$LABEL / cd9660 ro 0 0" > $1/etc/fstab
 mkisofs $bootable -l -r -part -no-desktop -V $LABEL -o $NAME $*
+rm $1/etc/fstab
+

Modified: head/release/sparc64/mkisoimages.sh
==============================================================================
--- head/release/sparc64/mkisoimages.sh	Tue Mar 22 00:52:44 2011	(r219855)
+++ head/release/sparc64/mkisoimages.sh	Tue Mar 22 01:14:53 2011	(r219856)
@@ -66,5 +66,7 @@ fi
 LABEL=$1; shift
 NAME=$1; shift
 
+echo "/dev/iso9660/$LABEL / cd9660 ro 0 0" > $1/etc/fstab
 mkisofs $bootable -r -J -V $LABEL -publisher "$publisher" -o $NAME $*
+rm $1/etc/fstab
 rm -f ${IMG}



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