2014-03-21 20:04:03 +00:00
|
|
|
#!/bin/sh -e
|
|
|
|
#
|
|
|
|
# Copyright (C) 2008-2011 Intel, 2014 sysmocom
|
|
|
|
# install.sh [device_name] [rootfs_name] [video_mode] [vga_mode]
|
|
|
|
#
|
|
|
|
|
|
|
|
PATH=/sbin:/bin:/usr/sbin:/usr/bin
|
|
|
|
|
|
|
|
# We want a 1 Gig partition on the cf
|
|
|
|
partition_size=1000
|
|
|
|
|
2014-08-26 16:06:36 +00:00
|
|
|
# Parse original arguments coming from the kernel cmdline.
|
|
|
|
# Then shift the first two arguments which contains
|
|
|
|
# partition information.
|
|
|
|
dev_name=$1
|
|
|
|
shift
|
|
|
|
image_name=$1
|
|
|
|
shift
|
|
|
|
|
|
|
|
kernel_cmdline_console=""
|
|
|
|
kernel_cmdline_video_mode=""
|
|
|
|
kernel_cmdline_vga_mode=""
|
|
|
|
|
|
|
|
while [ "$1" != "" ]; do
|
|
|
|
|
|
|
|
echo "$1" | grep -q "console="
|
|
|
|
success_console=$?
|
|
|
|
if [ $success_console -eq 0 ]; then
|
|
|
|
kernel_cmdline_console=$1
|
|
|
|
fi
|
|
|
|
shift
|
|
|
|
|
|
|
|
done
|
|
|
|
|
2014-03-21 20:04:03 +00:00
|
|
|
# Get a list of hard drives
|
|
|
|
hdnamelist=""
|
2014-08-26 16:06:36 +00:00
|
|
|
live_dev_name=${dev_name%%/*}
|
2014-03-21 20:04:03 +00:00
|
|
|
|
|
|
|
echo "Searching for hard drives ..."
|
|
|
|
|
|
|
|
for device in `ls /sys/block/`; do
|
|
|
|
case $device in
|
|
|
|
loop*)
|
|
|
|
# skip loop device
|
|
|
|
;;
|
|
|
|
ram*)
|
|
|
|
# skip ram device
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
# skip the device LiveOS is on
|
|
|
|
# Add valid hard drive name to the list
|
|
|
|
if [ $device != $live_dev_name -a -e /dev/$device ]; then
|
|
|
|
hdnamelist="$hdnamelist $device"
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
done
|
|
|
|
|
|
|
|
TARGET_DEVICE_NAME=""
|
|
|
|
for hdname in $hdnamelist; do
|
|
|
|
# Display found hard drives and their basic info
|
|
|
|
echo "-------------------------------"
|
|
|
|
echo /dev/$hdname
|
|
|
|
if [ -r /sys/block/$hdname/device/vendor ]; then
|
|
|
|
echo -n "VENDOR="
|
|
|
|
cat /sys/block/$hdname/device/vendor
|
|
|
|
fi
|
|
|
|
echo -n "MODEL="
|
|
|
|
cat /sys/block/$hdname/device/model
|
|
|
|
cat /sys/block/$hdname/device/uevent
|
|
|
|
echo
|
|
|
|
# Get user choice
|
|
|
|
while true; do
|
|
|
|
echo -n "Do you want to install this image there? [y/n] "
|
|
|
|
read answer
|
|
|
|
if [ "$answer" = "y" -o "$answer" = "n" ]; then
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
echo "Please answer y or n"
|
|
|
|
done
|
|
|
|
if [ "$answer" = "y" ]; then
|
|
|
|
TARGET_DEVICE_NAME=$hdname
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
if [ -n "$TARGET_DEVICE_NAME" ]; then
|
|
|
|
echo "Installing image on /dev/$TARGET_DEVICE_NAME ..."
|
|
|
|
else
|
|
|
|
echo "No hard drive selected. Installation aborted."
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
device=$TARGET_DEVICE_NAME
|
|
|
|
|
|
|
|
#
|
|
|
|
# The udev automounter can cause pain here, kill it
|
|
|
|
#
|
|
|
|
rm -f /etc/udev/rules.d/automount.rules
|
|
|
|
rm -f /etc/udev/scripts/mount*
|
|
|
|
|
|
|
|
#
|
|
|
|
# Unmount anything the automounter had mounted
|
|
|
|
#
|
|
|
|
umount /dev/${device}* 2> /dev/null || /bin/true
|
|
|
|
|
|
|
|
if [ ! -b /dev/loop0 ] ; then
|
|
|
|
mknod /dev/loop0 b 7 0
|
|
|
|
fi
|
|
|
|
|
|
|
|
mkdir -p /tmp
|
|
|
|
cat /proc/mounts > /etc/mtab
|
|
|
|
|
|
|
|
# MMC devices are special in a couple of ways
|
|
|
|
# 1) they use a partition prefix character 'p'
|
|
|
|
# 2) they are detected asynchronously (need rootwait)
|
|
|
|
rootwait=""
|
|
|
|
part_prefix=""
|
|
|
|
if [ ! "${device#mmcblk}" = "${device}" ]; then
|
|
|
|
part_prefix="p"
|
|
|
|
rootwait="rootwait"
|
|
|
|
fi
|
|
|
|
rootfs=/dev/${device}${part_prefix}1
|
|
|
|
|
|
|
|
echo "*****************"
|
|
|
|
echo "Rootfs partition size: $rootfs_size MB ($rootfs)"
|
|
|
|
echo "*****************"
|
|
|
|
echo "Deleting partition table on /dev/${device} ..."
|
|
|
|
dd if=/dev/zero of=/dev/${device} bs=512 count=2
|
|
|
|
|
|
|
|
echo "Creating new partition table on /dev/${device} ..."
|
|
|
|
parted /dev/${device} mklabel msdos
|
|
|
|
|
|
|
|
echo "Creating rootfs partition on $rootfs"
|
|
|
|
parted /dev/${device} mkpart primary 0% $partition_size
|
|
|
|
|
|
|
|
parted /dev/${device} print
|
|
|
|
|
|
|
|
echo "Formatting $rootfs to ext4..."
|
|
|
|
mkfs.ext4 $rootfs
|
|
|
|
|
|
|
|
mkdir /tgt_root
|
|
|
|
mkdir -p /boot
|
|
|
|
|
|
|
|
echo "Copying rootfs files..."
|
2014-08-26 16:06:36 +00:00
|
|
|
dd if=/media/$dev_name/$image_name of=$rootfs bs=1024
|
2014-03-21 20:04:03 +00:00
|
|
|
|
|
|
|
# Handling of the target root partition
|
|
|
|
mount $rootfs /tgt_root
|
|
|
|
|
|
|
|
if [ -d /tgt_root/etc/ ] ; then
|
|
|
|
# We dont want udev to mount our root device while we're booting...
|
|
|
|
if [ -d /tgt_root/etc/udev/ ] ; then
|
|
|
|
echo "/dev/${device}" >> /tgt_root/etc/udev/mount.blacklist
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Handling of the target boot partition
|
|
|
|
mount --bind /tgt_root/boot /boot
|
|
|
|
echo "Preparing boot partition..."
|
|
|
|
|
|
|
|
GRUBCFG="/boot/grub/grub.cfg"
|
|
|
|
mkdir -p $(dirname $GRUBCFG)
|
|
|
|
|
2014-08-26 16:06:36 +00:00
|
|
|
baudrate=`echo $kernel_cmdline_console | cut -f 2 -d ',' | cut -f 1 -d 'n'`
|
|
|
|
|
2014-03-21 20:04:03 +00:00
|
|
|
cat > $GRUBCFG << EOF
|
|
|
|
default=0
|
|
|
|
timeout=1
|
|
|
|
|
2014-08-26 16:06:36 +00:00
|
|
|
serial --unit=0 --speed=$baudrate
|
2014-03-21 20:04:03 +00:00
|
|
|
terminal --timeout=2 serial
|
|
|
|
|
|
|
|
terminal_input --append serial
|
|
|
|
terminal_output --append serial
|
|
|
|
EOF
|
|
|
|
|
2015-02-24 19:59:11 +00:00
|
|
|
BOOTPASSWD=
|
|
|
|
BOOTUSER=
|
|
|
|
if [ -n "${BOOTPASSWD}" ] && [ -n "${BOOTUSER}" ]; then
|
|
|
|
cat >> $GRUBCFG << EOF
|
|
|
|
set superusers="$BOOTUSER"
|
|
|
|
password $BOOTUSER $BOOTPASSWD
|
|
|
|
EOF
|
|
|
|
fi
|
|
|
|
|
2014-03-21 20:04:03 +00:00
|
|
|
if [ -f /etc/grub.d/40_custom ] ; then
|
|
|
|
echo "Preparing custom grub2 menu..."
|
|
|
|
|
|
|
|
cat /etc/grub.d/40_custom >> $GRUBCFG
|
2015-02-24 19:59:11 +00:00
|
|
|
if [ -n "${BOOTPASSWD}" ] && [ -n "${BOOTUSER}" ]; then
|
|
|
|
sed -i "s/\(menuentry\)\(.*\)\({\)/\1\2--unrestricted \3/g" $GRUBCFG
|
|
|
|
fi
|
2014-03-21 20:04:03 +00:00
|
|
|
sed -i "s@__ROOTFS__@$rootfs $rootwait@g" $GRUBCFG
|
2014-08-26 16:06:36 +00:00
|
|
|
sed -i "s/__VIDEO_MODE__/$kernel_cmdline_video_mode/g" $GRUBCFG
|
|
|
|
sed -i "s/__VGA_MODE__/$kernel_cmdline_vga_mode/g" $GRUBCFG
|
|
|
|
sed -i "s/__CONSOLE__/$kernel_cmdline_console/g" $GRUBCFG
|
2015-02-14 21:00:08 +00:00
|
|
|
sed -i "s/quiet/net.ifnames=0 panic=60 quiet/g" $GRUBCFG
|
2014-08-26 15:27:04 +00:00
|
|
|
sed -i "s/rw/ro/g" $GRUBCFG
|
2014-03-21 20:04:03 +00:00
|
|
|
sed -i "/#/d" $GRUBCFG
|
|
|
|
sed -i "/exec tail/d" $GRUBCFG
|
|
|
|
chmod 0444 $GRUBCFG
|
|
|
|
fi
|
|
|
|
|
|
|
|
ln -fs /boot/bzImage /tgt_root/vmlinuz
|
|
|
|
grub-install /dev/${device}
|
|
|
|
echo "(hd0) /dev/${device}" > /boot/grub/device.map
|
|
|
|
|
|
|
|
umount /boot
|
|
|
|
umount /tgt_root
|
|
|
|
|
2014-04-01 18:19:37 +00:00
|
|
|
echo "Resizing partition"
|
2014-08-26 14:34:55 +00:00
|
|
|
e2fsck -f $rootfs || true
|
2014-04-01 18:19:37 +00:00
|
|
|
resize2fs $rootfs
|
2014-08-26 17:57:53 +00:00
|
|
|
sync
|
|
|
|
|
|
|
|
echo "Re-mounting the root and trying to apply backup."
|
|
|
|
mount $rootfs /tgt_root
|
|
|
|
|
|
|
|
echo "Finding backupfiles"
|
|
|
|
backupfile=`find /media/$dev_name/ -name "sysmocom-backup*.tar" | head -n1`
|
|
|
|
if [ -n "$backupfile" ]; then
|
|
|
|
if [ ! -r "$backupfile" ]; then
|
|
|
|
echo "configurations-file $backupfile it is not readable"
|
|
|
|
else
|
|
|
|
echo "restoring $backupfile"
|
|
|
|
backupfile_basename=`basename $backupfile`
|
|
|
|
cp $backupfile /tgt_root
|
|
|
|
chroot /tgt_root /usr/sbin/sysmocom-restore $backupfile_basename
|
|
|
|
rm /tgt_root/$backupfile_basename
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
echo "No configurations-file found"
|
|
|
|
fi
|
2014-04-01 18:19:37 +00:00
|
|
|
|
2014-08-26 17:57:53 +00:00
|
|
|
umount /tgt_root
|
2014-03-21 20:04:03 +00:00
|
|
|
sync
|
|
|
|
|
|
|
|
echo "Remove your installation media, and press ENTER"
|
|
|
|
|
|
|
|
read enter
|
|
|
|
|
|
|
|
echo "Rebooting..."
|
|
|
|
reboot -f
|