--- trunk/magellan-initscripts/etc/rc.d/init.d/rc 2008/03/22 19:59:32 694 +++ trunk/magellan-initscripts/etc/rc.d/init.d/rc 2011/03/11 17:18:42 1248 @@ -1,8 +1,8 @@ #!/bin/bash -# $Header: /home/cvsd/magellan-cvs/magellan-src/magellan-initscripts/etc/rc.d/init.d/rc,v 1.20 2008-03-22 19:58:58 niro Exp $ +# $Id$ -source /etc/sysconfig/rc -source $rc_functions +source /etc/conf.d/rc +source ${rc_functions} # get mage version MAGEVER="$(< /etc/mageversion)" @@ -10,90 +10,15 @@ # source kernel config if exists [ -f /etc/conf.d/kernel ] && source /etc/conf.d/kernel -udev_version() -{ - local version=0 - - if [[ -x /sbin/udev ]] - then - version=$(/sbin/udev -V) - # We need it without a leading '0', else bash do the wrong thing - version=${version##0} - # Older udev's will print nothing - [[ -z ${version} ]] && version=0 - elif [[ -x /sbin/udevd ]] - then - version=$(/sbin/udevd --version) - version=${version##0} - [[ -z ${version} ]] && version=0 - fi - - echo "${version}" -} - -populate_udev() -{ - local opts - - # tell modprobe.sh to be verbose to $CONSOLE - echo CONSOLE=${CONSOLE} > /dev/.udev_populate - - # populate /dev with devices already found by the kernel - echo -e ${COLOREDSTAR}" Populating /dev with existing devices through uevents ..." - if [[ ${RC_COLDPLUG} = yes ]] - then - /sbin/udevtrigger - else - # do not run any init-scripts - /sbin/udevadm control --env do_not_run_plug_service=1 - - # only create device nodes - /sbin/udevtrigger --attr-match=dev - - # run persistent-net stuff - /sbin/udevtrigger --subsystem-match=net - fi - evaluate_retval - - # loop until everything is finished - echo -e ${COLOREDSTAR}" Letting udev process events ..." - /sbin/udevsettle --timeout=60 - evaluate_retval - - # unset this variable - udevadm control --env do_not_run_plug_service= - - rm -f /dev/.udev_populate - return 0 -} - -seed_dev() -{ - # seed /dev with some things that we know we need - echo -e ${COLOREDSTAR}" Seeding /dev with needed nodes ..." - ( - [ ! -c /dev/console ] && mknod /dev/console c 5 1 - [ ! -c /dev/tty1 ] && mknod /dev/tty1 c 4 1 - [ ! -c /dev/null ] && mknod /dev/null c 1 3 - - # copy over any persistant things - if [[ -d /lib/udev/devices ]] - then - cp -RPp /lib/udev/devices/* /dev 2>/dev/null - fi +# override devicemanager helper functions +if [[ ${RC_DEVICEMANAGER} = udev ]] && [[ -f ${rc_base}/init.d/udev ]] +then + source ${rc_base}/init.d/udev - # not provided by sysfs but needed - ln -snf /proc/self/fd /dev/fd - ln -snf fd/0 /dev/stdin - ln -snf fd/1 /dev/stdout - ln -snf fd/2 /dev/stderr - [[ -e /proc/kcore ]] && ln -snf /proc/kcore /dev/core - - # create problematic directories - mkdir -p /dev/pts /dev/shm - ) - evaluate_retval -} +elif [[ ${RC_DEVICEMANAGER} = mdev ]] && [[ -f ${rc_base}/init.d/mdev ]] +then + source ${rc_base}/init.d/mdev +fi trap "" INT QUIT TSTP @@ -101,16 +26,16 @@ if [[ $runlevel = sysinit ]] then - echo - echo -e "${COLGREEN}Starting ${COLBLUE}MAGELLAN (v${MAGEVER}) ${COLGREEN}Linux${COLDEFAULT}" - echo -e "Copyright 2001-2008 Niels Rogalla; http://magellan-linux.net" - echo + rc_echo + rc_echo -e "${COLGREEN}Starting ${COLBLUE}MAGELLAN (v${MAGEVER}) ${COLGREEN}Linux${COLDEFAULT}" + rc_echo "Copyright 2001-2011 Niels Rogalla; http://magellan-linux.net" + rc_echo # mount proc filesystem, needed for bootsplash; # no use of '/etc/rc.d/init.d/mountproc' anymore if [ ! -e /proc/mounts ] then - echo -e ${COLOREDSTAR}"Mounting proc file system ..." + rc_print "Mounting proc file system ..." mount -n /proc evaluate_retval fi @@ -122,77 +47,17 @@ # mount sys file system before udev if [ -d /sys ] then - echo -e ${COLOREDSTAR}"Mounting sysfs file system ..." + rc_print "Mounting sysfs file system ..." mount -n -t sysfs sysfs /sys evaluate_retval else - echo -e ${COLORED}"Fatal: mountpoint /sys missing ..." - echo -e ${COLYELLOW}"Please create the directory /sys (mkdir -p /sys)." - echo -e ${COLYELLOW}"It's essential for a 2.6 kernel." + rc_echo -e ${COLORED}"Fatal: mountpoint /sys missing ..." + rc_echo -e ${COLYELLOW}"Please create the directory /sys (mkdir -p /sys)." + rc_echo -e ${COLYELLOW}"It's essential for a 2.6 kernel." fi - - #### load udev #### - # check if /dev/console exists outside tmpfs - [ -c /dev/console ] ; need_redirect=$? - - # create a ramdisk for populating udev - echo -e ${COLOREDSTAR}"Mounting udev at /dev ..." - # many video drivers needed exec access - fstype=ramfs - # tmpfs was suggested by Greg Kroah-Hartman - kernel_supports_fs tmpfs && fstype=tmpfs - mount -n -t ${fstype} udev /dev -o exec,nosuid,mode=0755,size=10M - evaluate_retval - - # if a device tarball exists load it and if it is activated - echo -e ${COLOREDSTAR}"Configurating system to use udev ..." - if [[ ${RC_DEVICE_TARBALL} = yes ]] - then - echo -e ${COLOREDSTAR}" Populating /dev with saved device nodes ..." - tar -jxpf /lib/udev/state/devices.tar.bz2 -C /dev - evaluate_retval - fi - - # other eeded device nodes with udev - seed_dev - - if [ -e /proc/sys/kernel/hotplug ] - then - echo -e ${COLOREDSTAR}" Using netlink for hotplug events ..." - echo "" > /proc/sys/kernel/hotplug - evaluate_retval - else - echo -e ${COLOREDSTAR}${COLYELLOW}" Kernel was not compiled with hotplug support !" - print_status failure - fi - - echo -e ${COLOREDSTAR}" Starting udevd daemon ..." - if [ ${need_redirect} -eq 1 ] - then - # we need to open fds 0 1 2 - /sbin/udevd --daemon /dev/console 2>/dev/console - else - /sbin/udevd --daemon - fi - evaluate_retval - - # write root_link rule - /lib/udev/write_root_link_rule - # populate udev device nodes - populate_udev - - # create nodes that udev can't - echo -e ${COLOREDSTAR}" Finializing udev configuration ..." - [[ -x /sbin/dmsetup ]] && /sbin/dmsetup mknodes &>/dev/null - [[ -x /sbin/lvm ]] && /sbin/lvm vgscan -P --mknodes --ignorelockingfailure &>/dev/null - [[ -x /sbin/evms_activate ]] && /sbin/evms_activate -q &>/dev/null - print_status success - - # same thing as /dev/.devfsd - touch /dev/.udev - ## end udev ## - + # start device management + start_devicemanager ## load devpts ## # devfs/udev with 2.6 has no ptys, so devpts is also needed @@ -206,25 +71,25 @@ if [ ! -d "/dev/pts" -a -e "/dev/.devfsd" ] && is_fs_mounted devfs then mkdir -p /dev/pts &> /dev/null || \ - echo "Could not create /dev/pts !" + rc_echo "Could not create /dev/pts !" fi # now mount devpts if [ -d /dev/pts ] then - echo -e ${COLOREDSTAR}"Mounting devpts at /dev/pts ..." + rc_print "Mounting devpts at /dev/pts ..." mount -n -t devpts -o gid=4,mode=0620 devpts /dev/pts evaluate_retval fi else # devpts is not supported, give a warning - echo -e ${COLRED}"No devpts filesystem found ..." - echo -e ${COLYELLOW}"Your Kernel doesn't support the devpts filesystem." - echo -e ${COLYELLOW}"Devfs with a kernel-2.6.x needs devpts," - echo -e ${COLYELLOW}"or no pty's are available." - echo -e ${COLYELLOW}"Please make shure that this is enabled in your kernel." - echo - echo -e ${COLYELLOW}"Press any key to continue ..." + rc_echo -e ${COLRED}"No devpts filesystem found ..." + rc_echo -e ${COLYELLOW}"Your Kernel doesn't support the devpts filesystem." + rc_echo -e ${COLYELLOW}"Devfs/Udev with a kernel-2.6.x needs devpts," + rc_echo -e ${COLYELLOW}"or no pty's are available." + rc_echo -e ${COLYELLOW}"Please make sure that this is enabled in your kernel." + rc_echo + rc_echo -e ${COLYELLOW}"Press any key to continue ..." read fi ## end devpts ## @@ -233,14 +98,14 @@ ## load usbfs ## if kernel_supports_fs usbfs then - echo -e ${COLOREDSTAR}"Mounting usbfs at /proc/bus/usb ..." + rc_print "Mounting usbfs at /proc/bus/usb ..." mount -n -t usbfs usbfs /proc/bus/usb evaluate_retval fi ## end usbfs ## ## services state dir ## - echo -e ${COLOREDSTAR}"Mounting tmpfs at ${svcdir} ..." + rc_print "Mounting tmpfs at ${svcdir} ..." mount -n -t tmpfs tmpfs "${svcdir}" -o rw,mode=0644,size="${svcsize}"k evaluate_retval @@ -260,17 +125,20 @@ if [[ ${RC_DEVICE_TARBALL} = yes ]] && \ [ -e /dev/.udev -a ! -e /dev/.devfsd -a ! -e /.bootdev ] then - echo -e ${COLOREDSTAR}"Saving /dev device nodes ..." + rc_print "Saving /dev device nodes ..." ( cd /dev; tar -jclpf "/tmp/devices-$$.tar.bz2" * &> /dev/null ) mv -f "/tmp/devices-$$.tar.bz2" /lib/udev/state/devices.tar.bz2 evaluate_retval fi + + # stop device management + stop_devicemanager fi if [ "$runlevel" = "" ] then - echo "Usage: $0 " >&2 + rc_echo "Usage: $0 " >&2 exit 1 fi @@ -280,7 +148,7 @@ if [ ! -d $rc_base/rc$runlevel.d ] then - echo "$rc_base/rc$runlevel.d does not exist" + rc_echo "$rc_base/rc$runlevel.d does not exist" exit 1 fi @@ -300,8 +168,8 @@ if [ ! -f $prev_start ] && [ ! -f $sysinit_start ] then $WARNING - echo "$i can't be executed because it was" - echo "not started in the previous runlevel ($previous)" + rc_echo "$i can't be executed because it was" + rc_echo "not started in the previous runlevel ($previous)" $NORMAL continue fi