Use klibc's mount again for fuse mounts
[live-boot-grml.git] / backend / initramfs-tools / live.hook
1 #!/bin/sh
2
3 set -e
4
5 . /usr/share/initramfs-tools/hook-functions
6
7 [ "${QUIET}" ] || echo -n "live-boot:"
8
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/*
12 do
13         if [ -e "${_FILE}" ]
14         then
15                 . "${_FILE}"
16         fi
17 done
18
19 # Checking live-boot
20 if [ ! -e /bin/live-boot ]
21 then
22         echo
23         echo "W: live-boot-initramfs-tools (backend) installed without live-boot,"
24         echo "W: this initramfs will *NOT* have live support."
25         exit 0
26 fi
27
28 [ "${QUIET}" ] || echo -n " core"
29
30 mkdir -p "${DESTDIR}/bin"
31 cp -a /bin/live-boot "${DESTDIR}/bin"
32
33 mkdir -p "${DESTDIR}/lib/live"
34 cp -a /lib/live/boot "${DESTDIR}/lib/live"
35
36 mkdir -p "${DESTDIR}/etc/live"
37 if [ -e /etc/live/boot.conf ]
38 then
39         cp -a /etc/live/boot.conf "${DESTDIR}/etc/live"
40 fi
41 if [ -e /etc/live/boot ]
42 then
43         cp -a /etc/live/boot "${DESTDIR}/etc/live"
44 fi
45
46 # klibc dependencies
47 for FILE in /lib/libacl* /lib/libblkid* /lib/libuuid* /lib/libdevmapper* /lib/libattr*
48 do
49         if [ ! -e "${DESTDIR}/${FILE}" ] && ls "${FILE}" > /dev/null 2>&1
50         then
51                 cp -a "${FILE}" "${DESTDIR}/${FILE}"
52         fi
53 done
54
55 # udev dependencies
56 if [ "${MINIMAL:-}" != "y" ]
57 then
58         for FILE in /lib/udev/*_id
59         do
60                 copy_exec "${FILE}"
61         done
62 fi
63
64 if [ -e /lib/udev/rules.d/60-cdrom_id.rules ] && [ "${DISABLE_CDROM:-}" != "y" ]
65 then
66         mkdir -p "${DESTDIR}/lib/udev/rules.d"
67         cp -p /lib/udev/rules.d/60-cdrom_id.rules "${DESTDIR}/lib/udev/rules.d"
68 fi
69
70 [ "${QUIET}" ] || echo -n " filesystems"
71
72 # Configuration: keymap (usefull when using encryption)
73 if [ -x /bin/loadkeys ] && [ -r /etc/console/boottime.kmap.gz ]
74 then
75         copy_exec /bin/loadkeys
76
77         mkdir -p "${DESTDIR}/etc"
78         cp /etc/console/boottime.kmap.gz "${DESTDIR}/etc"
79 fi
80
81 # Configuration: Unique ID
82 if [ -n "${LIVE_GENERATE_UUID}" ]
83 then
84         mkdir -p "${DESTDIR}/conf"
85         uuidgen -r > "${DESTDIR}/conf/uuid.conf"
86 fi
87
88 # Filesystem: btrfs
89 manual_add_modules btrfs
90
91 # Filesystem: cifs
92 if [ -x /sbin/mount.cifs ]
93 then
94         copy_exec /sbin/mount.cifs
95         manual_add_modules cifs
96 fi
97
98 # Filesystem: ext3/ext4
99 manual_add_modules ext3
100 manual_add_modules ext4
101
102 # Filesystem: hfs/hfsplus
103 manual_add_modules hfs
104 manual_add_modules hfsplus
105
106 # Filesystem: jffs2
107 manual_add_modules jffs2
108
109 if [ -x /usr/bin/rsync ] && [ "${MINIMAL:-}" != "y" ]
110 then
111         copy_exec /usr/bin/rsync /bin
112 fi
113
114 # Filesystem: squashfs
115 copy_exec /sbin/losetup
116 manual_add_modules loop
117 manual_add_modules squashfs
118 manual_add_modules sqlzma
119 manual_add_modules unlzma
120
121 # Filesystem: aufs/overlay
122 manual_add_modules aufs
123 manual_add_modules overlay
124
125 # Filesystem: vfat
126 if [ "${DISABLE_FAT:-}" != "y" ]
127 then
128         manual_add_modules nls_cp437
129         manual_add_modules nls_iso8859-1
130         manual_add_modules nls_utf8
131         manual_add_modules nls_ascii
132         manual_add_modules vfat
133 fi
134
135 # Filesystem: ntfs
136 if [ "${DISABLE_NTFS:-}" != "y" ]
137 then
138         manual_add_modules ntfs
139 fi
140
141 [ "${QUIET}" ] || echo -n " devices"
142 # Hardware: cdrom
143 if [ "${DISABLE_CDROM:-}" != "y" ]
144 then
145         manual_add_modules ide-cd
146         manual_add_modules ide-generic
147         manual_add_modules ohci1394
148         manual_add_modules sbp2
149         manual_add_modules sr_mod
150 fi
151
152 # Hardware: usb
153 if [ "${DISABLE_USB:-}" != "y" ]
154 then
155         manual_add_modules sd_mod
156 fi
157
158 # Hardware: network
159 auto_add_modules net
160
161 # Program: eject
162 if [ -x /usr/bin/eject ]
163 then
164         copy_exec /usr/bin/eject /bin
165 fi
166
167 [ "${QUIET}" ] || echo -n " utils"
168
169 # Feature: Verify Checksums
170 if [ -e /etc/progress-linux_version ]
171 then
172         copy_exec /usr/bin/sha256sum /bin
173 else
174         copy_exec /usr/bin/md5sum /bin
175 fi
176
177 # Program: memdisk
178 if [ -x /usr/bin/memdiskfind ]
179 then
180 [ "${QUIET}" ] || echo -n " memdisk"
181         copy_exec /usr/bin/memdiskfind
182         manual_add_modules phram
183         manual_add_modules mtdblock
184 fi
185
186 # Program: udev
187 if [ -x /bin/udevadm ]
188 then
189         [ "${QUIET}" ] || echo -n " udev"
190         copy_exec /bin/udevadm
191 fi
192
193 # Program: blockdev
194 if [ -x /sbin/blockdev ]
195 then
196         [ "${QUIET}" ] || echo -n " blockdev"
197         copy_exec /sbin/blockdev
198 fi
199
200 # FUSE kernel module
201 if [ "${DISABLE_FUSE:-n}" != "y" ]
202 then
203         manual_add_modules fuse
204
205         # FUSE filesystem: httpfs2
206         if [ -x /usr/bin/httpfs2_ssl ]
207         then
208                 [ "${QUIET}" ] || echo -n " httpfs:ssl"
209                 copy_exec /usr/bin/httpfs2_ssl /bin/httpfs
210         elif [ -x /usr/bin/httpfs2 ]
211         then
212                 [ "${QUIET}" ] || echo -n " httpfs"
213                 copy_exec /usr/bin/httpfs2 /bin/httpfs
214         fi
215
216         # FUSE filesystem: curlftpfs
217         if [ -x /usr/bin/curlftpfs ]
218         then
219                 [ "${QUIET}" ] || echo -n " ftpfs"
220                 copy_exec /usr/bin/curlftpfs /bin
221         fi
222 fi
223
224 # iSCSI
225 if [ -x /usr/sbin/iscsistart ]
226 then
227         [ "${QUIET}" ] || echo -n " iscsi"
228         copy_exec /usr/sbin/iscsistart /bin
229         #manual_add_modules ib_iser
230         manual_add_modules iscsi_tcp
231         manual_add_modules crc32c
232 fi
233
234 # Some experimental stuff
235
236 [ "${QUIET}" ] || echo -n " dns"
237
238 # /lib/libnss_dns.so.*:a   DNS
239 # /lib/libnss_files.so.*:  /etc/hosts and /etc/passwd
240 # /lib/libnss_compat.so.*: /etc/passwd
241
242 for _SHLIB in $(find /lib -name 'libnss_dns.so.*')
243 do
244         copy_exec "${_SHLIB}"
245 done
246
247 # might be needed if /etc/hosts is used
248 #mkdir -p "${DESTDIR}/etc"
249 #cp -p /etc/nsswitch.conf "${DESTDIR}/etc"
250
251 [ "${QUIET}" ] || echo .