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:
parent
b6b88d3a07
commit
e687cc1e79
@ -7,7 +7,7 @@ hostid_file=${hostid_file:-/etc/hostid}
|
|||||||
|
|
||||||
depend()
|
depend()
|
||||||
{
|
{
|
||||||
need checkroot
|
need root
|
||||||
before devd net
|
before devd net
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -6,8 +6,7 @@ description="Saves a kernel dump."
|
|||||||
|
|
||||||
depend()
|
depend()
|
||||||
{
|
{
|
||||||
need checkfs
|
need localmount
|
||||||
before swap
|
|
||||||
}
|
}
|
||||||
|
|
||||||
start()
|
start()
|
||||||
|
29
init.d.Linux/mtab
Normal file
29
init.d.Linux/mtab
Normal 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
|
||||||
|
}
|
@ -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
|
|
||||||
}
|
|
130
init.d/checkroot
130
init.d/checkroot
@ -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
37
init.d/fsck
Normal 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
|
||||||
|
}
|
@ -4,11 +4,6 @@
|
|||||||
|
|
||||||
description="Sets the hostname of the machine."
|
description="Sets the hostname of the machine."
|
||||||
|
|
||||||
depend()
|
|
||||||
{
|
|
||||||
need checkroot
|
|
||||||
}
|
|
||||||
|
|
||||||
start()
|
start()
|
||||||
{
|
{
|
||||||
hostname=${hostname-${HOSTNAME-localhost}}
|
hostname=${hostname-${HOSTNAME-localhost}}
|
||||||
|
@ -6,7 +6,8 @@ description="Mounts disks and swap according to /etc/fstab."
|
|||||||
|
|
||||||
depend()
|
depend()
|
||||||
{
|
{
|
||||||
need checkfs
|
need fsck
|
||||||
|
use modules mtab
|
||||||
}
|
}
|
||||||
|
|
||||||
start()
|
start()
|
||||||
|
25
init.d/root
Normal file
25
init.d/root
Normal 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"
|
||||||
|
}
|
@ -2,11 +2,6 @@
|
|||||||
# Copyright 2007-2008 Roy Marples <roy@marples.name>
|
# Copyright 2007-2008 Roy Marples <roy@marples.name>
|
||||||
# All rights reserved. Released under the 2-clause BSD license.
|
# All rights reserved. Released under the 2-clause BSD license.
|
||||||
|
|
||||||
depend()
|
|
||||||
{
|
|
||||||
need localmount
|
|
||||||
}
|
|
||||||
|
|
||||||
start()
|
start()
|
||||||
{
|
{
|
||||||
ebegin "Activating swap"
|
ebegin "Activating swap"
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
BOOT= bootmisc checkroot checkfs hostname localmount \
|
BOOT= bootmisc fsck hostname localmount \
|
||||||
swap sysctl urandom
|
root swap sysctl urandom
|
||||||
DEFAULT= local netmount
|
DEFAULT= local netmount
|
||||||
|
|
||||||
LEVELDIR= ${DESTDIR}/etc/runlevels
|
LEVELDIR= ${DESTDIR}/etc/runlevels
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
BOOT+= clock consolefont keymaps modules net.lo procfs
|
BOOT+= clock consolefont keymaps modules mtab net.lo procfs
|
||||||
DEFAULT+= hdparm
|
DEFAULT+= hdparm
|
||||||
|
Loading…
x
Reference in New Issue
Block a user