Remove the over-engineered checkfs and checkroot scripts and replace with simple fsck, root and mtab scripts. Update dependencies accordingly.

This commit is contained in:
Roy Marples 2008-01-31 16:10:18 +00:00
parent b6b88d3a07
commit e687cc1e79
12 changed files with 98 additions and 224 deletions

View File

@ -7,7 +7,7 @@ hostid_file=${hostid_file:-/etc/hostid}
depend()
{
need checkroot
need root
before devd net
}

View File

@ -6,8 +6,7 @@ description="Saves a kernel dump."
depend()
{
need checkfs
before swap
need localmount
}
start()

29
init.d.Linux/mtab Normal file
View File

@ -0,0 +1,29 @@
#!/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license.
description="Update /etc/mtab to match what the kernel knows about"
depend()
{
need root
}
start()
{
ebegin "Updating /etc/mtab"
if ! echo 2>/dev/null >/etc/mtab; then
ewend 1 "/etc/mtab is not updateable"
return 0
fi
# With / as tmpfs we cannot umount -at tmpfs in localmount as that
# makes / readonly and dismounts all tmpfs even if in use which is
# not good. Luckily, umount uses /etc/mtab instead of /proc/mounts
# which allows this hack to work.
grep -v "^[^ ]* / tmpfs " /proc/mounts > /etc/mtab
# Remove stale backups
rm -f /etc/mtab~ /etc/mtab~~
eend 0
}

View File

@ -1,77 +0,0 @@
#!/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license.
description="Check filesystems according to /etc/fstab for errors and \
optionally repair them."
# Hard return to parse fstabinfo output
_IFS="
"
depend()
{
need checkroot
after modules
keywords notimeout
}
do_checkfs()
{
local retval=0 opts=
[ "${RC_UNAME}" = "Linux" ] && opts="-C0 -T"
ebegin "Checking all filesystems"
# Load our partitions into $@
local IFS="$_IFS"
set -- $(fstabinfo --passno ">1")
unset IFS
if [ $# = 0 ]; then
eend 0
return 0
fi
fsck -p ${opts} "$@"
retval=$?
if [ ${retval} -eq 0 ]; then
eend 0
elif [ ${retval} -eq 1 ]; then
ewend 1 "Filesystem errors corrected."
retval=0
elif [ ${retval} -eq 2 ]; then
ewend 1 "System should be rebooted"
elif [ ${retval} -eq 8 ]; then
ewend 1 "Operational error, continuing"
retval=0
else
if yesno ${rc_force_auto:-${RC_FORCE_AUTO}}; then
eend 2 "Fsck could not correct all errors, rerunning"
fsck -y ${opts} "$@"
retval=$?
eend ${retval}
fi
if [ ${retval} -gt 3 ]; then
eend 2 "Fsck could not correct all errors, manual repair needed"
exec rc-abort || exit 1
fi
fi
return ${retval}
}
start()
{
do_checkfs
}
stop()
{
# fsck on shutdown if we need to
if yesno "${fsck_shutdown:-${FSCK_SHUTDOWN}}"; then
do_checkfs
fi
return 0
}

View File

@ -1,130 +0,0 @@
#!/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license.
description="Check the root filesystem according to /etc/fstab for errors \
and optionally repair them."
depend()
{
keywords notimeout
}
do_mtab()
{
# Don't create mtab if /etc is readonly
if ! echo 2>/dev/null >/etc/mtab; then
ewarn "Skipping /etc/mtab initialization (ro root)"
return 0
fi
ebegin "Updating /etc/mtab"
# With / as tmpfs we cannot umount -at tmpfs in localmount as that
# makes / readonly and dismounts all tmpfs even if in use which is
# not good. Luckily, umount uses /etc/mtab instead of /proc/mounts
# which allows this hack to work.
grep -v "^[^ ]* / tmpfs " /proc/mounts > /etc/mtab
# Remove stale backups
rm -f /etc/mtab~ /etc/mtab~~
eend 0
}
root_rw()
{
echo 2>/dev/null >/.test.$$ || return 1
rm -f /.test.$$
}
do_fsck()
{
local retval=0 opts= root=
case "${RC_UNAME}" in
FreeBSD) opts="-F";;
Linux) opts="-T -C0";;
esac
# Don't bother doing a fsck on these
if [ -n "${CDBOOT}" ] || is_net_fs / || is_union_fs /; then
return 0
fi
if root_rw; then
einfo "root filesystem is mounted read-write - skipping"
return 0
fi
root=$(fstabinfo --blockdevice /)
[ ! -e "${root}" -a -e /dev/root ] && root=/dev/root
# Obey the fs_passno setting for / (see fstab(5))
local pass=$(fstabinfo --passno /)
if [ ${pass:-0} != "0" ]; then
ebegin "Checking root filesystem"
fsck ${opts} -p "${root}"
retval=$?
else
ebegin "Skipping root filesystem check (fstab's passno == 0)"
retval=0
fi
if [ ${retval} -eq 0 ]; then
eend 0
elif [ ${retval} -eq 1 ]; then
ewend 1 "Filesystem repaired"
retval=0
elif [ ${retval} -eq 8 ]; then
ewend 1 $"Operational error, continuing"
retval=0
elif [ ${retval} -eq 2 -o ${retval} -eq 3 ]; then
ewend 1 "Filesystem repaired, but reboot needed!"
if ! yesno ${rc_force_auto:-${RC_FORCE_AUTO}}; then
printf "\a"; sleep 1; printf "\a"; sleep 1
printf "\a"; sleep 1; printf "\a"; sleep 1
ewarn "Rebooting in 10 seconds ..."
sleep 10
fi
einfo "Rebooting"
reboot -f
else
if yesno ${rc_force_auto:-${RC_FORCE_AUTO}}; then
eend 2 "Rerunning fsck in force mode"
fsck ${opts} -y "${root}"
retval=$?
else
eend 2 "Filesystem couldn't be fixed :("
exec rc-abort || exit 1
fi
if [ ${retval} != "0" ]; then
einfo "Unmounting filesystems"
if [ "${RC_UNAME}" = "Linux" ]; then
mount -a -o remount,ro /
else
mount -u -o ro /
fi
einfo "Rebooting"
reboot -f
fi
fi
}
start()
{
do_fsck || return 1
if ! root_rw; then
ebegin "Remounting root filesystem read/write"
if [ "${RC_UNAME}" = "Linux" ]; then
mount -n -o remount,rw /
else
mount -u -o rw /
fi
eend $? "Root filesystem could not be mounted read/write" || return $?
fi
# Only Linux has mtab
[ "${RC_UNAME}" = "Linux" -a -e /proc/mounts ] && do_mtab
# We got here, so return 0
return 0
}

