slitaz-boot-scripts annotate etc/init.d/rcS @ rev 41

Log boot into /var/log/boot.log using script and vcsa2txt
author Pascal Bellard <pascal.bellard@slitaz.org>
date Sat Mar 01 12:11:15 2008 +0000 (2008-03-01)
parents 2bba74627aab
children b816cb7cece4
rev   line source
pankso@5 1 #!/bin/sh
pankso@5 2 # /etc/init.d/rcS - Initial boot script for SliTaz GNU/Linux. rcS is the main
pankso@5 3 # initialisation script used to check fs, mount, clean, run scripts and start
pankso@5 4 # daemons.
pankso@5 5 #
pankso@5 6 # Config file is : /etc/rcS.conf
pankso@5 7 #
pankso@5 8 . /etc/init.d/rc.functions
pankso@5 9 . /etc/rcS.conf
pankso@5 10
pascal@41 11 if [ "$1" != "logged" ]; then #logged
pascal@41 12
pankso@5 13 # Start by sleeping a bit.
pankso@5 14 echo "Processing /etc/init.d/rcS... "
pankso@5 15 sleep 1
pankso@5 16
pankso@5 17 # Mount /proc.
pankso@5 18 echo -n "Mounting proc filesystem... "
pankso@5 19 /bin/mount proc
pankso@5 20 status && sleep 1
pankso@5 21
pankso@5 22 # Before mounting filesystems we check fs specified in the file
pankso@5 23 # /etc/rcS.conf and variable $CHECK_FS.
pankso@5 24 if [ ! "$CHECK_FS" = "" ]; then
pankso@5 25 mount -o remount,ro /
pankso@5 26 for i in $CHECK_FS
pankso@5 27 do
pankso@5 28 echo "Checking filesystem on : $i"
pankso@5 29 /sbin/e2fsck -p $i
pankso@5 30 sleep 2
pankso@5 31 done
pankso@5 32 fi
pankso@5 33
pankso@5 34 # Remount rootfs rw.
pankso@5 35 echo "Remounting rootfs read/write... "
pankso@5 36 /bin/mount -o remount,rw /
pankso@5 37
pankso@5 38 # Mount all stuff from /etc/fstab.
pankso@5 39 echo "Mounting all staff from fstab... "
pankso@5 40 /bin/mount -a
pankso@5 41
pankso@5 42 # Start Udev to populate /dev and handle hotplug events
pankso@5 43 if [ "$UDEV" = "yes" ]; then
pankso@5 44 echo -n "Starting udev daemon..."
pankso@5 45 /sbin/udevd --daemon
pankso@5 46 status
pankso@5 47 echo -n "Executing : udevstart..."
pankso@5 48 /sbin/udevstart
pankso@5 49 status
pankso@5 50 echo "/sbin/udevd" > /proc/sys/kernel/hotplug
pankso@5 51 fi
pankso@5 52
pascal@41 53 /bin/dmesg > /var/log/dmesg.log
pascal@41 54 /usr/bin/vcsa2txt < /dev/vcsa1 > /var/log/boot.log
pascal@41 55 /usr/bin/script -a -q -c '/etc/init.d/rcS logged' /var/log/boot.log
pascal@41 56
pascal@41 57 else #logged
pascal@41 58
pankso@19 59 # Creat /dev/cdrom if needed (symlink does not exist on LiveCD). Chmod
pankso@19 60 # hack for Asunder and burnbox allowing all users to burn/rip CD/DVD.
pankso@20 61 # Add also /dev/cdrom to fstab if entry dos not exist.
pankso@19 62 #
pankso@19 63 DRIVE_NAME=`cat /proc/sys/dev/cdrom/info | grep "drive name" | cut -f 3`
pankso@19 64 if [ ! "`readlink /dev/cdrom`" ]; then
pankso@19 65 echo -n "Creating symlink : /dev/cdrom..."
pankso@19 66 ln -s /dev/$DRIVE_NAME /dev/cdrom
pankso@19 67 chmod 0666 /dev/cdrom
pankso@19 68 status
pankso@19 69 fi
pankso@19 70 if ! grep -q "/dev/cdrom" /etc/fstab; then
pankso@19 71 echo -n "Adding /dev/cdrom to fstab..."
pankso@19 72 echo '/dev/cdrom /media/cdrom iso9660 user,noauto 0 0' \
pankso@19 73 >> /etc/fstab
pankso@19 74 status
pankso@19 75 fi
pankso@19 76 chmod 0666 /dev/$DRIVE_NAME
pankso@19 77
pankso@15 78 # Handle kernel cmdline parameter modprobe=<module_list>
pankso@17 79 if grep -q " modprobe=" /proc/cmdline; then
pankso@15 80 MODULES=`sed -e 's/.* modprobe=\([^ ]*\).*/\1/' -e 's/,/\n/g' < /proc/cmdline`
pankso@15 81 for i in $MODULES; do
pankso@15 82 echo -n "Loading kernel module $i"
pankso@15 83 /sbin/modprobe $i
pankso@15 84 status
pankso@15 85 done
pankso@15 86 fi
pankso@15 87
pankso@5 88 # Handle kernel cmdline parameter config=<device>,<path> to source a
pankso@5 89 # disk init script
pankso@5 90 if grep -q " config=" /proc/cmdline; then
pankso@5 91 CONFIG=`cat /proc/cmdline | sed 's/.* config=\([^ ]*\).*/\1/'`
pankso@5 92 DEVICE=${CONFIG%,*}
pankso@5 93 SCRIPT=${CONFIG#*,}
pankso@5 94 echo -n "Source $SCRIPT from $DEVICE... "
pankso@5 95 if /bin/mount -r $DEVICE /mnt; then
pankso@5 96 . /mnt/$SCRIPT
pankso@5 97 /bin/umount /mnt
pankso@5 98 fi
pankso@5 99 status
pankso@5 100 fi
pankso@5 101
pankso@5 102 # Start syslogd and klogd.
pankso@5 103 if [ "$KERNEL_LOG_DAEMONS" = "yes" ]; then
pankso@5 104 echo -n "Starting system log deamon: syslogd... "
pankso@5 105 /sbin/syslogd -s $SYSLOGD_ROTATED_SIZE && status
pankso@5 106 echo -n "Starting kernel log daemon: klogd... "
pankso@5 107 /sbin/klogd && status
pankso@5 108 else
pankso@5 109 echo "Kernel log daemons are disabled in /etc/rc.conf... "
pankso@5 110 fi
pankso@5 111
pankso@5 112 # Clean up the system.
pankso@5 113 if [ "$CLEAN_UP_SYSTEM" = "yes" ]; then
pankso@5 114 echo -n "Cleaning up the system... "
pankso@5 115 rm -rf /tmp/*
pankso@5 116 rm -f /var/run/*.pid
pankso@39 117 rm -f /var/lock/*
pankso@5 118 status
pankso@5 119 else
pankso@5 120 echo "System clean up is disabled in /etc/rcS.conf... "
pankso@5 121 echo "Keeping all tmp and pid files... "
pankso@5 122 status
pankso@5 123 fi
pankso@5 124
pankso@5 125 # Set up tmp X11 and ICE dir.
pankso@5 126 echo -n "Setting up tmp X11 and ICE unix dir... "
pankso@5 127 /bin/mkdir -p /tmp/.X11-unix
pankso@5 128 /bin/mkdir -p /tmp/.ICE-unix
pankso@5 129 /bin/chmod 1777 /tmp/.X11-unix
pankso@5 130 /bin/chmod 1777 /tmp/.ICE-unix
pankso@5 131 status
pankso@5 132
pankso@5 133 # Load all modules listed in config file.
pankso@5 134 if [ ! "$LOAD_MODULES" = "" ]; then
pankso@5 135 for mod in $LOAD_MODULES
pankso@5 136 do
pankso@5 137 modprobe $mod
pankso@5 138 done
pankso@5 139 fi
pankso@5 140
pankso@5 141 # Start all scripts specified with $RUN_SCRIPTS.
pankso@5 142 echo "Executing all initialisation scripts..."
pankso@5 143 for script in $RUN_SCRIPTS
pankso@5 144 do
pankso@32 145 if [ -x /etc/init.d/$daemon ]; then
pankso@32 146 /etc/init.d/$script
pankso@32 147 fi
pankso@5 148 done
pankso@5 149
pankso@32 150 # Re-source main config file, in Live mode daemons list ca be modified
pankso@32 151 # by boot options.
pankso@32 152 . /etc/rcS.conf
pankso@32 153
pankso@5 154 # Start all daemons specified with $RUN_DAEMONS.
pankso@5 155 echo "Starting all daemons specified in /etc/rcS.conf..."
pankso@5 156 for daemon in $RUN_DAEMONS
pankso@5 157 do
pankso@32 158 if [ -x /etc/init.d/$daemon ]; then
pankso@32 159 /etc/init.d/$daemon start
pankso@32 160 fi
pankso@5 161 done
pankso@5 162
pankso@5 163 # Reset screen and display a bold message.
pankso@5 164 if [ -n "$MESSAGE" ]; then
pankso@5 165 /usr/bin/reset
pankso@5 166 echo -e "\033[1m$MESSAGE\033[0m"
pankso@5 167 fi
pankso@5 168
pascal@41 169 fi #logged