3 # Copyright (C) 2009 Red Hat Inc.
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.
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.
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.
19 # This is called from the Makefile to build the initramfs.
26 if [ "@DIST@" = "REDHAT" ]; then
28 # Decide on names for the final output. These have to match Makefile.am.
29 output=appliance/initramfs.@REPO@.@host_cpu@.img
30 koutput=appliance/vmlinuz.@REPO@.@host_cpu@
34 # Create the basic initramfs.
35 exec 5<appliance/packagelist
37 while read pkg 0<&5; do
38 packages="$packages -i $pkg"
42 @FEBOOTSTRAP@ $packages -u @UPDATES@ @REPO@ initramfs @MIRROR@
44 # /sysroot is where the guest root filesystem will be mounted.
45 @FEBOOTSTRAP_RUN@ initramfs -- mkdir -p --mode=0777 /sysroot
47 # Create /tmp if it is missing.
48 @FEBOOTSTRAP_RUN@ initramfs -- mkdir -p --mode=0777 /tmp
50 # Create /selinux if it is missing.
51 @FEBOOTSTRAP_RUN@ initramfs -- mkdir -p --mode=0755 /selinux
53 # Nuke some stuff. The kernel pulls mkinitrd and plymouth which pulls in
54 # all of Python. Sheez.
55 (cd initramfs && find -name '*python*' -print0) |
56 xargs -0 @FEBOOTSTRAP_RUN@ initramfs -- rm -rf
57 (cd initramfs && find -name '*plymouth*' -print0) |
58 xargs -0 @FEBOOTSTRAP_RUN@ initramfs -- rm -rf
59 (cd initramfs && find -name 'libply-*' -print0) |
60 xargs -0 @FEBOOTSTRAP_RUN@ initramfs -- rm -rf
62 # In Fedora >= 11, it pulls in all of Perl from somewhere. Nuke from orbit.
63 @FEBOOTSTRAP_RUN@ initramfs -- rm -rf /usr/lib/perl5 /usr/lib64/perl5
65 # Anaconda? JPEG images?
66 @FEBOOTSTRAP_RUN@ initramfs -- rm -rf /usr/lib/anaconda-runtime
68 # Don't need any firmware.
69 @FEBOOTSTRAP_RUN@ initramfs -- rm -rf /lib/firmware
71 # Don't need any keyboard maps.
72 @FEBOOTSTRAP_RUN@ initramfs -- rm -rf /lib/kbd
74 # Remove anything in home directory. Because of the potential for disaster
75 # we don't put a slash before 'home'.
76 (cd initramfs && echo home/*) |
77 xargs @FEBOOTSTRAP_RUN@ initramfs -- rm -rf
79 # Remove /var/lib/yum stuff.
80 @FEBOOTSTRAP_RUN@ initramfs -- rm -rf /var/lib/yum
82 # Remove some unreadable binaries which are incompatible with
83 # the supermin appliance. Since these binaries can't be read
84 # from the host filesystem, they generate warnings like:
85 # cpio: ./usr/bin/chfn: Cannot open: Permission denied
86 # These binaries are not needed for operation of the appliance.
87 @FEBOOTSTRAP_RUN@ initramfs -- rm -f \
90 /usr/libexec/pt_chown \
94 /usr/sbin/tzdata-update \
101 /lib/dbus-1/dbus-daemon-launch-helper \
102 /lib64/dbus-1/dbus-daemon-launch-helper \
110 /etc/sysconfig/iptables-config \
111 /etc/default/useradd \
112 /etc/security/opasswd \
121 $(cd initramfs && echo usr/sbin/glibc_post_upgrade.*)
123 # Kernel modules take up nearly half of the image. Only include ones
124 # which are on the whitelist.
125 exec 5<appliance/kmod.whitelist
127 while read kmod 0<&5; do
128 whitelist="$whitelist -a -not -name $kmod"
133 find lib/modules/*/kernel -name '*.ko' $whitelist -a -print0 ) |
134 xargs -0 febootstrap-run initramfs -- rm
136 # Pull the kernel out into the current directory. We don't want it in
137 # the initramfs image.
138 cp initramfs/boot/vmlinuz* $koutput
139 @FEBOOTSTRAP_RUN@ initramfs -- rm -rf boot
141 # Minimize the image.
142 @FEBOOTSTRAP_MINIMIZE@ initramfs
144 # Add some missing configuration files.
145 if [ ! -f initramfs/etc/hosts ]; then
146 cat > hosts.new <<'__EOF__'
147 127.0.0.1 guestfs localhost.localdomain localhost
148 ::1 localhost6.localdomain6 localhost6
150 @FEBOOTSTRAP_INSTALL@ initramfs hosts.new /etc/hosts 0644 root.root
154 if [ ! -f initramfs/etc/fstab ]; then
155 @FEBOOTSTRAP_RUN@ initramfs -- touch /etc/fstab
158 echo nameserver 10.0.2.3 > resolv.conf.new
159 @FEBOOTSTRAP_INSTALL@ initramfs resolv.conf.new /etc/resolv.conf 0644 root.root
164 # Now directly run the update script to copy/update the daemon in the
166 cd appliance && bash update.sh
168 elif [ "@DIST@" = "DEBIAN" ]; then
169 cd @top_builddir@/appliance
170 debirf make -n debian
171 mkdir -p @top_builddir@/initramfs
172 touch @top_builddir@/initramfs/fakeroot.log