Move kernel module list to a separate whitelist file.
[libguestfs.git] / appliance / make.sh.in
1 #!/bin/bash -
2 # @configure_input@
3 # Copyright (C) 2009 Red Hat Inc.
4 #
5 # This program is free software; you can redistribute it and/or modify
6 # it under the terms of the GNU General Public License as published by
7 # the Free Software Foundation; either version 2 of the License, or
8 # (at your option) any later version.
9 #
10 # This program is distributed in the hope that it will be useful,
11 # but WITHOUT ANY WARRANTY; without even the implied warranty of
12 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13 # GNU General Public License for more details.
14 #
15 # You should have received a copy of the GNU General Public License
16 # along with this program; if not, write to the Free Software
17 # Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
18
19 # This is called from the Makefile to build the initramfs.
20
21 unset CDPATH
22
23 set -e
24
25 cd @top_builddir@
26
27 modules="
28 -i augeas-libs
29 -i bash
30 -i binutils
31 -i coreutils
32 -i dosfstools
33 -i file
34 -i grub
35 -i iputils
36 -i kernel
37 -i lvm2
38 -i MAKEDEV
39 -i module-init-tools
40 -i net-tools
41 -i ntfs-3g
42 -i ntfsprogs
43 -i procps
44 -i strace
45 -i util-linux-ng
46 -i zerofree
47 "
48
49 # Decide on names for the final output.  These have to match Makefile.am.
50 output=appliance/initramfs.@REPO@.@host_cpu@.img
51 koutput=appliance/vmlinuz.@REPO@.@host_cpu@
52 rm -f $output
53 rm -f $koutput
54
55 # Create the basic initramfs.
56 @FEBOOTSTRAP@ $modules -u @UPDATES@ @REPO@ initramfs @MIRROR@
57
58 # /sysroot is where the guest root filesystem will be mounted.
59 @FEBOOTSTRAP_RUN@ initramfs -- mkdir -p --mode=0777 /sysroot
60
61 # Create /tmp if it is missing.
62 @FEBOOTSTRAP_RUN@ initramfs -- mkdir -p --mode=0777 /tmp
63
64 # Nuke some stuff.  The kernel pulls mkinitrd and plymouth which pulls in
65 # all of Python.  Sheez.
66 (cd initramfs && find -name '*plymouth*' -print0) |
67   xargs -0 @FEBOOTSTRAP_RUN@ initramfs -- rm -rf
68 (cd initramfs && find -name '*python*' -print0) |
69   xargs -0 @FEBOOTSTRAP_RUN@ initramfs -- rm -rf
70
71 # In Fedora >= 11, it pulls in all of Perl from somewhere.  Nuke from orbit.
72 @FEBOOTSTRAP_RUN@ initramfs -- rm -rf /usr/lib/perl5 /usr/lib64/perl5
73
74 # Anaconda?  JPEG images?
75 @FEBOOTSTRAP_RUN@ initramfs -- rm -rf /usr/lib/anaconda-runtime
76
77 # Don't need any firmware.
78 @FEBOOTSTRAP_RUN@ initramfs -- rm -rf /lib/firmware
79
80 # Don't need any keyboard maps.
81 @FEBOOTSTRAP_RUN@ initramfs -- rm -rf /lib/kbd
82
83 # Kernel modules take up nearly half of the image.  Only include ones
84 # which are on the whitelist.
85 grep -v '^[[:space:]]*$' < appliance/kmod.whitelist |
86   grep -v '^#' > kmod.whitelist.tmp
87 exec 5<kmod.whitelist.tmp
88 whitelist=
89 while read kmod 0<&5; do
90     whitelist="$whitelist -a -not -name $kmod"
91 done
92 exec 5<&-
93 rm kmod.whitelist.tmp
94 #echo whitelist=$whitelist
95
96 (cd initramfs && \
97   find lib/modules/*/kernel -name '*.ko' $whitelist -a -print0 ) |
98   xargs -0 febootstrap-run initramfs -- rm
99
100 # Pull the kernel out into the current directory.  We don't want it in
101 # the initramfs image.
102 cp initramfs/boot/vmlinuz* $koutput
103 @FEBOOTSTRAP_RUN@ initramfs -- rm -rf boot
104
105 # Minimize the image.
106 @FEBOOTSTRAP_MINIMIZE@ initramfs
107
108 # Add some missing configuration files.
109 if [ ! -f initramfs/etc/hosts ]; then
110     cat > hosts.new <<'__EOF__'
111 127.0.0.1 guestfs localhost.localdomain localhost
112 ::1       localhost6.localdomain6 localhost6
113 __EOF__
114     @FEBOOTSTRAP_INSTALL@ initramfs hosts.new /etc/hosts 0644 root.root
115     rm hosts.new
116 fi
117
118 if [ ! -f initramfs/etc/fstab ]; then
119     @FEBOOTSTRAP_RUN@ initramfs -- touch /etc/fstab
120 fi
121
122 echo nameserver 10.0.2.3 > resolv.conf.new
123 @FEBOOTSTRAP_INSTALL@ initramfs resolv.conf.new /etc/resolv.conf 0644 root.root
124 rm resolv.conf.new
125
126 # Create the init script.
127 cat > init.new <<'__EOF__'
128 #!/bin/sh
129 echo Starting /init script ...
130 PATH=/sbin:/usr/sbin:$PATH
131 mount -t tmpfs none /dev
132 mkdir /dev/pts /dev/shm /dev/mapper
133 MAKEDEV mem null port zero core full ram tty console fd \
134   hda hdb hdc hdd sda sdb sdc sdd loop sd
135 mknod /dev/ptmx c 5 2; chmod 0666 /dev/ptmx
136 mknod /dev/random c 1 8;  chmod 0666 /dev/random
137 mknod /dev/urandom c 1 9; chmod 0444 /dev/urandom
138 mount -t proc /proc /proc
139 mount -t sysfs /sys /sys
140 mount -t devpts -o gid=5,mode=620 /dev/pts /dev/pts
141 ln -sf /proc/self/fd/0 /dev/stdin
142 ln -sf /proc/self/fd/1 /dev/stdout
143 ln -sf /proc/self/fd/2 /dev/stderr
144 modprobe virtio_pci
145 modprobe virtio_net
146 modprobe dm_mod ||:
147 /sbin/ifconfig lo 127.0.0.1
148 /sbin/ifconfig eth0 10.0.2.10
149 /sbin/route add default gw 10.0.2.2
150 lvm vgscan --ignorelockingfailure
151 lvm vgchange -ay --ignorelockingfailure
152 if grep -sq guestfs_rescue=1 /proc/cmdline; then
153   bash -i
154 fi
155 exec guestfsd -f
156 __EOF__
157
158 @FEBOOTSTRAP_INSTALL@ initramfs init.new /init 0755 root.root
159 rm init.new
160
161 # Just in case the kernel isn't looking for /init, make /sbin/init
162 # be our script, not the real init.
163 #@FEBOOTSTRAP_RUN@ initramfs -- ln -f /init /sbin/init
164
165 ls -lh $koutput
166
167 # Now directly run the update script to copy/update the daemon in the
168 # initramfs.
169 cd appliance && bash update.sh