37
init.d/fsck Normal file
View File

@ -0,0 +1,37 @@
#!/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license.
description="Check and repair filesystems according to /etc/fstab"
depend()
{
need swap
after clock modules
keywords notimeout
}
start()
{
local retval=0 opts= root=
if [ "${RC_UNAME}" = "Linux" ]; then
opts="${opts} -A -C0 -T"
if echo 2>/dev/null >/.test.$$; then
rm -f /.test.$$
opts="${opts} -R"
fi
fi
ebegin "Checking local filesystems"
fsck -p ${opts}
case $? in
0) eend 0; return 0;;
1) ewend 1 "Filesystems repaired"; return 0;;
2|4) ewend 1 "Filesystems repaired, but reboot needed"
reboot; exec rc-abort; return 1;;
8) ewend 1 "Operational error"; return 0;;
12) ewend 1 "fsck interupted"; return 1;;
*) eend 2 "Filesystems couldn't be fixed"
exec rc-abort; return 1;;
esac
}

View File

@ -4,11 +4,6 @@
description="Sets the hostname of the machine."
depend()
{
need checkroot
}
start()
{
hostname=${hostname-${HOSTNAME-localhost}}

View File

@ -6,7 +6,8 @@ description="Mounts disks and swap according to /etc/fstab."
depend()
{
need checkfs
need fsck
use modules mtab
}
start()

25
init.d/root Normal file
View File

@ -0,0 +1,25 @@
#!/sbin/runscript
# Copyright 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license.
description="Mount the root fs read/write"
depend()
{
need fsck
}
start()
{
if echo 2>/dev/null >/.test.$$; then
rm -f /.test.$$
return 0
fi
ebegin "Remounting root filesystem read/write"
case "${RC_UNAME}" in
Linux) mount -n -o remount,rw /;;
*) mount -u -o rw /;;
esac
eend $? "Root filesystem could not be mounted read/write"
}

View File

@ -2,11 +2,6 @@
# Copyright 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license.
depend()
{
need localmount
}
start()
{
ebegin "Activating swap"

View File

@ -1,5 +1,5 @@
BOOT= bootmisc checkroot checkfs hostname localmount \
swap sysctl urandom
BOOT= bootmisc fsck hostname localmount \
root swap sysctl urandom
DEFAULT= local netmount
LEVELDIR= ${DESTDIR}/etc/runlevels

View File

@ -1,2 +1,2 @@
BOOT+= clock consolefont keymaps modules net.lo procfs
BOOT+= clock consolefont keymaps modules mtab net.lo procfs
DEFAULT+= hdparm