source: MondoRescue/branches/2.2.9/mindi/mindi@ 2748

Last change on this file since 2748 was 2748, checked in by Bruno Cornec, 13 years ago
  • Fix Arch Linux kbd printed in log file now instead of screen.
  • Property svn:executable set to *
  • Property svn:keywords set to Rev Id
File size: 112.2 KB
Line 
1#!/bin/bash
2
3# $Id: mindi 2748 2011-03-21 23:58:07Z bruno $
4#
5#-----------------------------------------------------------------------------
6# mindi - mini-Linux distro based on the user's filesystem & distribution
7#
8# Mindi can create a multi-image boot/root kit. The first image is the boot
9# disk: it contains a kernel, a ramdisk etc. The second disk is data disk #1;
10# the third disk is data disk #2; and so it goes.
11#
12# See http://www.mondorescue.org for details.
13#-----------------------------------------------------------------------------
14
15### Which arch are we on (useful for ia64 port)
16ARCH=`/bin/uname -m`
17KERVERRUN=`/bin/uname -r`
18# By default we use the running kernel as a reference
19KERVER=$KERVERRUN
20
21# In case of problem with udev you can try to add udevdebug
22MINDI_ADDITIONAL_BOOT_PARAMS="devfs=nomount noresume selinux=0 barrier=off udevtimeout=10"
23
24MINDI_REV=PBREV
25MINDI_VER=PBVER
26
27MINDI_VERSION=${MINDI_VER}-r$MINDI_REV
28MINDI_PREFIX=XXX
29MINDI_CONF=YYY
30MINDI_SBIN=${MINDI_PREFIX}/sbin
31MINDI_LIB=LLL
32
33# Temporary directory for mindi
34TMPDIR=/tmp
35
36EXTRA_SPACE=69152 # increase if you run out of ramdisk space
37BOOT_SIZE=24576 # size of the boot disk
38
39PROMPT_MAKE_CD_IMAGE="yes"
40 # Ask if you want to make a CD Image to be written?
41 # if this is set to 'no', then the image will be created automatically
42
43PROMPT_MAKE_USB_IMAGE="yes"
44 # Ask if you want to make a USB Image to be written?
45 # if this is set to 'no', then the image will be created automatically
46
47USE_OWN_KERNEL="yes"
48 # If set to "no", you will be prompted for whether or not
49 # you want to use your own kernel, or the supplied default.
50 # If "yes" mindi will automatically use your own kernel.
51
52KERNEL_IS_XEN="no"
53 # If set to "no", the kernel is not a Xen kernel
54 # If "yes", mindi will modify isolinux.cfg for the Xen kernel.
55
56MY_FSTAB=/etc/fstab
57TAPE_MODS="ht st osst ide-tape ide_tape"
58SCSI_MODS="3w-xxxx 3w_xxxx 3w_9xxx 3w-9xxx 53c7,8xx a100u2w a320raid aacraid adpahci advansys aha152x aha1542 aha1740 aic79xx aic79xx_mod aic7xxx aic7xxx_mod aic7xxx_old AM53C974 atp870u BusLogic cciss cpqfc hpsa dmx3191d dpt_i2o dtc eata eata_dma eata_pio fdomain gdth g_NCR5380 i2o_block i2o_core ide-scsi ieee1394 imm in2000 initio ips iscsi iscsi_tcp libiscsi scsi_transport_iscsi libiscsi_tcp isp megaraid megaraid_mm megaraid_mbox megaraid_sas mega_sr mptbase mptscsih mptsas mptspi mptfc mptscsi mptctl NCR53c406a ncr53c8xx nsp32 pas16 pci2000 pci2220i pcmcia ppa psi240i qla1280 qla2200 qla2300 qla2400 qla2xxx qla2xxx_conf qlogicfas qlogicfc qlogicisp qlogicfas qlogicfas408 raw1394 scsi_mod scsi_transport_sas scsi_transport_spi scsi_transport_fc sd_mod crc_t10dif crc-t10dif seagate sg sim710 sr_mod sym53c416 sym53c8xx sym53c8xx_2 t128 tmscsim u14-34f ultrastor wd7000 vmhgfs intermodule scsi_dh scsi_tgt emcpdm emcpgpx emcpmpx emcp dc395x diskdumplib scsi_dump_register"
59
60# ide-probe-mod
61IDE_MODS="ide ide-floppy floppy ide-generic ide-detect ide-mod ide-disk ide_disk ide-cd ide_cd ide_cd_mod ide-cd_mod ide-cs ide-core ide_core ide-gd_mod ide_gd_mod edd paride ata_generic ide_pci_generic ata_piix libata dock via82cxxx generic nvidia ahci libahci sata_nv cmd64x pata_amd pata_marvell pata_serverworks pata_sis pata_sil680 pata_jmicron amd74xx sis5513 jmicron sata_promise sata_via serverworks sata_svw blkbk virtio"
62PCMCIA_MODS="pcmcia_core ds yenta_socket"
63USB_MODS="usb-storage usb-ohci usb-uhci usbcore usb_storage input hid uhci_hcd ehci_hcd uhci-hcd ehci-hcd ohci-hcd ohci_hcd xhci usbkbd usbhid keybdev mousedev libusual scsi_mod ff-memless ums_cypress ums-cypress cp210x usbserial"
64NET_MODS="auth_rpcgss sunrpc nfs nfs_acl lockd fscache loop mii 3c59x e100 bcm5700 bnx2 bnx2x mdio e1000 e1000e igb dca eepro100 ne2k-pci tg3 libphy pcnet32 8139cp 8139too 8390 forcedeth vmxnet vmxnet3 vmnet exportfs fuse libcrc32c netbk xenblktap r8169"
65CDROM_MODS="$TAPE_MODS $IDE_MODS $USB_MODS $PCMCIA_MODS $SCSI_MODS $NET_MODS af_packet cdrom isocd isofs inflate_fs nls_iso8859-1 nls_base nls_cp437 nls_utf8 sg sr_mod zlib_inflate iso9660"
66# Those modules will only go on the backup media, not the boot media.
67EXTRA_MODS="$CDROM_MODS vfat fat loop md-mod linear raid0 raid1 xor raid10 raid5 raid456 raid6_pq async_pq xor async_tx async_memcpy async_xor lvm-mod dm-mod dm_mod dm-snapshot dm_snapshot dm-zero dm_zero dm-mirror dm_mirror dm-multipath dm-round-robin dm-emc dm-hp-sw dm-rdac dm-region-hash dm-snapshot dm-log multipath jfs xfs xfs_support pagebuf reiserfs ext2 ext3 minix nfs nfs_acl nfsd lockd sunrpc jbd mbcache ext4 jbd2 crc16 ocfs2 ocfs2_dlm ocfs2_nodemanager configfs"
68# Replace with that line for HP OCMP e.g.
69#DENY_MODS="MPS_Driver_Mapper mps octtldrv tscttl streams kqemu fdomain"
70DENY_MODS="kqemu"
71# Force some modules to be included
72FORCE_MODS=""
73
74LOGFILE=/var/log/mindi.log
75MINDI_CACHE=/var/cache/mindi
76BOOT_MEDIA_MESSAGE="\
77To format and restore all files automatically, type 'nuke' <enter>.\n\
78To restore some/all files interactively, type 'interactive' <enter>.\n\
79To compare the archives with your filesystem, type 'compare' <enter>.\n\
80To boot to a command-line prompt (expert mode), type 'expert' <enter>.\n\
81You may add one or more of the following parameters as well:-\n\n\
82 donteject - mondorestore will not eject the CD; this is useful if, for\n\
83 instance, your PC's case has a concealed CD-ROM drive\n\
84 noresize - your mountlist will not be adjusted to use your unallocated\n\
85 hard disk space\n\
86 textonly - do not call any Newt library routines; this is unattractive\n\
87 but valuable if you find your Newt library has bugs in it\n\n\
88e.g. Type 'nuke donteject textonly' if you have an unstable Newt library and \n\
89a PC whose CD-ROM drive tray would be damaged if it unexpectedly ejected.\n\
90"
91FDISK=$MINDI_SBIN/parted2fdisk
92
93# Using a config file allow to overwrite some values
94MINDI_CONFIG="$MINDI_CONF/mindi.conf"
95if [ -f $MINDI_CONFIG ]; then
96 . $MINDI_CONFIG
97fi
98DEPLIST_FILE="$MINDI_CONF/deplist.txt"
99DEPLIST_DIR="$MINDI_CONF/deplist.d"
100
101ISO_CMD="/usr/bin/mkisofs"
102ISO_OPT="-J -r -v -p Mindi -publisher http://www.mondorescue.org -A Mindi"
103
104# Mandriva system e.g. use cdrkit, which uses genisoimage instead of mkisofs.
105# However, they use exactly the same command line parameters, so just
106# use genisoimage if it's available.
107if [ ! -x $ISO_CMD ]; then
108 ISO_CMD=/usr/bin/genisoimage
109fi
110
111# Last function called before exiting
112# Parameter is exit code value
113# Should be declared here as used immediately below potentialy
114MindiExit() {
115 echo "Mindi $MINDI_VERSION is exiting" >> $LOGFILE
116 echo "End date : `date`" >> $LOGFILE
117 if [ _"$MONDO_SHARE" != _"" ] ; then
118 echo "------------- mindi logfile included -------------------------" >> /var/log/mondoarchive.log
119 cat $LOGFILE >> /var/log/mondoarchive.log
120 echo "--------------------------------------------------------------">> /var/log/mondoarchive.log
121 fi
122
123 cd /
124 sync&
125
126 # Clean temporary files only when standalone mindi
127 if [ _"$MINDI_TMP" != _"$MONDO_TMP" ]; then
128 rm -Rf $MINDI_TMP
129 fi
130 exit $1
131}
132
133LogIt() {
134 if [ -e /dev/stderr ] ; then
135 echo -e "$1" >> /dev/stderr
136 elif [ -e /usr/bin/logger ] ; then
137 /usr/bin/logger -s $1
138 fi
139 echo -e "$1" >> $LOGFILE
140 if [ _"$2" != _"" ]; then
141 grep -Ev "tar: Removing \`/\'" "$2" >> $LOGFILE
142 fi
143 rm -f "$2"
144}
145
146
147Die() {
148 local i
149 if [ "$1" = "" ] ; then
150 LogIt "FATAL ERROR"
151 else
152 LogIt "FATAL ERROR. $1"
153 fi
154 if [ _"$2" != _"" ]; then
155 grep -Ev "tar: Removing \`/\'" "$2" >> $LOGFILE
156 fi
157 rm -f "$2"
158
159 LogIt "Please e-mail a copy of $LOGFILE to the mailing list."
160 LogIt "See http://www.mondorescue.org for more information."
161 LogIt "WE CANNOT HELP unless you enclose that file.\n"
162 MindiExit -1
163}
164
165# Now we can create what we need
166MINDI_TMP=`mktemp -d $TMPDIR/mindi.XXXXXXXXXX`
167if [ $? -ne 0 ]; then
168 df $TMPDIR
169 Die "Unable to create a temporary directory ! Check space on $TMPDIR"
170fi
171if [ _"$MINDI_TMP" = _"" ]; then
172 Die "MINDI_TMP is empty, aborting"
173fi
174if [ _"$MINDI_TMP" = _"/" ]; then
175 Die "MINDI_TMP is /, aborting"
176fi
177export MINDI_TMP
178
179# ----------------------------------------------------------------------------
180
181
182AbortHere() {
183 [ "$mountpoint" ] && umount $mountpoint 2>> $LOGFILE
184 Die "Program is terminating in response to signal received from OS/user"
185}
186
187
188Aborted() {
189 trap SIGHUP SIGTERM SIGTRAP SIGINT
190 [ "$MINDI_CACHE" != "" ] && rm -f $MINDI_CACHE/mindi*img $MINDI_CACHE/*gz $MINDI_CACHE/mindi.iso
191 [ "$minidir_root" != "" ] && rm -Rf $minidir_root/*
192 Die "User abort."
193}
194
195
196AddFileToCfgIfExists() {
197 [ -e "$1" ] && echo -en "$2 `cat $1`\n" >> $3
198}
199
200
201AddKeyboardMappingFile() {
202 local mappath r included_list included_item i res ii sss
203 mappath=$1
204 KBDEPTH=$(($KBDEPTH+1))
205 [ "$KBDEPTH" -gt "128" ] && Die "Edit $MINDI_SBIN/mindi and disable FindAndAddUserKeyboardMappingFile (line 2160, approx.)"
206 if [ -e "$bigdir/$mappath" ] ; then
207 echo "$mappath already added" >> $LOGFILE
208 return
209 elif [ -d "$bigdir/$mappath" ] ; then
210 echo "Cannot add $mappath: it's a directory. Sorry."
211 return
212 fi
213 echo "Added kbd map $mappath" >> $LOGFILE
214 if [ ! -e "$mappath" ] ; then
215 mappath=`grep "i[3-8]86" $MINDI_TMP/keymaps.find | grep "$locale[^r][^/]" | grep -vx " *#.*"`
216 if [ ! -e "$mappath" ] ; then
217 LogIt "Cannot add $mappath: kbd map file not found"
218 return
219 fi
220 else
221 echo -en "`basename $mappath | tr '.' '#' | sed s/#kmap#gz// | sed s/#inc#gz//` " | tr '#' '.'
222 fi
223
224 mkdir -p $bigdir/etc
225 tar cf - -C / $mappath 2>> $MINDI_TMP/$$.log | (cd "$bigdir" ; tar xf -) || LogIt "AKMF -- Could not copy $mappath to $bigdir" $MINDI_TMP/$$.log
226 if [ "`echo $mappath | grep -F ".gz"`" ] ; then
227 included_list=`gzip -dc $mappath | grep -Fi include | sed s/'"'// | sed s/'"'// | cut -d' ' -f2`
228 else
229 included_list=`grep -Fi include $mappath | sed s/'"'// | sed s/'"'// | cut -d' ' -f2`
230 fi
231 for included_item in $included_list ; do
232 if [ ! -e "$included_item" ] ; then
233 sss=`grep -F "${included_item}.inc" $MINDI_TMP/keymaps.find`
234 [ "$sss" = "" ] && sss=`grep -F "$included_item" $MINDI_TMP/keymaps.find`
235 for ii in $sss ; do
236 [ -e "$ii" ] && AddKeyboardMappingFile $ii
237 done
238 else
239 AddKeyboardMappingFile $included_item
240 fi
241 done
242}
243
244
245CopyDependenciesToDirectory() {
246 local outdir incoming fname counter d found
247 outdir=$1
248 mkdir -p $outdir
249 incoming=`ReadLine`
250 counter=0
251 while [ "$incoming" != "" ] ; do
252 # Non absolute file names should not arrive till here => skipped
253 if [ `echo "$incoming" | cut -c1` != '/' ]; then
254 LogIt "Unable to handle $incoming"
255 incoming=`ReadLine`
256 continue
257 fi
258 # no parent directory of incoming should be a link, copy is not possible in that case
259 d=`dirname "$incoming"`
260 found="false"
261 while [ $d != "/" -a $found = "false" ]; do
262 [ -h "$d" ] && found="true"
263 d=`dirname "$d"`
264 done
265 if [ -d "$incoming" ] && [ ! -h "$incoming" ]; then
266 find $incoming/* -maxdepth 0 2> /dev/null | CopyDependenciesToDirectory $outdir
267 elif [ -e "$incoming" ] && [ $found = "false" ]; then
268 tar cf - -C / $incoming 2>> $MINDI_TMP/$$.log | (cd "$outdir" ; tar xf -) || Die "Cannot copy $incoming to $outdir - did you run out of disk space?" $MINDI_TMP/$$.log
269
270 # Only uncompress modules if not using udevd
271 if [ "`echo "$incoming" | grep "lib/modules/.*\..*o\.gz"`" != "" ] && [ "`ps auxww | grep -v grep | grep -qw udevd`" != "" ]; then
272 gunzip -f $outdir/$incoming || LogIt "Cannot gunzip $outdir/$incoming"
273 fi
274 [ -x "$outdir" ] && StripExecutable $outdir "-$filename-"
275 counter=$(($counter+1))
276 if [ "$counter" -ge "5" ] ; then
277 counter=0
278 echo -en "."
279 fi
280 fi
281 incoming=`ReadLine`
282 done
283}
284
285
286CountItemsIn() {
287 local r
288 r=0
289 for q in $1 ; do
290 r=$(($r+1))
291 done
292 echo $r
293}
294
295
296DropOptimizedLibraries() {
297 local outdir filelist list_of_optimized_libraries optimized_lib_name vanilla_lib_name reason msg resolved res
298 filelist=$1
299 outdir=$2
300
301 list_of_optimized_libraries=`grep "lib/i[5-7]86/" $filelist`
302 if [ "$list_of_optimized_libraries" = "" ] ; then
303 return 0
304 fi
305 echo -en "Dropping i686-optimized libraries if appropriate"
306 for optimized_lib_name in $list_of_optimized_libraries ; do
307 echo -en "."
308 reason=""
309 vanilla_lib_name=`echo "$optimized_lib_name" | sed -e 's/i[5-7]86//' -e 's/cmov//' -e 's/nosegneg//' | tr -s '/' '/'`
310 echo "$vanilla_lib_name" >> $filelist
311 echo "Adding $vanilla_lib_name to filelist" >> $LOGFILE
312 mkdir -p $outdir$optimized_lib_name > /dev/null 2> /dev/null
313 rmdir $outdir$optimized_lib_name > /dev/null 2> /dev/null
314
315 # This may return multiple files
316 for resolved in `ReadAllLink $vanilla_lib_name`; do
317 echo "Adding as deps $resolved to filelist" >> $LOGFILE
318 vanilla_resolved_name=`echo "$resolved" | sed -e 's/i[5-7]86//' -e 's/cmov//' -e 's/nosegneg//' | tr -s '/' '/'`
319 mkdir -p $outdir$resolved> /dev/null 2> /dev/null
320 rmdir $outdir$resolved > /dev/null 2> /dev/null
321 ln -sf $vanilla_resolved_name $outdir$resolved
322 echo "Excluding deps $resolved" >> $LOGFILE
323 grep -Fvx "$resolved" "$filelist" > $filelist.tmp
324 echo "Replacing it with $vanilla_resolved_name" >> $LOGFILE
325 echo "$vanilla_resolved_name" >> $filelist.tmp
326 mv -f $filelist.tmp $filelist
327 done
328 done
329 $AWK '{ print $1; }' $filelist | sort -u > $filelist.tmp
330 mv -f $filelist.tmp $filelist
331 echo -e "$DONE"
332}
333
334
335FindAndAddUserKeyboardMappingFile() {
336 local r res mapfile mappath included_item included_list keyfile mp locale
337 LogIt "Analyzing your keyboard's configuration."
338 KEYDIR=/lib/kbd
339 [ ! -e "$KEYDIR" ] && KEYDIR=/usr/share/kbd # Slackware
340 [ ! -e "$KEYDIR" ] && KEYDIR=/usr/lib/kbd
341 [ ! -e "$KEYDIR" ] && KEYDIR=/usr/share
342 [ ! -e "$KEYDIR" ] && KEYDIR=/etc/condole
343 [ ! -e "$KEYDIR" ] && KEYDIR=/etc/condole-setup
344 if [ ! -e "$KEYDIR" ] ; then
345 LogIt "Keyboard mapping directory not found. I shall use default map at boot-time."
346 return 0
347 fi
348 if [ -e "/etc/sysconfig/keyboard" ] ; then
349 echo "Red Hat-style config detected." >> $LOGFILE
350 keyfile=/etc/sysconfig/keyboard
351 elif [ -e "/etc/rc.d/rc.keymap" ] ; then
352 echo "Slackware-style config detected." >> $LOGFILE
353 keyfile=/etc/rc.d/rc.keymap
354 elif [ -e "/etc/rc.config" ] ; then
355 echo "Debian-style config detected." >> $LOGFILE
356 keyfile=/etc/rc.config
357 elif [ -e "/etc/console/boottime.kmap.gz" ] ; then
358 echo "Debian-style config detected." >> $LOGFILE
359 echo -en "Adding the following keyboard mapping tables: "
360 mkdir -p $bigdir/tmp
361 echo "/etc/console/boottime.kmap.gz" > $bigdir/tmp/KEYMAP-LIVES-HERE
362 KBDEPTH=0
363 mkdir -p $bigdir/etc/console
364 cp /etc/console/boottime.kmap.gz $bigdir/etc/console 2>> $LOGFILE
365 echo -e "$DONE"
366 return 0
367 elif [ -e "/etc/console-setup/boottime.kmap.gz" ] ; then
368 echo "Ubuntu-style config detected." >> $LOGFILE
369 echo -en "Adding the following keyboard mapping tables: "
370 mkdir -p $bigdir/tmp
371 echo "/etc/console-setup/boottime.kmap.gz" > $bigdir/tmp/KEYMAP-LIVES-HERE
372 KBDEPTH=0
373 mkdir -p $bigdir/etc/console-setup
374 cp /etc/console-setup/boottime.kmap.gz $bigdir/etc/console-setup 2>> $LOGFILE
375 echo -e "$DONE"
376 return 0
377 elif [ -e "/etc/rc.conf" ] ; then
378 echo "ArchLinux config detected." >> $LOGFILE
379 keyfile=/etc/rc.conf
380 elif [ -e "/etc/conf.d/keymaps" ] ; then
381 echo "Gentoo-style config detected." >> $LOGFILE
382 keyfile=/etc/conf.d/keymaps
383 else
384 echo -en "Searching for rc.config ..."
385 keyfile=`find /etc -name rc.config | head -n1`
386 if [ "$keyfile" = "" ] || [ ! -e "$keyfile" ] ; then
387 LogIt "Unknown config detected. Default keyboard map will be used."
388 return
389 else
390 echo "Found $keyfile" >> $LOGFILE
391 fi
392 fi
393 if [ ! -e "$KEYDIR/keymaps" ] ; then
394 LogIt "Keyboard mapping directory not found. Default keyboard map will be used."
395 return
396 fi
397 echo "keyfile=$keyfile" >> $LOGFILE
398 locale=`grep -F KEYTABLE "$keyfile" | tr -d '"' |cut -d'=' -f2`
399 [ ! "$locale" ] && locale=`grep '.map$' "$keyfile" | sed 's/^.* //'` # Slackware
400 [ ! "$locale" ] && locale=`grep -E '^KEYMAP=' "$keyfile" | tr -d '"' |cut -d'=' -f2` # Gentoo & ArchLinux
401 echo "locale=$locale" >> $LOGFILE
402 #
403 # Process the keymaps dir once for all
404 # AddKeyboardMappingFile will use it recursively
405 #
406 find $KEYDIR/keymaps > $MINDI_TMP/keymaps.find
407 mp=`grep "i[3-8]86" $MINDI_TMP/keymaps.find | grep -F "/${locale}." | grep -vx " *#.*"`
408 [ ! "$mp" ] && mp=`grep "i[3-8]86" $MINDI_TMP/keymaps.find | grep "$locale[^r][^/]" | grep -vx " *#.*"`
409 # If we have multiple keymaps then log it !!
410 echo "$mp" | grep -q " "
411 if [ $? -eq 0 ]; then
412 echo "WARNING: Multiple keymaps found: $mp" | tee -a $LOGFILE
413 echo "The following one will be used" >> $LOGFILE
414 fi
415 for i in $mp ; do
416 mappath=$i
417 [ -e "$i" ] && [ ! -d "$i" ] && break
418 done
419 if [ ! -e "$mappath" ] || [ -d "$mappath" ] ; then
420 mappath=$(find / -name "*/kbd/keymaps/*/$locale")
421 fi
422 echo "mappath = $mappath" >> $LOGFILE
423 if [ ! -e "$mappath" ] || [ -d "$mappath" ] ; then
424 LogIt "Keyboard mapping file not found. Default keyboard map will be used."
425 return
426 fi
427 echo -en "Adding the following keyboard mapping tables: "
428 mkdir -p $bigdir/tmp
429 echo "$mappath" > $bigdir/tmp/KEYMAP-LIVES-HERE
430 KBDEPTH=0
431 AddKeyboardMappingFile $mappath
432 echo -e "$DONE"
433 rm -f $MINDI_TMP/keymaps.find
434 return 0
435}
436
437
438FindMboot32Binary() {
439 MBOOTC32=/usr/lib/syslinux/mboot.c32
440 [ ! -e "$MBOOTC32" ] && MBOOTC32=/usr/lib/syslinux/mboot.c32
441 [ ! -e "$MBOOTC32" ] && MBOOTC32=/usr/lib64/syslinux/mboot.c32
442 [ ! -e "$MBOOTC32" ] && MBOOTC32=/usr/share/syslinux/mboot.c32
443 [ ! -e "$MBOOTC32" ] && MBOOTC32=/usr/share/lib/syslinux/mboot.c32
444 [ ! -e "$MBOOTC32" ] && MBOOTC32=/usr/share/lib64/syslinux/mboot.c32
445 [ ! -e "$MBOOTC32" ] && MBOOTC32=`find / -name mboot.c32 | grep -x "/.*/mboot.c32"`
446 [ ! -e "$MBOOTC32" ] && Die "Please install mboot.c32 first. If your syslinux RPM doesn't include mboot.c32, you may download an isolinux RPM from Mondo's website - go to http://www.mondorescue.com and click on 'Download'"
447 echo "Found mboot.c32 at $MBOOTC32" >> $LOGFILE
448 LogIt " Found mboot.c32 at $MBOOTC32"
449}
450
451FindIsolinuxBinary() {
452 ISOLINUX=/usr/lib/isolinux.bin
453 [ ! -e "$ISOLINUX" ] && ISOLINUX=/usr/lib/syslinux/isolinux.bin
454 [ ! -e "$ISOLINUX" ] && ISOLINUX=/usr/lib64/syslinux/isolinux.bin
455 [ ! -e "$ISOLINUX" ] && ISOLINUX=/usr/share/syslinux/isolinux.bin
456 [ ! -e "$ISOLINUX" ] && ISOLINUX=/usr/share/lib/syslinux/isolinux.bin
457 [ ! -e "$ISOLINUX" ] && ISOLINUX=/usr/share/lib64/syslinux/isolinux.bin
458 [ ! -e "$ISOLINUX" ] && ISOLINUX=`find / -name isolinux.bin | grep -x "/.*/isolinux.bin"`
459 [ ! -e "$ISOLINUX" ] && Die "Please install isolinux first. If your syslinux RPM doesn't include isolinux, you may download an isolinux RPM from Mondo's website - go to http://www.mondorescue.com and click on 'Download'"
460 echo "Found isolinux.bin at $ISOLINUX" >> $LOGFILE
461}
462
463
464FindSpecificModuleInPath() {
465 local modpaths pwd line
466 pwd=`pwd`
467 if [ "$YOUR_KERNEL_SUCKS" ] ; then
468 cd "$MINDI_TMP"
469 else
470 cd /
471 fi
472 if [ ! -e "$1" ] ; then
473 LogIt "WARNING - cannot search specific path '$1'"
474 return 1
475 fi
476 # Find all files and links (required for some VMWare VMs)
477 modpaths=`find $1 -name $2.*o -o -name $2.o.gz -o -name $2.ko.gz -o -name $2 -type f -o -type l`
478 echo "$modpaths"
479 cd "$pwd"
480}
481
482
483GenerateGiantDependencyList() {
484 local incoming loc fname list_of_files i tempfile outfile progress filelist res r mapfile mappath included_list included_item old_pwd tempdepfile modres noof_lines lvmversion lvmresolved
485
486 echo -en "Analyzing dependency requirements"
487 outfile=$1
488 tempfile=$MINDI_TMP/$$.txt
489 incoming=`ReadLine`
490
491 > $tempfile
492 progress=0
493 res=0
494 noof_lines=$2
495 while [ "$incoming" != "" ] ; do
496 if echo "$incoming" | grep -x " *#.*" &> /dev/null ; then
497 incoming=`ReadLine`
498 continue
499 fi
500 if [ "$incoming" = "LVMFILES:" ] ; then
501 break
502 fi
503 filelist=`GenerateListForFile "$incoming"`
504 r=$?
505 [ "$r" -ne "0" ] && LogIt "$incoming not found"
506 res=$(($res+$r))
507# echo "'$incoming' generates filelist '$filelist'" >> $LOGFILE
508 for fname in $filelist ; do
509 [ "$fname" != "" ] && echo "$fname" >> $tempfile
510 done
511 progress=$(($progress+1))
512 echo -en "\r\t\t\t\t\t\t\t\t"
513 i=$(($progress*100))
514 i=$(($i/$noof_lines))
515 echo -en "$i"
516 echo -en "%"
517 modres=$(($progress%4))
518 [ "$modres" -eq "0" ] && echo -en "\t/"
519 [ "$modres" -eq "1" ] && echo -en "\t-"
520 [ "$modres" -eq "2" ] && echo -en "\t\\"
521 [ "$modres" -eq "3" ] && echo -en "\t|"
522 incoming=`ReadLine`
523 done
524 if [ "$incoming" = "LVMFILES:" ] ; then
525 incoming=`ReadLine`
526 lvmversion=""
527 while [ "$incoming" != "" ] ; do
528 if echo "$incoming" | grep -x " *#.*" &> /dev/null ; then
529 incoming=`ReadLine`
530 continue
531 fi
532 filelist=`GenerateListForFile "$incoming"`
533 for tool in $filelist ; do
534 lvmresolved=`readlink -f $tool`
535 if [ "$tool" = "$lvmresolved" ]; then
536 echo "$tool" >> $tempfile
537 elif echo "$lvmresolved" | grep "lvmiopversion" &> /dev/null ; then
538 if [ "$lvmversion" = "" ] ; then
539 lvmversion=`$lvmresolved`
540 echo "$lvmresolved" >> $tempfile
541 fi
542 toolstripped=`echo $tool | $AWK -F / '{print $NF;}'`
543 if [ "$lvmversion" = "200" ]; then
544 # pvdata and lvmcreate_initrd don't exist in LVM2
545 case "$toolstripped" in
546 "pvdata")
547 continue
548 ;;
549 "lvmcreate_initrd")
550 continue
551 ;;
552 esac
553 fi
554 toolpath="/sbin/lvm-"$lvmversion"/"$toolstripped
555 if [ -e "$toolpath" ] ; then
556 echo "$toolpath" >> $tempfile
557 echo "$tool" >> $tempfile
558 else
559 toolpath="/lib/lvm-"$lvmversion"/"$toolstripped
560 fi
561 if [ -e "$toolpath" ] ; then
562 echo "$toolpath" >> $tempfile
563 echo "$tool" >> $tempfile
564 else
565 echo "Where are your LVM-Tools? Couldn't find $tool"
566 fi
567 else
568 echo "$tool" >> $tempfile
569 fi
570 done
571 progress=$(($progress+1))
572 echo -en "\r\t\t\t\t\t\t\t\t"
573 i=$(($progress*100))
574 i=$(($i/$noof_lines))
575 echo -en "$i"
576 echo -en "%"
577 modres=$(($progress%4))
578 [ "$modres" -eq "0" ] && echo -en "\t/"
579 [ "$modres" -eq "1" ] && echo -en "\t-"
580 [ "$modres" -eq "2" ] && echo -en "\t\\"
581 [ "$modres" -eq "3" ] && echo -en "\t|"
582 incoming=`ReadLine`
583 done
584 fi
585 echo -en "$DONE\nMaking complete dependency list"
586
587 tr -s '/' '/' < $tempfile | sort -u > $tempfile.new
588 mv -f $tempfile.new $tempfile
589 > $outfile.pre
590 progress=0
591 noof_lines=`cat $tempfile | wc -l`
592 echo "---------------------------------" >> $LOGFILE
593 echo "List of dependencies: " >> $LOGFILE
594 echo "---------------------------------" >> $LOGFILE
595 for fname in `cat $tempfile` ; do
596 echo "$fname" | tee -a $LOGFILE >> $outfile.pre
597 LocateDeps $fname | tee -a $LOGFILE >> $outfile.pre
598 progress=$(($progress+1))
599 echo -en "\r\t\t\t\t\t\t\t\t"
600 i=$(($progress*100))
601 i=$(($i/$noof_lines))
602 echo -en "$i"
603 echo -en "%"
604 modres=$(($progress%4))
605 [ "$modres" -eq "0" ] && echo -en "\t/"
606 [ "$modres" -eq "1" ] && echo -en "\t-"
607 [ "$modres" -eq "2" ] && echo -en "\t\\"
608 [ "$modres" -eq "3" ] && echo -en "\t|"
609 done
610 if [ _"$MONDO_SHARE" != _"" ]; then
611 mkdir -p $bigdir/tmp
612 mkdir -p $bigdir/sbin
613 mkdir -p $bigdir/bin
614 if [ -e "$MINDI_TMP/post-nuke.tgz" ] ; then
615 LogIt "\nIncorporating post-nuke tarball"
616 old_pwd=`pwd`
617 cd "$bigdir"
618 tar -zxf $MINDI_TMP/post-nuke.tgz 2>> $MINDI_TMP/$$.log || LogIt "Error occurred when untarring post-nuke tarball" $MINDI_TMP/$$.log
619 cd "$old_pwd"
620 fi
621 if cp -f $MINDI_TMP/mondo*restore $bigdir/usr/bin 2>> $LOGFILE ; then
622 LocateDeps $bigdir/usr/bin/mondo*restore >> $outfile.pre
623 else
624 LogIt "Cannot find mondo*restore in mondo's tempdir, $MINDI_TMP"
625 LogIt "I bet you've got a spare copy of Mondo or Mindi floating around on your system."
626 LogIt "If Mindi was called by Mondo then send me a bug report.\n It not, type 'ps ax' to see which Mondo-related process is still running;\n then kill it. :-)\n Finally, run Mindi again."
627 Die "Odd."
628 fi
629 cp -f $MINDI_TMP/BOOTLOADER.* $bigdir 2>> $LOGFILE || LogIt "\nMondo v1.2x defaults to LILO as the bootloader, BTW."
630 if [ -e "$MINDI_TMP/NETFS-DEV" ] ; then
631 LogIt "\nIncorporating Network-related settings"
632 for r in NETFS-* ISO-PREFIX ; do
633 cp -f $MINDI_TMP/$r $bigdir/tmp 2>> $LOGFILE || Die "Cannot copy $r - did you run out of disk space?"
634 echo "Copying $r to ramdisk" >> $LOGFILE
635 done
636 fi
637 fi
638 tr ' ' '\n' < $outfile.pre | tr -s '/' '/' | grep -Fvx "" | sort -u | grep -Ev "/libX11|/libXext|/libXi|/libgtk|/libgdk" > $outfile
639 rm -f $tempfile $outfile.pre
640 [ "$res" -eq "0" ] && echo -e "\r\t\t\t\t\t\t\t\t$DONE" || echo "\nFailed."
641 return $res
642}
643
644
645GenerateListForFile() {
646 local files_found loc fname incoming i res
647 incoming="$1"
648 files_found=""
649 res=0
650
651 for fname in $incoming ; do
652 files_found="$files_found `LocateFile $fname`"
653 done
654
655 echo "$files_found" | tr ' ' '\n' | sort -u | tr '\n' ' '
656}
657
658
659# Returns all disk devices which are part of a raid array
660GetAllRaidMembers() {
661 $AWK "/^[[:space:]]*#/ {next} /^[[:space:]]*device/ if(\$2) {print \$2}" < /etc/raidtab
662}
663
664
665GetFileSizeList() {
666 local i
667 for i in `find $1 -type d -o -print` ; do
668 du -sk $i
669 done
670}
671
672
673GetHomeDir() {
674 local res loc
675 loc=`which $1 2>/dev/null`
676 res=`file $loc | $AWK '{print $NF;}'`
677 dirname $res
678}
679
680
681# Check kernel filesystem capabilites for accessing initrd image
682# Could be ext2 FS (old mode) or initramfs (new mode)
683#
684# Interface definition:
685# param #1: absolute path to kernel image
686GetInitrdFilesystemToUse() {
687
688 # interface test: make sure we have one parameter
689 if [ $# -ne 1 ]; then
690 Die "GetInitrdFilesystemToUse(): Expected 1 parameter, got $#."
691 fi
692
693 # interface parameters
694 local lvKernelImage=$1
695
696 # local constants (filesystem magic strings)
697 local lcMagicCramfs="<3>cramfs: wrong magic"
698 local lcMagicExt2fs="EXT2-fs: blocksize too small for device."
699 local lcMagicExt3fs="<3>EXT3-fs: blocksize too small for journal device."
700 local lcMagicInitfs="<6>checking if image is initramfs...|<6>Unpacking initramfs...|<6>Trying to unpack rootfs image as
701initramfs"
702
703 # local variables
704 local lvOffset
705 local lvScanRes
706 local lvUseFilesystem
707
708 # say where we are.
709 echo " GetInitrdFilesystemToUse(): called with parameter: $lvKernelImage" >> $LOGFILE
710
711 # verify that file exists
712 [ ! -f $lvKernelImage ] && Die "File $lvKernelImage not found. Terminating."
713
714 # Kernel may be gzip compressed
715 file $lvKernelImage 2>&1 | grep -q gzip
716 if [ $? -eq 0 ]; then
717 lvScanRes=`gzip -cd $lvKernelImage | strings | grep -E "$lcMagicCramfs|$lcMagicExt2fs|$lcMagicExt3fs|$lcMagicInitfs"`
718
719 # determine which filesystem to use for initrd image: ext2|3fs, gzip'ed cpio (initramfs) or cramfs
720 if [ `echo $lvScanRes | grep -Ec "$lcMagicExt2fs"` -eq 1 ]; then
721 lvUseFilesystem="ext2fs"
722 elif [ `echo $lvScanRes | grep -Ec "$lcMagicExt3fs"` -eq 1 ]; then
723 lvUseFilesystem="ext3fs"
724 elif [ `echo $lvScanRes | grep -Ec "$lcMagicInitfs"` -eq 1 ]; then
725 lvUseFilesystem="initramfs"
726 elif [ `echo $lvScanRes | grep -Ec "$lcMagicCramfs"` -eq 1 ]; then
727 lvUseFilesystem="cramfs"
728 else
729 lvUseFilesystem="UNSUPPORTED"
730 fi
731
732 else
733 # In that case, we are after 2.6.30 and use the supported initramfs
734 lvUseFilesystem="initramfs"
735 fi
736 # say what we are using
737 echo " GetInitrdFilesystemToUse(): Filesytem to use for initial ram disk is $lvUseFilesystem.\n" >> $LOGFILE
738
739 # return file system to use
740 echo "$lvUseFilesystem"
741
742}
743
744# Searches parent raid device of given disk device
745# $1: disk device (i.e. /dev/hda1)
746GetParentRaidDev() {
747 $AWK "/^[[:space:]]*#/ {next} /^[[:space:]]*raiddev/ {dev=\$2} /^[[:space:]]*device/ {if(\$2==\"$1\") {print dev; exit}}" < /etc/raidtab
748}
749
750
751# Searches members of raid device
752# $1: raid device (/dev/md...)
753GetRaidDevMembers() {
754 $AWK "/^[[:space:]]*#/ {next} /^[[:space:]]*raiddev/ {if(dev) exit; if(\$2 == \"$1\") dev=\$2} /^[[:space:]]*device/ {if(dev) {print \$2}}" < /etc/raidtab
755}
756
757
758HackPathsToFailsafe() {
759 local incoming newpath stub i pwd
760 incoming=`ReadLine`
761 pwd=`pwd`
762 cd "$MINDI_TMP"
763 while [ "$incoming" != "" ] ; do
764 stub=`basename $incoming`
765 newpath=`FindSpecificModuleInPath lib/modules/$FAILSAFE_KVER $stub`
766 for i in $newpath ; do
767 echo "$i"
768 done
769 read incoming
770 done
771 cd "$pwd"
772}
773
774
775ListAllPartitions() {
776 local res currline partition all_partitions ap_orig remaining i j
777
778 grep -Evx " *#.*| *none.*" $MY_FSTAB | $AWK '/^\/dev\/[imhs]d||^LABEL=\/|^UUID=/ && !/\/fdd|\/cdr|\/zip|\/floppy/ {print $1}'
779 [ -e "/etc/raidtab" ] && $AWK '/^ *device/ {print $2}' /etc/raidtab
780 if [ -e "/vmfs/volumes" ]; then
781 # For VMWare ESX 3 get the device names of these volumes
782 vdf -P | grep -E '/vmfs/volumes' | $AWK '{print $1}'
783 fi
784 return
785}
786
787
788ListImagesForUser() {
789 local path fname
790 path=$MINDI_CACHE
791 echo -en "In the directory '$path' you will find the images:-\n"
792 for fname in `ls $path | grep -F mindi-` ; do
793 printf "%19s " $fname
794 done
795 echo " "
796}
797
798
799ListKernelModulePaths() {
800 local module_list module fname r kern
801 module_list="$MODULES"
802 # Remove unwanted modules from list
803 for i in $DENY_MODS; do
804 module_list=`echo ${module_list} | tr ' ' '\n' | grep -Ev "^${i}$" | tr '\n' ' '`
805 EXTRA_MODS=`echo ${EXTRA_MODS} | tr ' ' '\n' | grep -Ev "^${i}$" | tr '\n' ' '`
806 done
807###
808### Sq-Modification ... Use kernelname for module search path if specified
809###
810 if [ "${kernelname}" != "" -a "${kernelname}" != "FAILSAFE" ]
811 then
812 kern=${kernelname}
813 else
814 kern="$KERVERRUN"
815 fi
816 export KERVER=$kern
817###
818### Sq-Mod End
819###
820 # Get rid of duplicates, so that if a live kernel module also appears
821 # in $EXTRA_MODS that it won't get reported as "live module file not found" twice.
822 for module in `echo $module_list $EXTRA_MODS | tr ' ' '\n' | sort -u` ; do
823 r=`find /lib/modules/$kern -type f | grep "/${module}\..*o" | tail -n1`
824 if [ -z "$r" ]; then
825 if [ "`echo "$MODULES" | grep -w $module`" ]; then
826 r="[live module file not found]"
827 else
828 r="[extra module file not found]"
829 fi
830 else
831 [ -f "$r" ] && echo "$r"
832 fi
833 echo "module $module --> $r" >> $LOGFILE
834 done
835 find /lib/modules/$kern/modules.* -type f 2> /dev/null
836}
837
838#
839# Critical function which computes all dependencies (dyn. lib.)
840# for a list of binaries
841#
842LocateDeps() {
843 local incoming fname deps
844 incoming="$*"
845 for fname in $incoming ; do
846 if [ ! -e "$fname" ] ; then
847 echo "WARNING - $fname does not exist; cannot be LDD'd." >> $LOGFILE
848 if echo $fname | grep lvm &> /dev/null ; then
849 echo "This warning only affects you if you are using LVM." >> $LOGFILE
850 if echo "$MODULES" | grep lvm &> /dev/null ; then
851 echo "I think you are, so please take heed!" >> $LOGFILE
852 else
853 echo "I don't think you are, so don't worry about it." >> $LOGFILE
854 fi
855 fi
856 elif [ -h "$fname" ] && [ -x "$fname" ] ; then
857 echo "$fname is softlink" >> $LOGFILE
858 else
859 ldd $fname 2> /dev/null | ProcessLDD
860 fi
861 done
862}
863
864
865# Give all symlinks recursively of a full path name
866ReadAllLink() {
867 file="$1"
868
869 echo $file | grep -q '\.\./'
870 if [ $? -eq 0 ]; then
871 # We need to normalise the path with .. in it
872 file=`echo $file | perl -pi -e 's|([^/]+)/([^/]+)/\.\./([^/]+)|$1/$3|'`
873 fi
874 echo "$file"
875 if [ ! -h $file ]; then
876 return 0
877 fi
878
879 link=`readlink $file`
880 d=`dirname $file`
881 fchar=`echo $link | cut -c1`
882 # If mother dir is a link print it
883 if [ -h "$d" ]; then
884 echo "$d"
885 d=`readlink $d`
886 fi
887 if [ "$fchar" != "/" ]; then
888 # Relative or local link
889 ReadAllLink "$d/$link"
890 else
891 # Absolute path
892 ReadAllLink $link
893 fi
894}
895
896
897LocateFile() {
898 local i path fname_to_find location output resolved tmp stub cache_id loclist
899 fname_to_find="$1"
900 # It's an absolute path
901 if echo "$fname_to_find" | grep -x "/.*" ; then
902 output="$fname_to_find"
903 if [ -h "$output" ] ; then
904 output="`ReadAllLink $output` $output"
905 fi
906 echo "$output"
907 return 0
908 fi
909 # It's not an absolute path
910 output=""
911 for path in /etc /usr /usr/bin /usr/sbin /bin /usr/X11R6/bin /sbin /usr/local/bin /usr/local/sbin `find /usr/lib /lib /usr/local/lib /usr/X11R6/lib /usr/lib64 /lib64 /usr/local/lib64 /usr/X11R6/lib64 -type d -maxdepth 1 2> /dev/null` ; do
912 #for path in /etc /usr /usr/bin /usr/sbin /bin /usr/X11R6/bin /sbin /usr/local/bin /usr/local/sbin /usr/lib /usr/lib64 /usr/lib64/* /lib /lib64 /lib64/* /usr/local/lib /usr/local/lib64 /usr/local/lib64/* /usr/X11R6/lib /usr/X11R6/lib64 /usr/X11R6/lib64/* ; do
913 [ -h "$path" ] && continue
914 [ ! -e "$path/$fname_to_find" ] && continue
915 output="$path/$fname_to_find $output"
916 if [ -h "$path/$fname_to_find" ] ; then
917 output="`ReadAllLink $path/$fname_to_find` $output"
918 fi
919 done
920 if [ "$output" = "" ] ; then
921 return 1
922 fi
923 echo "$output"
924 return 0
925}
926
927
928# Called by TurnTgzIntoRdz, to make /tmp/mondo-restore.cfg
929MakeMondoConfigFile() {
930 local outfile use_lzo use_comp use_star
931 outfile=$1
932 > $outfile
933 [ "$TAPESIZE" ] && echo "media-size $TAPESIZE" >> $outfile
934 [ "$TAPEDEV" ] && echo "media-dev $TAPEDEV" >> $outfile
935 [ "$USBDEVICE" ] && echo "usb-dev $USBDEVICE" >> $outfile
936 [ "$FILES_IN_FILELIST" ] && echo "files-in-filelist $FILES_IN_FILELIST" >> $outfile
937 [ "$LAST_FILELIST_NUMBER" ] && echo "last-filelist-number $LAST_FILELIST_NUMBER" >> $outfile
938 [ "$INTERNAL_TAPE_BLOCK_SIZE" ] && echo "internal-tape-block-size $INTERNAL_TAPE_BLOCK_SIZE" >> $outfile
939 use_lzo=$USE_LZO; [ "$use_lzo" = "" ] && use_lzo="no"
940 use_gzip=$USE_GZIP; [ "$use_gzip" = "" ] && use_gzip="no"
941 use_comp=$USE_COMP; [ "$use_comp" = "" ] && use_comp="yes"
942 use_star=$USE_STAR; [ "$use_star" = "" ] && use_star="no"
943 echo "use-lzo $use_lzo" >> $outfile
944 echo "use-gzip $use_gzip" >> $outfile
945 echo "use-star $use_star" >> $outfile
946 echo "use-comp $use_comp" >> $outfile
947 echo "datestamp `date`" >> $outfile
948 [ "$ESTIMATED_TOTAL_NOOF_SLICES" ] && echo "total-slices $ESTIMATED_TOTAL_NOOF_SLICES" >> $outfile
949 AddFileToCfgIfExists $MINDI_TMP/NETFS-CLIENT-IPADDR netfs-client-ipaddr $outfile
950 AddFileToCfgIfExists $MINDI_TMP/NETFS-CLIENT-NETMASK netfs-client-netmask $outfile
951 AddFileToCfgIfExists $MINDI_TMP/NETFS-CLIENT-BROADCAST netfs-client-broadcast $outfile
952 AddFileToCfgIfExists $MINDI_TMP/NETFS-CLIENT-DEFGW netfs-client-defgw $outfile
953 AddFileToCfgIfExists $MINDI_TMP/NETFS-SERVER-MOUNT netfs-server-mount $outfile
954 AddFileToCfgIfExists $MINDI_TMP/NETFS-SERVER-PATH netfs-server-path $outfile
955 AddFileToCfgIfExists $MINDI_TMP/NETFS-DEV netfs-dev $outfile
956 AddFileToCfgIfExists $MINDI_TMP/NETFS-PROTO netfs-proto $outfile
957 AddFileToCfgIfExists $MINDI_TMP/NETFS-SERVER-IPADDR netfs-server-ipaddr $outfile
958 AddFileToCfgIfExists $MINDI_TMP/ISO-DEV iso-dev $outfile
959 AddFileToCfgIfExists $MINDI_TMP/ISO-MNT iso-mnt $outfile
960 AddFileToCfgIfExists $MINDI_TMP/ISO-PREFIX iso-prefix $outfile
961 AddFileToCfgIfExists $MINDI_TMP/ISODIR isodir $outfile
962 AddFileToCfgIfExists $MINDI_TMP/BOOTLOADER.DEVICE bootloader.device $outfile
963 AddFileToCfgIfExists $MINDI_TMP/BOOTLOADER.NAME bootloader.name $outfile
964 AddFileToCfgIfExists $MINDI_TMP/KEYMAP-LIVES-HERE keymap-lives-here $outfile
965 AddFileToCfgIfExists $MINDI_TMP/TAPEDEV-HAS-DATA-DISKS tapedev-has-data-disks $outfile
966 AddFileToCfgIfExists $MINDI_TMP/BACKUP-MEDIA-TYPE backup-media-type $outfile
967 AddFileToCfgIfExists $MINDI_TMP/DIFFERENTIAL differential $outfile
968 AddFileToCfgIfExists $MINDI_TMP/ACL acl $outfile
969 AddFileToCfgIfExists $MINDI_TMP/XATTR xattr $outfile
970 AddFileToCfgIfExists $MINDI_TMP/OBDR obdr $outfile
971}
972
973# Get PV's for an LV
974GetPVsForLV() {
975 if [ -n "$1" ]; then
976 vg=`$LVMCMD lvdisplay $1 2>/dev/null |awk '/VG Name/{print $NF;exit}'`
977 if [ -z "$vg" ]; then
978 return
979 fi
980 $LVMCMD vgdisplay -v $vg 2>/dev/null | awk '/PV Name/{print $NF}'
981 fi
982}
983
984
985MakeMountlist() {
986 local scratchdir mountlist all_partitions current_partition \
987partition_size partition_format outstring partition_number \
988partition_mountpt c_p lwm_info psz lvm_dev unofficial_outstring \
989absolute_partition old_partition_fmt current_lvolume uname skip
990
991 echo "Your raw fstab file looks like this:" >> $LOGFILE
992 echo "------------------------------------" >> $LOGFILE
993 cat $MY_FSTAB >> $LOGFILE
994 echo "Your mountlist will look like this:" | tee -a $LOGFILE
995 echo "-----------------------------------" >> $LOGFILE
996
997# scratchdir, mountlist(OUT)
998 scratchdir=$MINDI_TMP
999 mountlist=$1
1000
1001# NB: partition = device
1002# NB: mountpt = where the device is mounted
1003
1004 [ -e "$MY_FSTAB" ] || Die "Cannot find your fstab file ($MY_FSTAB)"
1005
1006 [ "$mountlist" != "" ] && rm -Rf $mountlist
1007 > $mountlist
1008 all_partitions=""
1009
1010 if [ $LVM != "false" ]; then
1011 echo -en "Analyzing LVM...\n"
1012 $MINDI_LIB/analyze-my-lvm > $MINDI_TMP/lvm.res
1013 if [ $? -ne 0 ]; then
1014 LVM="false"
1015 fi
1016 # Excluded LVs and GVs are not reported here
1017 all_partitions=`cat $MINDI_TMP/lvm.res | grep -F ">>>" | cut -d' ' -f2-`
1018 fi
1019 all_partitions="$all_partitions `ListAllPartitions 2> /dev/null`"
1020 for i in $IMAGE_DEVS ; do
1021 mount | grep -F "$i " > /dev/null 2> /dev/null && Die "Sorry, $i is already mounted! CANNOT DO IMAGEDEV on it if it's mounted."
1022 done
1023 [ "$IMAGE_DEVS" != "" ] && all_partitions="`echo "$all_partitions $IMAGE_DEVS" | tr ' ' '\n' | sort -u | tr '\n ' ' '`"
1024 printf " %-15s %-15s %-15s %-15s %-15s\n" DEVICE MOUNTPOINT FORMAT "SIZE (MB)" LABEL/UUID | tee -a $LOGFILE
1025 useless_dev="/dev/floppy /dev/fd0h1440 /dev/fd0H1440 /dev/cdrom /dev/cdrom/cdrom /dev/cdrom/cdrom1 /dev/cdrom/cdrom2 /dev/cdrom0 /dev/cdrom1 /dev/cdrom2 /dev/cdrom3 /dev/cdrw /dev/scd /dev/ram :/ /dev/sr0 /dev/sr1 /dev/cdrom1"
1026 for c_p in $all_partitions ; do
1027 # Skip evices, network FS, cisf
1028 [ "`echo "$useless_dev" | grep -F "$c_p"`" != "" ] || [ "`echo "$c_p" | grep ":"`" != "" ] || [ "`echo "$c_p" | grep -E "^//"`" != "" ]&& continue
1029 [ "`echo "$c_p" | grep -x "/dev/cdroms.*"`" ] && continue
1030 if [ -h "$c_p" ] && [ "`echo "$c_p" | grep -F "/dev/hd"`" = "" ] && [ "`echo "$c_p" | grep -F "/dev/sd"`" = "" ] && [ "`echo "$c_p" | grep -F "/dev/md"`" = "" ] ; then
1031 current_partition=`readlink -f $c_p`
1032 [ "`echo "$current_partition" | grep -F "/dev/mapper"`" != "" ] && current_partition="$c_p"
1033 [ "`echo "$useless_dev" | grep -F "$current_partition"`" ] && continue
1034 else
1035 current_partition="$c_p"
1036 fi
1037 [ "$c_p" = "none" ] && continue
1038 # Debian 5 does that
1039 [ "$c_p" = "proc" ] && continue
1040 redhat_label=""
1041 label=""
1042 uuid=""
1043 absolute_partition=`readlink -f $c_p`
1044 partition_mountpt=`tr -s '\t' ' ' < $MY_FSTAB | /bin/grep -w "$current_partition" | /bin/grep -vx " *#.*" | $AWK '{print $2}' | head -n1`
1045
1046 # Detects noauto partitions not mounted and exclude them
1047 partition_option=`tr -s '\t' ' ' < $MY_FSTAB | /bin/grep -w "$current_partition" | /bin/grep -vx " *#.*" | $AWK '{print $4}' | head -n1`
1048 if [ "`echo "$partition_option" | grep -i noauto`" != "" ] && [ "`mount | grep -w "$partition_mountpt"`" = "" ] ; then
1049 continue
1050 fi
1051
1052 # set default in case we dont't find it
1053 str_to_find_fmt_with=$current_partition
1054
1055 # This part tries to retrieve the correct device from a LABEL line in /etc/fstab
1056 # current_partition contains only first column of /etc/fstab
1057 if [ "`echo "$current_partition" | /bin/grep -i "LABEL="`" != "" ]; then
1058 redhat_label=`echo "$current_partition" | cut -d'=' -f2`
1059 actual_dev=""
1060
1061 # 1st try, findfs - the RHEL way of finding labels and their partitions
1062 if [ -x "/sbin/findfs" ]; then
1063 actual_dev=`/sbin/findfs LABEL=${redhat_label} 2> /dev/null`
1064 fi
1065
1066 # 2nd try : blkid, the good way for all LABEL except swap
1067 if [ "x$actual_dev" = "x" -a -x "/sbin/blkid" ]; then
1068 actual_dev=`/sbin/blkid | /bin/grep "$redhat_label" | grep LABEL= | cut -d':' -f1`
1069 # For LVM FS it will give a /dev/dm-# which should then be converted
1070 if [ $LVM = "v2" ] && [ "`echo $actual_dev | grep '/dev/dm'`" ]; then
1071 major=`/bin/ls -l $actual_dev | $AWK '{print $5}'`
1072 minor=`/bin/ls -l $actual_dev | $AWK '{print $6}'`
1073 for dev in `ls /dev/mapper/*`; do
1074 major1=`/bin/ls -l $dev | $AWK '{print $5}'`
1075 minor1=`/bin/ls -l $dev | $AWK '{print $6}'`
1076 if [ $major1 = $major ] && [ $minor1 = $minor ]; then
1077 actual_dev=`/bin/ls -l $dev | $AWK '{print $10}'`
1078 break
1079 fi
1080 done
1081 fi
1082 fi
1083
1084 # 3rd try, which works on a standard partition (ext2/3), but not on swap
1085 # For LVM gives a /dev/mapper entry
1086 if [ "x$actual_dev" = "x" ]; then
1087 actual_dev=`/bin/mount -l | /bin/grep "\[$redhat_label\]" | cut -d' ' -f1`
1088 fi
1089
1090 # 4th try, with vol_id
1091 # SWAP only
1092 if [ "x$actual_dev" = "x" -a -x "/sbin/vol_id" ]; then
1093 list_swaps=`cat /proc/swaps | /bin/grep "/dev/" | $AWK '{ print $1 }' `
1094 for dev_swap in $list_swaps ; do
1095 dev_exists=`/sbin/vol_id $dev_swap | /bin/grep "$redhat_label"`
1096 if [ "x$dev_exists" != "x" ]; then
1097 actual_dev=$dev_swap
1098 break;
1099 fi
1100 done
1101 fi
1102
1103 # 5th try : pre-formated LABEL. Format is : LABEL=SWAP-mydevice or SW-mydevice. e.g. : LABEL=SWAP-hda5
1104 # LABEL=SW-cciss/c0d0p3 (RDP)
1105 # or could be a string that isn't a complete device name (eg. LABEL =SWAP-cciss/c0d0p)
1106 # SWAP only
1107 if [ "x$actual_dev" = "x" -a _"`echo $current_partition | /bin/grep -iE 'LABEL=SWAP|LABEL=SW-'`" != _"" ]; then
1108 skip=""
1109 uname=$KERVERRUN
1110 [ "`echo $uname | grep "2.4.[0-9]"`" != "" ] && skip=16
1111 # 2.6.12 needs 16 (FC3)
1112 [ "`echo $uname | grep "2.6.[0-1]"`" != "" ] && skip=16
1113 # 2.6.19 and upper needs 1052
1114 [ "`echo $uname | grep "2.6.19"`" != "" ] && skip=1052
1115 [ "`echo $uname | grep "2.6.[2-9]"`" != "" ] && skip=1052
1116 if [ $skip = "" ]; then
1117 Die "Your kernel is too old. I don't know how to support labelled swap spaces with it"
1118 fi
1119 for try_dev in `tail +2 /proc/swaps | cut -d' ' -f1`
1120 do
1121 # Location of the swap label for kernel 2.6
1122 try_dev_label=`dd bs=1 count=16 skip=$skip if=$try_dev 2> /dev/null`
1123 if [ "x$try_dev_label" = "x$redhat_label" ]; then
1124 actual_dev=$try_dev
1125 fi
1126 done
1127 fi
1128
1129 # Check if one of all those tries has known success
1130 if [ "x$actual_dev" != "x" ]; then
1131 current_partition=$actual_dev
1132 else
1133 Die "Your system uses a LABEL partition ($current_partition), but you lack the tool to support it.\nPlease replace labels with their correct devices in $MY_FSTAB or install findfs|blkid|vol_id"
1134 fi
1135 # This part tries to retrieve the correct device from a UUID line in /etc/fstab
1136 # current_partition contains only first column of /etc/fstab
1137 elif [ "`echo "$current_partition" | /bin/grep -i "UUID="`" != "" ]; then
1138 uuid=`echo "$current_partition" | cut -d'=' -f2`
1139 actual_dev=""
1140
1141 # 1st try, findfs - the RHEL way of finding labels and their partitions
1142 if [ -x "/sbin/findfs" ]; then
1143 actual_dev=`/sbin/findfs UUID=${uuid} 2> /dev/null`
1144 fi
1145
1146 # 2nd try : blkid, the good way for all UUID except swap
1147 if [ "x$actual_dev" = "x" -a -x "/sbin/blkid" ]; then
1148 actual_dev=`/sbin/blkid | /bin/grep "$uuid" | grep UUID= | cut -d':' -f1`
1149 # For LVM FS it will give a /dev/dm-# which should then be converted
1150 if [ $LVM = "v2" ] && [ "`echo $actual_dev | grep '/dev/dm'`" ]; then
1151 major=`/bin/ls -l $actual_dev | $AWK '{print $5}'`
1152 minor=`/bin/ls -l $actual_dev | $AWK '{print $6}'`
1153 for dev in `ls /dev/mapper/*`; do
1154 major1=`/bin/ls -l $dev | $AWK '{print $5}'`
1155 minor1=`/bin/ls -l $dev | $AWK '{print $6}'`
1156 if [ $major1 = $major ] && [ $minor1 = $minor ]; then
1157 actual_dev=`/bin/ls -l $dev | $AWK '{print $10}'`
1158 break
1159 fi
1160 done
1161 fi
1162 fi
1163
1164 # 3th try, with vol_id
1165 if [ "x$actual_dev" = "x" -a -x "/sbin/vol_id" ]; then
1166 list_dev=`mount | /bin/grep -E '^/' | $AWK '{ print $1 }' `
1167 for dev in $list_dev ; do
1168 dev_exists=`/sbin/vol_id $dev | /bin/grep "$uuid"`
1169 if [ "x$dev_exists" != "x" ]; then
1170 actual_dev=$dev
1171 break;
1172 fi
1173 done
1174 fi
1175
1176 # 4th try, with dumpuuid (VMWare only ?) for swap
1177 if [ "x$actual_dev" = "x" -a -x "/sbin/dumpuuid" ]; then
1178 list_dev=`cat /proc/swaps | /bin/grep -E '^/' | $AWK '{ print $1 }' `
1179 for dev in $list_dev ; do
1180 dev_exists=`/sbin/dumpuuid $dev | /bin/grep "$uuid"`
1181 if [ "x$dev_exists" != "x" ]; then
1182 actual_dev=$dev
1183 break;
1184 fi
1185 done
1186 fi
1187
1188 # Check if one of all those tries has known success
1189 if [ "x$actual_dev" != "x" ]; then
1190 current_partition=$actual_dev
1191 else
1192 Die "Your system uses a UUID partition ($current_partition),\nbut you lack the tool to support it.\nPlease replace labels with their correct devices in $MY_FSTAB or\ninstall findfs|blkid|vol_id or\nrelabel the partition with the correct UUID if it's a swap partition."
1193 fi
1194 else
1195 # Needs to handle the recent OpenSUSE fancy way of dealing with fstab :-(
1196 # they use symlinks in fstab unrelated to what is shown in mount !
1197 if [ _"$partition_mountpt" = _"" ]; then
1198 # set default in case we dont't find it
1199 for tmpp in `tr -s '\t' ' ' < $MY_FSTAB | /bin/grep -Ev "^#" | $AWK '{print $1}'`; do
1200 if [ _"`readlink -f $tmpp`" = _"$current_partition" ]; then
1201 str_to_find_fmt_with=$tmpp
1202 partition_mountpt=`tr -s '\t' ' ' < $MY_FSTAB | /bin/grep -w "$tmpp" | /bin/grep -vx " *#.*" | $AWK '{print $2}' | head -n1`
1203 break;
1204 fi
1205 done
1206 fi
1207 fi
1208
1209 # Look for devices which have to be excluded
1210 skip=0
1211 if [ "$MINDI_EXCLUDE_DEVS" ] ; then
1212 l=""
1213 list_of_devices="`ReadAllLink $current_partition`"
1214 for d in $list_of_devices; do
1215 l="$l `$MINDI_LIB/analyze-my-lvm --givemapperofdm $d`"
1216 done
1217
1218 # Remove PVs from LVs excluded
1219 l="$l `GetPVsForLV $current_partition`"
1220
1221 # We want a single unique list
1222 list_of_devices="`echo $l | sort -u`"
1223
1224 for d in $MINDI_EXCLUDE_DEVS ; do
1225 if [ "`echo " $list_of_devices " | grep " $d"`" != "" ]; then
1226 echo "Excluding $current_partition from mountlist (due to excluded device $d)" >> $LOGFILE
1227 skip=1
1228 continue
1229 fi
1230 done
1231 fi
1232 if [ $skip -eq 1 ]; then
1233 continue
1234 fi
1235
1236 partition_format=`$AWK '$1 == "'"$str_to_find_fmt_with"'" {print $3}' $MY_FSTAB`
1237 # Some distributions such as Debian do not put /dev/<VG>/<LV> in fstab
1238 # for LVM partitions but use /dev/mapper/<VG>-<LV> instead. Fortunately,
1239 # the former is then a link to the latter, so we test whether
1240 # $current_partition is actually such a link or not and set
1241 # $current_lvolume accordingly. On Debian you may find more than one answer
1242 # so we remove the one corresponding to /dev/.static
1243 # On RedHat even if the device name is different (/dev/mapper/<VG><LV>), the
1244 # principle is the same and we need to find the link to it as well.
1245 # Note that $current_lvolume may well be an
1246 # ordinary device. It is just to make sure that we feed the right value
1247 # into any of the LVM tools if possible.
1248
1249 current_lvolume="$current_partition"
1250 if [ $LVM = "v2" ] && [ "`echo $current_partition | grep -E '^/dev/mapper/'`" ]; then
1251 # .static dir are a Debian specificity
1252 current_lvolume="`find /dev -lname "$current_partition" | grep -Ev '^/dev/\.static/'`"
1253 echo $current_lvolume | grep -q ' '
1254 if [ $? -eq 0 ]; then
1255 echo "WARNING: Multiple Logical Volumes found. Report to dev team" >> $LOGFILE
1256 fi
1257 # if it's not found, it may well be a real device such as a multipath one
1258 # /dev/mapper/mpath... Thus we revert the situation so that next test succeed
1259 if [ _"$current_lvolume" = _"" ]; then
1260 current_lvolume="$current_partition"
1261 fi
1262 fi
1263 #
1264 # End of LVM device style variation code (other than $current_lvolume).
1265
1266 if [ $LVM != "false" ] && [ "`$LVMCMD lvdisplay $current_lvolume 2> /dev/null`" ]; then
1267 # Size computed via LVM not directly
1268 partition_size="lvm"
1269 else
1270 partition_size=`SizeOfPartition $current_partition`
1271 [ "`echo "$current_partition" | grep "[0-9]"`" = "" ] && continue
1272 [ "`echo "$current_partition" | grep -c "^/"`" -ne "1" ] && continue
1273 if [ "$partition_format" = "swap" ] || [ "$partition_mountpt" = "swap" ] ; then
1274 partition_size=`grep -Fv "Priority" /proc/swaps | tr -s '\t' ' ' | grep -F "$current_partition" | $AWK '{print $3}'`
1275 [ "$partition_mountpt" != "swap" ] && partition_mountpt="swap"
1276 [ "$partition_format" != "swap" ] && partition_format="swap"
1277 if [ "$partition_size" = "" ] ; then
1278 totalsize=0
1279 items=0
1280 for i in `tr -s ' ' '\t' < /proc/swaps | grep -Fv "Filename" | cut -f3` ; do
1281 totalsize=$(($totalsize+$i))
1282 items=$(($items+1))
1283 done
1284 [ "$items" -gt "0" ] && partition_size=$(($totalsize/$items)) || partition_size=0
1285 [ "$partition_size" -lt "125000" ] && partition_size=125000
1286 echo "I'm guessing $c_p is $(($partition_size/1024))MB" >> $LOGFILE
1287 fi
1288 fi
1289 fi
1290 [ "$partition_mountpt" = "swap" ] && partition_format="swap"
1291 [ "$partition_format" = "swap" ] && partition_mountpt="swap"
1292 if [ "$partition_mountpt" = "" ] ; then
1293 if [ "`$LVMCMD pvdisplay $current_lvolume 2> /dev/null`" != "" ] ; then
1294 if [ "`grep -F device /etc/raidtab 2> /dev/null | grep -w $current_partition`" ] ; then
1295 partition_mountpt="raid"
1296 partition_format="raid"
1297 else
1298 partition_mountpt="lvm"
1299 partition_format="lvm"
1300 fi
1301 fi
1302 fi
1303 psz=$partition_size
1304 echo "Examining $current_partition (mount=$partition_mountpt fmt=$partition_format psz=$psz)" >> $LOGFILE
1305 [ "$psz" != "lvm" ] && psz=$(($psz/1024))
1306 if [ "`echo " $IMAGE_DEVS " | grep -F " $current_partition "`" != "" ] ; then
1307 partition_mountpt="image"
1308 old_partition_fmt=$partition_format
1309 partition_format="`$FDISK -l 2>> $LOGFILE | tr '*' ' ' | tr '+' ' ' | tr -s ' ' '\t' | grep -w "$absolute_partition" | cut -f5`"
1310 partition_size=$(($partition_size+1)); # just in case
1311 if [ "$partition_format" = "Linux" ] ; then
1312 echo "Are you imaging a mounted swap partition? Silly..." >> $LOGFILE
1313 echo "Reverting format from $old_partition_fmt to $partition_format" >> $LOGFILE
1314 partition_format=$old_partition_fmt
1315 fi
1316 fi
1317
1318 if [ ! "$partition_mountpt" ] ; then
1319 echo "------- $FDISK -l $qq log ------------" >> $LOGFILE
1320 for qq in "" `find /dev/ida/c*d* ! -name '*p*' 2> /dev/null`; do
1321 partition_format=`$FDISK -l $qq 2>> $LOGFILE | grep -w "$c_p" | sed 's/12/|/' | tr -s '\t' ' ' | cut -d'|' -f2 | cut -d' ' -f2-9`
1322 [ "$partition_format" ] && break
1323 done
1324 echo "------- $FDISK log end ------------" >> $LOGFILE
1325 if [ "$partition_format" = "Compaq diagnostics" ] ; then
1326 partition_format="compaq"
1327 elif [ ! "`grep -F device /etc/raidtab 2> /dev/null | grep -w $current_partition`" ] ; then
1328 LogIt "Unable to find mountpoint of $current_partition - ignoring"
1329 continue
1330 fi
1331 fi
1332 if [ "$redhat_label" ]; then
1333 label="$redhat_label"
1334 elif [ "$uuid" ]; then
1335 label="$uuid"
1336 fi
1337 partition_format="`echo "$partition_format" | cut -d',' -f1`"; # in case user has ext3,ext2 or something dumb like that
1338 [ "$partition_format" = "auto" ] && partition_format="`mount | grep -w $current_partition | $AWK '{print$5;}'`"; # in case user uses 'auto' (dumb!)
1339 unofficial_outstring=`printf "\t%-15s %-15s %-15s %7s %-15s\n" $current_partition $partition_mountpt $partition_format $psz "$label"`
1340 if [ "$current_partition" = "" ] ; then
1341 echo "Unknown partition (outstring = $unofficial_outstring)" >> $LOGFILE
1342 elif [ "$partition_mountpt" = "" ] && [ -f "/etc/raidtab" ] ; then
1343 if [ "`grep -F device /etc/raidtab 2>/dev/null | grep -F $current_partition`" ] ; then
1344 partition_mountpt=raid
1345 partition_format=raid
1346 printf "\t%-15s %-15s %-15s %7s %-15s\n" $current_partition $partition_mountpt $partition_format $psz "$label" | tee -a $LOGFILE
1347 printf "%s %s %s %s %s %s\n" $current_partition $partition_mountpt $partition_format $partition_size "$label" >> $mountlist
1348 else
1349 echo "Unknown mountpoint (outstring = $unofficial_outstring)" >> $LOGFILE
1350 fi
1351 elif [ "$partition_format" = "" ] ; then
1352 echo "Unknown format (outstring = $unofficial_outstring)" >> $LOGFILE
1353 elif [ "$partition_size" = "" ] ; then
1354 echo "Unknown partition size (outstring = $unofficial_outstring)" >> $LOGFILE
1355 elif [ "$partition_mountpt" = "/proc" ] || [ "$partition_mountpt" = "/dev/pts" ] ; then
1356 continue
1357 else
1358 if [ "$partition_format" = "dos" ] || [ "$partition_format" = "msdos" ] ; then
1359 echo "vfat should be used instead of dos/msdos as a partition format" >> $LOGFILE
1360 partition_format="vfat"
1361 fi
1362 printf "\t%-15s %-15s %-15s %7s %-15s\n" $current_partition $partition_mountpt $partition_format $psz "$label" | tee -a $LOGFILE
1363 printf "%s %s %s %s %s\n" $current_partition $partition_mountpt $partition_format $partition_size "$label" >> $mountlist
1364 fi
1365 done
1366}
1367
1368CheckMountlist() {
1369 local file=$1
1370 # Coherency verification
1371 ML01=`cat $file | wc -l`
1372 ML02=`grep -v ' lvm ' $file | wc -l`
1373 ML1=`$AWK '{print $1}' $file | sort -u | wc -l`
1374 ML2=`grep -v ' lvm ' $file | $AWK '{print $2}' | sort -u | wc -l`
1375 if [ "$ML01" -ne "$ML1" ]; then
1376 echo "--------------------------------------------" >> $LOGFILE
1377 echo "WARNING: Duplicate device entry in mountlist" | tee -a $LOGFILE
1378 echo "--------------------------------------------" >> $LOGFILE
1379 fi
1380 if [ "$ML02" -ne "$ML2" ]; then
1381 echo "--------------------------------------------" >> $LOGFILE
1382 echo "WARNING: Duplicate mountpoint entry in mountlist" | tee -a $LOGFILE
1383 echo "------------------------------------------------" >> $LOGFILE
1384 fi
1385}
1386
1387MakeSureNumberIsInteger() {
1388 res=`echo "$1" | tr -s '\-[0-9]' ' '`
1389 if [ "$res" != " " ] && [ "$res" != "" ] ; then
1390 echo "result = '$res'"
1391 Die "$1 should be an integer"
1392 fi
1393}
1394
1395
1396OfferToMakeBootableISO() {
1397 local i old_pwd
1398 if [ -z "$ISO_CMD" ]; then
1399 LogIt "Neither mkisofs nor genisoimage found, unable to make CD image"
1400 return
1401 fi
1402 if [ "$PROMPT_MAKE_CD_IMAGE" = "yes" ] && [ _"$MONDO_SHARE" = _"" ]; then
1403 echo -en "Shall I make a bootable CD image? (y/[n]) "
1404 read i
1405 [ "$i" != "y" ] && [ "$i" != "Y" ] && return 0
1406 fi
1407 rm -Rf $MINDI_TMP/iso
1408 mkdir -p $MINDI_TMP/iso/{images,archives}
1409 cp -f $MINDI_CACHE/{*.gz,*.img} $MINDI_TMP/iso/images 2>> $LOGFILE || LogIt "OfferToMakeBootableISO: Cannot copy $MINDI_CACHE/*.gz to $MINDI_TMP/iso/images"
1410 echo "mindi_lib = $MINDI_LIB" >> $LOGFILE
1411 for i in memdisk memtest.bin memtest.img ; do
1412 j=$MINDI_LIB/$i
1413 k=$MINDI_TMP/iso
1414 if [ -e "$j" ] ; then
1415 LogIt "Copying $j to $k"
1416 cp -f $j $k 2>> $LOGFILE || Die "Failed to copy $j to $k"
1417 cp -f $j $MINDI_TMP 2>> $LOGFILE || Die "Failed to copy $j to $MINDI_TMP"
1418 if [ _"$MONDO_SHARE" != _"" ]; then
1419 cp -f $j $MONDO_ROOT 2>> $LOGFILE || Die "Failed to copy $j to $MONDO_ROOT"
1420 fi
1421 fi
1422 done
1423 MakeMessageFile > $MINDI_TMP/iso/message.txt
1424 if [ $KERNEL_IS_XEN = "yes" ]; then
1425 cp $xenkernelpath $MINDI_TMP/iso/xen.gz 2>> $LOGFILE || Die "Cannot copy xen.gz ($xenkernelpath) to mindi tmp ($MINDI_TMP/iso/xen.gz). Did you run out of disk space?"
1426 cp $MBOOTC32 $MINDI_TMP/iso/mboot.c32 2>> $LOGFILE || Die "Cannot copy mboot.c32 ($MBOOTC32) to mindi tmp ($MINDI_TMP/iso/mboot.c32). Did you run out of disk space?"
1427 fi
1428 cp $kernelpath $MINDI_TMP/iso/vmlinuz 2>> $LOGFILE || Die "Cannot copy vmlinuz ($kernelpath) to mindi tmp ($MINDI_TMP/iso/vmlinuz). Did you run out of disk space?"
1429 cp $MINDI_TMP/initrd.img $MINDI_TMP/iso/initrd.img 2>> $LOGFILE || Die "Cannot copy initrd.img ($MINDI_TMP/initrd.img) to $MINDI_TMP/iso/initrd.img. Did you run out of disk space?"
1430
1431 if [ _"$MONDO_SHARE" != _"" ]; then
1432 if [ $KERNEL_IS_XEN = "yes" ]; then
1433 cp $xenkernelpath $MONDO_ROOT/xen.gz 2>> $LOGFILE || Die "Cannot copy xen.gz ($xenkernelpath) to mindi tmp ($MINDI_TMP/iso/xen.gz). Did you run out of disk space?"
1434 cp $MBOOTC32 $MONDO_ROOT/mboot.c32 2>> $LOGFILE || Die "Cannot copy mboot.c32 ($MBOOTC32) to mindi tmp ($MINDI_TMP/iso/mboot.c32). Did you run out of disk space?"
1435 fi
1436 cp $kernelpath $MONDO_ROOT/vmlinuz 2>> $LOGFILE || Die "Cannot copy vmlinuz ($kernelpath) to mondo root ($MONDO_ROOT/vmlinuz). Did you run out of disk space?"
1437 cp $MINDI_TMP/initrd.img $MONDO_ROOT/initrd.img 2>> $LOGFILE || Die "Cannot copy initrd.img ($MINDI_TMP/initrd.img) to $MONDO_ROOT/initrd.img. Did you run out of disk space?"
1438 fi
1439 MakeBootConfFile isolinux > $MINDI_TMP/iso/isolinux.cfg
1440 if [ "$ARCH" != "ia64" ] ; then
1441 cp $ISOLINUX $MINDI_TMP/iso/isolinux.bin 2>> $LOGFILE || Die "Cannot copy isolinux.bin ($ISOLINUX) to $MINDI_TMP/iso - did you run out of disk space?"
1442 fi
1443 old_pwd=`pwd`
1444 cd "$MINDI_TMP/iso"
1445 if [ "$ARCH" != "ia64" ] ; then
1446 if [ _"$MONDO_SHARE" != _"" ]; then
1447 cp -f $MINDI_TMP/iso/{isolinux.cfg,initrd.img,vmlinuz,isolinux.bin,message.txt} $MONDO_ROOT 2>> $LOGFILE || Die "Cannot copy core files to ramdisk for boot disk (under $MONDO_ROOT). Did you run out of disk space?"
1448 if [ $KERNEL_IS_XEN = "yes" ]; then
1449 cp -f $MINDI_TMP/iso/{mboot.c32,xen.gz} $MONDO_ROOT 2>> $LOGFILE || Die "Cannot copy Xen core files to ramdisk for boot disk (under $MONDO_ROOT). Did you run out of disk space?"
1450 fi
1451 cp -f $MONDO_SHARE/autorun $MINDI_TMP/iso 2>> $LOGFILE
1452 fi
1453 $ISO_CMD -U $ISO_OPT -V Mindi_Image -o $MINDI_CACHE/mindi.iso -b isolinux.bin -c boot.cat -no-emul-boot -boot-load-size 4 -boot-info-table . > /dev/null 2> $MINDI_TMP/mkisofs.log
1454 else
1455 $ISO_CMD $ISO_OPT -V Mindi_Image -o $MINDI_CACHE/mindi.iso -b images/mindi-bootroot.$BOOT_SIZE.img -c images/boot.cat -no-emul-boot . > /dev/null 2> $MINDI_TMP/mkisofs.log
1456 fi
1457 if [ "$?" -ne "0" ] ; then
1458 echo "----------- $ISO_CMD's errors --------------" >> $LOGFILE
1459 cat $MINDI_TMP/mkisofs.log >> $LOGFILE
1460 echo "$ISO_CMD returned the following errors:-"
1461 cat $MINDI_TMP/mkisofs.log
1462 LogIt "Failed to create ISO image."
1463 else
1464 echo "Created bootable ISO image at $MINDI_CACHE/mindi.iso" | tee -a $LOGFILE
1465 fi
1466 rm -f $MINDI_TMP/mkisofs.log
1467 cd "$old_pwd"
1468}
1469
1470
1471OfferToMakeBootableUSB() {
1472 local i
1473 if [ "$PROMPT_MAKE_USB_IMAGE" = "yes" ] && [ _"$MONDO_SHARE" = _"" ]; then
1474 echo -n "Shall I make a bootable USB device ? (y/[n]) "
1475 read i
1476 [ "$i" != "y" ] && [ "$i" != "Y" ] && return 0
1477 if [ "$USBDEVICE" = "" ]; then
1478 echo -en "Please enter the device name of your USB device (e.g. /dev/sda) : "
1479 read dev
1480 USBDEVICE=$dev
1481 fi
1482 echo "WARNING: This will erase all content on $USBDEVICE"
1483 echo -en "Are you sure you want to use $USBDEVICE (y/[n]) "
1484 read i
1485 [ "$i" != "y" ] && [ "$i" != "Y" ] && return 0
1486 fi
1487 rm -Rf $MINDI_TMP/usb
1488 mkdir -p $MINDI_TMP/usb
1489 USBPART="${USBDEVICE}1"
1490
1491 echo -en "Transforming $USBDEVICE in a Bootable device "
1492 echo -en "."
1493 echo "Transforming $USBDEVICE in a Bootable device" >> $LOGFILE
1494 echo "Checking $USBDEVICE" >> $LOGFILE
1495 $FDISK -l $USBDEVICE 2>> $LOGFILE 1>> $LOGFILE
1496 if [ $? -ne 0 ]; then
1497 echo "Unable to access $USBDEVICE" | tee -a $LOGFILE
1498 echo "Make sure your USB device is pluged in" | tee -a $LOGFILE
1499 exit -1
1500 fi
1501 echo -en "."
1502 echo "Unmounting $USBPART just in case" >> $LOGFILE
1503 umount $USBPART 2>> $LOGFILE 1>> $LOGFILE
1504 # If your key has no MBR it may cause an issue
1505 # Use dd if=mbr.bin of=$USBDEVICE or ms-sys -s $USBDEVICE
1506 echo "Preparing $USBDEVICE" >> $LOGFILE
1507 $FDISK $USBDEVICE 2>> $LOGFILE 1>> $LOGFILE << EOF
1508d
1509d
1510d
1511d
1512n
1513p
15141
1515
1516
1517t
1518b
1519a
15201
1521w
1522EOF
1523 if [ $? -ne 0 ]; then
1524 echo "Unable to create a vfat Filesystem on $USBDEVICE" | tee -a $LOGFILE
1525 echo "Make sure your USB device is pluged in" | tee -a $LOGFILE
1526 $FDISK -l $USBDEVICE 2>&1 | tee -a $LOGFILE
1527 MindiExit -1
1528 fi
1529 echo "The USB device $USBDEVICE now looks like this:" >> $LOGFILE
1530 $FDISK -l $USBDEVICE 2>&1 | tee -a $LOGFILE
1531 echo -en "."
1532 # Some distro do auto mount at that point (Ubuntu)
1533 echo "Unmounting $USBPART just in case again" >> $LOGFILE
1534 umount $USBPART 2>> $LOGFILE 1>> $LOGFILE
1535 echo -en "."
1536 echo "Creating a vfat filesystem on $USBPART" >> $LOGFILE
1537 mkdosfs -F 32 $USBPART 2>&1 >> $LOGFILE
1538 if [ $? -ne 0 ]; then
1539 echo "Unable to create a vfat filesystem on $USBPART" | tee -a $LOGFILE
1540 echo "Make sure your USB device is pluged in and partitioned ($USBPART must exist on it)" | tee -a $LOGFILE
1541 $FDISK -l $USBDEVICE 2>&1 | tee -a $LOGFILE
1542 MindiExit -1
1543 fi
1544 echo -en "."
1545 echo "Mounting $USBPART on $MINDI_TMP/usb" >> $LOGFILE
1546 mount $USBPART $MINDI_TMP/usb 2>> $LOGFILE
1547 if [ $? -ne 0 ]; then
1548 echo "Unable to mount $USBPART on $MINDI_TMP/usb" | tee -a $LOGFILE
1549 echo "Make sure your USB device is pluged in, partitioned and formated ($USBPART must exist on it)" | tee -a $LOGFILE
1550 $FDISK -l $USBDEVICE 2>&1 | tee -a $LOGFILE
1551 MindiExit -1
1552 fi
1553 echo -en "."
1554 mkdir -p $MINDI_TMP/usb/images
1555 cp -f $MINDI_CACHE/*.img $MINDI_CACHE/*.gz $MINDI_TMP/usb/images 2>> $LOGFILE || LogIt "OfferToMakeBootableUSB: Cannot copy $i to $MINDI_TMP/usb/images"
1556 echo -en "."
1557 echo "mindi_lib = $MINDI_LIB" >> $LOGFILE
1558 for i in memdisk memtest.bin memtest.img ; do
1559 j=$MINDI_LIB/$i
1560 k=$MINDI_TMP/usb
1561 if [ -e "$j" ] ; then
1562 LogIt "Copying $j to $k"
1563 cp -f $j $k 2>> $LOGFILE || Die "Failed to copy $j to $k"
1564 cp -f $j $MINDI_TMP 2>> $LOGFILE || Die "Failed to copy $j to $MINDI_TMP"
1565 fi
1566 done
1567 echo -en "."
1568 MakeMessageFile > $MINDI_TMP/usb/message.txt
1569 echo -en "."
1570 cp $kernelpath $MINDI_TMP/usb/vmlinuz 2>> $LOGFILE || Die "Cannot copy vmlinuz ($kernelpath) to mindi tmp ($MINDI_TMP/usb/vmlinuz). Did you run out of disk space?"
1571 echo -en "."
1572 cp $MINDI_TMP/initrd.img $MINDI_TMP/usb/initrd.img 2>> $LOGFILE
1573 echo -en "."
1574 MakeBootConfFile syslinux > $MINDI_TMP/usb/syslinux.cfg
1575 echo -en "."
1576 echo "----------- syslinux's conf --------------" |tee -a $LOGFILE
1577 cat $MINDI_TMP/usb/syslinux.cfg |tee -a $LOGFILE
1578 echo "------------------------------------------" |tee -a $LOGFILE
1579 umount $MINDI_TMP/usb
1580 if [ "$ARCH" != "ia64" ] ; then
1581 syslinux -s $USBPART 2>> $MINDI_TMP/syslinux.log
1582 if [ "$?" -ne "0" ] ; then
1583 echo "----------- syslinux's errors --------------" |tee -a $LOGFILE
1584 cat $MINDI_TMP/syslinux.log |tee -a $LOGFILE
1585 echo "------------------------------------------" |tee -a $LOGFILE
1586 LogIt "Failed to create USB image."
1587 else
1588 echo -e "$DONE"
1589 echo "Created bootable USB image on $USBDEVICE" >> $LOGFILE
1590 fi
1591 rm -f $MINDI_TMP/syslinux.log
1592 else
1593 echo "No USB boot support for ia64" | tee -a $LOGFILE
1594 MindiExit -1
1595 fi
1596}
1597
1598
1599MakeMessageFile() {
1600
1601 if [ -x "/bin/lsb_release" ]; then
1602 DESC=`/bin/lsb_release -d | cut -d: -f2 | sed "s/[ \t]*//"`
1603 elif [ -r /etc/issue.net ]; then
1604 DESC=`head -1 /etc/issue.net`
1605 elif [ -r /etc/issue ]; then
1606 DESC=`head -1 /etc/issue`
1607 elif [ -x "/usr/bin/pbdistrocheck" ]; then
1608 # For pb >= 0.9.8
1609 DESC=`/usr/bin/pbdistrocheck -s | cut -d, -f1-4`
1610 else
1611 DESC="Unknown desc"
1612 fi
1613 sed "s/ZZZZZ/$MINDI_VERSION/" $MINDI_LIB/msg-txt | sed "s/KKKKK/Kernel $KERVER/" | sed "s/AAAAA/on a $ARCH architecture/" | sed "s/TTTTT/`LC_TIME=C date`/" | sed "s/MMMMM/`hostname`/" | sed "s/DDDDD/$DESC/"
1614 if [ _"$MONDO_SHARE" != _"" ]; then
1615 if [ "$CDRECOVERY" != "yes" ] ; then
1616 if [ -e "$MINDI_TMP/NETFS-DEV" ] ; then
1617 echo -en "Press <enter> to continue.\n"
1618 elif [ ! "$MINDI_TMP" ] ; then
1619 echo -en "FYI, this is _not_ a Mondo Rescue CD.\n"
1620 if [ -e "$MINDI_LIB/memtest.img" ] ; then
1621 echo -en "Type 'memtest' <Enter> to test your PC's memory intensively.\nJust press <Enter> to go to the main test menu.\n"
1622 fi
1623 else
1624 echo -en "$BOOT_MEDIA_MESSAGE"
1625 fi
1626 else
1627 echo -en "\
1628To restore your disk to factory defaults, type 'RESTORE' <enter>.\n\
1629CAUTION: THIS WILL ERASE YOUR WHOLE DISK !!!\n"
1630 fi
1631 fi
1632 echo -en "\n\n\n"
1633}
1634
1635
1636MakeBootConfFile() {
1637 local options i ooo
1638 options=""
1639 # Type of boot file (elilo or syslinux/isolinux)
1640 type=$1
1641 if [ "$type" = "elilo" ]; then
1642 sep="="
1643 else
1644 sep=" "
1645 fi
1646
1647 # Generic header for conf file
1648 if [ "$type" != "elilo" ] ; then
1649 echo -en "prompt 1\ndisplay message.txt\n"
1650 else
1651 echo -en "prompt\n"
1652 fi
1653
1654 # Compute which default option to boot from
1655 if [ "$CDRECOVERY" = "yes" ] ; then
1656 echo -en "default${sep}RESTORE\n"
1657 # In case it's mondoarchive
1658 elif [ _"$MONDO_SHARE" != _"" ]; then
1659 if [ -e "$MINDI_TMP/NETFS-DEV" ] ; then
1660 echo -en "default${sep}iso\n"
1661 else
1662 echo -en "default${sep}interactive\n"
1663 fi
1664 else
1665 echo -en "default${sep}expert\n"
1666 fi
1667
1668 # Handle timeout
1669 if [ "$CDRECOVERY" != "yes" ] ; then
1670 echo -en "timeout${sep}300\n"
1671 else
1672 echo -en "timeout${sep}10000\n"
1673 fi
1674 echo -en "\n"
1675
1676 # prepare which labels will be generated
1677 if [ "$CDRECOVERY" = "yes" ] ; then
1678 options="RESTORE expert"
1679 else
1680 if [ _"$MONDO_SHARE" != _"" ]; then
1681 options="interactive expert compare iso nuke isonuke"
1682 else
1683 options="expert"
1684 fi
1685 fi
1686
1687 # Generate rest of conf file
1688 for i in $options ; do
1689 ooo=$i
1690 [ "$ooo" = "RESTORE" ] && ooo="nuke"
1691 if [ "$type" = "elilo" ]; then
1692 outstr="image=/vmlinuz\n\tlabel=$i\n\tinitrd=/initrd.img\n\troot=/dev/ram0 append=\" rw ramdisk_size=$ramdisk_size $ooo $MINDI_ADDITIONAL_BOOT_PARAMS \"\n"
1693 else
1694 ps="/"
1695 if [ "$type" = "syslinux" ]; then
1696 ps=""
1697 fi
1698 if [ $KERNEL_IS_XEN = "no" ]; then
1699 outstr="label $i\n\tkernel ${ps}vmlinuz\n\tappend initrd=${ps}initrd.img root=/dev/ram0 rw ramdisk_size=$ramdisk_size ${ooo} $MINDI_ADDITIONAL_BOOT_PARAMS\n"
1700 else
1701 outstr="label $i\n\tkernel ${ps}mboot.c32\n\tappend ${ps}xen.gz --- ${ps}vmlinuz root=/dev/ram0 rw ramdisk_size=$ramdisk_size ${ooo} $MINDI_ADDITIONAL_BOOT_PARAMS --- ${ps}initrd.img\n"
1702 fi
1703 fi
1704 echo -en "$outstr"
1705 done
1706 if [ -e "$MINDI_LIB/memtest.img" ] ; then
1707 if [ "$type" = "elilo" ]; then
1708 echo -en "image=/memtest.bin\n\tlabel=memtest\n"
1709 echo -en "image=/memdisk\n\tlabel=memdisk\nappend=\"initrd=memtest.img\"\n"
1710 else
1711 ps="/"
1712 if [ "$type" = "syslinux" ]; then
1713 ps=""
1714 fi
1715 echo -en "label memtest\n\tkernel ${ps}memtest.bin\n"
1716 echo -en "label memdisk\n\tkernel ${ps}memdisk\nappend initrd=${ps}memtest.img\n"
1717 fi
1718 fi
1719}
1720
1721
1722PrepareBootDiskImage_LILO() {
1723 local imagesdir dev imagefile mountpoint fname i kernelpath cfg_file testpath options retval outstr old_pwd ooo max_kernel_size liloconf
1724 imagesdir=$MINDI_CACHE
1725 kernelpath=$1
1726
1727 retval=0
1728 [ ! -e "$kernelpath" ] && Die "PBDI lilo - cannot find $kernelpath kernel"
1729 echo -en "Making "$BOOT_SIZE"KB boot disk..."
1730 TurnTgzIntoRdz $MINDI_LIB/rootfs $MINDI_TMP/initrd.img `du -sk $kernelpath | cut -f1` || Die "Could not turn rootfs into initrd.img; are you SURE your kernel supports loopfs?"
1731 echo -en "..."
1732 imagefile=$imagesdir/mindi-bootroot.$BOOT_SIZE.img
1733 mountpoint=$MINDI_TMP/mountpoint.$$
1734 mkdir -p $mountpoint
1735 dd if=/dev/zero of=$imagefile bs=1k count=$BOOT_SIZE &> /dev/null || Die "Cannot dd blank file"
1736 mkdosfs $imagefile >> $LOGFILE 2>> $LOGFILE
1737 mount -t vfat -o loop $imagefile $mountpoint || LogIt "Cannot mount (PBDI)"
1738 # copy Mindi's skeleton fs & lilo/syslinux/whatever stuff into it
1739 mkdir -p $mountpoint/etc
1740 liloconf=$mountpoint/elilo.conf
1741
1742 MakeBootConfFile elilo > $liloconf
1743
1744 # Copy it so that CD-ROM menu entry is satisfied
1745 mountefi=0
1746 df -T | grep /boot/efi | grep -q vfat
1747 if [ $? -ne 0 ]; then
1748 mount /boot/efi
1749 if [ $? -ne 0 ]; then
1750 echo "You have to mount your EFI partition when using mindi"
1751 MindiExit -1
1752 fi
1753 mountefi=1
1754 fi
1755 el=`find /boot/efi -name elilo.efi`
1756 cp $el $mountpoint
1757 cp $liloconf $mountpoint
1758 if [ $mountefi -eq 1 ]; then
1759 umount /boot/efi 2>&1 > /dev/null
1760 fi
1761
1762 echo "Copying $MINDI_TMP/initrd.img to $mountpoint..." >> $LOGFILE
1763 cp -f $MINDI_TMP/initrd.img $mountpoint 2>> $LOGFILE
1764 if [ "$?" -ne "0" ] ; then
1765 LogIt "Failed to copy $MINDI_TMP/initrd.img to $mountpoint"
1766 cat $MINDI_TMP/mtpt.$$ >> $LOGFILE
1767 LogIt "Please unload some of your modules and try again."
1768 rm -f $MINDI_TMP/mtpt.$$
1769 LogIt "Cannot incorporate initrd.img in bootdisk (kernel / modules too big?)"
1770 retval=$(($retval+1))
1771 fi
1772 MakeMessageFile > $mountpoint/message.txt
1773
1774 mkdir -p $mountpoint/tmp
1775 if [ -f "$MINDI_TMP/mondo-restore.cfg" ]; then
1776 cp -f $MINDI_TMP/mondo-restore.cfg $mountpoint/tmp
1777 fi
1778
1779 # copy the kernel across
1780 [ "$mountpoint" != "" ] && rm -Rf $mountpoint/lost+found
1781 dd if=/dev/zero of=$mountpoint/zero bs=1k count=16 &> /dev/null
1782 free_space=`df -k -P $mountpoint | tail -n1 | tr -s ' ' '\t' | cut -f4`
1783 cp -f $kernelpath $mountpoint/vmlinuz > /dev/null 2>> $LOGFILE
1784 if [ "$?" -ne "0" ] ; then
1785 echo "Files at mountpoint ($mountpoint) :-" >> $LOGFILE
1786 du -sk $mountpoint/* >> $LOGFILE
1787 echo "--- end of list of files ---" >> $LOGFILE
1788 echo -en "Kernel size = `du -sk $kernelpath | cut -f1` K\nRamdisk free = $free_space K\n" >> $LOGFILE
1789 [ "$mountpoint" != "" ] && rm -f $mountpoint/vmlinuz
1790 cd "$old_pwd"
1791 umount $mountpoint || Die "Cannot unmount mountpoint ($mountpoint)"
1792 rmdir $mountpoint || LogIt "Cannot rmdir (PBDI)"
1793 # losetup /dev/loop0 -d
1794 [ "$imagefile" != "" ] && rm -f $imagefile
1795 Die "Sorry, your kernel is too big for your image"
1796 return 0
1797 fi
1798 max_kernel_size=$(($free_space+`du -sk $kernelpath | cut -f1`))
1799 echo "Free space left on image = $free_space KB" >> $LOGFILE
1800 echo "Max kernel size on $BOOT_SIZE KB image (est'd) = $max_kernel_size K" >> $LOGFILE
1801 # make it bootable
1802 [ "$mountpoint" != "" ] && rm -f $mountpoint/zero
1803 [ -e "$MINDI_LIB/memdisk" ] && cp -f $MINDI_LIB/memdisk $mountpoint 2>> $LOGFILE
1804 if [ "$KERN_DISK_MADE" ] ; then
1805 echo "Not running LILO. It's not that kind of disk." >> $LOGFILE
1806 fi
1807
1808 cp `dirname $kernelpath`/*.efi $mountpoint 2>> $LOGFILE
1809 umount $mountpoint || Die "Cannot unmount mountpoint ($mountpoint)"
1810 echo -en "..."
1811 rmdir $mountpoint || LogIt "Cannot rmdir (PBDI)"
1812 if [ "$retval" -eq "0" ] ; then
1813 echo -en "...$DONE\n"
1814 if [ "$KERN_DISK_MADE" ] ; then
1815 LogIt "$BOOT_SIZE KB boot disks were created OK\n"
1816 fi
1817 else
1818 echo -en "...failed\n"
1819 LogIt $BOOT_SIZE"KB boot disk was NOT created\n"
1820 [ "$imagefile" != "" ] && rm -f $imagefile
1821 fi
1822 [ "$retval" -ne "0" ] && LogIt "PrepareBootDiskImage() is returning nonzero"
1823 return $retval
1824}
1825
1826
1827PrepareBootDiskImage_ISOLINUX() {
1828 local imagesdir dev imagefile mountpoint fname i kernelpath cfg_file testpath options retval outstr old_pwd ooo max_kernel_size bootimage
1829 imagesdir=$MINDI_CACHE
1830 kernelpath=$1
1831 do_boot_root_thingy=""
1832 local retval old_pwd
1833 retval=0
1834
1835 [ ! -e "$kernelpath" ] && Die "PBDI isolinux - cannot find $kernelpath kernel"
1836 echo -en "Making "$BOOT_SIZE"KB boot disk..."
1837 TurnTgzIntoRdz $MINDI_LIB/rootfs $MINDI_TMP/initrd.img `du -sk $kernelpath | cut -f1` || Die "Could not turn rootfs into initrd.img; are you SURE your kernel supports loopfs?"
1838 echo -en "..."
1839 imagefile=$MINDI_TMP/mindi-bootroot.$BOOT_SIZE.img
1840 mountpoint=$MINDI_TMP/mountpoint.$$
1841 mkdir -p $mountpoint
1842 dd if=/dev/zero of=$imagefile bs=1k count=$BOOT_SIZE &> /dev/null || Die "Cannot dd blank file"
1843 echo "Creating vfat filesystem on $imagefile" >> $LOGFILE
1844 mkfs.vfat $imagefile >> $LOGFILE 2>> $LOGFILE
1845 # syslinux should be run on a local file (doen't work through NFS Cf: #297)
1846 syslinux $imagefile >> $LOGFILE 2>> $LOGFILE
1847
1848 # Only move it now to its final destination and use it now
1849 mv $imagefile $imagesdir
1850 imagefile=$imagesdir/mindi-bootroot.$BOOT_SIZE.img
1851
1852 mount -t vfat -o loop $imagefile $mountpoint || LogIt "Cannot mount (PBDI)"
1853
1854 # copy Mindi's skeleton fs & lilo/syslinux/whatever stuff into it
1855 MakeMessageFile > $mountpoint/message.txt
1856 MakeBootConfFile isolinux > $mountpoint/syslinux.cfg
1857 echo "Copying $MINDI_TMP/initrd.img to $mountpoint/initrd.img..." >> $LOGFILE
1858 cp -f $MINDI_TMP/initrd.img $mountpoint/initrd.img 2>> $LOGFILE
1859 if [ "$?" -ne "0" ] ; then
1860 LogIt "Failed to copy $MINDI_TMP/initrd.img to $mountpoint"
1861 cat $MINDI_TMP/mtpt.$$ >> $LOGFILE
1862 LogIt "Please unload some of your modules and try again."
1863 rm -f $MINDI_TMP/mtpt.$$
1864 LogIt "Cannot incorporate initrd.img in bootdisk (kernel / modules too big?)"
1865 retval=$(($retval+1))
1866 fi
1867
1868 mkdir -p $mountpoint/tmp
1869 if [ -f "$MINDI_TMP/mondo-restore.cfg" ]; then
1870 cp -f $MINDI_TMP/mondo-restore.cfg $mountpoint/tmp
1871 fi
1872
1873 # copy the kernel across
1874 [ "$mountpoint" != "" ] && rm -Rf $mountpoint/lost+found
1875 dd if=/dev/zero of=$mountpoint/zero bs=1k count=16 &> /dev/null
1876 free_space=`df -k -P $mountpoint | tail -n1 | tr -s ' ' '\t' | cut -f4`
1877
1878 retval=0
1879 cp -f $kernelpath $mountpoint/vmlinuz &> /dev/null
1880 retval=$?
1881 if [ $KERNEL_IS_XEN = "yes" ]; then
1882 cp -f $xenkernelpath $mountpoint/xenkernel &> /dev/null
1883 let retval+=$?
1884 fi
1885
1886 if [ "$retval" -ne "0" ] ; then
1887 echo "Files at mountpoint ($mountpoint) :-" >> $LOGFILE
1888 du -sk $mountpoint/* >> $LOGFILE
1889 echo "--- end of list of files ---" >> $LOGFILE
1890 echo -en "Kernel size = `du -sk $kernelpath | cut -f1` K\nRamdisk free = $free_space K\n" >> $LOGFILE
1891 [ "$mountpoint" != "" ] && rm -f $mountpoint/vmlinuz
1892 cd "$old_pwd"
1893 umount $mountpoint || Die "Cannot unmount mountpoint ($mountpoint)"
1894 rmdir $mountpoint || LogIt "Cannot rmdir (PBDI)"
1895
1896 Die "Sorry, your kernel is too big for your image"
1897 return 0
1898 fi
1899 max_kernel_size=$(($free_space+`du -sk $kernelpath | cut -f1`))
1900 echo "Free space left on image = $free_space KB" >> $LOGFILE
1901 echo "Max kernel size on $BOOT_SIZE KB image (est'd) = $max_kernel_size K" >> $LOGFILE
1902
1903 # make it bootable
1904 [ "$mountpoint" != "" ] && rm -f $mountpoint/zero
1905 mkdir -p $mountpoint/etc
1906 [ -e "$MINDI_LIB/memdisk" ] && cp -f $MINDI_LIB/memdisk $mountpoint 2>> $LOGFILE
1907 umount $mountpoint || Die "Cannot unmount mountpoint ($mountpoint)"
1908 echo -en "..."
1909 rmdir $mountpoint || LogIt "Cannot rmdir (PBDI)"
1910
1911 if [ "$retval" -eq "0" ] ; then
1912 echo -en "...$DONE\n"
1913 if [ "$KERN_DISK_MADE" ] ; then
1914 [ "$imagefile" != "" ] && rm -f $imagefile
1915 LogIt "$BOOT_SIZE KB boot disks were created OK\n"
1916 fi
1917 else
1918 echo -en "...failed\n"
1919 LogIt $BOOT_SIZE"KB boot disk was NOT created\n"
1920 [ "$imagefile" != "" ] && rm -f $imagefile
1921 fi
1922 [ "$retval" -ne "0" ] && LogIt "PrepareBootDiskImage() is returning nonzero"
1923 return $retval
1924}
1925
1926
1927ParseModprobeForIncludes() {
1928local MODPROBE_CONF mpincfile includes include
1929
1930MODPROBE_CONF=/etc/modprobe.conf
1931mpincfile=$1
1932touch $mpincfile
1933if [ -a $MODPROBE_CONF ]; then
1934 includes=$($AWK '/^[ \t]*include[ \t]+/ {if(NF>=2){print $2}}' $MODPROBE_CONF|sort -u)
1935 if [ -n "$includes" ]; then
1936 for include in $includes
1937 do
1938 if [ -a "$include" ]; then
1939 echo $include >> $mpincfile
1940 fi
1941 done
1942 fi
1943fi
1944}
1945
1946
1947PrepareDataDiskImages() {
1948 local needlist bigdir diskdir imagesdir res i j k old_pwd lines lfiles includefile
1949
1950 imagesdir=$MINDI_CACHE
1951 rm -f $imagesdir/mindi.iso
1952 needlist=$MINDI_TMP/what-we-need.txt
1953 bigdir=$MINDI_TMP/bigdir
1954 mkdir -p $bigdir/usr/bin
1955 mkdir -p $bigdir/usr/sbin
1956 includefile=$MINDI_TMP/$$.includefile.txt
1957
1958 if [ -e "$DEPLIST_FILE" ]; then
1959 lfiles="$DEPLIST_FILE $DEPLIST_DIR/*"
1960 else
1961 lfiles="$DEPLIST_DIR/*"
1962 fi
1963 lines=`grep -vx " *#.*" $lfiles | grep -vx "" | wc -l`
1964 ParseModprobeForIncludes $includefile
1965 lines=$(($lines+`cat $includefile | wc -l`))
1966 cat $lfiles $includefile | GenerateGiantDependencyList $needlist $lines
1967 res=$?
1968 rm -f $includefile
1969 if [ "$YOUR_KERNEL_SUCKS" ]; then
1970 pwd=`pwd`
1971 cd "$MINDI_TMP"
1972 for i in `ListKernelModulePaths | HackPathsToFailsafe` ; do
1973 tar cf - ./$i 2>> $MINDI_TMP/$$.log | (cd "$bigdir" ; tar xf -) || Die "PDDI can't copy $i->$bigdir" $MINDI_TMP/$$.log
1974 done
1975 for i in $EXTRA_MODS ; do
1976 j=`find lib/modules/$FAILSAFE_KVER -name $i.*o.gz 2> /dev/null`
1977 [ ! "$j" ] && echo "WARNING - cannot find failsafe module $i.o.gz" >> $LOGFILE
1978 for k in $j ; do
1979 tar cf - $k 2>> $MINDI_TMP/$$.log | (cd "$bigdir" ; tar xf -) || LogIt "ERROR on module $k" $MINDI_TMP/$$.log
1980 echo "Added failsafe module $k to ramdisk" >> $LOGFILE
1981 done
1982 done
1983 cd "$pwd"
1984 else
1985 ListKernelModulePaths >> $needlist
1986 fi
1987 if [ "$res" -ne "0" ] ; then
1988 Die "You have $res files present in dependency list\nbut absent from filesystem."
1989 fi
1990 FindAndAddUserKeyboardMappingFile
1991 mkdir -p $bigdir/tmp
1992 if [ _"$MONDO_SHARE" != _"" ]; then
1993 MakeMondoConfigFile $MINDI_TMP/mondo-restore.cfg
1994 cp -f $MINDI_TMP/mondo-restore.cfg $bigdir/tmp &> /dev/null
1995 fi
1996 [ -d "/mnt/.boot.d" ] && echo "Oh Jebus" > $bigdir/tmp/DUMBASS-GENTOO
1997 DropOptimizedLibraries $needlist $bigdir
1998 echo -en "Assembling dependency files"
1999 CopyDependenciesToDirectory < $needlist $bigdir
2000
2001 # also copy io.sys and msdos.sys, if we can find them
2002 for i in `mount | cut -d' ' -f3` ; do
2003 for j in io.sys msdos.sys ; do
2004 [ -e "$i/$j" ] && cp -f $i/$j $bigdir 2>> $LOGFILE
2005 done
2006 done
2007
2008 # master boot record, too
2009 i=`cat $MINDI_TMP/BOOTLOADER.DEVICE 2> /dev/null`
2010 if [ "$i" ] ; then
2011 LogIt "Backing up $i's MBR"
2012 dd if=$i of=$bigdir/BOOTLOADER.MBR bs=446 count=1 >> $LOGFILE 2>> $LOGFILE
2013 sleep 1
2014 sync
2015 j=$i
2016 [ -h "$j" ] && j=`readlink -f $j`
2017 LogIt "Creating /dev/boot_device ($j)"
2018 mkdir -p $bigdir/dev
2019 cp -pRdf $j $bigdir/dev/boot_device 2>> $LOGFILE || Die "Unable to create /dev/boot_device on ramdisk"
2020 fi
2021
2022 old_pwd=`pwd`
2023 cd "$bigdir"
2024
2025 # Get terminfo content
2026 ti="usr/share/terminfo/l"
2027 if [ -d /$ti ]; then
2028 mkdir -p $ti
2029 cp -Rdf /$ti/* $ti 2>> $LOGFILE || LogIt "WARNING - error occurred while copying terminfo"
2030 fi
2031 if [ -e "$MONDO_SHARE/restore-scripts" ]; then
2032 cp -Rdf $MONDO_SHARE/restore-scripts/* . 2>> $LOGFILE
2033 [ "$?" -ne "0" ] && [ _"$MONDO_SHARE" != _"" ] && Die "Cannot find/install $MONDO_SHARE/restore-scripts"
2034 fi
2035 if [ -d "/lib/dev-state" ]; then
2036 tar cf - -C / ./lib/dev-state 2>> $MINDI_TMP/$$.log | tar xf - || LogIt "Unable to handle /lib/dev-state" $MINDI_TMP/$$.log
2037 fi
2038 cd "$old_pwd"
2039 echo -e "$DONE"
2040 TOTAL_BIGDIR_SIZE=`du -sk $bigdir | cut -f1`
2041 MakeMountlist $MINDI_TMP/mountlist.txt
2042 CheckMountlist $MINDI_TMP/mountlist.txt
2043 mkdir -p $bigdir/tmp
2044 cp -f $MINDI_TMP/mountlist.txt $bigdir/tmp/mountlist.txt 2>> $LOGFILE || Die "Cannot copy mountlist.txt from $MINDI_TMP to data disk"
2045 if [ _"$MONDO_SHARE" != _"" ]; then
2046 cp -f $bigdir/tmp/mountlist.txt $MINDI_TMP/. 2>> $LOGFILE
2047 fi
2048 if [ $LVM != "false" ]; then
2049 $MINDI_LIB/analyze-my-lvm > $bigdir/tmp/i-want-my-lvm
2050 if [ "$?" -ne "0" ]; then
2051 LVM="false"
2052 rm -f $bigdir/tmp/i-want-my-lvm
2053 else
2054 echo "Your i-want-my-lvm file content is:" >> $LOGFILE
2055 echo "-----------------------------------" >> $LOGFILE
2056 cat $bigdir/tmp/i-want-my-lvm >> $LOGFILE
2057 echo "-----------------------------------" >> $LOGFILE
2058 fi
2059 fi
2060 echo "Your mountlist.txt file content is:" >> $LOGFILE
2061 echo "-----------------------------------" >> $LOGFILE
2062 cat $bigdir/tmp/mountlist.txt >> $LOGFILE
2063 echo "-----------------------------------" >> $LOGFILE
2064
2065 echo -en "$FILES_IN_FILELIST" > $bigdir/FILES-IN-FILELIST 2>> $LOGFILE
2066 echo -en "$LAST_FILELIST_NUMBER" > $bigdir/LAST-FILELIST-NUMBER 2>> $LOGFILE
2067 if [ _"$MONDO_SHARE" != _"" ]; then
2068 for q in filelist.full.gz biggielist.txt ; do
2069 [ ! -e "$MINDI_TMP/$q" ] && Die "Cannot find $MINDI_TMP/$q"
2070 cp -pRdf $MINDI_TMP/$q $bigdir/tmp 2>> $LOGFILE
2071 done
2072 fi
2073
2074 echo -en "Tarring and zipping the data content..."
2075 size_of_all_tools=`du -sk $bigdir | cut -f1`
2076 (cd "$bigdir" ; tar -b 4096 -cf - . 2>> $MINDI_TMP/$$.log | gzip -9 > $imagesdir/all.tar.gz || LogIt "Problem creating all.tar.gz" $MINDI_TMP/$$.log)
2077 du -sk $imagesdir/*gz >> $LOGFILE
2078 echo -e "$DONE"
2079
2080 FRIENDLY_OUTSTRING="Boot and data disk images were created."
2081 rm -rf $bigdir
2082 rm -f $needlist
2083}
2084
2085
2086ProcessLDD() {
2087 local incoming f d nd bd bnd
2088 read incoming
2089 while [ "$incoming" != "" ]; do
2090 # We take the full path name of the dyn. lib. we want
2091 incoming=`echo "$incoming" | $AWK '{if (match($1,/\//)) {print $1} else {if (match($3,/\//)) print $3} fi}'`
2092 for f in $incoming ; do
2093 # echo modified file name if one of the parent dir is a link
2094 # by replacing the original dirname by the destination of the link
2095 d="`dirname $f`"
2096 found="false"
2097 while [ "$d" != "/" ]; do
2098 if [ -h "$d" ]; then
2099 nd=`readlink -f $d`
2100 bd=`basename $d`
2101 bnd=`basename $nd`
2102 f=`echo $f | sed "s~/$bd/~/$bnd/~"`
2103 echo $d
2104 fi
2105 d="`dirname $d`"
2106 done
2107
2108 echo "$f"
2109 echo "`ReadAllLink $f`"
2110 done
2111 read incoming
2112 done
2113}
2114
2115
2116Prompt() {
2117 echo -en "$1"
2118 read line
2119}
2120
2121
2122ReadLine() {
2123 local i incoming
2124 read incoming
2125 i=0
2126 while [ "$i" -le "32" ] && [ "$incoming" = "" ] ; do
2127 i=$(($i+1))
2128 read incoming
2129 done
2130 echo "$incoming"
2131}
2132
2133
2134SizeOfPartition() {
2135 local devpath drive res stub
2136 device=$1
2137 if [ "`echo "$device" | grep -F "/dev/md"`" != "" ] ; then
2138 res=`SizeOfRaidPartition $device`
2139 [ "$res" = "" ] && Die "Cannot find $device's size - is your /etc/raidtab sane?"
2140 echo "$res"
2141 return 0
2142 fi
2143 # patch from Bill <bill@iwizard.biz> - 2003/08/25
2144 res=`$FDISK -s $device 2>> $LOGFILE`
2145 # end patch
2146 # take only the first in case of multiple mount (cifs, nfs, ...)
2147 [ "$res" = "" ] && res=`df -k -P -x supermount | tr -s '\t' ' ' | grep -F "$device " | cut -d' ' -f2 | head -1`
2148 [ "$res" = "" ] && res="-1"
2149 echo $res
2150 return 0
2151}
2152
2153
2154SizeOfRaidPartition() {
2155 local real_dev smallest_size silly tmp
2156
2157 silly=999999999
2158 smallest_size=$silly
2159
2160 for real_dev in `GetRaidDevMembers $1` ; do
2161 tmp=`SizeOfPartition $real_dev`
2162 [ "$tmp" -lt "$smallest_size" ] && smallest_size=$tmp
2163 done
2164
2165 if [ "$smallest_size" = "$silly" ] ; then
2166 echo "-1"
2167 return 1
2168 else
2169 echo "$smallest_size"
2170 return 0
2171 fi
2172}
2173
2174
2175StripComments()
2176{
2177 local tempfile
2178
2179 tempfile=$MINDI_TMP/$$.strip.txt
2180 cp -f $1 $tempfile 2>> $LOGFILE
2181 $AWK '{if (substr($0,0,1)!="#" || substr($0,0,3)=="#!/") {print $0;};}' $tempfile > $1
2182 rm -f $tempfile
2183 echo "Stripped comments from $2" >> $LOGFILE
2184}
2185
2186
2187
2188StripExecutable()
2189{
2190 local tmpfile
2191
2192 tmpfile=$MINDI_TMP/stripped.$$.dat
2193 [ -d "$1" ] || [ -h "$1" ] && return
2194 cp -f $1 $tmpfile 2>> $LOGFILE
2195 strip $tmpfile 2> /dev/null
2196 if [ "$?" -eq "0" ] ; then
2197 cp -f $tmpfile $1 2>> $LOGFILE
2198 echo "Stripped binary $2" >> $LOGFILE
2199 fi
2200 rm -f $tmpfile
2201}
2202
2203KernelVer() {
2204 local fkern_ver fname
2205
2206 fname=$1
2207 file $fname | grep -q gzip
2208 if [ "$?" -eq "0" ] ; then
2209 # Used by ia64
2210 fkern_ver=`gzip -cd $fname | strings 2> /dev/null | grep "[2-9]+*[.][0-9]+*[.][0-9]+*[^\@]*@"`
2211 else
2212 fkern_ver=`strings $fname 2> /dev/null | grep "[2-9]+*[.][0-9]+*[.][0-9]+*[^\@]*@"`
2213 fi
2214 echo "$fkern_ver"
2215}
2216
2217
2218TryToFindKernelPath() {
2219 local fname incoming res fkern_ver we_want_version possible_kernels noof_kernels kernelpath kdate duff_kernels
2220
2221 we_want_version=$KERVERRUN
2222 possible_kernels=""
2223 duff_kernels=""
2224
2225 if [ "$ARCH" = "ia64" ] ; then
2226 root="/boot/efi/efi"
2227 else
2228 root="/"
2229 fi
2230 # See if we're booted from a Xen kernel
2231 if [ -d /proc/sys/xen ]; then
2232 # It's a Xen kernel
2233 KERNEL_IS_XEN="yes"
2234 LogIt "It's a Xen kernel..."
2235 fi
2236
2237 for fname in `find $root -maxdepth 2 -type f | grep -Ei 'lin|kern|xen' | grep -Ev '^/proc/|^/net/'` ; do
2238 [ ! -e "$fname" ] && continue
2239 [ "$fname" = "/boot/vmlinuz.shipped" ] && [ -f "/boot/vmlinuz" ] && continue; # ignore SuSE's extra kernel
2240 fkern_ver=`KernelVer $fname`
2241 [ "$fkern_ver" = "" ] && continue
2242 [ "`echo "$fkern_ver" |grep -F "$we_want_version "`" = "" ] && continue
2243 [ -f "$fname" ] || continue
2244 [ -h "$fname" ] && continue
2245 kdate=`uname -v | $AWK '{for(i=1;i<NF;i++){if(index($i,":")){print $i;};};}' | $AWK '{print $NF;}'`
2246 file $fname | grep -q gzip
2247 if [ "$?" -eq "0" ] ; then
2248 # Used by ia64
2249 if [ "`gzip -cd $fname | strings 2> /dev/null | grep -F "$kdate"`" = "" ] ; then
2250 LogIt "Have you recompiled your kernel \"$fname\" w/o rebooting? Naughty but I'll allow it..."
2251 duff_kernels="$fname $duff_kernels"
2252 else
2253 [ "`echo "$fname" | grep -F "vmlinux"`" ] && continue
2254 possible_kernels="$fname $possible_kernels"
2255 fi
2256 else
2257 if [ "`strings $fname 2> /dev/null | grep -F "$kdate"`" = "" ] ; then
2258 LogIt "Have you recompiled your kernel \"$fname\" w/o rebooting?\n Naughty but I'll allow it..."
2259 duff_kernels="$fname $duff_kernels"
2260 else
2261 [ "`echo "$fname" | grep -F "vmlinux"`" ] && continue
2262 possible_kernels="$fname $possible_kernels"
2263 fi
2264 fi
2265 done
2266 if [ ! "$possible_kernels" ] && uname -a | grep Knoppix > /dev/null ; then
2267 possible_kernels=`find /boot/vmlinuz-2.* | tail -n1`
2268 fi
2269 if [ ! "$possible_kernels" ] ; then
2270 LogIt "No kernel matches exactly. Are there any duff kernels?"
2271 possible_kernels="$duff_kernels"
2272 if [ ! "$possible_kernels" ] ; then
2273 LogIt "Sorry, no duff kernels either"
2274 else
2275 LogIt "I bet you're running Debian or Gentoo, aren't you?"
2276 LogIt "Your kernel doesn't have a sane builddate. Oh well..."
2277 fi
2278 fi
2279 possible_kernels=`echo "$possible_kernels" | tr -s ' ' '\n' | grep -vi "xen" | sort -u | tr '\n' ' '`
2280 noof_kernels=`CountItemsIn "$possible_kernels"`
2281 if [ $KERNEL_IS_XEN = "yes" ]; then
2282 possible_xenkernels=`echo "$possible_kernels" | tr -s ' ' '\n' | grep -i "xen" | sort -u | tr '\n' ' '`
2283 noof_xenkernels=`CountItemsIn "$possible_xenkernels"`
2284 FindMboot32Binary
2285 fi
2286 if [ "$noof_kernels" -eq "0" ] ; then
2287 LogIt "Could not find your kernel."
2288 if [ -e "/boot/vmlinuz" ] ; then
2289 LogIt "Using /boot/vmlinuz as a last resort."
2290 output=/boot/vmlinuz
2291 else
2292 output=""
2293 fi
2294 elif [ "$noof_kernels" -eq "1" ] ; then
2295 kernelpath=`echo "$possible_kernels" | sed s/' '//`
2296 echo "Your kernel is $kernelpath (v$KERVERRUN)" >> $LOGFILE
2297 output="$kernelpath"
2298 else
2299 for i in $possible_kernels ; do
2300 if echo $i | grep "$KERVERRUN" ; then
2301 LogIt "OK, I used my initiative and found that "
2302 LogIt "$i is probably your kernel. "
2303 output="$i"
2304 fi
2305 done
2306 if [ -n "$output" ]; then
2307 if echo " $possible_kernels " | grep -F "/boot/vmlinuz " &> /dev/null ; then
2308 output=/boot/vmlinuz
2309 echo "Schlomo, this one's for you." >> $LOGFILE
2310 else
2311 LogIt "Two or more possible kernels found. You may specify any one of them and the "
2312 LogIt "boot disks will still work, probably. If one does not work, try another."
2313 LogIt "$possible_kernels"
2314 echo ""
2315 fi
2316 fi
2317 fi
2318 if [ $KERNEL_IS_XEN = "yes" ]; then
2319 if [ "$noof_xenkernels" -eq "0" ]; then
2320 xenkernelpath=""
2321 elif [ "$noof_xenkernels" -eq "1" ]; then
2322 xenkernelpath=`echo "$possible_xenkernels" | sed s/' '//`
2323 echo "Your Xen kernel is $xenkernelpath (v$KERVERRUN)" >> $LOGFILE
2324 else
2325 for i in $possible_xenkernels ; do
2326 if echo $i | grep "$KERVERRUN" ; then
2327 LogIt "OK, I used my initiative and found that "
2328 LogIt "$i is probably your Xen kernel. "
2329 xenkernelpath="$i"
2330 fi
2331 done
2332 if [ -n "$xenkernelpath" ]; then
2333 new_possible_xenkernels=`echo "$possible_xenkernels" | tr -s ' ' '\n' | grep -E "^/boot" | sort -u | tr '\n' ' '`
2334 if [ ! -n "$new_possible_xenkernels" ]; then
2335 xenkernelpath=`echo $new_possible_xenkernels | tr -s ' ' '\n' | head -1`
2336 LogIt "Using $xenkernelpath"
2337 else
2338 LogIt "Two or more possible Xen kernels found. You may specify any one of them and the "
2339 LogIt "boot disks will still work, probably. If one does not work, try another."
2340 LogIt "$possible_xenkernels"
2341 echo ""
2342 xenkernelpath=`echo $possible_xenkernels | tr -s ' ' '\n' | head -1`
2343 LogIt "Using $xenkernelpath"
2344 fi
2345 fi
2346 fi
2347 xenkernelname=`basename $xenkernelpath`
2348 if [[ -z "$xenkernelpath" || ! -f "$xenkernelpath" ]]; then
2349 Die "Cannot find Xen kernel $xenkernelpath, aborting"
2350 fi
2351 fi
2352 echo "$output"
2353}
2354
2355
2356TurnTgzIntoRdz() {
2357 local tgz_dir_fname rdz_fname tempfile mountpoint old_pwd nodes kernelsize maxsize res currsize not_copied j k s w needed_modules_path
2358
2359 tgz_dir_fname=$1
2360 rdz_fname=$2
2361 kernelsize=$3
2362 maxsize=$(($BOOT_SIZE-$kernelsize))
2363 maxsize=$(($maxsize*2)); # to allow for compression of 50%
2364 tempfile=$MINDI_TMP/temp.rd
2365 mountpoint=$MINDI_TMP/mnt1
2366 res=0
2367 echo -en "..."
2368 dd if=/dev/zero of=$tempfile bs=1k count=$ramdisk_size &> /dev/null || Die "Not enough room for temporary ramdisk (TurnTgzIntoRdz)"
2369 echo -en "..."
2370 echo "Creating ext2 filesystem on $tempfile" >> $LOGFILE
2371 mke2fs -b 1024 -m 1 -i 2048 -F $tempfile >> $LOGFILE 2>> $LOGFILE || Die "Unable to create an ext2 file system on $tempfile"
2372 echo -en "..."
2373 mkdir -p $mountpoint
2374 mount -t ext2 -o loop $tempfile $mountpoint || Die "Cannot loopmount $tempfile to $mountpoint! The reason may be missing support for loopfs or ext2 (or both) in the running kernel."
2375 echo -en "..."
2376 old_pwd=`pwd`
2377 cd "$mountpoint"
2378
2379 # AL04Oct08: Check whether /lib64 is a link and if so explicitly create one in rootfs
2380 if [ -h "/lib64" ]; then
2381 mkdir -p lib || LogIt "Unable to create lib in $mountpoint."
2382 ln -s lib lib64 || LogIt "/lib64 is a symbolic link, but I couldn't create it in $mountpoint."
2383 fi
2384
2385 cp -Rdf $tgz_dir_fname/* . 2>&1 >> $LOGFILE
2386 tar -zxf symlinks.tgz || Die "Cannot untar symlinks.tgz"
2387
2388 cd dev || Die "Can't cd to dev"
2389 tar -zxf dev-entries.tgz || Die "Cannot untar dev-entries.tgz"
2390 rm -f dev-entries.tgz
2391 cd ..
2392
2393 for w in insmod.static insmod.static.old ; do
2394 s=`which $w 2> /dev/null`
2395 if [ -e "$s" ] ; then
2396 tar cf - -C / $s 2> /dev/null | tar xf -
2397 fi
2398 done
2399
2400 [ -e "/dev/.devfsd" ] && echo "/dev/.devfsd found" > tmp/USE-DEVFS
2401
2402 # Handle the case where busybox and mount are dynamically linked
2403 file $MINDI_LIB/rootfs/bin/busybox 2>&1 | grep -q "dynamically"
2404 if [ $? -eq 0 ]; then
2405 # We want to use the real mount and all the supported variants (nfs, cifs, ...)
2406 rm -f bin/mount $MINDI_TMP/busy.lis
2407 mountlis=`grep -E "mount|fuse|ssh" $DEPLIST_FILE $DEPLIST_DIR/* | grep -v " *#.*" | cut -d: -f2 | sort -u`
2408 LocateDeps $MINDI_LIB/rootfs/bin/busybox $mountlis >> $MINDI_TMP/busy.lis
2409 # Special for libs
2410 for f in `grep -E "libnss" $DEPLIST_FILE $DEPLIST_DIR/* | grep -v " *#.*" | cut -d: -f2`; do
2411 echo "`ReadAllLink $f`" >> $MINDI_TMP/busy.lis
2412 done
2413 # Initial / are trucated by tar
2414 tar cf - $mountlis `sort -u $MINDI_TMP/busy.lis` 2>> $MINDI_TMP/$$.log | tar xf - || LogIt "Problem in mount analysis" $MINDI_TMP/$$.log
2415 rm -f $MINDI_TMP/busy.lis
2416 fi
2417
2418 # Copy of files mandatory for ssh to automate mount if sshfs is used
2419 mkdir $mountpoint/.ssh
2420 cp -rp ~root/.ssh/*.pub ~root/.ssh/config ~root/.ssh/known* $mountpoint/.ssh 2> /dev/null
2421 echo > $mountpoint/tmp/myssh << EOF
2422ssh -o StrictHostKeyChecking=no $*
2423EOF
2424 chmod 755 $mountpoint/tmp/myssh
2425
2426 # Copy of files mandatory for ld.so
2427 cp -rp /etc/ld.so.c* $mountpoint/etc
2428
2429 # Avoid an issue on some distro (RHEL5)
2430 rm -f $mountpoint/etc/ld.so.conf.d/kernelcap*
2431
2432 mkdir -p $mountpoint/tmp
2433 # Management of udev (which includes modprobe in rules)
2434 ps auxww | grep -v grep | grep -qw udevd
2435 if [ $? -eq 0 ]; then
2436 echo "udev device manager found" > $mountpoint/tmp/USE-UDEV
2437 LogIt "udev device manager found"
2438 tar cf - -C / /etc/udev 2>> $MINDI_TMP/$$.log | tar xf - || LogIt "Problem in /etc/udev analysis" $MINDI_TMP/$$.log
2439 # This avoids NIC remapping if on another machine at restore time on Debian at least
2440 rm -f ./etc/udev/rules.d/z[0-9][0-9]_persistent-net.rules
2441 # This avoids NIC remapping if on another machine at restore time on Ubuntu at least
2442 rm -f ./etc/udev/rules.d/[0-9][0-9]-persistent-net.rules
2443 tar cf - -C / /lib*/udev 2>> $MINDI_TMP/$$.log | tar xf - || LogIt "Problem in /lib/udev analysis" $MINDI_TMP/$$.log
2444 if [ -x /sbin/udevd ]; then
2445 lis2=`grep -Ev '^#' $MINDI_CONF/udev.files`
2446 lis=""
2447 # Get only the files which exist in that list
2448 # and potentially their symlink structure
2449 for i in $lis2; do
2450 if [ -h $i ]; then
2451 j=$i
2452 while [ -h $j ]; do
2453 lis="$lis $j"
2454 j=`readlink $j`
2455 done
2456 lis="$lis $j"
2457 elif [ -f $i ]; then
2458 lis="$lis $i"
2459 fi
2460 done
2461 # And their deps
2462 LocateDeps $lis > $MINDI_TMP/udev.lis
2463 for i in $lis; do
2464 if [ "`echo $i | cut -c1`" = "/" ]; then
2465 j=`echo $i | cut -c2-`
2466 [ "$j" != "" ] && rm -f $j
2467 fi
2468 done
2469 tar cf - -C / $lis `sort -u $MINDI_TMP/udev.lis` 2>> $MINDI_TMP/$$.log | tar xf - || LogIt "Problem in udev.lis analysis" $MINDI_TMP/$$.log
2470 rm -f $MINDI_TMP/udev.lis
2471 else
2472 echo "udevd daemon not in standard place (/sbin)" 2>&1 | tee -a $LOGFILE
2473 echo "mindi will use static devices which may cause problems" 2>&1 | tee -a $LOGFILE
2474 rm -f $mountpoint/tmp/USE-UDEV
2475 fi
2476 fi
2477
2478 # Management of potential HW info (Proliant only at the moment)
2479 rm -rf $MINDI_CACHE/bkphw
2480 mindi-bkphw $MINDI_CACHE $MINDI_CONF | tee -a $LOGFILE
2481 if [ -d $MINDI_CACHE/bkphw ]; then
2482 LogIt "Hardware Information found and saved ..."
2483 cp -rp $MINDI_CACHE/bkphw .
2484 if [ -f $MINDI_CACHE/tools.files ]; then
2485 lis=`grep -Ev '^#' $MINDI_CACHE/tools.files`
2486 LocateDeps $lis > $MINDI_TMP/tools.lis
2487 tar cf - $lis `sort -u $MINDI_TMP/tools.lis` 2>> $MINDI_TMP/$$.log | tar xf - || LogIt "Problem in tools.lis analysis" $MINDI_TMP/$$.log
2488 fi
2489 if [ -f $MINDI_CACHE/mindi-rsthw ]; then
2490 mv -f $MINDI_CACHE/mindi-rsthw .
2491 chmod 755 ./mindi-rsthw
2492 fi
2493 rm -f $MINDI_TMP/tools.lis $MINDI_CACHE/tools.files
2494 fi
2495
2496 # Management of perl scripts delivered needed at restore time
2497 mindi-get-perl-modules `cat $MINDI_CONF/perl-scripts` > $MINDI_TMP/perl.lis
2498 tar cf - `cat $MINDI_TMP/perl.lis` 2>> $MINDI_TMP/$$.log | tar xf - || LogIt "Problem in perl scripts analysis" $MINDI_TMP/$$.log
2499
2500 for w in cdrom groovy-stuff ; do
2501 mkdir -p mnt/$w
2502 done
2503
2504 tar cf - -C / /dev/fd0*[1,2][4,7,8]* 2>> $MINDI_TMP/$$.log | tar xf - || LogIt "Problem in fd dev analysis" $MINDI_TMP/$$.log
2505
2506 cd "$old_pwd"
2507 echo -en "..."
2508 old_pwd=`pwd`
2509 if [ "$YOUR_KERNEL_SUCKS" ] ; then
2510 cd "$MINDI_TMP"
2511 needed_modules_path=lib/modules/$FAILSAFE_KVER
2512 else
2513 cd /
2514 if [ "${kernelname}" != "" ]
2515 then
2516 needed_modules_path=lib/modules/${kernelname}
2517 else
2518 needed_modules_path=lib/modules/$KERVERRUN
2519 fi
2520 fi
2521
2522 needed_modules=""
2523 list_of_groovy_mods="$CDROM_MODS $FORCE_MODS"
2524
2525 if [ -e "$MINDI_TMP/NETFS-DEV" ] ; then
2526 # For PXE boot
2527 list_of_groovy_mods="$list_of_groovy_mods $NET_MODS"
2528 fi
2529 if [ "$PROMPT_MAKE_USB_IMAGE" = "yes" ] && [ "$USBDEVICE" != "" ]; then
2530 list_of_groovy_mods="$list_of_groovy_mods $EXTRA_MODS"
2531 fi
2532 for i in $DENY_MODS; do
2533 echo "Removing $i from the list of modules to load" >> $LOGFILE
2534 list_of_groovy_mods=`echo ${list_of_groovy_mods} | tr ' ' '\n' | grep -Ev "^${i}$" | tr '\n' ' '`
2535 done
2536
2537 [ -e "$needed_modules_path" ] || LogIt "path $needed_modules_path does not exist.\n If you're not using a modular kernel then you're NUTS."
2538 for i in $list_of_groovy_mods ; do
2539 needed_modules="$needed_modules `FindSpecificModuleInPath $needed_modules_path $i`"
2540 done
2541
2542 for i in `echo $needed_modules | tr ' ' '\n' | sort -u`; do
2543 [ -e "$i" ] && s=`du -sk $i | cut -f1` || s=""
2544 [ "$YOUR_KERNEL_SUCKS" ] && i=$MINDI_TMP/$i
2545 echo "Adding $i ($s KB) to the rootfs" >> $LOGFILE
2546 tar cf - -C / $i 2>> $MINDI_TMP/$$.log | (cd "$mountpoint" ; tar xf -) || LogIt "Unable to copy $i to $mountpoint" $MINDI_TMP/$$.log
2547 # Uncompress modules if not using udev and native modprobe
2548 if [ ! -f $mountpoint/tmp/USE-UDEV ]; then
2549 if [ "`echo "$i" | grep -F ".gz"`" ]; then
2550 echo "Uncompressing $i" >> $LOGFILE
2551 gunzip -f $mountpoint/$i
2552 fi
2553 fi
2554 done
2555
2556 # Also copy modules.dep in case of udev so that normal modprobe works
2557 tar cf - -C / /$needed_modules_path/modules.dep 2>> $MINDI_TMP/$$.log | (cd "$mountpoint" ; tar xf -) || LogIt "Unable to copy modules.dep to $mountpoint" $MINDI_TMP/$$.log
2558
2559 # Copy FW in case some drivers needs it
2560 if [ -d "/lib/firmware" ]; then
2561 cp -rp /lib/firmware $mountpoint/lib
2562 fi
2563
2564 if [ ! -e "/sbin/devfsd" ] || [ "$kernelpath" = "$MINDI_LIB/vmlinuz" ] ; then
2565 echo "Deleting devfsd daemon from ramdisk" >> $LOGFILE
2566 [ ! -e "/sbin/devfsd" ] && echo "...because /sbin/devfsd not found" >> $LOGFILE
2567 [ "$kernelpath" = "$MINDI_LIB/vmlinuz" ] && echo "...because kernel is failsafe" >> $LOGFILE
2568 rm -f $mountpoint/sbin/devfsd
2569 fi
2570 cd "$old_pwd"
2571 [ "$TAPEDEV" ] && echo -en "$TAPEDEV" > $mountpoint/tmp/TAPEDEV-LIVES-HERE
2572 dd if=/dev/zero of=$mountpoint/zero &> /dev/null
2573 rm -f $mountpoint/zero
2574 if [ _"$MONDO_SHARE" != _"" ]; then
2575 MakeMondoConfigFile $mountpoint/tmp/mondo-restore.cfg
2576 cp -f $mountpoint/tmp/mondo-restore.cfg $MINDI_TMP 2>> $LOGFILE || Die "Cannot copy mondo-restore.cfg to ramdisk"
2577 cp -f $MINDI_TMP/mountlist.txt $mountpoint/tmp/ 2>> $LOGFILE || Die "Cannot copy mountlist to ramdisk"
2578 echo -en "$FILES_IN_FILELIST" > $mountpoint/tmp/FILES-IN-FILELIST
2579 echo -en "$LAST_FILELIST_NUMBER" > $mountpoint/tmp/LAST-FILELIST-NUMBER
2580 [ "$USE_LZO" = "yes" ] && echo -en "Pras 4 Pres 2004" >> $mountpoint/tmp/USING-LZO
2581 [ "$USE_GZIP" = "yes" ] && echo -en "YES" >> $mountpoint/tmp/USING-GZIP
2582 [ "$USE_COMP" = "yes" ] && echo -en "Compression, yep" >> $mountpoint/tmp/USING-COMP
2583 [ "$USE_STAR" = "yes" ] && echo -en "Using star. Hooray." >> $mountpoint/tmp/USING-STAR
2584 fi
2585 mkdir -p $mountpoint/proc
2586 echo "$BOOT_SIZE" > $mountpoint/tmp/$BOOT_SIZE.siz
2587
2588 echo "---------------------------" >> $LOGFILE
2589 echo "Content of initial ramdisk:" >> $LOGFILE
2590 echo "---------------------------" >> $LOGFILE
2591 (cd "$mountpoint" ; ls -Rla ) >> $LOGFILE
2592 echo "---------------------------" >> $LOGFILE
2593
2594 # Determine what filesystem to use for initrd image
2595 echo "Call GetInitrdFilesystemToUse() with parameter ${kernelpath} to get filesystem to use for initrd." >> $LOGFILE
2596 gvFileSystem=`GetInitrdFilesystemToUse ${kernelpath}`
2597 [ -z gvFileSystem ] && Die "GetFilesystemToUse() failed. Terminating."
2598 if [ "$gvFileSystem" = "ext2fs" ] || [ "$gvFileSystem" = "ext3fs" ]; then
2599 # say what will be used
2600 echo "Creating an $gvFileSystem initrd image..." >> $LOGFILE
2601 # kernel expects linuxrc in ext2 filesystem
2602 ( cd "$mountpoint" && ln -sf sbin/init linuxrc )
2603 # unmount loop filesystem and create image file using the standard approach
2604 umount $mountpoint || Die "Cannot unmount $tempfile"
2605 dd if=$tempfile bs=1k 2> /dev/null > ${rdz_fname}.tmp 2> /dev/null
2606 bs=`tune2fs -l ${rdz_fname}.tmp | grep -E '^Block size:' | cut -d: -f2 | sed 's/^ *//'`
2607 MINDI_ADDITIONAL_BOOT_PARAMS="$MINDI_ADDITIONAL_BOOT_PARAMS ramdisk_blocksize=$bs"
2608 gzip -c9 ${rdz_fname}.tmp > $rdz_fname
2609 rm -f ${rdz_fname}.tmp
2610 # log that we are done
2611 echo "...done." >> $LOGFILE
2612 elif [ "$gvFileSystem" = "initramfs" ]; then
2613 # say what will be used
2614 echo "Creating a gzip'ed cpio (AKA initramfs) initrd image..." >> $LOGFILE
2615 # make sure that cpio is there
2616 which cpio &> /dev/null; [ $? -eq 0 ] || Die "cpio not found. Please install package cpio and try again."
2617 # go into filesystem
2618 cd "$mountpoint"
2619 # kernel expects init in cpio filesystem
2620 ln -sf sbin/init init
2621 # create cpio image file and unmount loop filesystem
2622 find . -print | cpio -o -H newc | gzip -9 > $rdz_fname 2> /dev/null
2623 cd "$old_pwd"
2624 umount $mountpoint || Die "Cannot unmount $tempfile"
2625 # log that we are done
2626 echo "...done." >> $LOGFILE
2627 else
2628 Die "Filesystem $gvFileSystem not supported for initrd image. Terminating."
2629 fi
2630
2631 if [ "$res" -eq "0" ] ; then
2632 echo -en "..."
2633 else
2634 echo -en "\rMade an rdz WITH ERRORS. \n"
2635 fi
2636 return 0
2637}
2638
2639
2640##############################################################################
2641#----------------------------------- Main -----------------------------------#
2642##############################################################################
2643
2644# Now we can create what we need
2645mkdir -p $MINDI_TMP
2646
2647# Purge from potential old run
2648if [ _"$MINDI_CACHE" = _"" ]; then
2649 Die "MINDI_CACHE undefined"
2650fi
2651
2652if [ "$1" = "--printvar" ] ; then
2653 shift
2654 if [ _"$1" != _"" ] ; then
2655 set | grep -Ew "^$1" | cut -d= -f2
2656 fi
2657 exit 0
2658fi
2659
2660> $LOGFILE
2661echo "mindi v$MINDI_VERSION" >> $LOGFILE
2662echo "$ARCH architecture detected" >> $LOGFILE
2663echo "mindi called with the following arguments:" >> $LOGFILE
2664echo "$@" >> $LOGFILE
2665echo "Start date : `date`" >> $LOGFILE
2666echo "-----------------------------" >> $LOGFILE
2667
2668[ -e "/sbin/mkdosfs" ] && [ ! -e "/sbin/mkfs.vfat" ] && ln -sf /sbin/mkdosfs /sbin/mkfs.vfat
2669
2670# Log some capital variables
2671[ "$MINDI_PREFIX" = "XXX" ] && Die "Mindi has not been installed correctly."
2672echo "MONDO_SHARE = $MONDO_SHARE" >> $LOGFILE
2673echo "MINDI_LIB = $MINDI_LIB" >> $LOGFILE
2674echo "MINDI_SBIN = $MINDI_SBIN" >> $LOGFILE
2675[ "$MINDI_CONF" = "YYY" ] && Die "Mindi has not been installed correctly."
2676echo "MINDI_CONF = $MINDI_CONF" >> $LOGFILE
2677if [ -f $MINDI_CONFIG ]; then
2678 echo "-----------------------------" >> $LOGFILE
2679 echo " Mindi configuration file " >> $LOGFILE
2680 echo "-----------------------------" >> $LOGFILE
2681 grep -Ev '^#' $MINDI_CONFIG >> $LOGFILE
2682 echo "-----------------------------" >> $LOGFILE
2683fi
2684
2685
2686trap AbortHere SIGTERM SIGHUP SIGQUIT SIGKILL SIGABRT SIGINT
2687
2688# Sanity checks
2689which which > /dev/null 2> /dev/null || Die "Please install 'which'."
2690which strings > /dev/null 2> /dev/null || Die "Please install binutils and libbinutils; you have no 'strings' executable."
2691which gawk > /dev/null 2> /dev/null || Die "Gawk is missing from your computer. Please install gawk. You may find the package on Debian's website. How did I know you're running Debian? Because only Debian would be stupid enough not to include gawk in your distribution."
2692which gawk > /dev/null 2> /dev/null && AWK=`which gawk 2>/dev/null` || AWK="`which awk 2>/dev/null`"
2693if which awk &> /dev/null ; then
2694 if ! which gawk &> /dev/null ; then
2695 LogIt "You have awk but not gawk.\nPlease note that mindi works fine with a _sane_ awk binary.\nIf your awk binary misbehaves then please contact your vendor\nor distribution's mailing list for technical support.\n"
2696 fi
2697fi
2698which mke2fs > /dev/null 2> /dev/null || Die "Please put mke2fs in system path"
2699[ ! -e "$FDISK" ] && Die "Cannot find $FDISK"
2700
2701[ "`echo $KERVERRUN | grep "2.4.[0-6]" | grep -v "2.4.[0-9][0-9]"`" != "" ] && echo "WARNING! Your kernel may have buggy loopfs code. Consider upgrading to 2.4.7"
2702
2703# Update the PATH variable if incomplete
2704if [ -e "/sbin/mkfs" ] && ! which mkfs &> /dev/null ; then
2705 PATH=$PATH:/sbin:/usr/sbin
2706 export PATH
2707 echo "Your PATH did not include /sbin or /usr/sbin. I have fixed that, temporarily." >> $LOGFILE
2708 echo "However, you may wish to ask your vendor to provide a permanent fix..." >> $LOGFILE
2709 echo " Or you might like to call 'su -' instead of 'su', for example." >> $LOGFILE
2710fi
2711
2712# If we have a distribution-specific script for finding a FAILSAFE kernel, use it.
2713if [ -f "$MINDI_LIB/FindDistroFailsafe" ] && [ ! "$1" = "--makemountlist" ] && [ "$kernelpath" = "FAILSAFE" ]; then
2714 source $MINDI_LIB/FindDistroFailsafe
2715 # Log kernel image
2716 LogIt "FAILSAFE kernel image to be used is: $FAILSAFE_KBIN ($FAILSAFE_KVER)"
2717else
2718 [ -f "$MINDI_LIB/vmlinuz" ] && FAILSAFE_KVER=`strings $MINDI_LIB/vmlinuz 2> /dev/null | grep -E "2\.[46]" | cut -d' ' -f1`
2719fi
2720
2721if ! which mkfs.vfat 1> /dev/null 2> /dev/null ; then
2722 Die "mkfs.vfat missing from your filesystem - please install your dosfstools RPM or DEB package. Perhaps your PATH environmental variable is broken, too?"
2723fi
2724
2725### BERLIOS
2726### Fix as it's not mandatory on ia64
2727if [ "$ARCH" = "ia64" ] ; then
2728 if which elilo &> /dev/null ; then
2729 LILO_EXE=elilo
2730 else
2731 LILO_EXE=`which false 2> /dev/null`
2732 fi
2733else
2734 FindIsolinuxBinary
2735fi
2736trap "Aborted" SIGTERM
2737DONE="\r\t\t\t\t\t\t\t\tDone. "
2738kernelpath=""
2739MONDO_ROOT=/var/cache/mondo
2740mkdir -p $MONDO_ROOT
2741
2742if [ -d "/proc/lvm" ]; then
2743 # LVM v1
2744 LVMCMD=""
2745 LVM="v1"
2746elif [ -d "/dev/mapper" ]; then
2747 # LVM v2
2748 LVMCMD="lvm"
2749 LVM="v2"
2750else
2751 LVM="false"
2752fi
2753echo "LVM set to $LVM" >> $LOGFILE
2754echo "----------" >> $LOGFILE
2755echo "mount result:" >> $LOGFILE
2756echo "-------------" >> $LOGFILE
2757mount >> $LOGFILE
2758echo "-------------" >> $LOGFILE
2759if [ -e /etc/raidtab ]; then
2760 echo "-------------" >> $LOGFILE
2761 echo "/etc/raidtab content:" >> $LOGFILE
2762 echo "-------------" >> $LOGFILE
2763 cat /etc/raidtab >> $LOGFILE
2764fi
2765echo "-------------" >> $LOGFILE
2766echo "cat /proc/cmdline:" >> $LOGFILE
2767echo "-------------" >> $LOGFILE
2768cat /proc/cmdline >> $LOGFILE
2769echo "-------------" >> $LOGFILE
2770echo "cat /proc/swaps:" >> $LOGFILE
2771echo "-------------" >> $LOGFILE
2772cat /proc/swaps >> $LOGFILE
2773echo "-------------" >> $LOGFILE
2774echo "cat /proc/partitions:" >> $LOGFILE
2775echo "-------------" >> $LOGFILE
2776cat /proc/partitions >> $LOGFILE
2777echo "-------------" >> $LOGFILE
2778echo "cat /proc/filesystems:" >> $LOGFILE
2779echo "-------------" >> $LOGFILE
2780cat /proc/filesystems >> $LOGFILE
2781echo "-------------" >> $LOGFILE
2782echo "lsmod result:" >> $LOGFILE
2783echo "-------------" >> $LOGFILE
2784lsmod >> $LOGFILE
2785MODULES="`cat /proc/modules | $AWK '{print $1}'`"
2786if [ -x /usr/sbin/esxcfg-module ]; then
2787 echo "-------------" >> $LOGFILE
2788 echo "VMWare ESX server detected - Enabling dedicated support" >> $LOGFILE
2789 echo "-------------" >> $LOGFILE
2790 echo "VMWare modules" >> $LOGFILE
2791 echo "-------------" >> $LOGFILE
2792 /usr/sbin/esxcfg-module -l >> $LOGFILE
2793 MODULES="$MODULES `/usr/sbin/esxcfg-module -l | $AWK '{print $1}'`"
2794fi
2795echo "FORCE_MODS:" >> $LOGFILE
2796echo "-------------" >> $LOGFILE
2797echo $FORCE_MODS >> $LOGFILE
2798echo "-------------" >> $LOGFILE
2799echo "DENY_MODS:" >> $LOGFILE
2800echo "-------------" >> $LOGFILE
2801echo $DENY_MODS >> $LOGFILE
2802echo "-------------" >> $LOGFILE
2803echo "df result:" >> $LOGFILE
2804echo "----------" >> $LOGFILE
2805df -T >> $LOGFILE
2806echo "-------------" >> $LOGFILE
2807echo "Liste of extra modules is:" >> $LOGFILE
2808echo "$EXTRA_MODS" >> $LOGFILE
2809echo "-------------" >> $LOGFILE
2810
2811# Compute libata version
2812laver=`modinfo libata 2> /dev/null | grep -Ei '^Version:' | cut -d: -f2 | cut -d. -f1 | sed 's/ *//g' 2> /dev/null`
2813# If libata v2 is used then remove ide-generic as it will perturbate boot
2814if [ "`echo $MODULES | grep libata`" ]; then
2815 if [ "$laver" = "2" ]; then
2816 DENY_MODS="$DENY_MODS ide-generic"
2817 echo "ide-generic removed from module list as your system uses libata v2+" >> $LOGFILE
2818 echo "-------------" >> $LOGFILE
2819 fi
2820fi
2821
2822# Check for ISO_CMD command
2823if [ ! -x $ISO_CMD ]; then
2824 echo "NOTE: No CD image (ISO file) utility found" >> $LOGFILE
2825fi
2826
2827FLOPPY_WAS_MOUNTED=""
2828for mtpt in /media/floppy /mnt/floppy /floppy ; do
2829 if mount | grep -w $mtpt &> /dev/null ; then
2830 FLOPPY_WAS_MOUNTED="$FLOPPY_WAS_MOUNTED $mtpt"
2831 umount $mtpt
2832 fi
2833done
2834
2835#
2836# If we have a USB device we need to store info
2837# and remove it from the parameters line
2838#
2839if [ "$#" -ne "0" ] ; then
2840 if [ "$1" = "--usb" ] ; then
2841 shift
2842 USBDEVICE=$1
2843 if [ _"$USBDEVICE" = _"" ]; then
2844 Die "No USB device specified"
2845 fi
2846 shift
2847 fi
2848fi
2849
2850if [ "$#" -ne "0" ] ; then
2851 if [ "$1" = "--findkernel" ] ; then
2852 res=`TryToFindKernelPath`
2853 # Avoids logfile content for mondo
2854 export MONDO_SHARE=""
2855 if [ "$res" = "" ] ; then
2856 MindiExit -1
2857 else
2858 echo "$res"
2859 MindiExit 0
2860 fi
2861 elif [ "$1" = "--locatedeps" ] ; then
2862 [ ! "$2" ] && Die "Please specify the binary to look at"
2863 LocateDeps $*
2864 # Avoids logfile content for mondo
2865 export MONDO_SHARE=""
2866 MindiExit $?
2867 elif [ "$1" = "--readalllink" ] ; then
2868 [ ! "$2" ] && Die "Please specify the binary to look at"
2869 ReadAllLink $2
2870 # Avoids logfile content for mondo
2871 export MONDO_SHARE=""
2872 MindiExit $?
2873 elif [ "$1" = "--makemessage" ] ; then
2874 MakeMessageFile
2875 MindiExit 0
2876 elif [ "$1" = "--makemountlist" ] ; then
2877 [ ! "$2" ] && Die "Please specify the output file"
2878 MakeMountlist $2
2879 CheckMountlist $2
2880 # Avoids logfile content for mondo
2881 export MONDO_SHARE=""
2882 MindiExit $?
2883 elif [ "$1" = "-V" ] || [ "$1" = "-v" ] || [ "$1" = "--version" ] || [ "$1" = "-version" ] ; then
2884 echo "Mindi v$MINDI_VERSION"
2885 # Avoids logfile content for mondo
2886 export MONDO_SHARE=""
2887 MindiExit 0
2888 elif [ "$#" -ge "9" ] && [ "$1" = "--custom" ] ; then
2889 MONDO_TMP=$2
2890 # Change MINDI_TMP for the one provided by mondo
2891 # So that it can get back the built files
2892 if [ _"$MONDO_TMP" = _"" ]; then
2893 Die "MONDO_TMP is empty, aborting"
2894 fi
2895 if [ _"$MONDO_TMP" = _"/" ]; then
2896 Die "MONDO_TMP is /, aborting"
2897 fi
2898 mv $MINDI_TMP/* $MINDI_TMP/.??* $MONDO_TMP 2>> $LOGFILE
2899 rmdir $MINDI_TMP
2900 export MINDI_TMP=$MONDO_TMP
2901 mkdir -p $MINDI_TMP
2902
2903 # This is the scratch dir in mondo - subdir images
2904 MINDI_CACHE=$3
2905
2906 kernelpath=$4; [ "$kernelpath" = "(null)" ] && kernelpath=""
2907 [ "$kernelpath" = "" ] && kernelpath=`TryToFindKernelPath`
2908
2909###
2910### Sq-Modification...
2911### Attempt to locate kernel specific module path
2912### if module path is found then use it other wise use uname -r to set it...
2913###
2914 if [ $KERNEL_IS_XEN = "yes" ]; then
2915 LogIt "xenkernelpath = $xenkernelpath"
2916 LogIt "xenkernelname = $xenkernelname"
2917 fi
2918 kernelname=`echo $kernelpath | cut -d'-' -f2- | sed 's/.[bg]z[2]*$//'`
2919 if [ ! -d "/lib/modules/$kernelname" ] && [ "$kernelpath" != "FAILSAFE" ]
2920 then
2921 LogIt "Module path for ${kernelpath} not found..."
2922 LogIt "using running kernel\'s modules."
2923 kernelname=$KERVERRUN
2924 fi
2925 LogIt "kernelname = $kernelname"
2926 LogIt "kernelpath = $kernelpath"
2927###
2928### end of Sq-Modification
2929###
2930 TAPEDEV=$5
2931 TAPESIZE=$6
2932 FILES_IN_FILELIST=$7
2933 USE_LZO=$8
2934 CDRECOVERY=$9
2935 if [ "${10}" = "(null)" ] || [ "${10}" = "" ] ; then
2936 IMAGE_DEVS=""
2937 else
2938 IMAGE_DEVS="`echo "${10}" | tr '|' ' '`"
2939 fi
2940 if [ "${11}" ] ; then
2941 LILO_OPTIONS=""
2942 # LogIt "LILO will use conservative settings, to be compatible with older BIOSes."
2943 fi
2944 LAST_FILELIST_NUMBER=${12}
2945 ESTIMATED_TOTAL_NOOF_SLICES=${13}
2946 export MINDI_EXCLUDE_DEVS="${14}"
2947 USE_COMP="${15}"
2948 USE_LILO="${16}"
2949 USE_STAR="${17}"
2950 INTERNAL_TAPE_BLOCK_SIZE="${18}"
2951 DIFFERENTIAL="${19}"
2952 USE_GZIP="${20}"
2953 NOT_BOOT="${21}"
2954 [ "$USE_COMP" = "" ] && USE_COMP=yes
2955 [ "$USE_GZIP" = "" ] && USE_GZIP=no
2956 [ "$NOT_BOOT" = "" ] && NOT_BOOT=no
2957 [ "$TAPEDEV" ] && LogIt "This is a tape-based backup. Fine."
2958 # MONDO_ROOT is the real scratchdir
2959 MONDO_ROOT=`echo $MINDI_CACHE | sed 's/\(.*\)\/.*/\1/'`
2960 if [ _"$MONDO_ROOT" != _"" ]; then
2961 mkdir -p $MONDO_ROOT
2962 else
2963 Die "MONDO_ROOT is undefined"
2964 fi
2965 else
2966 echo "Syntax: mindi (--custom ....)" >> /dev/stderr
2967 MindiExit -1
2968 fi
2969fi
2970
2971if [ _"$MINDI_CACHE" != _"" ]; then
2972 rm -rf $MINDI_CACHE/* 2> /dev/null
2973 mkdir -p $MINDI_CACHE
2974fi
2975
2976[ "$CDRECOVERY" = "yes" ] || CDRECOVERY=no
2977
2978if [ _"$MONDO_SHARE" = _"" ]; then
2979 LogIt "Mindi Linux mini-distro generator v$MINDI_VERSION"
2980 LogIt "Latest Mindi is available from http://www.mondorescue.org"
2981 LogIt "BusyBox sources are available from http://www.busybox.net"
2982 LogIt "------------------------------------------------------------------------------"
2983else
2984 echo "You are using Mindi-Linux v$MINDI_VERSION to make boot+data disks" >> $LOGFILE
2985fi
2986if [ -f $MINDI_LIB/rootfs/bin/busybox ]; then
2987 LogIt "Mindi-`$MINDI_LIB/rootfs/bin/busybox 2>&1 | head -1`"
2988else
2989 LogIt "Unable to find mindi-busybox, please install it"
2990 MindiExit -1
2991fi
2992
2993# for Mandrake 9.2, which comes with two aes.o.gz modules :-/
2994insmod /lib/modules/$KERVERRUN/*/*/misc/aes.*o.gz >> $LOGFILE 2>> $LOGFILE
2995for i in loop cdrom ide-cd isofs linear raid0 raid1 raid5 ; do
2996 insmod $i >> $LOGFILE 2>> $LOGFILE
2997done
2998
2999KERN_DISK_MADE=""
3000
3001echo "DIFFERENTIAL = $DIFFERENTIAL" >> $LOGFILE
3002echo "INTERNAL TAPE BLOCK SIZE = $INTERNAL_TAPE_BLOCK_SIZE" >> $LOGFILE
3003echo "NOT_BOOT = '$NOT_BOOT'" >> $LOGFILE
3004if [ "$NOT_BOOT" != "" ] && [ "$NOT_BOOT" != "0" ] && [ "$NOT_BOOT" != "no" ] ; then
3005 LogIt "Just creating mondo-restore.cfg and a small all.tar.gz for Mondo. Nothing else."
3006 MakeMondoConfigFile $MINDI_TMP/mondo-restore.cfg
3007 MakeMountlist $MINDI_TMP/mountlist.txt
3008 CheckMountlist $MINDI_TMP/mountlist.txt
3009 mkdir -p $MINDI_TMP/small-all/tmp
3010 cd "$MINDI_TMP/small-all"
3011 cp -f $MINDI_TMP/{mountlist.txt,mondo-restore.cfg,filelist.full.gz,biggielist.txt} tmp 2>> $LOGFILE || Die "Cannot copy small all.tar.gz"
3012 tar -cv ./tmp | gzip -9 > $MINDI_TMP/all.tar.gz 2>> $MINDI_TMP/$$.log || Die "Cannot make small all.tar.gz" $MINDI_TMP/$$.log
3013 sleep 2
3014 LogIt "Done. Exiting."
3015 MindiExit 0
3016fi
3017
3018if [ "$PROMPT_MAKE_USB_IMAGE" = "yes" ] && [ "$USBDEVICE" != "" ]; then
3019 LogIt "Including the generation of a Bootable USB device on $USBDEVICE"
3020fi
3021
3022if [ "$kernelpath" = "" ] ; then
3023 [ _"$MONDO_SHARE" != _"" ] && Die "Please use -k <path> to specify kernel."
3024 echo -en "Do you want to use your own kernel to build the boot disk ([y]/n) ?"
3025 read ch
3026 if [ "$ch" != "n" ] && [ "$ch" != "N" ] ; then
3027 USE_OWN_KERNEL="yes"
3028 else
3029 USE_OWN_KERNEL="no"
3030 fi
3031 if [ "$USE_OWN_KERNEL" = "yes" ]; then
3032 YOUR_KERNEL_SUCKS=""
3033 kernelpath=`TryToFindKernelPath`
3034 if [ "$kernelpath" = "" ] ; then
3035 echo -n "Please enter kernel path : "
3036 read kernelpath
3037 fi
3038 else
3039 YOUR_KERNEL_SUCKS="That's why you're using mine, dude. :-)"
3040 fi
3041fi
3042if [ "$YOUR_KERNEL_SUCKS" != "" ] || [ "$kernelpath" = "" ] || [ "$kernelpath" = "SUCKS" ] || [ "$kernelpath" = "FAILSAFE" ] ; then
3043 # If we have a distribution-specific script for finding a FAILSAFE kernel, use it.
3044 if [ -f "$MINDI_LIB/FindDistroFailsafe" ] && [ ! "$1" = "--makemountlist" ]; then
3045 source $MINDI_LIB/FindDistroFailsafe
3046 # Log kernel image
3047 LogIt "FAILSAFE kernel image to be used is: $FAILSAFE_KBIN ($FAILSAFE_KVER)"
3048 kernelpath="$FAILSAFE_KBIN"
3049 LogIt "I shall include a failsafe kernel, not your kernel, in the boot disks.\n"
3050 LogIt "The failsafe kernel is $kernelpath.\n"
3051 LogIt "However, you are still running your kernel. If Mindi fails to create your\n"
3052 LogIt "disks then it may still be a result of a problem with your kernel.\n"
3053 pwd=`pwd`
3054 cd "$MINDI_TMP"
3055 mkdir -p lib/modules
3056 cp -a "/lib/modules/$FAILSAFE_KVER" "lib/modules/$FAILSAFE_KVER" || Die "Cannot copy kernel modules."
3057 cd "$pwd"
3058 else
3059 kernelpath=$MINDI_LIB/vmlinuz
3060 LogIt "I shall include Mindi's failsafe kernel, not your kernel, in the boot disks."
3061 LogIt "However, you are still running your kernel. If Mindi fails to create your"
3062 LogIt "disks then it may still be a result of a problem with your kernel."
3063 pwd=`pwd`
3064 cd "$MINDI_TMP"
3065 bzip2 -dc $MINDI_LIB/lib.tar.bz2 | tar -x || Die "Cannot unzip lib.tar.bz2"
3066 cd "$pwd"
3067 fi
3068 YOUR_KERNEL_SUCKS="Your kernel sucks"
3069fi
3070echo -e "Mindi's temp dir = $MINDI_TMP \nMindi's output dir=$MINDI_CACHE" >> $LOGFILE
3071[ "$(($RANDOM%64))" -eq "0" ] && LogIt "Dude, I've looked inside your computer and it's really dusty..."
3072
3073[ "$YOUR_KERNEL_SUCKS" ] && [ ! "$FAILSAFE_KVER" ] && Die "Please install mindi-kernel package. You need it.\nGo to http://www.mondorescue.org and download it, then install it."
3074
3075PrepareDataDiskImages
3076
3077ramdisk_size=$(($size_of_all_tools+$EXTRA_SPACE))
3078rds=$(($ramdisk_size-$((ramdisk_size%4096))))
3079export ramdisk_size=$rds
3080
3081echo "Ramdisk will be $ramdisk_size KB" >> $LOGFILE
3082if [ "$ARCH" = "ia64" ] ; then
3083 PrepareBootDiskImage_LILO $kernelpath || Die "Failed to create ia64 image disk image."
3084else
3085 PrepareBootDiskImage_ISOLINUX $kernelpath || Die "Failed to create $ramdisk_size MB disk image."
3086fi
3087
3088[ -e "$MINDI_LIB/memtest.img" ] && BOOT_MEDIA_MESSAGE="$BOOT_MEDIA_MESSAGE\n\
3089...Or type 'memtest' to test your PC's RAM thoroughly.\n"
3090
3091if [ _"$MONDO_SHARE" = _"" ]; then
3092 ListImagesForUser
3093 OfferToMakeBootableISO
3094 if [ "$PROMPT_MAKE_USB_IMAGE" = "yes" ]; then
3095 OfferToMakeBootableUSB
3096 fi
3097 LogIt "Finished."
3098elif [ "$TAPEDEV" ] ; then
3099 if [ "$ARCH" != "ia64" ] ; then
3100 # We need to keep the img file as boot file for ia64 platform
3101 rm -f $MINDI_CACHE/{*img,*iso}
3102 else
3103 rm -f $MINDI_CACHE/*iso
3104 fi
3105 if [ "$PROMPT_MAKE_USB_IMAGE" = "yes" ] && [ "$USBDEVICE" != "" ]; then
3106 OfferToMakeBootableUSB
3107 fi
3108 OfferToMakeBootableISO
3109 if [ -e "$MINDI_CACHE/all.tar.gz" ] ; then
3110 cp -f $MINDI_CACHE/all.tar.gz $MINDI_TMP/ 2>> $LOGFILE
3111 else
3112 Die "Cannot find all.tar.gz, to be written to tape"
3113 fi
3114elif [ "$PROMPT_MAKE_USB_IMAGE" = "yes" ] && [ "$USBDEVICE" != "" ]; then
3115 OfferToMakeBootableUSB
3116else
3117 OfferToMakeBootableISO
3118fi
3119# cleanup
3120LogIt "$FRIENDLY_OUTSTRING"
3121for mtpt in $FLOPPY_WAS_MOUNTED ; do
3122 mount $mtpt
3123done
3124MindiExit 0
Note: See TracBrowser for help on using the repository browser.