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
RevLine 
[747]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#
[1880]8# Mindi can create a multi-image boot/root kit. The first image is the boot
[747]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)
[1565]16ARCH=`/bin/uname -m`
[2292]17KERVERRUN=`/bin/uname -r`
18# By default we use the running kernel as a reference
19KERVER=$KERVERRUN
[747]20
[2442]21# In case of problem with udev you can try to add udevdebug
[2564]22MINDI_ADDITIONAL_BOOT_PARAMS="devfs=nomount noresume selinux=0 barrier=off udevtimeout=10"
[747]23
[1691]24MINDI_REV=PBREV
25MINDI_VER=PBVER
[747]26
27MINDI_VERSION=${MINDI_VER}-r$MINDI_REV
28MINDI_PREFIX=XXX
29MINDI_CONF=YYY
30MINDI_SBIN=${MINDI_PREFIX}/sbin
[934]31MINDI_LIB=LLL
[747]32
[925]33# Temporary directory for mindi
34TMPDIR=/tmp
35
[2718]36EXTRA_SPACE=69152 # increase if you run out of ramdisk space
[2716]37BOOT_SIZE=24576 # size of the boot disk
[747]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
[1684]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
[966]47USE_OWN_KERNEL="yes"
[747]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.
[925]51
[2629]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
[747]56MY_FSTAB=/etc/fstab
57TAPE_MODS="ht st osst ide-tape ide_tape"
[2708]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"
[747]59
60# ide-probe-mod
[2737]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"
[747]62PCMCIA_MODS="pcmcia_core ds yenta_socket"
[2722]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"
[1993]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.
[2733]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"
[1230]68# Replace with that line for HP OCMP e.g.
[2073]69#DENY_MODS="MPS_Driver_Mapper mps octtldrv tscttl streams kqemu fdomain"
[1828]70DENY_MODS="kqemu"
[1399]71# Force some modules to be included
[1354]72FORCE_MODS=""
[925]73
[747]74LOGFILE=/var/log/mindi.log
[1880]75MINDI_CACHE=/var/cache/mindi
[747]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"
[925]91FDISK=$MINDI_SBIN/parted2fdisk
[747]92
[925]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
[1885]98DEPLIST_FILE="$MINDI_CONF/deplist.txt"
[2409]99DEPLIST_DIR="$MINDI_CONF/deplist.d"
100
[1885]101ISO_CMD="/usr/bin/mkisofs"
102ISO_OPT="-J -r -v -p Mindi -publisher http://www.mondorescue.org -A Mindi"
[925]103
[2457]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
[2685]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
[1485]165# Now we can create what we need
[2150]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
[2153]171if [ _"$MINDI_TMP" = _"" ]; then
172 Die "MINDI_TMP is empty, aborting"
173fi
174if [ _"$MINDI_TMP" = _"/" ]; then
175 Die "MINDI_TMP is /, aborting"
176fi
[2150]177export MINDI_TMP
[940]178
[747]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
[1880]190 [ "$MINDI_CACHE" != "" ] && rm -f $MINDI_CACHE/mindi*img $MINDI_CACHE/*gz $MINDI_CACHE/mindi.iso
[747]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
[1764]215 mappath=`grep "i[3-8]86" $MINDI_TMP/keymaps.find | grep "$locale[^r][^/]" | grep -vx " *#.*"`
[747]216 if [ ! -e "$mappath" ] ; then
[963]217 LogIt "Cannot add $mappath: kbd map file not found"
[747]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
[2712]225 tar cf - -C / $mappath 2>> $MINDI_TMP/$$.log | (cd "$bigdir" ; tar xf -) || LogIt "AKMF -- Could not copy $mappath to $bigdir" $MINDI_TMP/$$.log
[747]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
[925]232 if [ ! -e "$included_item" ] ; then
[1764]233 sss=`grep -F "${included_item}.inc" $MINDI_TMP/keymaps.find`
234 [ "$sss" = "" ] && sss=`grep -F "$included_item" $MINDI_TMP/keymaps.find`
[925]235 for ii in $sss ; do
[747]236 [ -e "$ii" ] && AddKeyboardMappingFile $ii
[925]237 done
238 else
239 AddKeyboardMappingFile $included_item
240 fi
[747]241 done
242}
243
244
245CopyDependenciesToDirectory() {
[1989]246 local outdir incoming fname counter d found
[747]247 outdir=$1
248 mkdir -p $outdir
249 incoming=`ReadLine`
250 counter=0
251 while [ "$incoming" != "" ] ; do
[1526]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
[747]266 find $incoming/* -maxdepth 0 2> /dev/null | CopyDependenciesToDirectory $outdir
[1526]267 elif [ -e "$incoming" ] && [ $found = "false" ]; then
[2712]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
[1989]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"
[925]273 fi
[1989]274 [ -x "$outdir" ] && StripExecutable $outdir "-$filename-"
[925]275 counter=$(($counter+1))
276 if [ "$counter" -ge "5" ] ; then
277 counter=0
278 echo -en "."
279 fi
[747]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
[859]303 return 0
[747]304 fi
305 echo -en "Dropping i686-optimized libraries if appropriate"
306 for optimized_lib_name in $list_of_optimized_libraries ; do
[859]307 echo -en "."
308 reason=""
[1483]309 vanilla_lib_name=`echo "$optimized_lib_name" | sed -e 's/i[5-7]86//' -e 's/cmov//' -e 's/nosegneg//' | tr -s '/' '/'`
[859]310 echo "$vanilla_lib_name" >> $filelist
[2168]311 echo "Adding $vanilla_lib_name to filelist" >> $LOGFILE
[859]312 mkdir -p $outdir$optimized_lib_name > /dev/null 2> /dev/null
313 rmdir $outdir$optimized_lib_name > /dev/null 2> /dev/null
[2168]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
[747]328 done
[925]329 $AWK '{ print $1; }' $filelist | sort -u > $filelist.tmp
[747]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
[963]337 LogIt "Analyzing your keyboard's configuration."
[747]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
[1713]342 [ ! -e "$KEYDIR" ] && KEYDIR=/etc/condole
343 [ ! -e "$KEYDIR" ] && KEYDIR=/etc/condole-setup
[747]344 if [ ! -e "$KEYDIR" ] ; then
[963]345 LogIt "Keyboard mapping directory not found. I shall use default map at boot-time."
[747]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
[963]364 cp /etc/console/boottime.kmap.gz $bigdir/etc/console 2>> $LOGFILE
[747]365 echo -e "$DONE"
366 return 0
[1713]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
[2744]377 elif [ -e "/etc/rc.conf" ] ; then
[2748]378 echo "ArchLinux config detected." >> $LOGFILE
[2744]379 keyfile=/etc/rc.conf
[1465]380 elif [ -e "/etc/conf.d/keymaps" ] ; then
381 echo "Gentoo-style config detected." >> $LOGFILE
382 keyfile=/etc/conf.d/keymaps
[747]383 else
384 echo -en "Searching for rc.config ..."
385 keyfile=`find /etc -name rc.config | head -n1`
386 if [ "$keyfile" = "" ] || [ ! -e "$keyfile" ] ; then
[963]387 LogIt "Unknown config detected. Default keyboard map will be used."
[747]388 return
389 else
390 echo "Found $keyfile" >> $LOGFILE
391 fi
392 fi
393 if [ ! -e "$KEYDIR/keymaps" ] ; then
[963]394 LogIt "Keyboard mapping directory not found. Default keyboard map will be used."
[747]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
[2744]400 [ ! "$locale" ] && locale=`grep -E '^KEYMAP=' "$keyfile" | tr -d '"' |cut -d'=' -f2` # Gentoo & ArchLinux
[747]401 echo "locale=$locale" >> $LOGFILE
[1764]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 " *#.*"`
[747]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
[1854]420 mappath=$(find / -name "*/kbd/keymaps/*/$locale")
[747]421 fi
422 echo "mappath = $mappath" >> $LOGFILE
423 if [ ! -e "$mappath" ] || [ -d "$mappath" ] ; then
[963]424 LogIt "Keyboard mapping file not found. Default keyboard map will be used."
[747]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
[2055]430 KBDEPTH=0
[747]431 AddKeyboardMappingFile $mappath
432 echo -e "$DONE"
[1764]433 rm -f $MINDI_TMP/keymaps.find
[747]434 return 0
435}
436
437
[2629]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
[747]451FindIsolinuxBinary() {
452 ISOLINUX=/usr/lib/isolinux.bin
453 [ ! -e "$ISOLINUX" ] && ISOLINUX=/usr/lib/syslinux/isolinux.bin
[1491]454 [ ! -e "$ISOLINUX" ] && ISOLINUX=/usr/lib64/syslinux/isolinux.bin
[747]455 [ ! -e "$ISOLINUX" ] && ISOLINUX=/usr/share/syslinux/isolinux.bin
456 [ ! -e "$ISOLINUX" ] && ISOLINUX=/usr/share/lib/syslinux/isolinux.bin
[1491]457 [ ! -e "$ISOLINUX" ] && ISOLINUX=/usr/share/lib64/syslinux/isolinux.bin
[1854]458 [ ! -e "$ISOLINUX" ] && ISOLINUX=`find / -name isolinux.bin | grep -x "/.*/isolinux.bin"`
[747]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
[2712]468 cd "$MINDI_TMP"
[747]469 else
470 cd /
471 fi
472 if [ ! -e "$1" ] ; then
[963]473 LogIt "WARNING - cannot search specific path '$1'"
[747]474 return 1
475 fi
[2553]476 # Find all files and links (required for some VMWare VMs)
[2600]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`
[747]478 echo "$modpaths"
[2712]479 cd "$pwd"
[747]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
[940]488 tempfile=$MINDI_TMP/$$.txt
[747]489 incoming=`ReadLine`
490
491 > $tempfile
492 progress=0
493 res=0
494 noof_lines=$2
495 while [ "$incoming" != "" ] ; do
[861]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
[747]503 filelist=`GenerateListForFile "$incoming"`
504 r=$?
[963]505 [ "$r" -ne "0" ] && LogIt "$incoming not found"
[747]506 res=$(($res+$r))
[861]507# echo "'$incoming' generates filelist '$filelist'" >> $LOGFILE
[747]508 for fname in $filelist ; do
[861]509 [ "$fname" != "" ] && echo "$fname" >> $tempfile
[747]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
[861]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`
[1342]535 if [ "$tool" = "$lvmresolved" ]; then
[861]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;}'`
[1342]543 if [ "$lvmversion" = "200" ]; then
[861]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
[747]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`
[1876]592 echo "---------------------------------" >> $LOGFILE
593 echo "List of dependencies: " >> $LOGFILE
594 echo "---------------------------------" >> $LOGFILE
[747]595 for fname in `cat $tempfile` ; do
[1876]596 echo "$fname" | tee -a $LOGFILE >> $outfile.pre
597 LocateDeps $fname | tee -a $LOGFILE >> $outfile.pre
[925]598 progress=$(($progress+1))
[747]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 "%"
[925]604 modres=$(($progress%4))
[747]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
[1684]610 if [ _"$MONDO_SHARE" != _"" ]; then
[925]611 mkdir -p $bigdir/tmp
612 mkdir -p $bigdir/sbin
613 mkdir -p $bigdir/bin
[940]614 if [ -e "$MINDI_TMP/post-nuke.tgz" ] ; then
[963]615 LogIt "\nIncorporating post-nuke tarball"
[925]616 old_pwd=`pwd`
[2712]617 cd "$bigdir"
[2166]618 tar -zxf $MINDI_TMP/post-nuke.tgz 2>> $MINDI_TMP/$$.log || LogIt "Error occurred when untarring post-nuke tarball" $MINDI_TMP/$$.log
[2712]619 cd "$old_pwd"
[747]620 fi
[963]621 if cp -f $MINDI_TMP/mondo*restore $bigdir/usr/bin 2>> $LOGFILE ; then
[925]622 LocateDeps $bigdir/usr/bin/mondo*restore >> $outfile.pre
623 else
[963]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."
[925]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
[2092]629 cp -f $MINDI_TMP/BOOTLOADER.* $bigdir 2>> $LOGFILE || LogIt "\nMondo v1.2x defaults to LILO as the bootloader, BTW."
[2380]630 if [ -e "$MINDI_TMP/NETFS-DEV" ] ; then
631 LogIt "\nIncorporating Network-related settings"
632 for r in NETFS-* ISO-PREFIX ; do
[963]633 cp -f $MINDI_TMP/$r $bigdir/tmp 2>> $LOGFILE || Die "Cannot copy $r - did you run out of disk space?"
[925]634 echo "Copying $r to ramdisk" >> $LOGFILE
635 done
636 fi
[747]637 fi
[925]638 tr ' ' '\n' < $outfile.pre | tr -s '/' '/' | grep -Fvx "" | sort -u | grep -Ev "/libX11|/libXext|/libXi|/libgtk|/libgdk" > $outfile
[747]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
[1230]681# Check kernel filesystem capabilites for accessing initrd image
[2429]682# Could be ext2 FS (old mode) or initramfs (new mode)
[1230]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"
[2047]698 local lcMagicExt2fs="EXT2-fs: blocksize too small for device."
[2390]699 local lcMagicExt3fs="<3>EXT3-fs: blocksize too small for journal device."
[2311]700 local lcMagicInitfs="<6>checking if image is initramfs...|<6>Unpacking initramfs...|<6>Trying to unpack rootfs image as
701initramfs"
[1230]702
703 # local variables
704 local lvOffset
705 local lvScanRes
706 local lvUseFilesystem
707
708 # say where we are.
[2495]709 echo " GetInitrdFilesystemToUse(): called with parameter: $lvKernelImage" >> $LOGFILE
[1230]710
711 # verify that file exists
712 [ ! -f $lvKernelImage ] && Die "File $lvKernelImage not found. Terminating."
713
[1566]714 # Kernel may be gzip compressed
[1730]715 file $lvKernelImage 2>&1 | grep -q gzip
[1566]716 if [ $? -eq 0 ]; then
[2390]717 lvScanRes=`gzip -cd $lvKernelImage | strings | grep -E "$lcMagicCramfs|$lcMagicExt2fs|$lcMagicExt3fs|$lcMagicInitfs"`
[2429]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"
[2393]728 else
[2429]729 lvUseFilesystem="UNSUPPORTED"
[2393]730 fi
731
[2429]732 else
733 # In that case, we are after 2.6.30 and use the supported initramfs
[1230]734 lvUseFilesystem="initramfs"
735 fi
736 # say what we are using
[2429]737 echo " GetInitrdFilesystemToUse(): Filesytem to use for initial ram disk is $lvUseFilesystem.\n" >> $LOGFILE
[1230]738
739 # return file system to use
740 echo "$lvUseFilesystem"
741
742}
743
[747]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() {
[2292]759 local incoming newpath stub i pwd
[747]760 incoming=`ReadLine`
761 pwd=`pwd`
[2712]762 cd "$MINDI_TMP"
[747]763 while [ "$incoming" != "" ] ; do
[925]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
[747]770 done
[2712]771 cd "$pwd"
[747]772}
773
774
775ListAllPartitions() {
776 local res currline partition all_partitions ap_orig remaining i j
777
[2070]778 grep -Evx " *#.*| *none.*" $MY_FSTAB | $AWK '/^\/dev\/[imhs]d||^LABEL=\/|^UUID=/ && !/\/fdd|\/cdr|\/zip|\/floppy/ {print $1}'
[747]779 [ -e "/etc/raidtab" ] && $AWK '/^ *device/ {print $2}' /etc/raidtab
[1824]780 if [ -e "/vmfs/volumes" ]; then
781 # For VMWare ESX 3 get the device names of these volumes
[2431]782 vdf -P | grep -E '/vmfs/volumes' | $AWK '{print $1}'
[1824]783 fi
[747]784 return
785}
786
787
788ListImagesForUser() {
789 local path fname
[1983]790 path=$MINDI_CACHE
[747]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() {
[2583]800 local module_list module fname r kern
[1399]801 module_list="$MODULES"
[1230]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' ' '`
[1726]805 EXTRA_MODS=`echo ${EXTRA_MODS} | tr ' ' '\n' | grep -Ev "^${i}$" | tr '\n' ' '`
[1230]806 done
[747]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
[2292]814 kern="$KERVERRUN"
[747]815 fi
[2292]816 export KERVER=$kern
[747]817###
818### Sq-Mod End
819###
[2471]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
[747]823 r=`find /lib/modules/$kern -type f | grep "/${module}\..*o" | tail -n1`
[2471]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
[2583]830 else
831 [ -f "$r" ] && echo "$r"
[2471]832 fi
[747]833 echo "module $module --> $r" >> $LOGFILE
834 done
835 find /lib/modules/$kern/modules.* -type f 2> /dev/null
836}
837
[1784]838#
839# Critical function which computes all dependencies (dyn. lib.)
840# for a list of binaries
841#
[747]842LocateDeps() {
843 local incoming fname deps
[1724]844 incoming="$*"
[747]845 for fname in $incoming ; do
846 if [ ! -e "$fname" ] ; then
[963]847 echo "WARNING - $fname does not exist; cannot be LDD'd." >> $LOGFILE
[747]848 if echo $fname | grep lvm &> /dev/null ; then
849 echo "This warning only affects you if you are using LVM." >> $LOGFILE
[1399]850 if echo "$MODULES" | grep lvm &> /dev/null ; then
[747]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
[1526]859 ldd $fname 2> /dev/null | ProcessLDD
[747]860 fi
861 done
862}
863
[925]864
[860]865# Give all symlinks recursively of a full path name
866ReadAllLink() {
867 file="$1"
[747]868
[2174]869 echo $file | grep -q '\.\./'
[2175]870 if [ $? -eq 0 ]; then
[2174]871 # We need to normalise the path with .. in it
872 file=`echo $file | perl -pi -e 's|([^/]+)/([^/]+)/\.\./([^/]+)|$1/$3|'`
873 fi
[1883]874 echo "$file"
[860]875 if [ ! -h $file ]; then
876 return 0
877 fi
[747]878
[1883]879 link=`readlink $file`
[862]880 d=`dirname $file`
[1883]881 fchar=`echo $link | cut -c1`
882 # If mother dir is a link print it
[1230]883 if [ -h "$d" ]; then
[1784]884 echo "$d"
[1883]885 d=`readlink $d`
886 fi
887 if [ "$fchar" != "/" ]; then
888 # Relative or local link
889 ReadAllLink "$d/$link"
[860]890 else
[1883]891 # Absolute path
892 ReadAllLink $link
[1230]893 fi
[860]894}
895
[925]896
[747]897LocateFile() {
898 local i path fname_to_find location output resolved tmp stub cache_id loclist
899 fname_to_find="$1"
[1526]900 # It's an absolute path
[747]901 if echo "$fname_to_find" | grep -x "/.*" ; then
[859]902 output="$fname_to_find"
[860]903 if [ -h "$output" ] ; then
904 output="`ReadAllLink $output` $output"
905 fi
[859]906 echo "$output"
907 return 0
[747]908 fi
[1526]909 # It's not an absolute path
[747]910 output=""
[1526]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
[747]919 done
920 if [ "$output" = "" ] ; then
[860]921 return 1
[747]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
[1698]935 [ "$USBDEVICE" ] && echo "usb-dev $USBDEVICE" >> $outfile
[747]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"
[998]940 use_gzip=$USE_GZIP; [ "$use_gzip" = "" ] && use_gzip="no"
[747]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
[998]944 echo "use-gzip $use_gzip" >> $outfile
[747]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
[2380]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
[940]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
[949]968 AddFileToCfgIfExists $MINDI_TMP/ACL acl $outfile
969 AddFileToCfgIfExists $MINDI_TMP/XATTR xattr $outfile
[1948]970 AddFileToCfgIfExists $MINDI_TMP/OBDR obdr $outfile
[747]971}
972
[2618]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}
[747]983
[2618]984
[747]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 \
[2013]989absolute_partition old_partition_fmt current_lvolume uname skip
[747]990
[967]991 echo "Your raw fstab file looks like this:" >> $LOGFILE
992 echo "------------------------------------" >> $LOGFILE
[747]993 cat $MY_FSTAB >> $LOGFILE
[967]994 echo "Your mountlist will look like this:" | tee -a $LOGFILE
995 echo "-----------------------------------" >> $LOGFILE
[747]996
997# scratchdir, mountlist(OUT)
[940]998 scratchdir=$MINDI_TMP
[747]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
[1684]1006 [ "$mountlist" != "" ] && rm -Rf $mountlist
[747]1007 > $mountlist
1008 all_partitions=""
1009
1010 if [ $LVM != "false" ]; then
[1885]1011 echo -en "Analyzing LVM...\n"
[968]1012 $MINDI_LIB/analyze-my-lvm > $MINDI_TMP/lvm.res
[971]1013 if [ $? -ne 0 ]; then
[963]1014 LVM="false"
1015 fi
[2536]1016 # Excluded LVs and GVs are not reported here
[2424]1017 all_partitions=`cat $MINDI_TMP/lvm.res | grep -F ">>>" | cut -d' ' -f2-`
[747]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 ' ' '`"
[1755]1024 printf " %-15s %-15s %-15s %-15s %-15s\n" DEVICE MOUNTPOINT FORMAT "SIZE (MB)" LABEL/UUID | tee -a $LOGFILE
[747]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
[2452]1027 # Skip evices, network FS, cisf
1028 [ "`echo "$useless_dev" | grep -F "$c_p"`" != "" ] || [ "`echo "$c_p" | grep ":"`" != "" ] || [ "`echo "$c_p" | grep -E "^//"`" != "" ]&& continue
[747]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
[861]1031 current_partition=`readlink -f $c_p`
[747]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
[2193]1038 # Debian 5 does that
1039 [ "$c_p" = "proc" ] && continue
[747]1040 redhat_label=""
[1831]1041 label=""
[957]1042 uuid=""
[861]1043 absolute_partition=`readlink -f $c_p`
[747]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
[1986]1052 # set default in case we dont't find it
1053 str_to_find_fmt_with=$current_partition
1054
[747]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
[980]1058 redhat_label=`echo "$current_partition" | cut -d'=' -f2`
[747]1059 actual_dev=""
[853]1060
1061 # 1st try, findfs - the RHEL way of finding labels and their partitions
1062 if [ -x "/sbin/findfs" ]; then
[855]1063 actual_dev=`/sbin/findfs LABEL=${redhat_label} 2> /dev/null`
[853]1064 fi
[747]1065
[853]1066 # 2nd try : blkid, the good way for all LABEL except swap
1067 if [ "x$actual_dev" = "x" -a -x "/sbin/blkid" ]; then
[980]1068 actual_dev=`/sbin/blkid | /bin/grep "$redhat_label" | grep LABEL= | cut -d':' -f1`
[747]1069 # For LVM FS it will give a /dev/dm-# which should then be converted
[748]1070 if [ $LVM = "v2" ] && [ "`echo $actual_dev | grep '/dev/dm'`" ]; then
[963]1071 major=`/bin/ls -l $actual_dev | $AWK '{print $5}'`
1072 minor=`/bin/ls -l $actual_dev | $AWK '{print $6}'`
[747]1073 for dev in `ls /dev/mapper/*`; do
[963]1074 major1=`/bin/ls -l $dev | $AWK '{print $5}'`
1075 minor1=`/bin/ls -l $dev | $AWK '{print $6}'`
[747]1076 if [ $major1 = $major ] && [ $minor1 = $minor ]; then
[963]1077 actual_dev=`/bin/ls -l $dev | $AWK '{print $10}'`
[747]1078 break
1079 fi
1080 done
1081 fi
1082 fi
1083
[853]1084 # 3rd try, which works on a standard partition (ext2/3), but not on swap
[747]1085 # For LVM gives a /dev/mapper entry
1086 if [ "x$actual_dev" = "x" ]; then
[980]1087 actual_dev=`/bin/mount -l | /bin/grep "\[$redhat_label\]" | cut -d' ' -f1`
[747]1088 fi
1089
[853]1090 # 4th try, with vol_id
[747]1091 # SWAP only
1092 if [ "x$actual_dev" = "x" -a -x "/sbin/vol_id" ]; then
[963]1093 list_swaps=`cat /proc/swaps | /bin/grep "/dev/" | $AWK '{ print $1 }' `
[747]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
[853]1103 # 5th try : pre-formated LABEL. Format is : LABEL=SWAP-mydevice or SW-mydevice. e.g. : LABEL=SWAP-hda5
[789]1104 # LABEL=SW-cciss/c0d0p3 (RDP)
[853]1105 # or could be a string that isn't a complete device name (eg. LABEL =SWAP-cciss/c0d0p)
[747]1106 # SWAP only
[789]1107 if [ "x$actual_dev" = "x" -a _"`echo $current_partition | /bin/grep -iE 'LABEL=SWAP|LABEL=SW-'`" != _"" ]; then
[2013]1108 skip=""
[2292]1109 uname=$KERVERRUN
[2013]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
[853]1119 for try_dev in `tail +2 /proc/swaps | cut -d' ' -f1`
1120 do
1121 # Location of the swap label for kernel 2.6
[2013]1122 try_dev_label=`dd bs=1 count=16 skip=$skip if=$try_dev 2> /dev/null`
[853]1123 if [ "x$try_dev_label" = "x$redhat_label" ]; then
[855]1124 actual_dev=$try_dev
[853]1125 fi
1126 done
[747]1127 fi
[1008]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
[1885]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"
[1008]1134 fi
[957]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
[1009]1137 elif [ "`echo "$current_partition" | /bin/grep -i "UUID="`" != "" ]; then
[980]1138 uuid=`echo "$current_partition" | cut -d'=' -f2`
[957]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
[1531]1146 # 2nd try : blkid, the good way for all UUID except swap
[957]1147 if [ "x$actual_dev" = "x" -a -x "/sbin/blkid" ]; then
[980]1148 actual_dev=`/sbin/blkid | /bin/grep "$uuid" | grep UUID= | cut -d':' -f1`
[957]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
[963]1151 major=`/bin/ls -l $actual_dev | $AWK '{print $5}'`
1152 minor=`/bin/ls -l $actual_dev | $AWK '{print $6}'`
[957]1153 for dev in `ls /dev/mapper/*`; do
[963]1154 major1=`/bin/ls -l $dev | $AWK '{print $5}'`
1155 minor1=`/bin/ls -l $dev | $AWK '{print $6}'`
[957]1156 if [ $major1 = $major ] && [ $minor1 = $minor ]; then
[963]1157 actual_dev=`/bin/ls -l $dev | $AWK '{print $10}'`
[957]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
[963]1166 list_dev=`mount | /bin/grep -E '^/' | $AWK '{ print $1 }' `
[957]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
[1531]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
[747]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
[2069]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."
[747]1193 fi
1194 else
[1863]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
[1986]1198 # set default in case we dont't find it
[1863]1199 for tmpp in `tr -s '\t' ' ' < $MY_FSTAB | /bin/grep -Ev "^#" | $AWK '{print $1}'`; do
[1864]1200 if [ _"`readlink -f $tmpp`" = _"$current_partition" ]; then
[1863]1201 str_to_find_fmt_with=$tmpp
[1865]1202 partition_mountpt=`tr -s '\t' ' ' < $MY_FSTAB | /bin/grep -w "$tmpp" | /bin/grep -vx " *#.*" | $AWK '{print $2}' | head -n1`
[1864]1203 break;
[1863]1204 fi
1205 done
1206 fi
[747]1207 fi
1208
[2566]1209 # Look for devices which have to be excluded
1210 skip=0
1211 if [ "$MINDI_EXCLUDE_DEVS" ] ; then
[2568]1212 l=""
1213 list_of_devices="`ReadAllLink $current_partition`"
1214 for d in $list_of_devices; do
[2579]1215 l="$l `$MINDI_LIB/analyze-my-lvm --givemapperofdm $d`"
[2568]1216 done
[2618]1217
1218 # Remove PVs from LVs excluded
1219 l="$l `GetPVsForLV $current_partition`"
1220
1221 # We want a single unique list
[2568]1222 list_of_devices="`echo $l | sort -u`"
[2618]1223
[2566]1224 for d in $MINDI_EXCLUDE_DEVS ; do
[2568]1225 if [ "`echo " $list_of_devices " | grep " $d"`" != "" ]; then
[2566]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
[747]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
[755]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
[747]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"
[763]1250 if [ $LVM = "v2" ] && [ "`echo $current_partition | grep -E '^/dev/mapper/'`" ]; then
[755]1251 # .static dir are a Debian specificity
[763]1252 current_lvolume="`find /dev -lname "$current_partition" | grep -Ev '^/dev/\.static/'`"
[755]1253 echo $current_lvolume | grep -q ' '
[784]1254 if [ $? -eq 0 ]; then
[755]1255 echo "WARNING: Multiple Logical Volumes found. Report to dev team" >> $LOGFILE
1256 fi
[2072]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
[747]1262 fi
1263 #
1264 # End of LVM device style variation code (other than $current_lvolume).
1265
[745]1266 if [ $LVM != "false" ] && [ "`$LVMCMD lvdisplay $current_lvolume 2> /dev/null`" ]; then
1267 # Size computed via LVM not directly
[747]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
[2566]1317
[747]1318 if [ ! "$partition_mountpt" ] ; then
[965]1319 echo "------- $FDISK -l $qq log ------------" >> $LOGFILE
[1883]1320 for qq in "" `find /dev/ida/c*d* ! -name '*p*' 2> /dev/null`; do
[747]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
[965]1324 echo "------- $FDISK log end ------------" >> $LOGFILE
[747]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
[963]1328 LogIt "Unable to find mountpoint of $current_partition - ignoring"
[747]1329 continue
1330 fi
1331 fi
[1755]1332 if [ "$redhat_label" ]; then
1333 label="$redhat_label"
[1756]1334 elif [ "$uuid" ]; then
[1755]1335 label="$uuid"
1336 fi
[747]1337 partition_format="`echo "$partition_format" | cut -d',' -f1`"; # in case user has ext3,ext2 or something dumb like that
[963]1338 [ "$partition_format" = "auto" ] && partition_format="`mount | grep -w $current_partition | $AWK '{print$5;}'`"; # in case user uses 'auto' (dumb!)
[1755]1339 unofficial_outstring=`printf "\t%-15s %-15s %-15s %7s %-15s\n" $current_partition $partition_mountpt $partition_format $psz "$label"`
[747]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
[1755]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
[747]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
[2432]1359 echo "vfat should be used instead of dos/msdos as a partition format" >> $LOGFILE
[747]1360 partition_format="vfat"
1361 fi
[1755]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
[747]1364 fi
1365 done
1366}
1367
[2432]1368CheckMountlist() {
1369 local file=$1
1370 # Coherency verification
[2529]1371 ML01=`cat $file | wc -l`
[2585]1372 ML02=`grep -v ' lvm ' $file | wc -l`
[2432]1373 ML1=`$AWK '{print $1}' $file | sort -u | wc -l`
[2585]1374 ML2=`grep -v ' lvm ' $file | $AWK '{print $2}' | sort -u | wc -l`
[2529]1375 if [ "$ML01" -ne "$ML1" ]; then
[2432]1376 echo "--------------------------------------------" >> $LOGFILE
1377 echo "WARNING: Duplicate device entry in mountlist" | tee -a $LOGFILE
1378 echo "--------------------------------------------" >> $LOGFILE
1379 fi
[2529]1380 if [ "$ML02" -ne "$ML2" ]; then
[2432]1381 echo "--------------------------------------------" >> $LOGFILE
1382 echo "WARNING: Duplicate mountpoint entry in mountlist" | tee -a $LOGFILE
1383 echo "------------------------------------------------" >> $LOGFILE
1384 fi
1385}
[747]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
[2457]1398 if [ -z "$ISO_CMD" ]; then
1399 LogIt "Neither mkisofs nor genisoimage found, unable to make CD image"
1400 return
1401 fi
[1684]1402 if [ "$PROMPT_MAKE_CD_IMAGE" = "yes" ] && [ _"$MONDO_SHARE" = _"" ]; then
[966]1403 echo -en "Shall I make a bootable CD image? (y/[n]) "
[747]1404 read i
1405 [ "$i" != "y" ] && [ "$i" != "Y" ] && return 0
1406 fi
[940]1407 rm -Rf $MINDI_TMP/iso
[1983]1408 mkdir -p $MINDI_TMP/iso/{images,archives}
[2084]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"
[747]1410 echo "mindi_lib = $MINDI_LIB" >> $LOGFILE
1411 for i in memdisk memtest.bin memtest.img ; do
[953]1412 j=$MINDI_LIB/$i
[1983]1413 k=$MINDI_TMP/iso
[953]1414 if [ -e "$j" ] ; then
[963]1415 LogIt "Copying $j to $k"
[2092]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"
[1885]1418 if [ _"$MONDO_SHARE" != _"" ]; then
1419 cp -f $j $MONDO_ROOT 2>> $LOGFILE || Die "Failed to copy $j to $MONDO_ROOT"
1420 fi
[953]1421 fi
[747]1422 done
[1983]1423 MakeMessageFile > $MINDI_TMP/iso/message.txt
[2629]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
[2681]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?"
[2629]1430
[1885]1431 if [ _"$MONDO_SHARE" != _"" ]; then
[2681]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
[1929]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?"
[1983]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?"
[1885]1438 fi
[2073]1439 MakeBootConfFile isolinux > $MINDI_TMP/iso/isolinux.cfg
[747]1440 if [ "$ARCH" != "ia64" ] ; then
[2092]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?"
[747]1442 fi
[1983]1443 old_pwd=`pwd`
[2712]1444 cd "$MINDI_TMP/iso"
[747]1445 if [ "$ARCH" != "ia64" ] ; then
[1885]1446 if [ _"$MONDO_SHARE" != _"" ]; then
[2681]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?"
[2629]1450 fi
[1983]1451 cp -f $MONDO_SHARE/autorun $MINDI_TMP/iso 2>> $LOGFILE
[1885]1452 fi
[1983]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
[747]1454 else
[1983]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
[747]1456 fi
1457 if [ "$?" -ne "0" ] ; then
[1885]1458 echo "----------- $ISO_CMD's errors --------------" >> $LOGFILE
[940]1459 cat $MINDI_TMP/mkisofs.log >> $LOGFILE
[1885]1460 echo "$ISO_CMD returned the following errors:-"
[940]1461 cat $MINDI_TMP/mkisofs.log
[963]1462 LogIt "Failed to create ISO image."
[747]1463 else
[1880]1464 echo "Created bootable ISO image at $MINDI_CACHE/mindi.iso" | tee -a $LOGFILE
[747]1465 fi
[940]1466 rm -f $MINDI_TMP/mkisofs.log
[2712]1467 cd "$old_pwd"
[747]1468}
1469
1470
[1684]1471OfferToMakeBootableUSB() {
[2041]1472 local i
[1684]1473 if [ "$PROMPT_MAKE_USB_IMAGE" = "yes" ] && [ _"$MONDO_SHARE" = _"" ]; then
[2621]1474 echo -n "Shall I make a bootable USB device ? (y/[n]) "
[1764]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
[1722]1481 fi
[1764]1482 echo "WARNING: This will erase all content on $USBDEVICE"
1483 echo -en "Are you sure you want to use $USBDEVICE (y/[n]) "
[2040]1484 read i
1485 [ "$i" != "y" ] && [ "$i" != "Y" ] && return 0
[1684]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
[1857]1495 $FDISK -l $USBDEVICE 2>> $LOGFILE 1>> $LOGFILE
[1684]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 "."
[2461]1502 echo "Unmounting $USBPART just in case" >> $LOGFILE
[1721]1503 umount $USBPART 2>> $LOGFILE 1>> $LOGFILE
[2057]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
[2054]1506 echo "Preparing $USBDEVICE" >> $LOGFILE
[1721]1507 $FDISK $USBDEVICE 2>> $LOGFILE 1>> $LOGFILE << EOF
[2057]1508d
1509d
1510d
1511d
[1684]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
[2190]1529 echo "The USB device $USBDEVICE now looks like this:" >> $LOGFILE
1530 $FDISK -l $USBDEVICE 2>&1 | tee -a $LOGFILE
[1684]1531 echo -en "."
[2461]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 "."
[1684]1536 echo "Creating a vfat filesystem on $USBPART" >> $LOGFILE
[1688]1537 mkdosfs -F 32 $USBPART 2>&1 >> $LOGFILE
[1684]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 "."
[1691]1554 mkdir -p $MINDI_TMP/usb/images
[1983]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"
[1684]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"
[2092]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"
[1684]1565 fi
1566 done
1567 echo -en "."
[1983]1568 MakeMessageFile > $MINDI_TMP/usb/message.txt
[1684]1569 echo -en "."
[2092]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?"
[1684]1571 echo -en "."
[1983]1572 cp $MINDI_TMP/initrd.img $MINDI_TMP/usb/initrd.img 2>> $LOGFILE
[1684]1573 echo -en "."
[2041]1574 MakeBootConfFile syslinux > $MINDI_TMP/usb/syslinux.cfg
[1684]1575 echo -en "."
[2476]1576 echo "----------- syslinux's conf --------------" |tee -a $LOGFILE
1577 cat $MINDI_TMP/usb/syslinux.cfg |tee -a $LOGFILE
1578 echo "------------------------------------------" |tee -a $LOGFILE
[1721]1579 umount $MINDI_TMP/usb
[1684]1580 if [ "$ARCH" != "ia64" ] ; then
[2056]1581 syslinux -s $USBPART 2>> $MINDI_TMP/syslinux.log
[1684]1582 if [ "$?" -ne "0" ] ; then
1583 echo "----------- syslinux's errors --------------" |tee -a $LOGFILE
1584 cat $MINDI_TMP/syslinux.log |tee -a $LOGFILE
[2476]1585 echo "------------------------------------------" |tee -a $LOGFILE
[1684]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
[747]1599MakeMessageFile() {
[2292]1600
1601 if [ -x "/bin/lsb_release" ]; then
1602 DESC=`/bin/lsb_release -d | cut -d: -f2 | sed "s/[ \t]*//"`
[2732]1603 elif [ -r /etc/issue.net ]; then
[2731]1604 DESC=`head -1 /etc/issue.net`
[2732]1605 elif [ -r /etc/issue ]; then
[2731]1606 DESC=`head -1 /etc/issue`
[2292]1607 elif [ -x "/usr/bin/pbdistrocheck" ]; then
1608 # For pb >= 0.9.8
[2731]1609 DESC=`/usr/bin/pbdistrocheck -s | cut -d, -f1-4`
[747]1610 else
[2731]1611 DESC="Unknown desc"
[747]1612 fi
[2292]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/"
[1885]1614 if [ _"$MONDO_SHARE" != _"" ]; then
1615 if [ "$CDRECOVERY" != "yes" ] ; then
[2380]1616 if [ -e "$MINDI_TMP/NETFS-DEV" ] ; then
[1885]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"
[1983]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
[1885]1623 else
1624 echo -en "$BOOT_MEDIA_MESSAGE"
[747]1625 fi
[1983]1626 else
1627 echo -en "\
[747]1628To restore your disk to factory defaults, type 'RESTORE' <enter>.\n\
1629CAUTION: THIS WILL ERASE YOUR WHOLE DISK !!!\n"
[1983]1630 fi
[747]1631 fi
1632 echo -en "\n\n\n"
1633}
1634
1635
[1983]1636MakeBootConfFile() {
[1885]1637 local options i ooo
[747]1638 options=""
[1983]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
[925]1646
[1983]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"
[925]1652 fi
[1983]1653
1654 # Compute which default option to boot from
[747]1655 if [ "$CDRECOVERY" = "yes" ] ; then
[1983]1656 echo -en "default${sep}RESTORE\n"
1657 # In case it's mondoarchive
[1885]1658 elif [ _"$MONDO_SHARE" != _"" ]; then
[2380]1659 if [ -e "$MINDI_TMP/NETFS-DEV" ] ; then
[1983]1660 echo -en "default${sep}iso\n"
[747]1661 else
[1983]1662 echo -en "default${sep}interactive\n"
[747]1663 fi
1664 else
[1983]1665 echo -en "default${sep}expert\n"
[747]1666 fi
1667
[1983]1668 # Handle timeout
[747]1669 if [ "$CDRECOVERY" != "yes" ] ; then
[1983]1670 echo -en "timeout${sep}300\n"
1671 else
1672 echo -en "timeout${sep}10000\n"
[747]1673 fi
1674 echo -en "\n"
[1983]1675
[2124]1676 # prepare which labels will be generated
[747]1677 if [ "$CDRECOVERY" = "yes" ] ; then
[925]1678 options="RESTORE expert"
[1885]1679 else
1680 if [ _"$MONDO_SHARE" != _"" ]; then
[2344]1681 options="interactive expert compare iso nuke isonuke"
[747]1682 else
1683 options="expert"
[925]1684 fi
[747]1685 fi
[1983]1686
1687 # Generate rest of conf file
[747]1688 for i in $options ; do
[925]1689 ooo=$i
1690 [ "$ooo" = "RESTORE" ] && ooo="nuke"
[1983]1691 if [ "$type" = "elilo" ]; then
[2564]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"
[925]1693 else
[2073]1694 ps="/"
1695 if [ "$type" = "syslinux" ]; then
1696 ps=""
1697 fi
[2629]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
[925]1703 fi
[1885]1704 echo -en "$outstr"
[747]1705 done
[1983]1706 if [ -e "$MINDI_LIB/memtest.img" ] ; then
1707 if [ "$type" = "elilo" ]; then
1708 echo -en "image=/memtest.bin\n\tlabel=memtest\n"
[2073]1709 echo -en "image=/memdisk\n\tlabel=memdisk\nappend=\"initrd=memtest.img\"\n"
[1983]1710 else
[2073]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"
[1983]1717 fi
1718 fi
[747]1719}
1720
1721
1722PrepareBootDiskImage_LILO() {
[1983]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
[747]1726
1727 retval=0
[2690]1728 [ ! -e "$kernelpath" ] && Die "PBDI lilo - cannot find $kernelpath kernel"
[1885]1729 echo -en "Making "$BOOT_SIZE"KB boot disk..."
[1983]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?"
[747]1731 echo -en "..."
[1885]1732 imagefile=$imagesdir/mindi-bootroot.$BOOT_SIZE.img
[940]1733 mountpoint=$MINDI_TMP/mountpoint.$$
[747]1734 mkdir -p $mountpoint
[1885]1735 dd if=/dev/zero of=$imagefile bs=1k count=$BOOT_SIZE &> /dev/null || Die "Cannot dd blank file"
[1983]1736 mkdosfs $imagefile >> $LOGFILE 2>> $LOGFILE
1737 mount -t vfat -o loop $imagefile $mountpoint || LogIt "Cannot mount (PBDI)"
[964]1738 # copy Mindi's skeleton fs & lilo/syslinux/whatever stuff into it
[747]1739 mkdir -p $mountpoint/etc
[1983]1740 liloconf=$mountpoint/elilo.conf
[747]1741
[1983]1742 MakeBootConfFile elilo > $liloconf
[747]1743
[1230]1744 # Copy it so that CD-ROM menu entry is satisfied
[1983]1745 mountefi=0
1746 df -T | grep /boot/efi | grep -q vfat
1747 if [ $? -ne 0 ]; then
1748 mount /boot/efi
[1230]1749 if [ $? -ne 0 ]; then
[1983]1750 echo "You have to mount your EFI partition when using mindi"
1751 MindiExit -1
[1230]1752 fi
[1983]1753 mountefi=1
[1230]1754 fi
[1983]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
[1230]1761
[1983]1762 echo "Copying $MINDI_TMP/initrd.img to $mountpoint..." >> $LOGFILE
1763 cp -f $MINDI_TMP/initrd.img $mountpoint 2>> $LOGFILE
[747]1764 if [ "$?" -ne "0" ] ; then
[1983]1765 LogIt "Failed to copy $MINDI_TMP/initrd.img to $mountpoint"
[940]1766 cat $MINDI_TMP/mtpt.$$ >> $LOGFILE
[963]1767 LogIt "Please unload some of your modules and try again."
[940]1768 rm -f $MINDI_TMP/mtpt.$$
[1983]1769 LogIt "Cannot incorporate initrd.img in bootdisk (kernel / modules too big?)"
[747]1770 retval=$(($retval+1))
1771 fi
[1983]1772 MakeMessageFile > $mountpoint/message.txt
[747]1773
1774 mkdir -p $mountpoint/tmp
[1983]1775 if [ -f "$MINDI_TMP/mondo-restore.cfg" ]; then
1776 cp -f $MINDI_TMP/mondo-restore.cfg $mountpoint/tmp
[747]1777 fi
1778
[925]1779 # copy the kernel across
[1230]1780 [ "$mountpoint" != "" ] && rm -Rf $mountpoint/lost+found
[747]1781 dd if=/dev/zero of=$mountpoint/zero bs=1k count=16 &> /dev/null
[1796]1782 free_space=`df -k -P $mountpoint | tail -n1 | tr -s ' ' '\t' | cut -f4`
[2092]1783 cp -f $kernelpath $mountpoint/vmlinuz > /dev/null 2>> $LOGFILE
[1885]1784 if [ "$?" -ne "0" ] ; then
[925]1785 echo "Files at mountpoint ($mountpoint) :-" >> $LOGFILE
1786 du -sk $mountpoint/* >> $LOGFILE
1787 echo "--- end of list of files ---" >> $LOGFILE
[2691]1788 echo -en "Kernel size = `du -sk $kernelpath | cut -f1` K\nRamdisk free = $free_space K\n" >> $LOGFILE
[1998]1789 [ "$mountpoint" != "" ] && rm -f $mountpoint/vmlinuz
[2712]1790 cd "$old_pwd"
[747]1791 umount $mountpoint || Die "Cannot unmount mountpoint ($mountpoint)"
[963]1792 rmdir $mountpoint || LogIt "Cannot rmdir (PBDI)"
[925]1793 # losetup /dev/loop0 -d
[1998]1794 [ "$imagefile" != "" ] && rm -f $imagefile
[2691]1795 Die "Sorry, your kernel is too big for your image"
[1885]1796 return 0
[747]1797 fi
1798 max_kernel_size=$(($free_space+`du -sk $kernelpath | cut -f1`))
[1885]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
[1794]1801 # make it bootable
[1998]1802 [ "$mountpoint" != "" ] && rm -f $mountpoint/zero
[963]1803 [ -e "$MINDI_LIB/memdisk" ] && cp -f $MINDI_LIB/memdisk $mountpoint 2>> $LOGFILE
[1983]1804 if [ "$KERN_DISK_MADE" ] ; then
[925]1805 echo "Not running LILO. It's not that kind of disk." >> $LOGFILE
[747]1806 fi
[925]1807
[1983]1808 cp `dirname $kernelpath`/*.efi $mountpoint 2>> $LOGFILE
[747]1809 umount $mountpoint || Die "Cannot unmount mountpoint ($mountpoint)"
1810 echo -en "..."
[963]1811 rmdir $mountpoint || LogIt "Cannot rmdir (PBDI)"
[747]1812 if [ "$retval" -eq "0" ] ; then
[1885]1813 echo -en "...$DONE\n"
[747]1814 if [ "$KERN_DISK_MADE" ] ; then
[1885]1815 LogIt "$BOOT_SIZE KB boot disks were created OK\n"
[747]1816 fi
1817 else
[1885]1818 echo -en "...failed\n"
1819 LogIt $BOOT_SIZE"KB boot disk was NOT created\n"
[1998]1820 [ "$imagefile" != "" ] && rm -f $imagefile
[747]1821 fi
[963]1822 [ "$retval" -ne "0" ] && LogIt "PrepareBootDiskImage() is returning nonzero"
[747]1823 return $retval
1824}
1825
1826
[2073]1827PrepareBootDiskImage_ISOLINUX() {
[1983]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
[747]1831 do_boot_root_thingy=""
1832 local retval old_pwd
1833 retval=0
[925]1834
[2690]1835 [ ! -e "$kernelpath" ] && Die "PBDI isolinux - cannot find $kernelpath kernel"
[1885]1836 echo -en "Making "$BOOT_SIZE"KB boot disk..."
[1983]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?"
[747]1838 echo -en "..."
[2067]1839 imagefile=$MINDI_TMP/mindi-bootroot.$BOOT_SIZE.img
[940]1840 mountpoint=$MINDI_TMP/mountpoint.$$
[747]1841 mkdir -p $mountpoint
[1885]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
[2067]1845 # syslinux should be run on a local file (doen't work through NFS Cf: #297)
[1885]1846 syslinux $imagefile >> $LOGFILE 2>> $LOGFILE
1847
[2625]1848 # Only move it now to its final destination and use it now
[2067]1849 mv $imagefile $imagesdir
1850 imagefile=$imagesdir/mindi-bootroot.$BOOT_SIZE.img
1851
[963]1852 mount -t vfat -o loop $imagefile $mountpoint || LogIt "Cannot mount (PBDI)"
[925]1853
1854 # copy Mindi's skeleton fs & lilo/syslinux/whatever stuff into it
[1983]1855 MakeMessageFile > $mountpoint/message.txt
[2073]1856 MakeBootConfFile isolinux > $mountpoint/syslinux.cfg
[1983]1857 echo "Copying $MINDI_TMP/initrd.img to $mountpoint/initrd.img..." >> $LOGFILE
1858 cp -f $MINDI_TMP/initrd.img $mountpoint/initrd.img 2>> $LOGFILE
[747]1859 if [ "$?" -ne "0" ] ; then
[1983]1860 LogIt "Failed to copy $MINDI_TMP/initrd.img to $mountpoint"
[940]1861 cat $MINDI_TMP/mtpt.$$ >> $LOGFILE
[963]1862 LogIt "Please unload some of your modules and try again."
[940]1863 rm -f $MINDI_TMP/mtpt.$$
[1983]1864 LogIt "Cannot incorporate initrd.img in bootdisk (kernel / modules too big?)"
[747]1865 retval=$(($retval+1))
1866 fi
1867
1868 mkdir -p $mountpoint/tmp
[1983]1869 if [ -f "$MINDI_TMP/mondo-restore.cfg" ]; then
1870 cp -f $MINDI_TMP/mondo-restore.cfg $mountpoint/tmp
1871 fi
[747]1872
[925]1873 # copy the kernel across
[1230]1874 [ "$mountpoint" != "" ] && rm -Rf $mountpoint/lost+found
[747]1875 dd if=/dev/zero of=$mountpoint/zero bs=1k count=16 &> /dev/null
[1796]1876 free_space=`df -k -P $mountpoint | tail -n1 | tr -s ' ' '\t' | cut -f4`
[2629]1877
1878 retval=0
[2681]1879 cp -f $kernelpath $mountpoint/vmlinuz &> /dev/null
1880 retval=$?
1881 if [ $KERNEL_IS_XEN = "yes" ]; then
[2629]1882 cp -f $xenkernelpath $mountpoint/xenkernel &> /dev/null
1883 let retval+=$?
1884 fi
1885
1886 if [ "$retval" -ne "0" ] ; then
[747]1887 echo "Files at mountpoint ($mountpoint) :-" >> $LOGFILE
1888 du -sk $mountpoint/* >> $LOGFILE
1889 echo "--- end of list of files ---" >> $LOGFILE
[2691]1890 echo -en "Kernel size = `du -sk $kernelpath | cut -f1` K\nRamdisk free = $free_space K\n" >> $LOGFILE
[1998]1891 [ "$mountpoint" != "" ] && rm -f $mountpoint/vmlinuz
[2712]1892 cd "$old_pwd"
[747]1893 umount $mountpoint || Die "Cannot unmount mountpoint ($mountpoint)"
[963]1894 rmdir $mountpoint || LogIt "Cannot rmdir (PBDI)"
[747]1895
[2691]1896 Die "Sorry, your kernel is too big for your image"
[1885]1897 return 0
[747]1898 fi
1899 max_kernel_size=$(($free_space+`du -sk $kernelpath | cut -f1`))
[1885]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
[925]1902
1903 # make it bootable
[1998]1904 [ "$mountpoint" != "" ] && rm -f $mountpoint/zero
[747]1905 mkdir -p $mountpoint/etc
[963]1906 [ -e "$MINDI_LIB/memdisk" ] && cp -f $MINDI_LIB/memdisk $mountpoint 2>> $LOGFILE
[747]1907 umount $mountpoint || Die "Cannot unmount mountpoint ($mountpoint)"
1908 echo -en "..."
[963]1909 rmdir $mountpoint || LogIt "Cannot rmdir (PBDI)"
[747]1910
1911 if [ "$retval" -eq "0" ] ; then
[1885]1912 echo -en "...$DONE\n"
[747]1913 if [ "$KERN_DISK_MADE" ] ; then
[1998]1914 [ "$imagefile" != "" ] && rm -f $imagefile
[1885]1915 LogIt "$BOOT_SIZE KB boot disks were created OK\n"
[747]1916 fi
1917 else
[1885]1918 echo -en "...failed\n"
1919 LogIt $BOOT_SIZE"KB boot disk was NOT created\n"
[1998]1920 [ "$imagefile" != "" ] && rm -f $imagefile
[747]1921 fi
[963]1922 [ "$retval" -ne "0" ] && LogIt "PrepareBootDiskImage() is returning nonzero"
[747]1923 return $retval
1924}
1925
1926
[2006]1927ParseModprobeForIncludes() {
1928local MODPROBE_CONF mpincfile includes include
1929
1930MODPROBE_CONF=/etc/modprobe.conf
1931mpincfile=$1
1932touch $mpincfile
1933if [ -a $MODPROBE_CONF ]; then
[2431]1934 includes=$($AWK '/^[ \t]*include[ \t]+/ {if(NF>=2){print $2}}' $MODPROBE_CONF|sort -u)
[2006]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
[747]1947PrepareDataDiskImages() {
[2006]1948 local needlist bigdir diskdir imagesdir res i j k old_pwd lines lfiles includefile
[747]1949
[1983]1950 imagesdir=$MINDI_CACHE
[1902]1951 rm -f $imagesdir/mindi.iso
[940]1952 needlist=$MINDI_TMP/what-we-need.txt
1953 bigdir=$MINDI_TMP/bigdir
[747]1954 mkdir -p $bigdir/usr/bin
[1983]1955 mkdir -p $bigdir/usr/sbin
[2006]1956 includefile=$MINDI_TMP/$$.includefile.txt
[747]1957
[2409]1958 if [ -e "$DEPLIST_FILE" ]; then
1959 lfiles="$DEPLIST_FILE $DEPLIST_DIR/*"
1960 else
1961 lfiles="$DEPLIST_DIR/*"
1962 fi
[1885]1963 lines=`grep -vx " *#.*" $lfiles | grep -vx "" | wc -l`
[2006]1964 ParseModprobeForIncludes $includefile
[2019]1965 lines=$(($lines+`cat $includefile | wc -l`))
[2006]1966 cat $lfiles $includefile | GenerateGiantDependencyList $needlist $lines
[747]1967 res=$?
[2006]1968 rm -f $includefile
[747]1969 if [ "$YOUR_KERNEL_SUCKS" ]; then
[925]1970 pwd=`pwd`
[2712]1971 cd "$MINDI_TMP"
[747]1972 for i in `ListKernelModulePaths | HackPathsToFailsafe` ; do
[2712]1973 tar cf - ./$i 2>> $MINDI_TMP/$$.log | (cd "$bigdir" ; tar xf -) || Die "PDDI can't copy $i->$bigdir" $MINDI_TMP/$$.log
[747]1974 done
[925]1975 for i in $EXTRA_MODS ; do
[1810]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
[925]1978 for k in $j ; do
[2712]1979 tar cf - $k 2>> $MINDI_TMP/$$.log | (cd "$bigdir" ; tar xf -) || LogIt "ERROR on module $k" $MINDI_TMP/$$.log
[925]1980 echo "Added failsafe module $k to ramdisk" >> $LOGFILE
1981 done
1982 done
[2712]1983 cd "$pwd"
[747]1984 else
[925]1985 ListKernelModulePaths >> $needlist
[747]1986 fi
1987 if [ "$res" -ne "0" ] ; then
[1902]1988 Die "You have $res files present in dependency list\nbut absent from filesystem."
[747]1989 fi
1990 FindAndAddUserKeyboardMappingFile
1991 mkdir -p $bigdir/tmp
[1885]1992 if [ _"$MONDO_SHARE" != _"" ]; then
[940]1993 MakeMondoConfigFile $MINDI_TMP/mondo-restore.cfg
1994 cp -f $MINDI_TMP/mondo-restore.cfg $bigdir/tmp &> /dev/null
[747]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
[925]2001 # also copy io.sys and msdos.sys, if we can find them
[747]2002 for i in `mount | cut -d' ' -f3` ; do
[925]2003 for j in io.sys msdos.sys ; do
[963]2004 [ -e "$i/$j" ] && cp -f $i/$j $bigdir 2>> $LOGFILE
[925]2005 done
[747]2006 done
2007
[925]2008 # master boot record, too
[940]2009 i=`cat $MINDI_TMP/BOOTLOADER.DEVICE 2> /dev/null`
[747]2010 if [ "$i" ] ; then
[963]2011 LogIt "Backing up $i's MBR"
[925]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`
[963]2017 LogIt "Creating /dev/boot_device ($j)"
[925]2018 mkdir -p $bigdir/dev
[2089]2019 cp -pRdf $j $bigdir/dev/boot_device 2>> $LOGFILE || Die "Unable to create /dev/boot_device on ramdisk"
[747]2020 fi
2021
2022 old_pwd=`pwd`
[2712]2023 cd "$bigdir"
[747]2024
[1983]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"
[747]2030 fi
[1764]2031 if [ -e "$MONDO_SHARE/restore-scripts" ]; then
[747]2032 cp -Rdf $MONDO_SHARE/restore-scripts/* . 2>> $LOGFILE
[1335]2033 [ "$?" -ne "0" ] && [ _"$MONDO_SHARE" != _"" ] && Die "Cannot find/install $MONDO_SHARE/restore-scripts"
[747]2034 fi
[2290]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
[2712]2038 cd "$old_pwd"
[747]2039 echo -e "$DONE"
2040 TOTAL_BIGDIR_SIZE=`du -sk $bigdir | cut -f1`
[940]2041 MakeMountlist $MINDI_TMP/mountlist.txt
[2432]2042 CheckMountlist $MINDI_TMP/mountlist.txt
[1902]2043 mkdir -p $bigdir/tmp
[2092]2044 cp -f $MINDI_TMP/mountlist.txt $bigdir/tmp/mountlist.txt 2>> $LOGFILE || Die "Cannot copy mountlist.txt from $MINDI_TMP to data disk"
[1885]2045 if [ _"$MONDO_SHARE" != _"" ]; then
[1902]2046 cp -f $bigdir/tmp/mountlist.txt $MINDI_TMP/. 2>> $LOGFILE
[1885]2047 fi
[2032]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
[2552]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
[2032]2058 fi
2059 fi
[2302]2060 echo "Your mountlist.txt file content is:" >> $LOGFILE
2061 echo "-----------------------------------" >> $LOGFILE
[1902]2062 cat $bigdir/tmp/mountlist.txt >> $LOGFILE
[2302]2063 echo "-----------------------------------" >> $LOGFILE
[2432]2064
[2092]2065 echo -en "$FILES_IN_FILELIST" > $bigdir/FILES-IN-FILELIST 2>> $LOGFILE
2066 echo -en "$LAST_FILELIST_NUMBER" > $bigdir/LAST-FILELIST-NUMBER 2>> $LOGFILE
[1902]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`
[2712]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)
[1902]2077 du -sk $imagesdir/*gz >> $LOGFILE
2078 echo -e "$DONE"
2079
[747]2080 FRIENDLY_OUTSTRING="Boot and data disk images were created."
[1902]2081 rm -rf $bigdir
[747]2082 rm -f $needlist
2083}
2084
2085
2086ProcessLDD() {
[1784]2087 local incoming f d nd bd bnd
[747]2088 read incoming
[1784]2089 while [ "$incoming" != "" ]; do
[859]2090 # We take the full path name of the dyn. lib. we want
[2431]2091 incoming=`echo "$incoming" | $AWK '{if (match($1,/\//)) {print $1} else {if (match($3,/\//)) print $3} fi}'`
[1526]2092 for f in $incoming ; do
[1784]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
[1721]2108 echo "$f"
2109 echo "`ReadAllLink $f`"
[747]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
[925]2127 i=$(($i+1))
2128 read incoming
[747]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
[925]2138 res=`SizeOfRaidPartition $device`
2139 [ "$res" = "" ] && Die "Cannot find $device's size - is your /etc/raidtab sane?"
2140 echo "$res"
2141 return 0
[747]2142 fi
[925]2143 # patch from Bill <bill@iwizard.biz> - 2003/08/25
[960]2144 res=`$FDISK -s $device 2>> $LOGFILE`
[925]2145 # end patch
[2448]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`
[747]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
[925]2161 tmp=`SizeOfPartition $real_dev`
2162 [ "$tmp" -lt "$smallest_size" ] && smallest_size=$tmp
[747]2163 done
2164
2165 if [ "$smallest_size" = "$silly" ] ; then
[925]2166 echo "-1"
2167 return 1
[747]2168 else
[925]2169 echo "$smallest_size"
2170 return 0
[747]2171 fi
2172}
2173
2174
2175StripComments()
2176{
2177 local tempfile
[925]2178
[940]2179 tempfile=$MINDI_TMP/$$.strip.txt
[963]2180 cp -f $1 $tempfile 2>> $LOGFILE
[747]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
[925]2187
[747]2188StripExecutable()
2189{
2190 local tmpfile
[925]2191
[940]2192 tmpfile=$MINDI_TMP/stripped.$$.dat
[747]2193 [ -d "$1" ] || [ -h "$1" ] && return
[963]2194 cp -f $1 $tmpfile 2>> $LOGFILE
[747]2195 strip $tmpfile 2> /dev/null
2196 if [ "$?" -eq "0" ] ; then
[963]2197 cp -f $tmpfile $1 2>> $LOGFILE
[925]2198 echo "Stripped binary $2" >> $LOGFILE
[747]2199 fi
2200 rm -f $tmpfile
2201}
2202
[2292]2203KernelVer() {
2204 local fkern_ver fname
[747]2205
[2292]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
[747]2218TryToFindKernelPath() {
2219 local fname incoming res fkern_ver we_want_version possible_kernels noof_kernels kernelpath kdate duff_kernels
[925]2220
[2292]2221 we_want_version=$KERVERRUN
[747]2222 possible_kernels=""
2223 duff_kernels=""
2224
2225 if [ "$ARCH" = "ia64" ] ; then
2226 root="/boot/efi/efi"
2227 else
2228 root="/"
2229 fi
[2681]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
[925]2238 [ ! -e "$fname" ] && continue
[747]2239 [ "$fname" = "/boot/vmlinuz.shipped" ] && [ -f "/boot/vmlinuz" ] && continue; # ignore SuSE's extra kernel
[2292]2240 fkern_ver=`KernelVer $fname`
[747]2241 [ "$fkern_ver" = "" ] && continue
2242 [ "`echo "$fkern_ver" |grep -F "$we_want_version "`" = "" ] && continue
[925]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
[963]2250 LogIt "Have you recompiled your kernel \"$fname\" w/o rebooting? Naughty but I'll allow it..."
[925]2251 duff_kernels="$fname $duff_kernels"
2252 else
[747]2253 [ "`echo "$fname" | grep -F "vmlinux"`" ] && continue
2254 possible_kernels="$fname $possible_kernels"
[925]2255 fi
[747]2256 else
[925]2257 if [ "`strings $fname 2> /dev/null | grep -F "$kdate"`" = "" ] ; then
[963]2258 LogIt "Have you recompiled your kernel \"$fname\" w/o rebooting?\n Naughty but I'll allow it..."
[925]2259 duff_kernels="$fname $duff_kernels"
2260 else
[747]2261 [ "`echo "$fname" | grep -F "vmlinux"`" ] && continue
2262 possible_kernels="$fname $possible_kernels"
[925]2263 fi
[747]2264 fi
2265 done
2266 if [ ! "$possible_kernels" ] && uname -a | grep Knoppix > /dev/null ; then
[925]2267 possible_kernels=`find /boot/vmlinuz-2.* | tail -n1`
[747]2268 fi
2269 if [ ! "$possible_kernels" ] ; then
[963]2270 LogIt "No kernel matches exactly. Are there any duff kernels?"
[747]2271 possible_kernels="$duff_kernels"
2272 if [ ! "$possible_kernels" ] ; then
[963]2273 LogIt "Sorry, no duff kernels either"
[747]2274 else
[963]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..."
[747]2277 fi
2278 fi
[2681]2279 possible_kernels=`echo "$possible_kernels" | tr -s ' ' '\n' | grep -vi "xen" | sort -u | tr '\n' ' '`
[747]2280 noof_kernels=`CountItemsIn "$possible_kernels"`
[2681]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
[747]2286 if [ "$noof_kernels" -eq "0" ] ; then
[963]2287 LogIt "Could not find your kernel."
[925]2288 if [ -e "/boot/vmlinuz" ] ; then
[963]2289 LogIt "Using /boot/vmlinuz as a last resort."
[925]2290 output=/boot/vmlinuz
[747]2291 else
[925]2292 output=""
2293 fi
[747]2294 elif [ "$noof_kernels" -eq "1" ] ; then
2295 kernelpath=`echo "$possible_kernels" | sed s/' '//`
[2292]2296 echo "Your kernel is $kernelpath (v$KERVERRUN)" >> $LOGFILE
[747]2297 output="$kernelpath"
2298 else
2299 for i in $possible_kernels ; do
[2292]2300 if echo $i | grep "$KERVERRUN" ; then
[925]2301 LogIt "OK, I used my initiative and found that "
[963]2302 LogIt "$i is probably your kernel. "
[925]2303 output="$i"
2304 fi
[747]2305 done
[2681]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
[925]2324 else
[2681]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
[925]2346 fi
[2681]2347 xenkernelname=`basename $xenkernelpath`
2348 if [[ -z "$xenkernelpath" || ! -f "$xenkernelpath" ]]; then
2349 Die "Cannot find Xen kernel $xenkernelpath, aborting"
2350 fi
[747]2351 fi
[2681]2352 echo "$output"
[747]2353}
2354
2355
2356TurnTgzIntoRdz() {
[1983]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
[925]2358
[747]2359 tgz_dir_fname=$1
2360 rdz_fname=$2
[1983]2361 kernelsize=$3
[1885]2362 maxsize=$(($BOOT_SIZE-$kernelsize))
[747]2363 maxsize=$(($maxsize*2)); # to allow for compression of 50%
[940]2364 tempfile=$MINDI_TMP/temp.rd
2365 mountpoint=$MINDI_TMP/mnt1
[747]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 "..."
[1764]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"
[747]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`
[2712]2377 cd "$mountpoint"
[2034]2378
2379 # AL04Oct08: Check whether /lib64 is a link and if so explicitly create one in rootfs
[2042]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
[2034]2384
[959]2385 cp -Rdf $tgz_dir_fname/* . 2>&1 >> $LOGFILE
[747]2386 tar -zxf symlinks.tgz || Die "Cannot untar symlinks.tgz"
[1914]2387
[747]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
[925]2394 s=`which $w 2> /dev/null`
2395 if [ -e "$s" ] ; then
[2156]2396 tar cf - -C / $s 2> /dev/null | tar xf -
[925]2397 fi
[747]2398 done
2399
2400 [ -e "/dev/.devfsd" ] && echo "/dev/.devfsd found" > tmp/USE-DEVFS
[1724]2401
[1882]2402 # Handle the case where busybox and mount are dynamically linked
[1786]2403 file $MINDI_LIB/rootfs/bin/busybox 2>&1 | grep -q "dynamically"
2404 if [ $? -eq 0 ]; then
[1927]2405 # We want to use the real mount and all the supported variants (nfs, cifs, ...)
2406 rm -f bin/mount $MINDI_TMP/busy.lis
[2440]2407 mountlis=`grep -E "mount|fuse|ssh" $DEPLIST_FILE $DEPLIST_DIR/* | grep -v " *#.*" | cut -d: -f2 | sort -u`
[2438]2408 LocateDeps $MINDI_LIB/rootfs/bin/busybox $mountlis >> $MINDI_TMP/busy.lis
2409 # Special for libs
[2440]2410 for f in `grep -E "libnss" $DEPLIST_FILE $DEPLIST_DIR/* | grep -v " *#.*" | cut -d: -f2`; do
[2438]2411 echo "`ReadAllLink $f`" >> $MINDI_TMP/busy.lis
[1927]2412 done
[2438]2413 # Initial / are trucated by tar
[2166]2414 tar cf - $mountlis `sort -u $MINDI_TMP/busy.lis` 2>> $MINDI_TMP/$$.log | tar xf - || LogIt "Problem in mount analysis" $MINDI_TMP/$$.log
[1786]2415 rm -f $MINDI_TMP/busy.lis
2416 fi
2417
[2438]2418 # Copy of files mandatory for ssh to automate mount if sshfs is used
2419 mkdir $mountpoint/.ssh
[2439]2420 cp -rp ~root/.ssh/*.pub ~root/.ssh/config ~root/.ssh/known* $mountpoint/.ssh 2> /dev/null
[2438]2421 echo > $mountpoint/tmp/myssh << EOF
2422ssh -o StrictHostKeyChecking=no $*
2423EOF
2424 chmod 755 $mountpoint/tmp/myssh
2425
[2039]2426 # Copy of files mandatory for ld.so
[2042]2427 cp -rp /etc/ld.so.c* $mountpoint/etc
[2039]2428
[2164]2429 # Avoid an issue on some distro (RHEL5)
2430 rm -f $mountpoint/etc/ld.so.conf.d/kernelcap*
2431
[1914]2432 mkdir -p $mountpoint/tmp
[1724]2433 # Management of udev (which includes modprobe in rules)
[1759]2434 ps auxww | grep -v grep | grep -qw udevd
[1716]2435 if [ $? -eq 0 ]; then
[1914]2436 echo "udev device manager found" > $mountpoint/tmp/USE-UDEV
[1759]2437 LogIt "udev device manager found"
[2166]2438 tar cf - -C / /etc/udev 2>> $MINDI_TMP/$$.log | tar xf - || LogIt "Problem in /etc/udev analysis" $MINDI_TMP/$$.log
[1790]2439 # This avoids NIC remapping if on another machine at restore time on Debian at least
[2145]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
[2166]2443 tar cf - -C / /lib*/udev 2>> $MINDI_TMP/$$.log | tar xf - || LogIt "Problem in /lib/udev analysis" $MINDI_TMP/$$.log
[1720]2444 if [ -x /sbin/udevd ]; then
[1781]2445 lis2=`grep -Ev '^#' $MINDI_CONF/udev.files`
2446 lis=""
2447 # Get only the files which exist in that list
[1815]2448 # and potentially their symlink structure
[1781]2449 for i in $lis2; do
[1815]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
[1781]2458 lis="$lis $i"
2459 fi
2460 done
2461 # And their deps
[1759]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-`
[1998]2466 [ "$j" != "" ] && rm -f $j
[1759]2467 fi
2468 done
[2166]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
[1721]2470 rm -f $MINDI_TMP/udev.lis
[1720]2471 else
2472 echo "udevd daemon not in standard place (/sbin)" 2>&1 | tee -a $LOGFILE
[1724]2473 echo "mindi will use static devices which may cause problems" 2>&1 | tee -a $LOGFILE
[1914]2474 rm -f $mountpoint/tmp/USE-UDEV
[1720]2475 fi
[1716]2476 fi
[1786]2477
[1761]2478 # Management of potential HW info (Proliant only at the moment)
[1880]2479 rm -rf $MINDI_CACHE/bkphw
2480 mindi-bkphw $MINDI_CACHE $MINDI_CONF | tee -a $LOGFILE
2481 if [ -d $MINDI_CACHE/bkphw ]; then
[1761]2482 LogIt "Hardware Information found and saved ..."
[1880]2483 cp -rp $MINDI_CACHE/bkphw .
2484 if [ -f $MINDI_CACHE/tools.files ]; then
2485 lis=`grep -Ev '^#' $MINDI_CACHE/tools.files`
[1863]2486 LocateDeps $lis > $MINDI_TMP/tools.lis
[2166]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
[1863]2488 fi
[1880]2489 if [ -f $MINDI_CACHE/mindi-rsthw ]; then
2490 mv -f $MINDI_CACHE/mindi-rsthw .
[1761]2491 chmod 755 ./mindi-rsthw
2492 fi
[1880]2493 rm -f $MINDI_TMP/tools.lis $MINDI_CACHE/tools.files
[1761]2494 fi
2495
[2183]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
[1885]2500 for w in cdrom groovy-stuff ; do
[747]2501 mkdir -p mnt/$w
2502 done
2503
[2166]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
[1721]2505
[2712]2506 cd "$old_pwd"
[747]2507 echo -en "..."
2508 old_pwd=`pwd`
2509 if [ "$YOUR_KERNEL_SUCKS" ] ; then
[2712]2510 cd "$MINDI_TMP"
[1885]2511 needed_modules_path=lib/modules/$FAILSAFE_KVER
[747]2512 else
2513 cd /
2514 if [ "${kernelname}" != "" ]
2515 then
[1885]2516 needed_modules_path=lib/modules/${kernelname}
[747]2517 else
[2292]2518 needed_modules_path=lib/modules/$KERVERRUN
[747]2519 fi
2520 fi
[1885]2521
2522 needed_modules=""
[1993]2523 list_of_groovy_mods="$CDROM_MODS $FORCE_MODS"
[1885]2524
[2380]2525 if [ -e "$MINDI_TMP/NETFS-DEV" ] ; then
[747]2526 # For PXE boot
2527 list_of_groovy_mods="$list_of_groovy_mods $NET_MODS"
2528 fi
[1715]2529 if [ "$PROMPT_MAKE_USB_IMAGE" = "yes" ] && [ "$USBDEVICE" != "" ]; then
2530 list_of_groovy_mods="$list_of_groovy_mods $EXTRA_MODS"
2531 fi
[1727]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
[1885]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."
[747]2538 for i in $list_of_groovy_mods ; do
[1885]2539 needed_modules="$needed_modules `FindSpecificModuleInPath $needed_modules_path $i`"
[747]2540 done
[1914]2541
[2600]2542 for i in `echo $needed_modules | tr ' ' '\n' | sort -u`; do
[747]2543 [ -e "$i" ] && s=`du -sk $i | cut -f1` || s=""
[940]2544 [ "$YOUR_KERNEL_SUCKS" ] && i=$MINDI_TMP/$i
[747]2545 echo "Adding $i ($s KB) to the rootfs" >> $LOGFILE
[2712]2546 tar cf - -C / $i 2>> $MINDI_TMP/$$.log | (cd "$mountpoint" ; tar xf -) || LogIt "Unable to copy $i to $mountpoint" $MINDI_TMP/$$.log
[1914]2547 # Uncompress modules if not using udev and native modprobe
[1815]2548 if [ ! -f $mountpoint/tmp/USE-UDEV ]; then
2549 if [ "`echo "$i" | grep -F ".gz"`" ]; then
[1914]2550 echo "Uncompressing $i" >> $LOGFILE
[1727]2551 gunzip -f $mountpoint/$i
[1815]2552 fi
[1727]2553 fi
[747]2554 done
[1815]2555
2556 # Also copy modules.dep in case of udev so that normal modprobe works
[2712]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
[1815]2558
[2680]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
[1885]2564 if [ ! -e "/sbin/devfsd" ] || [ "$kernelpath" = "$MINDI_LIB/vmlinuz" ] ; then
[747]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
[2712]2570 cd "$old_pwd"
[747]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
[1885]2574 if [ _"$MONDO_SHARE" != _"" ]; then
[747]2575 MakeMondoConfigFile $mountpoint/tmp/mondo-restore.cfg
[2092]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"
[747]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
[998]2581 [ "$USE_GZIP" = "yes" ] && echo -en "YES" >> $mountpoint/tmp/USING-GZIP
[747]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
[1885]2586 echo "$BOOT_SIZE" > $mountpoint/tmp/$BOOT_SIZE.siz
[2438]2587
2588 echo "---------------------------" >> $LOGFILE
2589 echo "Content of initial ramdisk:" >> $LOGFILE
2590 echo "---------------------------" >> $LOGFILE
[2712]2591 (cd "$mountpoint" ; ls -Rla ) >> $LOGFILE
[2438]2592 echo "---------------------------" >> $LOGFILE
2593
[1230]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."
[2390]2598 if [ "$gvFileSystem" = "ext2fs" ] || [ "$gvFileSystem" = "ext3fs" ]; then
[1230]2599 # say what will be used
[2390]2600 echo "Creating an $gvFileSystem initrd image..." >> $LOGFILE
[1230]2601 # kernel expects linuxrc in ext2 filesystem
[2712]2602 ( cd "$mountpoint" && ln -sf sbin/init linuxrc )
[1230]2603 # unmount loop filesystem and create image file using the standard approach
2604 umount $mountpoint || Die "Cannot unmount $tempfile"
[1764]2605 dd if=$tempfile bs=1k 2> /dev/null > ${rdz_fname}.tmp 2> /dev/null
[1794]2606 bs=`tune2fs -l ${rdz_fname}.tmp | grep -E '^Block size:' | cut -d: -f2 | sed 's/^ *//'`
[2564]2607 MINDI_ADDITIONAL_BOOT_PARAMS="$MINDI_ADDITIONAL_BOOT_PARAMS ramdisk_blocksize=$bs"
[1799]2608 gzip -c9 ${rdz_fname}.tmp > $rdz_fname
[1764]2609 rm -f ${rdz_fname}.tmp
[1230]2610 # log that we are done
[1821]2611 echo "...done." >> $LOGFILE
[2390]2612 elif [ "$gvFileSystem" = "initramfs" ]; then
[1230]2613 # say what will be used
[1821]2614 echo "Creating a gzip'ed cpio (AKA initramfs) initrd image..." >> $LOGFILE
[1230]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
[2712]2618 cd "$mountpoint"
[1230]2619 # kernel expects init in cpio filesystem
2620 ln -sf sbin/init init
2621 # create cpio image file and unmount loop filesystem
[1929]2622 find . -print | cpio -o -H newc | gzip -9 > $rdz_fname 2> /dev/null
[2712]2623 cd "$old_pwd"
[1230]2624 umount $mountpoint || Die "Cannot unmount $tempfile"
2625 # log that we are done
2626 echo "...done." >> $LOGFILE
[2390]2627 else
[1230]2628 Die "Filesystem $gvFileSystem not supported for initrd image. Terminating."
[2390]2629 fi
2630
[747]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##############################################################################
[1021]2641#----------------------------------- Main -----------------------------------#
[747]2642##############################################################################
2643
[1885]2644# Now we can create what we need
2645mkdir -p $MINDI_TMP
[747]2646
[1885]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
[2183]2657 exit 0
[1885]2658fi
2659
[747]2660> $LOGFILE
2661echo "mindi v$MINDI_VERSION" >> $LOGFILE
2662echo "$ARCH architecture detected" >> $LOGFILE
2663echo "mindi called with the following arguments:" >> $LOGFILE
2664echo "$@" >> $LOGFILE
[800]2665echo "Start date : `date`" >> $LOGFILE
[1684]2666echo "-----------------------------" >> $LOGFILE
[747]2667
2668[ -e "/sbin/mkdosfs" ] && [ ! -e "/sbin/mkfs.vfat" ] && ln -sf /sbin/mkdosfs /sbin/mkfs.vfat
2669
[1010]2670# Log some capital variables
2671[ "$MINDI_PREFIX" = "XXX" ] && Die "Mindi has not been installed correctly."
[1885]2672echo "MONDO_SHARE = $MONDO_SHARE" >> $LOGFILE
[1010]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
[1885]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
[1010]2684
[1885]2685
[747]2686trap AbortHere SIGTERM SIGHUP SIGQUIT SIGKILL SIGABRT SIGINT
[1010]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"
[2222]2699[ ! -e "$FDISK" ] && Die "Cannot find $FDISK"
[1010]2700
[2292]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"
[1010]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
[1885]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
[1010]2720
[1737]2721if ! which mkfs.vfat 1> /dev/null 2> /dev/null ; then
[1010]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
[925]2725### BERLIOS
[747]2726### Fix as it's not mandatory on ia64
2727if [ "$ARCH" = "ia64" ] ; then
[1010]2728 if which elilo &> /dev/null ; then
2729 LILO_EXE=elilo
2730 else
[2024]2731 LILO_EXE=`which false 2> /dev/null`
[1010]2732 fi
[747]2733else
2734 FindIsolinuxBinary
2735fi
2736trap "Aborted" SIGTERM
2737DONE="\r\t\t\t\t\t\t\t\tDone. "
2738kernelpath=""
[1010]2739MONDO_ROOT=/var/cache/mondo
[747]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
[1021]2753echo "LVM set to $LVM" >> $LOGFILE
2754echo "----------" >> $LOGFILE
[1230]2755echo "mount result:" >> $LOGFILE
2756echo "-------------" >> $LOGFILE
2757mount >> $LOGFILE
2758echo "-------------" >> $LOGFILE
[1315]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
[1418]2766echo "cat /proc/cmdline:" >> $LOGFILE
2767echo "-------------" >> $LOGFILE
2768cat /proc/cmdline >> $LOGFILE
2769echo "-------------" >> $LOGFILE
[2014]2770echo "cat /proc/swaps:" >> $LOGFILE
2771echo "-------------" >> $LOGFILE
2772cat /proc/swaps >> $LOGFILE
2773echo "-------------" >> $LOGFILE
[2015]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
[1021]2782echo "lsmod result:" >> $LOGFILE
2783echo "-------------" >> $LOGFILE
2784lsmod >> $LOGFILE
[2431]2785MODULES="`cat /proc/modules | $AWK '{print $1}'`"
[1531]2786if [ -x /usr/sbin/esxcfg-module ]; then
[1797]2787 echo "-------------" >> $LOGFILE
[1497]2788 echo "VMWare ESX server detected - Enabling dedicated support" >> $LOGFILE
2789 echo "-------------" >> $LOGFILE
2790 echo "VMWare modules" >> $LOGFILE
2791 echo "-------------" >> $LOGFILE
[1531]2792 /usr/sbin/esxcfg-module -l >> $LOGFILE
[2431]2793 MODULES="$MODULES `/usr/sbin/esxcfg-module -l | $AWK '{print $1}'`"
[1497]2794fi
[1851]2795echo "FORCE_MODS:" >> $LOGFILE
[1021]2796echo "-------------" >> $LOGFILE
[1851]2797echo $FORCE_MODS >> $LOGFILE
[1882]2798echo "-------------" >> $LOGFILE
[1851]2799echo "DENY_MODS:" >> $LOGFILE
2800echo "-------------" >> $LOGFILE
2801echo $DENY_MODS >> $LOGFILE
2802echo "-------------" >> $LOGFILE
[1796]2803echo "df result:" >> $LOGFILE
[1785]2804echo "----------" >> $LOGFILE
[1796]2805df -T >> $LOGFILE
[1785]2806echo "-------------" >> $LOGFILE
[1230]2807echo "Liste of extra modules is:" >> $LOGFILE
2808echo "$EXTRA_MODS" >> $LOGFILE
2809echo "-------------" >> $LOGFILE
[747]2810
[1723]2811# Compute libata version
[2649]2812laver=`modinfo libata 2> /dev/null | grep -Ei '^Version:' | cut -d: -f2 | cut -d. -f1 | sed 's/ *//g' 2> /dev/null`
[1723]2813# If libata v2 is used then remove ide-generic as it will perturbate boot
[1726]2814if [ "`echo $MODULES | grep libata`" ]; then
[1727]2815 if [ "$laver" = "2" ]; then
[1726]2816 DENY_MODS="$DENY_MODS ide-generic"
[1727]2817 echo "ide-generic removed from module list as your system uses libata v2+" >> $LOGFILE
[1726]2818 echo "-------------" >> $LOGFILE
2819 fi
[1723]2820fi
2821
[2457]2822# Check for ISO_CMD command
2823if [ ! -x $ISO_CMD ]; then
2824 echo "NOTE: No CD image (ISO file) utility found" >> $LOGFILE
2825fi
2826
[747]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
[1684]2835#
2836# If we have a USB device we need to store info
2837# and remove it from the parameters line
2838#
[747]2839if [ "$#" -ne "0" ] ; then
[1684]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
[747]2851 if [ "$1" = "--findkernel" ] ; then
2852 res=`TryToFindKernelPath`
[1336]2853 # Avoids logfile content for mondo
2854 export MONDO_SHARE=""
[747]2855 if [ "$res" = "" ] ; then
[925]2856 MindiExit -1
[747]2857 else
2858 echo "$res"
[925]2859 MindiExit 0
[747]2860 fi
[1720]2861 elif [ "$1" = "--locatedeps" ] ; then
2862 [ ! "$2" ] && Die "Please specify the binary to look at"
[2438]2863 LocateDeps $*
[1720]2864 # Avoids logfile content for mondo
2865 export MONDO_SHARE=""
2866 MindiExit $?
[1815]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 $?
[2731]2873 elif [ "$1" = "--makemessage" ] ; then
2874 MakeMessageFile
2875 MindiExit 0
[747]2876 elif [ "$1" = "--makemountlist" ] ; then
2877 [ ! "$2" ] && Die "Please specify the output file"
2878 MakeMountlist $2
[2432]2879 CheckMountlist $2
[1336]2880 # Avoids logfile content for mondo
2881 export MONDO_SHARE=""
[925]2882 MindiExit $?
2883 elif [ "$1" = "-V" ] || [ "$1" = "-v" ] || [ "$1" = "--version" ] || [ "$1" = "-version" ] ; then
2884 echo "Mindi v$MINDI_VERSION"
[1336]2885 # Avoids logfile content for mondo
2886 export MONDO_SHARE=""
[925]2887 MindiExit 0
[747]2888 elif [ "$#" -ge "9" ] && [ "$1" = "--custom" ] ; then
[940]2889 MONDO_TMP=$2
2890 # Change MINDI_TMP for the one provided by mondo
2891 # So that it can get back the built files
[2153]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
[2092]2898 mv $MINDI_TMP/* $MINDI_TMP/.??* $MONDO_TMP 2>> $LOGFILE
[1010]2899 rmdir $MINDI_TMP
[1486]2900 export MINDI_TMP=$MONDO_TMP
[953]2901 mkdir -p $MINDI_TMP
[2238]2902
[1696]2903 # This is the scratch dir in mondo - subdir images
[1880]2904 MINDI_CACHE=$3
[2238]2905
[925]2906 kernelpath=$4; [ "$kernelpath" = "(null)" ] && kernelpath=""
[2681]2907 [ "$kernelpath" = "" ] && kernelpath=`TryToFindKernelPath`
2908
[747]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###
[2629]2914 if [ $KERNEL_IS_XEN = "yes" ]; then
2915 LogIt "xenkernelpath = $xenkernelpath"
2916 LogIt "xenkernelname = $xenkernelname"
2917 fi
[2657]2918 kernelname=`echo $kernelpath | cut -d'-' -f2- | sed 's/.[bg]z[2]*$//'`
[747]2919 if [ ! -d "/lib/modules/$kernelname" ] && [ "$kernelpath" != "FAILSAFE" ]
2920 then
[963]2921 LogIt "Module path for ${kernelpath} not found..."
2922 LogIt "using running kernel\'s modules."
[2292]2923 kernelname=$KERVERRUN
[747]2924 fi
[2657]2925 LogIt "kernelname = $kernelname"
2926 LogIt "kernelpath = $kernelpath"
[747]2927###
2928### end of Sq-Modification
2929###
[925]2930 TAPEDEV=$5
2931 TAPESIZE=$6
2932 FILES_IN_FILELIST=$7
2933 USE_LZO=$8
2934 CDRECOVERY=$9
[747]2935 if [ "${10}" = "(null)" ] || [ "${10}" = "" ] ; then
2936 IMAGE_DEVS=""
2937 else
2938 IMAGE_DEVS="`echo "${10}" | tr '|' ' '`"
2939 fi
[925]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}
[747]2945 ESTIMATED_TOTAL_NOOF_SLICES=${13}
[2564]2946 export MINDI_EXCLUDE_DEVS="${14}"
[747]2947 USE_COMP="${15}"
2948 USE_LILO="${16}"
[925]2949 USE_STAR="${17}"
2950 INTERNAL_TAPE_BLOCK_SIZE="${18}"
[747]2951 DIFFERENTIAL="${19}"
[998]2952 USE_GZIP="${20}"
2953 NOT_BOOT="${21}"
[747]2954 [ "$USE_COMP" = "" ] && USE_COMP=yes
[998]2955 [ "$USE_GZIP" = "" ] && USE_GZIP=no
[747]2956 [ "$NOT_BOOT" = "" ] && NOT_BOOT=no
[963]2957 [ "$TAPEDEV" ] && LogIt "This is a tape-based backup. Fine."
[1696]2958 # MONDO_ROOT is the real scratchdir
[1880]2959 MONDO_ROOT=`echo $MINDI_CACHE | sed 's/\(.*\)\/.*/\1/'`
[938]2960 if [ _"$MONDO_ROOT" != _"" ]; then
2961 mkdir -p $MONDO_ROOT
2962 else
2963 Die "MONDO_ROOT is undefined"
2964 fi
[747]2965 else
[925]2966 echo "Syntax: mindi (--custom ....)" >> /dev/stderr
2967 MindiExit -1
[747]2968 fi
2969fi
[2238]2970
2971if [ _"$MINDI_CACHE" != _"" ]; then
2972 rm -rf $MINDI_CACHE/* 2> /dev/null
2973 mkdir -p $MINDI_CACHE
2974fi
2975
[747]2976[ "$CDRECOVERY" = "yes" ] || CDRECOVERY=no
2977
[1684]2978if [ _"$MONDO_SHARE" = _"" ]; then
[963]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"
[747]2982 LogIt "------------------------------------------------------------------------------"
2983else
[1315]2984 echo "You are using Mindi-Linux v$MINDI_VERSION to make boot+data disks" >> $LOGFILE
[747]2985fi
[1005]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
[747]2992
2993# for Mandrake 9.2, which comes with two aes.o.gz modules :-/
[2292]2994insmod /lib/modules/$KERVERRUN/*/*/misc/aes.*o.gz >> $LOGFILE 2>> $LOGFILE
[747]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
[963]3005 LogIt "Just creating mondo-restore.cfg and a small all.tar.gz for Mondo. Nothing else."
[940]3006 MakeMondoConfigFile $MINDI_TMP/mondo-restore.cfg
3007 MakeMountlist $MINDI_TMP/mountlist.txt
[2432]3008 CheckMountlist $MINDI_TMP/mountlist.txt
[940]3009 mkdir -p $MINDI_TMP/small-all/tmp
[2712]3010 cd "$MINDI_TMP/small-all"
[2092]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"
[2166]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
[747]3013 sleep 2
[963]3014 LogIt "Done. Exiting."
[925]3015 MindiExit 0
[747]3016fi
3017
[1690]3018if [ "$PROMPT_MAKE_USB_IMAGE" = "yes" ] && [ "$USBDEVICE" != "" ]; then
[1684]3019 LogIt "Including the generation of a Bootable USB device on $USBDEVICE"
3020fi
3021
[747]3022if [ "$kernelpath" = "" ] ; then
[1335]3023 [ _"$MONDO_SHARE" != _"" ] && Die "Please use -k <path> to specify kernel."
[966]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"
[1809]3028 else
3029 USE_OWN_KERNEL="no"
[747]3030 fi
3031 if [ "$USE_OWN_KERNEL" = "yes" ]; then
[925]3032 YOUR_KERNEL_SUCKS=""
3033 kernelpath=`TryToFindKernelPath`
3034 if [ "$kernelpath" = "" ] ; then
3035 echo -n "Please enter kernel path : "
3036 read kernelpath
3037 fi
[747]3038 else
[925]3039 YOUR_KERNEL_SUCKS="That's why you're using mine, dude. :-)"
[747]3040 fi
3041fi
3042if [ "$YOUR_KERNEL_SUCKS" != "" ] || [ "$kernelpath" = "" ] || [ "$kernelpath" = "SUCKS" ] || [ "$kernelpath" = "FAILSAFE" ] ; then
[1885]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`
[2712]3054 cd "$MINDI_TMP"
[1885]3055 mkdir -p lib/modules
3056 cp -a "/lib/modules/$FAILSAFE_KVER" "lib/modules/$FAILSAFE_KVER" || Die "Cannot copy kernel modules."
[2712]3057 cd "$pwd"
[1885]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`
[2712]3064 cd "$MINDI_TMP"
[1885]3065 bzip2 -dc $MINDI_LIB/lib.tar.bz2 | tar -x || Die "Cannot unzip lib.tar.bz2"
[2712]3066 cd "$pwd"
[1885]3067 fi
[747]3068 YOUR_KERNEL_SUCKS="Your kernel sucks"
3069fi
[1880]3070echo -e "Mindi's temp dir = $MINDI_TMP \nMindi's output dir=$MINDI_CACHE" >> $LOGFILE
[963]3071[ "$(($RANDOM%64))" -eq "0" ] && LogIt "Dude, I've looked inside your computer and it's really dusty..."
[747]3072
[965]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."
[747]3074
[1983]3075PrepareDataDiskImages
3076
[747]3077ramdisk_size=$(($size_of_all_tools+$EXTRA_SPACE))
3078rds=$(($ramdisk_size-$((ramdisk_size%4096))))
[1983]3079export ramdisk_size=$rds
[747]3080
3081echo "Ramdisk will be $ramdisk_size KB" >> $LOGFILE
[1567]3082if [ "$ARCH" = "ia64" ] ; then
[1983]3083 PrepareBootDiskImage_LILO $kernelpath || Die "Failed to create ia64 image disk image."
[1567]3084else
[2073]3085 PrepareBootDiskImage_ISOLINUX $kernelpath || Die "Failed to create $ramdisk_size MB disk image."
[747]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
[1684]3091if [ _"$MONDO_SHARE" = _"" ]; then
[1983]3092 ListImagesForUser
3093 OfferToMakeBootableISO
[1684]3094 if [ "$PROMPT_MAKE_USB_IMAGE" = "yes" ]; then
[1983]3095 OfferToMakeBootableUSB
[1684]3096 fi
[963]3097 LogIt "Finished."
[747]3098elif [ "$TAPEDEV" ] ; then
[2078]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
[1898]3105 if [ "$PROMPT_MAKE_USB_IMAGE" = "yes" ] && [ "$USBDEVICE" != "" ]; then
[1983]3106 OfferToMakeBootableUSB
[1898]3107 fi
[1983]3108 OfferToMakeBootableISO
[1880]3109 if [ -e "$MINDI_CACHE/all.tar.gz" ] ; then
3110 cp -f $MINDI_CACHE/all.tar.gz $MINDI_TMP/ 2>> $LOGFILE
[747]3111 else
[925]3112 Die "Cannot find all.tar.gz, to be written to tape"
[747]3113 fi
[1695]3114elif [ "$PROMPT_MAKE_USB_IMAGE" = "yes" ] && [ "$USBDEVICE" != "" ]; then
[1983]3115 OfferToMakeBootableUSB
[747]3116else
[1983]3117 OfferToMakeBootableISO
[747]3118fi
3119# cleanup
[963]3120LogIt "$FRIENDLY_OUTSTRING"
[747]3121for mtpt in $FLOPPY_WAS_MOUNTED ; do
3122 mount $mtpt
3123done
[925]3124MindiExit 0
Note: See TracBrowser for help on using the repository browser.