X-Git-Url: https://git.distorted.org.uk/~mdw/distorted-chroot/blobdiff_plain/fd0f20e15d713daf7f0cb2cfe429edbcc50574fb..3e5b03e2c0f0a3ddf3a56136f475e99d44432f18:/bin/mkbuildchroot diff --git a/bin/mkbuildchroot b/bin/mkbuildchroot index 40f925b..58dc7c6 100755 --- a/bin/mkbuildchroot +++ b/bin/mkbuildchroot @@ -26,8 +26,11 @@ . state/config.sh # @@@config@@@ +## Convert the PROXY configuration setting into something that will affect +## `debootstrap'. case $PROXY in nil) ;; *) http_proxy=$PROXY; export PROXY ;; esac +## Parse the command-line. badp=nil forcep=nil while getopts "f" opt; do case $opt in @@ -43,19 +46,22 @@ d=$1 a=$2 case $d-$a in *-*-*) echo >&2 "$0: bad chroot name \`$arg'"; exit 2 ;; esac if [ ! -d /dev/$VG/ ]; then echo >&2 "$0: no volume group \`$VG'"; exit 2; fi +## Decide whether we need to do special things for installing a foreign +## architecture. qemup=nil dbsopts= for fa in $FOREIGN_ARCHS; do case $fa in "$a") - qemup=t qbsopts=--foreign - eval qhost=\$${a}_QEMUARCH qhost=\$${a}_QEMUHOST + qemup=t dbsopts=--foreign + eval qarch=\$${a}_QEMUARCH qhost=\$${a}_QEMUHOST break ;; esac done +## Construct the logical volume and lay a filesystem onto it. lv=$LVPREFIX$d-$a -mnt=mnt/$lv +mnt=$HERE/mnt/$lv mkdir -p $mnt if mountpoint -q $mnt; then umount $mnt; fi if [ -b /dev/$VG/$lv ]; then @@ -69,10 +75,19 @@ mkfs -j -L$d-$a /dev/$VG/$lv mount -orelatime,data=writeback,commit=3600,barrier=0 /dev/$VG/$lv $mnt/ mkdir -m755 $mnt/fs/ chmod 750 $mnt/ -pkgs=ccache,eatmydata,fakeroot,libfile-fcntllock-perl,locales,tzdata + +## Install the base system. +want=$BASE_PACKAGES +case $qemup in + t) want="$want $FOREIGN_BASE_PACKAGES" ;; + nil) want="$want $NATIVE_BASE_PACKAGES" ;; +esac +pkgs=; for p in $want; do pkgs=${pkgs:+$pkgs,}$p; done eatmydata debootstrap $dbsopts --arch=$a --variant=minbase \ --include=$pkgs $d $mnt/fs/ $DEBMIRROR +## If this is a cross-installation, then install the necessary `qemu' and +## complete the installation. case $qemup in t) install $LOCAL/cross/$d-$qhost/QEMU/qemu-$qarch-static \ @@ -83,16 +98,17 @@ case $qemup in ;; esac -cd $mnt/fs/usr/ -rm -rf local/; ln -s local.schroot/$a local +## Set up `/usr/local'. +rm -rf $mnt/fs/usr/local/; ln -s local.schroot/$a $mnt/fs/usr/local -cd $mnt/fs/etc/apt/ -rm -rf apt.conf sources.list -ln -s /usr/local.schroot/config/apt/conf.d/10sbuild apt.conf.d/ -ln -s /usr/local.schroot/config/apt/conf.d/90local apt.conf.d/ -ln -s /usr/local.schroot/config/apt/sources.$d sources.list +## Install the `apt' configuration. +rm -rf $mnt/fs/etc/apt/apt.conf $mnt/fs/etc/apt/sources.list +for c in $LOCAL/etc/apt/apt.conf.d/*; do + ln -s /usr/local.schroot/${c#$LOCAL/} $mnt/fs/etc/apt/apt.conf.d/ +done +ln -s /usr/local.schroot/etc/apt/sources.$d $mnt/fs/etc/apt/sources.list -cat >apt.conf.d/20arch <$mnt/fs/etc/apt/apt.conf.d/20arch <policy-rc.d <$mnt/fs/usr/sbin/policy-rc.d <&2 "policy-rc.d: Services disabled by policy." exit 101 EOF -chmod +x policy-rc.d +chmod +x $mnt/fs/usr/sbin/policy-rc.d -cd $mnt/fs/etc/ld.so.conf.d/ -cat >libc.conf <$mnt/fs/etc/ld.so.conf.d/libc.conf <zzz-local.conf <$mnt/fs/etc/ld.so.conf.d/zzz-local.conf </dev/null 2>&1 --no-rename --help then no_rename=--no-rename @@ -138,11 +159,18 @@ case $qemup in fi dpkg-divert --package install-cross-tools \$no_rename \ - --divert /usr/bin/$qemu.$a --add /usr/bin/$qemu" + --divert /usr/bin/qemu-$qarch-static.$a --add /usr/bin/qemu-$qarch-static" + + ## Install faster native tools. $STATE/bin/install-cross-tools $d $a + + ## Install `build-essential', which had been delayed from earlier. + schroot -uroot -csource:$LVPREFIX$d-$a -- \ + eatmydata apt-get -y install build-essential ;; esac +## Set the chroot's package state up properly. schroot -uroot -csource:$LVPREFIX$d-$a -- eatmydata sh -e -c ' apt-get update apt-get -y upgrade