X-Git-Url: http://git.annexia.org/?p=libguestfs.git;a=blobdiff_plain;f=make-initramfs.sh.in;h=b550ed926092d1592bb7ecc0cc4f277f3488fa14;hp=9856fe5290d0dc41855eb6e5d4684e87a4f4c713;hb=43db06ea892cc157324a6b837ca430607441c509;hpb=99bd425a0a8fb02c27e0c22b32dafa804773a7b1 diff --git a/make-initramfs.sh.in b/make-initramfs.sh.in index 9856fe5..b550ed9 100755 --- a/make-initramfs.sh.in +++ b/make-initramfs.sh.in @@ -20,12 +20,14 @@ set -e +unset CDPATH + # If you want to do some extra debugging and diagnosis of the # initramfs image, then uncomment this line. This makes the image # larger. debug=yes -modules="-i kernel -i bash -i coreutils -i lvm2 -i ntfs-3g -i util-linux-ng -i MAKEDEV -i net-tools" +modules="-i kernel -i bash -i coreutils -i lvm2 -i ntfs-3g -i util-linux-ng -i MAKEDEV -i net-tools -i augeas-libs -i file" if [ "x$debug" = "xyes" ]; then modules="$modules -i module-init-tools -i procps -i strace -i iputils" @@ -38,7 +40,7 @@ rm -f $output rm -f $koutput # Create the basic initramfs. -@FEBOOTSTRAP@ $modules @REPO@ initramfs @MIRROR@ +@FEBOOTSTRAP@ $modules -u @UPDATES@ @REPO@ initramfs @MIRROR@ # /sysroot is where the guest root filesystem will be mounted. mkdir initramfs/sysroot @@ -65,9 +67,16 @@ find initramfs -name '*plymouth*' -print0 | xargs -0 rm -rf find initramfs -name '*python*' -print0 | xargs -0 rm -rf # Modules take up nearly half of the image. It's a rough guess that -# we don't need any drivers (which take up most of the space). -#rm -rf initramfs/lib/modules/*/kernel/{drivers,sound} -rm -rf initramfs/lib/modules/*/kernel/arch/x86/kvm +# we don't need many drivers (which take up most of the space). +find initramfs/lib/modules/*/kernel \ + -name '*.ko' \ + -a ! -name 'mii.ko' \ + -a ! -name '8139cp.ko' \ + -a ! -name 'ext2.ko' \ + -a ! -name 'ext4.ko' \ + -a ! -name 'crc16.ko' \ + -a ! -name 'jbd2.ko' \ + -a -delete # Pull the kernel out into the current directory. We don't want it in # the initramfs image.