#!/bin/bash ### make sure this output shows up in the console exec 2>&1 exec > /dev/console ### . /etc/init.d/pl_functions verbose-message "PlanetLab BootCD - distro @PLDISTRO@ based on @FCDISTRO@" verbose-message "pl_sysinit: bringing system online" verbose-message "pl_sysinit: mounting file systems" verbose-run /bin/mount -v -a # on old systems that use init, we totally take control and replace # /etc/inittab with just our stuff, so nothing is going to run udev # for us and we need to start it ourselves if [ -x /sbin/start_udev ]; then verbose-message "pl_sysinit: starting udev daemon" verbose-run /sbin/start_udev else # on systemd-based systems, udev is triggered by systemd # but just in case we issue a warning verbose-message "pl_sysinit: WARNING cannot start udev daemon (probably safe under systemd)" fi verbose-message "pl_sysinit: invoking hardware initialization script" verbose-run /etc/init.d/pl_hwinit function check-initrd() { _mounted=0 if [ -f /usr/isolinux/pl_version ] ; then # it is mounted, but we should probably make sure its our boot cd # this can be done by making sure the /pl_version file (on initrd) # matches /usr/isolinux/pl_version initrd_version=$(/bin/cat /pl_version) cd_version=$(/bin/cat /usr/isolinux/pl_version) if [ "$initrd_version" == "$cd_version" ]; then _mounted=1 else verbose-message "pl_sysinit: WARNING pl_version mismatch" fi fi return $_mounted } function check-block-devices() { _mounted=0 # so that * expands to empty string if there are no block devices shopt -s nullglob for device in /sys/block/*; do device=$(/bin/basename $device) # skipping any devices that start with md or ra (ram) or lo # (loop) or fd (floppy) start_device=${device:0:2} if [ "$start_device" == "ra" ] || [ "$start_device" == "md" ] || [ "$start_device" == "lo" ] || [ "$start_device" == "fd" ]; then continue fi # If this is a removable (e.g., USB flash) device, then try to # look for an ISO image on each of its partitions. if [ "$(cat /sys/block/$device/removable)" = "1" ] ; then partitions=$(/bin/awk "\$4 ~ /${device}[0-9]*/ { print \$4 }" /proc/partitions) for partition in $partitions ; do echo $(date "+%H:%M:%S") "pl_sysinit: checking $partition for iso image" mkdir -p /tmp/$partition if /bin/mount -o ro -t msdos,ext2 /dev/$partition /tmp/$partition 2>&1 > /dev/null ; then # Look for the first ISO image for iso in /tmp/$partition/*.iso ; do if /sbin/losetup /dev/loop0 $iso ; then echo $(date "+%H:%M:%S") "pl_sysinit: using $(basename $iso) on $partition" device="loop0" break fi done if [ "$device" != "loop0" ] ; then /bin/umount /tmp/$partition 2>&1 > /dev/null fi fi done fi verbose-message "pl_sysinit: checking $device for /usr contents" /bin/mount -o ro -t iso9660 /dev/$device /usr 2>&1 > /dev/null if [ $? -eq 0 ]; then # it mounted, but we should probably make sure its our boot cd # this can be done by making sure the /pl_version file (on initrd) # matches /usr/isolinux/pl_version initrd_version=$(/bin/cat /pl_version) cd_version=$(/bin/cat /usr/isolinux/pl_version) if [ "$initrd_version" != "$cd_version" ]; then # eh, wrong cd, keep trying /bin/umount /usr 2>&1 /dev/null else verbose-message "pl_sysinit: found CD and mounted on /usr" _mounted=1 break fi fi done return $_mounted } verbose-message "pl_sysinit: finding CD to mount on /usr" mounted=0 check-initrd if [ $? -eq 1 ]; then mounted=1 else [ ! -d /usr ] && mkdir /usr check-block-devices [ $? -eq 1 ] && mounted=1 fi if [ $mounted -eq 0 ]; then hang-and-shutdown "pl_sysinit: ERROR - unable to find boot CD" exit 1 fi # parts of this were copied from devmap_mknod.sh from the device-mapper # source. Since fedora decided not to include it in the rpm, it is # being copied here function create-device-mapper-node() { DM_DIR="mapper" DM_NAME="device-mapper" DIR="/dev/$DM_DIR" CONTROL="$DIR/control" MAJOR=$(sed -n 's/^ *\([0-9]\+\) \+misc$/\1/p' /proc/devices) MINOR=$(sed -n "s/^ *\([0-9]\+\) \+$DM_NAME\$/\1/p" /proc/misc) if [ -n "$MAJOR" ] && [ -n "$MINOR" ]; then /bin/mkdir -p --mode=755 $DIR /bin/rm -f $CONTROL /bin/mknod --mode=600 $CONTROL c $MAJOR $MINOR else verbose-message "pl_sysinit: unable to create device mapper control node, continuing" fi } verbose-message "pl_sysinit: creating device mapper control node" create-device-mapper-node verbose-message "pl_sysinit: configuring kernel parameters" verbose-run /sbin/sysctl -e -p /etc/sysctl.conf # startup rsyslog if available (we're *NOT* running the standard rc) syslog=/etc/rc.d/init.d/rsyslog if [ -x $syslog ]; then verbose-message "pl_sysinit: starting rsyslog" verbose-run $syslog start else verbose-message "pl_sysinit: WARNING cannot start rsyslog" fi verbose-message "pl_sysinit: bringing network online" verbose-run /etc/init.d/pl_netinit function sync-clock() { /usr/sbin/ntpdate -b -t 10 -u pool.ntp.org # Handle /dev/rtc name change for newer kernels # otherwise hwclock fails baseMaj=`uname -r | cut -d "." -f1` baseMin=`uname -r | cut -d "." -f2` vers=`uname -r | cut -d "." -f3 | cut -d "-" -f1` if [ $baseMaj -eq 2 ];then if [ $baseMin -eq 6 ]; then if [ $vers -ge 32 ];then if [ "$(readlink /dev/rtc)" != "/dev/rtc0" ]; then rm -f /dev/rtc ln -s /dev/rtc0 /dev/rtc fi fi fi fi # save ntp clock to hardware /sbin/hwclock --systohc --utc } verbose-message "pl_sysinit: attempting to sync clock" sync-clock