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 /live/image/live/boot.conf /live/image/live/boot/*
20 if [ ! -e /lib/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}/lib/live"
31 cp -a /lib/live/boot.sh /lib/live/boot "${DESTDIR}/lib/live"
34 for FILE in /lib/libacl* /lib/libblkid* /lib/libuuid* /lib/libdevmapper* /lib/libattr*
36 if [ ! -e "${DESTDIR}"/"${FILE}" ] && ls ${FILE} > /dev/null 2>&1
38 cp -a "${FILE}" "${DESTDIR}"/"${FILE}"
43 for FILE in /lib/udev/*_id
49 if [ -e /lib/udev/rules.d/60-cdrom_id.rules ]
51 mkdir -p ${DESTDIR}/lib/udev/rules.d
52 cp -p /lib/udev/rules.d/60-cdrom_id.rules ${DESTDIR}/lib/udev/rules.d
55 [ "${QUIET}" ] || echo -n " filesystems"
57 # Configuration: keymap (usefull when using encryption)
58 if [ -x /bin/loadkeys ] && [ -r /etc/console/boottime.kmap.gz ]
60 copy_exec /bin/loadkeys
62 mkdir -p "${DESTDIR}"/etc
63 cp /etc/console/boottime.kmap.gz "${DESTDIR}"/etc
66 # Configuration: Unique ID
67 if [ -n "${LIVE_GENERATE_UUID}" ]
69 mkdir -p "${DESTDIR}"/conf
70 uuidgen -r > "${DESTDIR}"/conf/uuid.conf
74 manual_add_modules btrfs
77 if [ -x /sbin/mount.cifs ]
79 copy_exec /sbin/mount.cifs
80 manual_add_modules cifs
83 # Filesystem: ext3/ext4
84 manual_add_modules ext3
85 manual_add_modules ext4
88 manual_add_modules jffs2
90 if [ -x /usr/bin/rsync ]
92 copy_exec /usr/bin/rsync /bin
95 # Filesystem: squashfs
96 copy_exec /sbin/losetup
97 manual_add_modules loop
98 manual_add_modules squashfs
99 manual_add_modules sqlzma
100 manual_add_modules unlzma
102 # Filesystem: aufs/overlayfs/unionfs
103 manual_add_modules aufs
104 manual_add_modules overlayfs
105 manual_add_modules unionfs
107 # Filesystem: unionfs-fuse
108 if [ -x /usr/bin/unionfs-fuse ]
110 copy_exec /usr/bin/unionfs-fuse /bin
114 manual_add_modules nls_cp437
115 manual_add_modules nls_iso8859-1
116 manual_add_modules nls_utf8
117 manual_add_modules vfat
120 manual_add_modules ntfs
122 [ "${QUIET}" ] || echo -n " devices"
124 manual_add_modules ide-cd
125 manual_add_modules ide-generic
126 manual_add_modules ohci1394
127 manual_add_modules sbp2
128 manual_add_modules sr_mod
131 manual_add_modules sd_mod
137 if [ -x /usr/bin/eject ]
139 copy_exec /usr/bin/eject /bin
142 [ "${QUIET}" ] || echo -n " utils"
144 # Feature: Verify Checksums
145 copy_exec /usr/bin/sha256sum /bin
146 copy_exec /usr/bin/md5sum /bin
149 if [ -x /usr/bin/memdiskfind ]
151 [ "${QUIET}" ] || echo -n " memdisk"
152 copy_exec /usr/bin/memdiskfind
153 manual_add_modules phram
154 manual_add_modules mtdblock
158 if [ -x /sbin/udevadm ]
160 [ "${QUIET}" ] || echo -n " udev"
161 copy_exec /sbin/udevadm
163 if [ -x /usr/bin/udevinfo ]
165 [ "${QUIET}" ] || echo -n " udev"
166 copy_exec /usr/bin/udevinfo /bin
170 if [ -x /usr/bin/wget ]
172 [ "${QUIET}" ] || echo -n " wget"
173 copy_exec /usr/bin/wget /bin
177 if [ -x /sbin/blockdev ]
179 [ "${QUIET}" ] || echo -n " blockdev"
180 copy_exec /sbin/blockdev
184 manual_add_modules fuse
186 # FUSE filesystem: httpfs2
187 if [ -x /usr/bin/httpfs2_ssl ]
189 [ "${QUIET}" ] || echo -n " httpfs:ssl"
190 copy_exec /usr/bin/httpfs2_ssl /bin/httpfs
191 elif [ -x /usr/bin/httpfs2 ]
193 [ "${QUIET}" ] || echo -n " httpfs"
194 copy_exec /usr/bin/httpfs2 /bin/httpfs
197 # FUSE filesystem: curlftpfs
198 if [ -x /usr/bin/curlftpfs ]
200 [ "${QUIET}" ] || echo -n " ftpfs"
201 copy_exec /usr/bin/curlftpfs /bin
205 if [ -x /usr/sbin/iscsistart ]
207 [ "${QUIET}" ] || echo -n " iscsi"
208 copy_exec /usr/sbin/iscsistart /bin
209 #manual_add_modules ib_iser
210 manual_add_modules iscsi_tcp
211 manual_add_modules crc32c
214 # Some experimental stuff
216 case "${LIVE_DNS}" in
218 [ "${QUIET}" ] || echo -n " dns"
220 # /lib/libnss_dns.so.*:a DNS
221 # /lib/libnss_files.so.*: /etc/hosts and /etc/passwd
222 # /lib/libnss_compat.so.*: /etc/passwd
224 for _SHLIB in $(find /lib -name 'libnss_dns.so.*')
226 copy_exec "${_SHLIB}"
229 # might be needed if /etc/hosts is used
230 #mkdir -p "${DESTDIR}/etc"
231 #cp -p /etc/nsswitch.conf "${DESTDIR}/etc"
235 case "${LIVE_UNIONMOUNT}" in
237 [ "${QUIET}" ] || echo -n " unionmount"
240 # only mount from patched util-linux can do this currently
241 copy_exec /bin/mount /bin/mount_full
245 [ "${QUIET}" ] || echo .