5 . /usr/share/initramfs-tools/hook-functions
7 [ "${QUIET}" ] || echo -n "live-boot:"
9 # Reading configuration file from filesystem and live-media
10 for _FILE in /etc/live/boot.conf /etc/live/boot/* \
11 /lib/live/mount/media/live/boot.conf /lib/live/mount/media/live/boot/*
20 if [ ! -e /bin/live-boot ]
23 echo "W: live-boot-initramfs-tools (backend) installed without live-boot,"
24 echo "W: this initramfs will *NOT* have live support."
28 [ "${QUIET}" ] || echo -n " core"
30 mkdir -p "${DESTDIR}/bin"
31 cp -a /bin/live-boot /lib/live/boot "${DESTDIR}/bin"
33 mkdir -p "${DESTDIR}/lib/live"
34 cp -a /lib/live/boot "${DESTDIR}/lib/live"
37 for FILE in /lib/libacl* /lib/libblkid* /lib/libuuid* /lib/libdevmapper* /lib/libattr*
39 if [ ! -e "${DESTDIR}/${FILE}" ] && ls "${FILE}" > /dev/null 2>&1
41 cp -a "${FILE}" "${DESTDIR}/${FILE}"
46 for FILE in /lib/udev/*_id
51 if [ -e /lib/udev/rules.d/60-cdrom_id.rules ]
53 mkdir -p "${DESTDIR}/lib/udev/rules.d"
54 cp -p /lib/udev/rules.d/60-cdrom_id.rules "${DESTDIR}/lib/udev/rules.d"
57 [ "${QUIET}" ] || echo -n " filesystems"
59 # Configuration: keymap (usefull when using encryption)
60 if [ -x /bin/loadkeys ] && [ -r /etc/console/boottime.kmap.gz ]
62 copy_exec /bin/loadkeys
64 mkdir -p "${DESTDIR}/etc"
65 cp /etc/console/boottime.kmap.gz "${DESTDIR}/etc"
68 # Configuration: Unique ID
69 if [ -n "${LIVE_GENERATE_UUID}" ]
71 mkdir -p "${DESTDIR}/conf"
72 uuidgen -r > "${DESTDIR}/conf/uuid.conf"
76 manual_add_modules btrfs
79 if [ -x /sbin/mount.cifs ]
81 copy_exec /sbin/mount.cifs
82 manual_add_modules cifs
85 # Filesystem: ext3/ext4
86 manual_add_modules ext3
87 manual_add_modules ext4
89 # Filesystem: hfs/hfsplus
90 manual_add_modules hfs
91 manual_add_modules hfsplus
94 manual_add_modules jffs2
96 if [ -x /usr/bin/rsync ]
98 copy_exec /usr/bin/rsync /bin
101 # Filesystem: squashfs
102 copy_exec /sbin/losetup
103 manual_add_modules loop
104 manual_add_modules squashfs
105 manual_add_modules sqlzma
106 manual_add_modules unlzma
108 # Filesystem: aufs/overlay
109 manual_add_modules aufs
110 manual_add_modules overlay
113 manual_add_modules nls_cp437
114 manual_add_modules nls_iso8859-1
115 manual_add_modules nls_utf8
116 manual_add_modules vfat
119 manual_add_modules ntfs
121 [ "${QUIET}" ] || echo -n " devices"
123 manual_add_modules ide-cd
124 manual_add_modules ide-generic
125 manual_add_modules ohci1394
126 manual_add_modules sbp2
127 manual_add_modules sr_mod
130 manual_add_modules sd_mod
136 if [ -x /usr/bin/eject ]
138 copy_exec /usr/bin/eject /bin
142 # fuse does not work with klibc mount
143 copy_exec /bin/mount /bin/mount.util-linux
145 [ "${QUIET}" ] || echo -n " utils"
147 # Feature: Verify Checksums
148 if [ -e /etc/progress-linux_version ]
150 copy_exec /usr/bin/sha256sum /bin
152 copy_exec /usr/bin/md5sum /bin
156 if [ -x /usr/bin/memdiskfind ]
158 [ "${QUIET}" ] || echo -n " memdisk"
159 copy_exec /usr/bin/memdiskfind
160 manual_add_modules phram
161 manual_add_modules mtdblock
165 if [ -x /sbin/udevadm ]
167 [ "${QUIET}" ] || echo -n " udev"
168 copy_exec /sbin/udevadm
172 if [ -x /usr/bin/wget ]
174 [ "${QUIET}" ] || echo -n " wget"
175 copy_exec /usr/bin/wget /bin
179 if [ -x /sbin/blockdev ]
181 [ "${QUIET}" ] || echo -n " blockdev"
182 copy_exec /sbin/blockdev
186 manual_add_modules fuse
188 # FUSE filesystem: httpfs2
189 if [ -x /usr/bin/httpfs2_ssl ]
191 [ "${QUIET}" ] || echo -n " httpfs:ssl"
192 copy_exec /usr/bin/httpfs2_ssl /bin/httpfs
193 elif [ -x /usr/bin/httpfs2 ]
195 [ "${QUIET}" ] || echo -n " httpfs"
196 copy_exec /usr/bin/httpfs2 /bin/httpfs
199 # FUSE filesystem: curlftpfs
200 if [ -x /usr/bin/curlftpfs ]
202 [ "${QUIET}" ] || echo -n " ftpfs"
203 copy_exec /usr/bin/curlftpfs /bin
207 if [ -x /usr/sbin/iscsistart ]
209 [ "${QUIET}" ] || echo -n " iscsi"
210 copy_exec /usr/sbin/iscsistart /bin
211 #manual_add_modules ib_iser
212 manual_add_modules iscsi_tcp
213 manual_add_modules crc32c
216 # Some experimental stuff
218 case "${LIVE_DNS}" in
220 [ "${QUIET}" ] || echo -n " dns"
222 # /lib/libnss_dns.so.*:a DNS
223 # /lib/libnss_files.so.*: /etc/hosts and /etc/passwd
224 # /lib/libnss_compat.so.*: /etc/passwd
226 for _SHLIB in $(find /lib -name 'libnss_dns.so.*')
228 copy_exec "${_SHLIB}"
231 # might be needed if /etc/hosts is used
232 #mkdir -p "${DESTDIR}/etc"
233 #cp -p /etc/nsswitch.conf "${DESTDIR}/etc"
237 [ "${QUIET}" ] || echo .