summaryrefslogtreecommitdiffstats
path: root/appliance
diff options
context:
space:
mode:
authorGuido Günther <agx@sigxcpu.org>2009-06-30 15:01:14 +0200
committerRichard W.M. Jones <rjones@redhat.com>2009-07-02 14:12:24 +0100
commit9f19ddd0c42a509018340a82bd7dc13a0996e6f5 (patch)
treec4a8b2ff153429119bf02a64aed3dfb9d0a8e985 /appliance
parentbcd7bd3aabf4a28bca24bf5d22ed3a68322ec637 (diff)
downloadlibguestfs-9f19ddd0c42a509018340a82bd7dc13a0996e6f5.tar.gz
libguestfs-9f19ddd0c42a509018340a82bd7dc13a0996e6f5.tar.xz
libguestfs-9f19ddd0c42a509018340a82bd7dc13a0996e6f5.zip
Build Debian based appliance using debirf
Diffstat (limited to 'appliance')
-rwxr-xr-xappliance/make.sh.in236
-rwxr-xr-xappliance/update.sh.in26
2 files changed, 139 insertions, 123 deletions
diff --git a/appliance/make.sh.in b/appliance/make.sh.in
index 637bd07e..e98c3257 100755
--- a/appliance/make.sh.in
+++ b/appliance/make.sh.in
@@ -22,125 +22,131 @@ unset CDPATH
set -e
-cd @top_builddir@
-
-# Decide on names for the final output. These have to match Makefile.am.
-output=appliance/initramfs.@REPO@.@host_cpu@.img
-koutput=appliance/vmlinuz.@REPO@.@host_cpu@
-rm -f $output
-rm -f $koutput
-
-# Create the basic initramfs.
-exec 5<appliance/packagelist
-packages=
-while read pkg 0<&5; do
- packages="$packages -i $pkg"
-done
-exec 5<&-
-
-@FEBOOTSTRAP@ $packages -u @UPDATES@ @REPO@ initramfs @MIRROR@
-
-# /sysroot is where the guest root filesystem will be mounted.
-@FEBOOTSTRAP_RUN@ initramfs -- mkdir -p --mode=0777 /sysroot
-
-# Create /tmp if it is missing.
-@FEBOOTSTRAP_RUN@ initramfs -- mkdir -p --mode=0777 /tmp
-
-# Nuke some stuff. The kernel pulls mkinitrd and plymouth which pulls in
-# all of Python. Sheez.
-(cd initramfs && find -name '*plymouth*' -print0) |
- xargs -0 @FEBOOTSTRAP_RUN@ initramfs -- rm -rf
-(cd initramfs && find -name '*python*' -print0) |
- xargs -0 @FEBOOTSTRAP_RUN@ initramfs -- rm -rf
-
-# In Fedora >= 11, it pulls in all of Perl from somewhere. Nuke from orbit.
-@FEBOOTSTRAP_RUN@ initramfs -- rm -rf /usr/lib/perl5 /usr/lib64/perl5
-
-# Anaconda? JPEG images?
-@FEBOOTSTRAP_RUN@ initramfs -- rm -rf /usr/lib/anaconda-runtime
-
-# Don't need any firmware.
-@FEBOOTSTRAP_RUN@ initramfs -- rm -rf /lib/firmware
-
-# Don't need any keyboard maps.
-@FEBOOTSTRAP_RUN@ initramfs -- rm -rf /lib/kbd
-
-# Remove anything in home directory. Because this is potentially
-# liable to monstrous fuck-ups, we don't put a slash before 'home'.
-(cd initramfs && echo home/*) |
- xargs @FEBOOTSTRAP_RUN@ initramfs -- rm -rf
-
-# Remove /var/lib/yum stuff.
-@FEBOOTSTRAP_RUN@ initramfs -- rm -rf /var/lib/yum
-
-# Remove some unreadable binaries which are incompatible with
-# the supermin appliance. Since these binaries can't be read
-# from the host filesystem, they generate warnings like:
-# cpio: ./usr/bin/chfn: Cannot open: Permission denied
-# These binaries are not needed for operation of the appliance.
-@FEBOOTSTRAP_RUN@ initramfs -- rm -f \
- /usr/bin/chfn \
- /usr/bin/chsh \
- /usr/libexec/pt_chown \
- /usr/sbin/groupdel \
- /usr/sbin/groupadd \
- /usr/sbin/useradd \
- /usr/sbin/tzdata-update \
- /usr/sbin/userdel \
- /usr/sbin/usermod \
- /usr/sbin/groupmod \
- /usr/sbin/groupmems \
- /sbin/unix_update \
- $(cd initramfs && echo usr/sbin/glibc_post_upgrade.*)
-
-# Kernel modules take up nearly half of the image. Only include ones
-# which are on the whitelist.
-exec 5<appliance/kmod.whitelist
-whitelist=
-while read kmod 0<&5; do
- whitelist="$whitelist -a -not -name $kmod"
-done
-exec 5<&-
-
-(cd initramfs && \
- find lib/modules/*/kernel -name '*.ko' $whitelist -a -print0 ) |
- xargs -0 febootstrap-run initramfs -- rm
-
-# Pull the kernel out into the current directory. We don't want it in
-# the initramfs image.
-cp initramfs/boot/vmlinuz* $koutput
-@FEBOOTSTRAP_RUN@ initramfs -- rm -rf boot
-
-# Minimize the image.
-@FEBOOTSTRAP_MINIMIZE@ initramfs
-
-# Add some missing configuration files.
-if [ ! -f initramfs/etc/hosts ]; then
- cat > hosts.new <<'__EOF__'
-127.0.0.1 guestfs localhost.localdomain localhost
-::1 localhost6.localdomain6 localhost6
+if [ "@DIST@" = "REDHAT" ]; then
+ cd @top_builddir@
+ # Decide on names for the final output. These have to match Makefile.am.
+ output=appliance/initramfs.@REPO@.@host_cpu@.img
+ koutput=appliance/vmlinuz.@REPO@.@host_cpu@
+ rm -f $output
+ rm -f $koutput
+
+ # Create the basic initramfs.
+ exec 5<appliance/packagelist
+ packages=
+ while read pkg 0<&5; do
+ packages="$packages -i $pkg"
+ done
+ exec 5<&-
+
+ @FEBOOTSTRAP@ $packages -u @UPDATES@ @REPO@ initramfs @MIRROR@
+
+ # /sysroot is where the guest root filesystem will be mounted.
+ @FEBOOTSTRAP_RUN@ initramfs -- mkdir -p --mode=0777 /sysroot
+
+ # Create /tmp if it is missing.
+ @FEBOOTSTRAP_RUN@ initramfs -- mkdir -p --mode=0777 /tmp
+
+ # Nuke some stuff. The kernel pulls mkinitrd and plymouth which pulls in
+ # all of Python. Sheez.
+ (cd initramfs && find -name '*plymouth*' -print0) |
+ xargs -0 @FEBOOTSTRAP_RUN@ initramfs -- rm -rf
+ (cd initramfs && find -name '*python*' -print0) |
+ xargs -0 @FEBOOTSTRAP_RUN@ initramfs -- rm -rf
+
+ # In Fedora >= 11, it pulls in all of Perl from somewhere. Nuke from orbit.
+ @FEBOOTSTRAP_RUN@ initramfs -- rm -rf /usr/lib/perl5 /usr/lib64/perl5
+
+ # Anaconda? JPEG images?
+ @FEBOOTSTRAP_RUN@ initramfs -- rm -rf /usr/lib/anaconda-runtime
+
+ # Don't need any firmware.
+ @FEBOOTSTRAP_RUN@ initramfs -- rm -rf /lib/firmware
+
+ # Don't need any keyboard maps.
+ @FEBOOTSTRAP_RUN@ initramfs -- rm -rf /lib/kbd
+
+ # Remove anything in home directory. Because this is potentially
+ # liable to monstrous fuck-ups, we don't put a slash before 'home'.
+ (cd initramfs && echo home/*) |
+ xargs @FEBOOTSTRAP_RUN@ initramfs -- rm -rf
+
+ # Remove /var/lib/yum stuff.
+ @FEBOOTSTRAP_RUN@ initramfs -- rm -rf /var/lib/yum
+
+ # Remove some unreadable binaries which are incompatible with
+ # the supermin appliance. Since these binaries can't be read
+ # from the host filesystem, they generate warnings like:
+ # cpio: ./usr/bin/chfn: Cannot open: Permission denied
+ # These binaries are not needed for operation of the appliance.
+ @FEBOOTSTRAP_RUN@ initramfs -- rm -f \
+ /usr/bin/chfn \
+ /usr/bin/chsh \
+ /usr/libexec/pt_chown \
+ /usr/sbin/groupdel \
+ /usr/sbin/groupadd \
+ /usr/sbin/useradd \
+ /usr/sbin/tzdata-update \
+ /usr/sbin/userdel \
+ /usr/sbin/usermod \
+ /usr/sbin/groupmod \
+ /usr/sbin/groupmems \
+ /sbin/unix_update \
+ $(cd initramfs && echo usr/sbin/glibc_post_upgrade.*)
+
+ # Kernel modules take up nearly half of the image. Only include ones
+ # which are on the whitelist.
+ exec 5<appliance/kmod.whitelist
+ whitelist=
+ while read kmod 0<&5; do
+ whitelist="$whitelist -a -not -name $kmod"
+ done
+ exec 5<&-
+
+ (cd initramfs && \
+ find lib/modules/*/kernel -name '*.ko' $whitelist -a -print0 ) |
+ xargs -0 febootstrap-run initramfs -- rm
+
+ # Pull the kernel out into the current directory. We don't want it in
+ # the initramfs image.
+ cp initramfs/boot/vmlinuz* $koutput
+ @FEBOOTSTRAP_RUN@ initramfs -- rm -rf boot
+
+ # Minimize the image.
+ @FEBOOTSTRAP_MINIMIZE@ initramfs
+
+ # Add some missing configuration files.
+ if [ ! -f initramfs/etc/hosts ]; then
+ cat > hosts.new <<'__EOF__'
+ 127.0.0.1 guestfs localhost.localdomain localhost
+ ::1 localhost6.localdomain6 localhost6
__EOF__
- @FEBOOTSTRAP_INSTALL@ initramfs hosts.new /etc/hosts 0644 root.root
- rm hosts.new
-fi
+ @FEBOOTSTRAP_INSTALL@ initramfs hosts.new /etc/hosts 0644 root.root
+ rm hosts.new
+ fi
-if [ ! -f initramfs/etc/fstab ]; then
- @FEBOOTSTRAP_RUN@ initramfs -- touch /etc/fstab
-fi
+ if [ ! -f initramfs/etc/fstab ]; then
+ @FEBOOTSTRAP_RUN@ initramfs -- touch /etc/fstab
+ fi
+
+ echo nameserver 10.0.2.3 > resolv.conf.new
+ @FEBOOTSTRAP_INSTALL@ initramfs resolv.conf.new /etc/resolv.conf 0644 root.root
+ rm resolv.conf.new
-echo nameserver 10.0.2.3 > resolv.conf.new
-@FEBOOTSTRAP_INSTALL@ initramfs resolv.conf.new /etc/resolv.conf 0644 root.root
-rm resolv.conf.new
+ # Create the init script.
+ @FEBOOTSTRAP_INSTALL@ initramfs appliance/init /init 0755 root.root
-# Create the init script.
-@FEBOOTSTRAP_INSTALL@ initramfs appliance/init /init 0755 root.root
+ # Just in case the kernel isn't looking for /init, make /sbin/init
+ # be our script, not the real init.
+ #@FEBOOTSTRAP_RUN@ initramfs -- ln -f /init /sbin/init
-# Just in case the kernel isn't looking for /init, make /sbin/init
-# be our script, not the real init.
-#@FEBOOTSTRAP_RUN@ initramfs -- ln -f /init /sbin/init
+ ls -lh $koutput
-ls -lh $koutput
+ # Now directly run the update script to copy/update the daemon in the
+ # initramfs.
+ cd appliance && bash update.sh
+
+elif [ "@DIST@" = "DEBIAN" ]; then
+ cd @top_builddir@/appliance
+ debirf make -n debian
+fi
-# Now directly run the update script to copy/update the daemon in the
-# initramfs.
-cd appliance && bash update.sh
diff --git a/appliance/update.sh.in b/appliance/update.sh.in
index 3b779f85..4fbd6517 100755
--- a/appliance/update.sh.in
+++ b/appliance/update.sh.in
@@ -23,14 +23,24 @@ unset CDPATH
set -e
-cd @top_builddir@
+if [ "@DIST@" = "REDHAT" ]; then
+ cd @top_builddir@
+ output=appliance/initramfs.@REPO@.@host_cpu@.img
-output=appliance/initramfs.@REPO@.@host_cpu@.img
+ # Copy the daemon into the filesystem.
+ @FEBOOTSTRAP_INSTALL@ initramfs daemon/guestfsd /sbin/guestfsd 0755 root.root
-# Copy the daemon into the filesystem.
-@FEBOOTSTRAP_INSTALL@ initramfs daemon/guestfsd /sbin/guestfsd 0755 root.root
+ # Generate final image.
+ @FEBOOTSTRAP_TO_INITRAMFS@ initramfs > $output-t
+ mv $output-t $output
+ ls -lh $output
+elif [ "@DIST@" = "DEBIAN" ]; then
+ cd @top_builddir@/appliance
+
+ output=initramfs.@REPO@.@host_cpu@.img
+ vmlinuz=vmlinuz.@REPO@.@host_cpu@
+
+ ln -sf debian/debirf-libguestfs_@REPO@*.cgz $output
+ ln -sf debian/vmlinuz-* $vmlinuz
+fi
-# Generate final image.
-@FEBOOTSTRAP_TO_INITRAMFS@ initramfs > $output-t
-mv $output-t $output
-ls -lh $output