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 /run/live/medium/live/boot.conf /run/live/medium/live/boot/*
19 # Grml version information:
20 if [ -r /etc/grml_version ]
22 cp /etc/grml_version "${DESTDIR}"/etc
26 if [ ! -e /bin/live-boot ]
29 echo "W: live-boot-initramfs-tools (backend) installed without live-boot,"
30 echo "W: this initramfs will *NOT* have live support."
34 [ "${QUIET}" ] || echo -n " core"
36 mkdir -p "${DESTDIR}/bin"
37 cp -a /bin/live-boot "${DESTDIR}/bin"
39 mkdir -p "${DESTDIR}/lib/live"
40 cp -a /lib/live/boot "${DESTDIR}/lib/live"
42 mkdir -p "${DESTDIR}/etc/live"
43 if [ -e /etc/live/boot.conf ]
45 cp -a /etc/live/boot.conf "${DESTDIR}/etc/live"
47 if [ -e /etc/live/boot ]
49 cp -a /etc/live/boot "${DESTDIR}/etc/live"
53 for FILE in /lib/libacl* /lib/libblkid* /lib/libuuid* /lib/libdevmapper* /lib/libattr*
55 if [ ! -e "${DESTDIR}/${FILE}" ] && ls "${FILE}" > /dev/null 2>&1
57 cp -a "${FILE}" "${DESTDIR}/${FILE}"
62 if [ "${MINIMAL:-}" != "true" ] && [ "${MINIMAL:-}" != "yes" ]
64 for FILE in /lib/udev/*_id
70 if [ -e /lib/udev/rules.d/60-cdrom_id.rules ] && [ "${DISABLE_CDROM:-}" != "true" ] && \
71 [ "${DISABLE_CDROM:-}" != "yes" ]
73 mkdir -p "${DESTDIR}/lib/udev/rules.d"
74 cp -p /lib/udev/rules.d/60-cdrom_id.rules "${DESTDIR}/lib/udev/rules.d"
77 [ "${QUIET}" ] || echo -n " filesystems"
79 # Configuration: keymap (usefull when using encryption)
80 if [ -x /bin/loadkeys ] && [ -r /etc/console/boottime.kmap.gz ]
82 copy_exec /bin/loadkeys
84 mkdir -p "${DESTDIR}/etc"
85 cp /etc/console/boottime.kmap.gz "${DESTDIR}/etc"
88 # Configuration: Unique ID
89 if [ -n "${LIVE_GENERATE_UUID}" ]
91 mkdir -p "${DESTDIR}/conf"
92 uuidgen -r > "${DESTDIR}/conf/uuid.conf"
96 manual_add_modules btrfs
99 if [ -x /sbin/mount.cifs ]
101 copy_exec /sbin/mount.cifs
102 manual_add_modules cifs
105 # Filesystem: ext3/ext4
106 manual_add_modules ext3
107 manual_add_modules ext4
109 # Filesystem: hfs/hfsplus
110 manual_add_modules hfs
111 manual_add_modules hfsplus
114 manual_add_modules jffs2
116 if [ -x /usr/bin/rsync ] && [ "${MINIMAL:-}" != "true" ] && [ "${MINIMAL:-}" != "yes" ]
118 copy_exec /usr/bin/rsync /bin
121 # Filesystem: squashfs
122 copy_exec /sbin/losetup
123 manual_add_modules loop
124 manual_add_modules squashfs
125 manual_add_modules sqlzma
126 manual_add_modules unlzma
128 # Filesystem: aufs/overlay
129 manual_add_modules aufs
130 manual_add_modules overlay
133 if [ "${DISABLE_FAT:-}" != "true" ] && [ "${DISABLE_FAT:-}" != "yes" ]
135 manual_add_modules nls_cp437
136 manual_add_modules nls_iso8859-1
137 manual_add_modules nls_utf8
138 manual_add_modules nls_ascii
139 manual_add_modules vfat
143 if [ "${DISABLE_NTFS:-}" != "true" ] && [ "${DISABLE_NTFS:-}" != "yes" ]
145 manual_add_modules ntfs
148 [ "${QUIET}" ] || echo -n " devices"
150 if [ "${DISABLE_CDROM:-}" != "true" ] && [ "${DISABLE_CDROM:-}" != "yes" ]
152 manual_add_modules ide-cd
153 manual_add_modules ide-generic
154 manual_add_modules ohci1394
155 manual_add_modules sbp2
156 manual_add_modules sr_mod
160 if [ "${DISABLE_USB:-}" != "true" ] && [ "${DISABLE_USB:-}" != "yes" ]
162 manual_add_modules sd_mod
169 if [ -x /usr/bin/eject ]
171 copy_exec /usr/bin/eject /bin
174 [ "${QUIET}" ] || echo -n " utils"
176 # Feature: Verify Checksums
177 if [ -e /etc/progress-linux_version ]
179 copy_exec /usr/bin/sha256sum /bin
181 copy_exec /usr/bin/md5sum /bin
185 if [ -x /usr/bin/memdiskfind ]
187 [ "${QUIET}" ] || echo -n " memdisk"
188 copy_exec /usr/bin/memdiskfind
189 manual_add_modules phram
190 manual_add_modules mtdblock
194 if [ -x /bin/udevadm ]
196 [ "${QUIET}" ] || echo -n " udev"
197 copy_exec /bin/udevadm
201 if [ -x /sbin/blockdev ]
203 [ "${QUIET}" ] || echo -n " blockdev"
204 copy_exec /sbin/blockdev
208 if [ "${DISABLE_FUSE:-n}" != "true" ] && [ "${DISABLE_FUSE:-n}" != "yes" ]
210 manual_add_modules fuse
212 # FUSE filesystem: httpfs2
213 if [ -x /usr/bin/httpfs2_ssl ]
215 [ "${QUIET}" ] || echo -n " httpfs:ssl"
216 copy_exec /usr/bin/httpfs2_ssl /bin/httpfs
217 elif [ -x /usr/bin/httpfs2 ]
219 [ "${QUIET}" ] || echo -n " httpfs"
220 copy_exec /usr/bin/httpfs2 /bin/httpfs
223 # FUSE filesystem: curlftpfs
224 if [ -x /usr/bin/curlftpfs ]
226 [ "${QUIET}" ] || echo -n " ftpfs"
227 copy_exec /usr/bin/curlftpfs /bin
232 if [ -x /usr/sbin/iscsistart ]
234 [ "${QUIET}" ] || echo -n " iscsi"
235 copy_exec /usr/sbin/iscsistart /bin
236 #manual_add_modules ib_iser
237 manual_add_modules iscsi_tcp
238 manual_add_modules crc32c
241 # Some experimental stuff
243 [ "${QUIET}" ] || echo -n " dns"
245 # libnss_dns.so.*: DNS
246 # libnss_files.so.*: /etc/hosts and /etc/passwd
247 # libnss_compat.so.*: /etc/passwd
249 for _SHLIB in $(find /lib /usr/lib -name 'libnss_dns.so.*' -o -name 'libnss_files.so.*')
251 copy_exec "${_SHLIB}"
254 if [ ! -e "${DESTDIR}/etc/nsswitch.conf" ]
256 # Needed to make "hostname -f" honor the domainname provided by DHCP
257 echo "hosts: files dns" > "${DESTDIR}/etc/nsswitch.conf"
261 if [ -x /sbin/vconfig ]
263 copy_exec /sbin/vconfig
264 manual_add_modules 8021q
267 [ "${QUIET}" ] || echo .