mid-kid
6 years ago
commit
9cee612f10
15 changed files with 3757 additions and 0 deletions
@ -0,0 +1,25 @@ |
|||
config() { |
|||
NEW="$1" |
|||
OLD="$(dirname $NEW)/$(basename $NEW .new)" |
|||
if [ ! -r $OLD ]; then |
|||
mv $NEW $OLD |
|||
elif [ "$(cat $OLD | md5sum)" = "$(cat $NEW | md5sum)" ]; then |
|||
rm $NEW |
|||
fi |
|||
} |
|||
|
|||
preserve_perms() { |
|||
NEW="$1" |
|||
OLD="$(dirname $NEW)/$(basename $NEW .new)" |
|||
if [ -e $OLD ]; then |
|||
cp -a $OLD ${NEW}.incoming |
|||
cat $NEW > ${NEW}.incoming |
|||
mv ${NEW}.incoming $NEW |
|||
fi |
|||
config $NEW |
|||
} |
|||
|
|||
preserve_perms etc/rc.d/rc.lxc.new |
|||
config etc/lxc/default.conf.new |
|||
config etc/default/lxc.new |
|||
|
Binary file not shown.
@ -0,0 +1,489 @@ |
|||
#!/bin/bash |
|||
|
|||
# |
|||
# lxc: linux Container library |
|||
|
|||
# Authors: |
|||
# Daniel Lezcano <daniel.lezcano@free.fr> |
|||
|
|||
# Template for slackware by Matteo Bernardini <ponce@slackbuilds.org> |
|||
# some parts are taken from the debian one (used as model) |
|||
|
|||
# This library is free software; you can redistribute it and/or |
|||
# modify it under the terms of the GNU Lesser General Public |
|||
# License as published by the Free Software Foundation; either |
|||
# version 2.1 of the License, or (at your option) any later version. |
|||
|
|||
# This library is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
|||
# Lesser General Public License for more details. |
|||
|
|||
# You should have received a copy of the GNU Lesser General Public |
|||
# License along with this library; if not, write to the Free Software |
|||
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
|||
|
|||
cache=${cache:-/var/cache/lxc/slackware} |
|||
|
|||
# Use the primary Slackware site by default, but please consider changing |
|||
# this to a closer mirror site. |
|||
MIRROR=${MIRROR:-http://ftp.slackware.com/pub/slackware} |
|||
|
|||
if [ -z "$arch" ]; then |
|||
case "$( uname -m )" in |
|||
i?86) arch=i486 ;; |
|||
arm*) arch=arm ;; |
|||
*) arch=$( uname -m ) ;; |
|||
esac |
|||
fi |
|||
|
|||
configure_slackware() |
|||
{ |
|||
rootfs=$1 |
|||
hostname=$2 |
|||
|
|||
echo "Configuring..." ; echo |
|||
|
|||
# The next part contains excerpts taken from SeTconfig (written by |
|||
# Patrick Volkerding) from the slackware setup disk. |
|||
# But before pasting them just set a variable to use them as they are |
|||
T_PX=$rootfs |
|||
|
|||
( cd $T_PX ; chmod 755 ./ ) |
|||
( cd $T_PX ; chmod 755 ./var ) |
|||
if [ -d $T_PX/usr/src/linux ]; then |
|||
chmod 755 $T_PX/usr/src/linux |
|||
fi |
|||
if [ ! -d $T_PX/proc ]; then |
|||
mkdir $T_PX/proc |
|||
chown root.root $T_PX/proc |
|||
fi |
|||
if [ ! -d $T_PX/sys ]; then |
|||
mkdir $T_PX/sys |
|||
chown root.root $T_PX/sys |
|||
fi |
|||
chmod 1777 $T_PX/tmp |
|||
if [ ! -d $T_PX/var/spool/mail ]; then |
|||
mkdir -p $T_PX/var/spool/mail |
|||
chmod 755 $T_PX/var/spool |
|||
chown root.mail $T_PX/var/spool/mail |
|||
chmod 1777 $T_PX/var/spool/mail |
|||
fi |
|||
|
|||
echo "#!/bin/sh" > $T_PX/etc/rc.d/rc.keymap |
|||
echo "# Load the keyboard map. More maps are in /usr/share/kbd/keymaps." \ |
|||
>> $T_PX/etc/rc.d/rc.keymap |
|||
echo "if [ -x /usr/bin/loadkeys ]; then" >> $T_PX/etc/rc.d/rc.keymap |
|||
echo " /usr/bin/loadkeys us" >> $T_PX/etc/rc.d/rc.keymap |
|||
echo "fi" >> $T_PX/etc/rc.d/rc.keymap |
|||
chmod 755 $T_PX/etc/rc.d/rc.keymap |
|||
|
|||
# Network configuration is left to the user, that have to edit |
|||
# /etc/rc.d/rc.inet1.conf and /etc/resolv.conf of the container |
|||
# just set the hostname |
|||
cat <<EOF > $rootfs/etc/HOSTNAME |
|||
$hostname.example.net |
|||
EOF |
|||
cp $rootfs/etc/HOSTNAME $rootfs/etc/hostname |
|||
|
|||
# make needed devices, from Chris Willing's MAKEDEV.sh |
|||
# http://www.vislab.uq.edu.au/howto/lxc/MAKEDEV.sh |
|||
DEV=$rootfs/dev |
|||
mkdir -p ${DEV} |
|||
mknod -m 666 ${DEV}/null c 1 3 |
|||
mknod -m 666 ${DEV}/zero c 1 5 |
|||
mknod -m 666 ${DEV}/random c 1 8 |
|||
mknod -m 666 ${DEV}/urandom c 1 9 |
|||
mkdir -m 755 ${DEV}/pts |
|||
mkdir -m 1777 ${DEV}/shm |
|||
mknod -m 666 ${DEV}/tty c 5 0 |
|||
mknod -m 600 ${DEV}/console c 5 1 |
|||
mknod -m 666 ${DEV}/tty0 c 4 0 |
|||
mknod -m 666 ${DEV}/tty1 c 4 1 |
|||
mknod -m 666 ${DEV}/tty2 c 4 2 |
|||
mknod -m 666 ${DEV}/tty3 c 4 3 |
|||
mknod -m 666 ${DEV}/tty4 c 4 4 |
|||
mknod -m 666 ${DEV}/tty5 c 4 5 |
|||
mknod -m 666 ${DEV}/full c 1 7 |
|||
mknod -m 600 ${DEV}/initctl p |
|||
mknod -m 660 ${DEV}/loop0 b 7 0 |
|||
mknod -m 660 ${DEV}/loop1 b 7 1 |
|||
ln -s pts/ptmx ${DEV}/ptmx |
|||
ln -s /proc/self/fd ${DEV}/fd |
|||
|
|||
echo "Adding an etc/fstab that must be modified later with the" |
|||
echo "full path of the container's rootfs if you decide to move it." |
|||
cat >$rootfs/etc/fstab <<EOF |
|||
lxcpts $rootfs/dev/pts devpts defaults,newinstance 0 0 |
|||
none $rootfs/proc proc defaults 0 0 |
|||
none $rootfs/sys sysfs defaults 0 0 |
|||
none /dev/shm tmpfs defaults 0 0 |
|||
none /run tmpfs defaults,mode=0755 0 0 |
|||
EOF |
|||
|
|||
# Back up the existing init scripts and install the lxc versions: |
|||
( cd $rootfs/etc/rc.d |
|||
cp -a /usr/share/lxc/scripts/slackware/* . |
|||
chmod 755 *.lxc |
|||
for file in *.lxc ; do |
|||
cp -a $(basename $file .lxc) $(basename $file .lxc).orig |
|||
cp -a $file $(basename $file .lxc) |
|||
done |
|||
) |
|||
|
|||
# restart rc.inet1 to have routing for the loop device |
|||
echo "/etc/rc.d/rc.inet1 restart" >> $rootfs/etc/rc.d/rc.local |
|||
|
|||
# reduce the number of local consoles: two should be enough |
|||
sed -i '/^c3\|^c4\|^c5\|^c6/s/^/# /' $rootfs/etc/inittab |
|||
|
|||
# In a container, use shutdown for powerfail conditions. LXC sends the SIGPWR |
|||
# signal to init to shut down the container with lxc-stop and without this the |
|||
# container will be force stopped after a one minute timeout. |
|||
sed -i "s,pf::powerfail:/sbin/genpowerfail start,pf::powerfail:/sbin/shutdown -h now,g" $rootfs/etc/inittab |
|||
sed -i "s,pg::powerokwait:/sbin/genpowerfail stop,pg::powerokwait:/sbin/shutdown -c,g" $rootfs/etc/inittab |
|||
|
|||
# set a default combination for the luggage |
|||
echo "root:root" | chroot $rootfs chpasswd |
|||
echo "Root default password is 'root', please change it!" |
|||
|
|||
# borrow the time configuration from the local machine |
|||
cp -a /etc/localtime $rootfs/etc/localtime |
|||
|
|||
return 0 |
|||
} |
|||
|
|||
copy_slackware() |
|||
{ |
|||
rootfs=$1 |
|||
|
|||
# make a local copy of the installed filesystem |
|||
echo -n "Copying rootfs to $rootfs..." |
|||
mkdir -p $rootfs |
|||
cp -a $cache/rootfs-$release-$arch/* $rootfs/ || exit 1 |
|||
|
|||
# fix fstab with the actual path |
|||
sed -i "s|$cache/rootfs-$release-$arch|$rootfs|" $rootfs/etc/fstab |
|||
|
|||
return 0 |
|||
} |
|||
|
|||
install_slackware() |
|||
{ |
|||
rootfs=$1 |
|||
mkdir -p /var/lock/subsys/ |
|||
( |
|||
flock -n -x 200 |
|||
if [ $? -ne 0 ]; then |
|||
echo "Cache repository is busy." |
|||
return 1 |
|||
fi |
|||
|
|||
if [ "$arch" == "x86_64" ]; then |
|||
PKGMAIN=slackware64 |
|||
elif [ "$arch" == "arm" ]; then |
|||
PKGMAIN=slackwarearm |
|||
else |
|||
PKGMAIN=slackware |
|||
fi |
|||
|
|||
export CONF=$cache/slackpkg-conf |
|||
export ROOT=$cache/rootfs-$release-$arch |
|||
|
|||
mkdir -p $cache/cache-$release-$arch $cache/rootfs-$release-$arch \ |
|||
$cache/slackpkg-$release-$arch $CONF/templates |
|||
|
|||
echo "$MIRROR/$PKGMAIN-$release/" > $CONF/mirrors |
|||
touch $CONF/blacklist |
|||
|
|||
cat <<EOF > $CONF/slackpkg.conf |
|||
# v2.8 |
|||
ARCH=$arch |
|||
TEMP=$cache/cache-$release-$arch |
|||
WORKDIR=$cache/slackpkg-$release-$arch |
|||
DELALL=off |
|||
CHECKMD5=on |
|||
CHECKGPG=on |
|||
CHECKSIZE=off |
|||
PRIORITY=( patches %PKGMAIN extra pasture testing ) |
|||
POSTINST=on |
|||
ONLY_NEW_DOTNEW=off |
|||
ONOFF=on |
|||
DOWNLOAD_ALL=on |
|||
DIALOG=off |
|||
BATCH=on |
|||
DEFAULT_ANSWER=y |
|||
USE_INCLUDES=on |
|||
SPINNING=off |
|||
EOF |
|||
|
|||
# thanks to Vincent Batts for this list of packages |
|||
# (that I modified a little :P) |
|||
# http://connie.slackware.com/~vbatts/minimal/ |
|||
cat <<EOF > $CONF/templates/minimal-lxc.template |
|||
aaa_base |
|||
aaa_elflibs |
|||
aaa_terminfo |
|||
bash |
|||
bin |
|||
bzip2 |
|||
coreutils |
|||
dcron |
|||
dhcpcd |
|||
dialog |
|||
diffutils |
|||
e2fsprogs |
|||
elvis |
|||
etc |
|||
eudev |
|||
findutils |
|||
gawk |
|||
glibc-solibs |
|||
gnupg |
|||
grep |
|||
gzip |
|||
iputils |
|||
logrotate |
|||
mpfr |
|||
net-tools |
|||
network-scripts |
|||
ncurses |
|||
openssh |
|||
openssl-solibs |
|||
pkgtools |
|||
procps-ng |
|||
sed |
|||
shadow |
|||
sharutils |
|||
slackpkg |
|||
sysklogd |
|||
sysvinit |
|||
sysvinit-functions |
|||
sysvinit-scripts |
|||
tar |
|||
util-linux |
|||
wget |
|||
which |
|||
xz |
|||
EOF |
|||
|
|||
TEMPLATE=${TEMPLATE:-minimal-lxc} |
|||
if [ ! "$TEMPLATE" = "minimal-lxc" ]; then |
|||
if [ -f /etc/slackpkg/templates/$TEMPLATE.template ]; then |
|||
cat /etc/slackpkg/templates/$TEMPLATE.template \ |
|||
> $CONF/templates/$TEMPLATE.template |
|||
else |
|||
TEMPLATE="minimal-lxc" |
|||
fi |
|||
fi |
|||
|
|||
# clean previous installs |
|||
rm -fR $ROOT/* |
|||
|
|||
slackpkg -default_answer=n update |
|||
slackpkg install-template $TEMPLATE |
|||
|
|||
# add a slackpkg default mirror |
|||
echo "$MIRROR/$PKGMAIN-$release/" >> $ROOT/etc/slackpkg/mirrors |
|||
|
|||
# blacklist the devs package (we have to use our premade devices). |
|||
# do the same with the kernel packages (we use the host's one), |
|||
# but leave available headers and sources |
|||
echo "devs" >> $ROOT/etc/slackpkg/blacklist |
|||
sed -i \ |
|||
-e "s|^#kernel-|kernel-|" \ |
|||
-e "s|^kernel-headers|#kernel-headers|" \ |
|||
-e "s|^kernel-source|#kernel-source|" \ |
|||
$ROOT/etc/slackpkg/blacklist |
|||
|
|||
return 0 |
|||
|
|||
) 200>/var/lock/subsys/lxc |
|||
|
|||
return $? |
|||
} |
|||
|
|||
copy_configuration() |
|||
{ |
|||
path=$1 |
|||
rootfs=$2 |
|||
name=$3 |
|||
|
|||
cat <<EOF >> $path/config |
|||
|
|||
lxc.utsname = $name |
|||
|
|||
lxc.mount = $rootfs/etc/fstab |
|||
|
|||
lxc.tty = 4 |
|||
lxc.pts = 1024 |
|||
lxc.rootfs = $rootfs |
|||
|
|||
lxc.cgroup.devices.deny = a |
|||
# /dev/null and zero |
|||
lxc.cgroup.devices.allow = c 1:3 rwm |
|||
lxc.cgroup.devices.allow = c 1:5 rwm |
|||
# consoles |
|||
lxc.cgroup.devices.allow = c 5:1 rwm |
|||
lxc.cgroup.devices.allow = c 5:0 rwm |
|||
lxc.cgroup.devices.allow = c 4:0 rwm |
|||
lxc.cgroup.devices.allow = c 4:1 rwm |
|||
# /dev/{,u}random |
|||
lxc.cgroup.devices.allow = c 1:9 rwm |
|||
lxc.cgroup.devices.allow = c 1:8 rwm |
|||
lxc.cgroup.devices.allow = c 136:* rwm |
|||
lxc.cgroup.devices.allow = c 5:2 rwm |
|||
# rtc |
|||
lxc.cgroup.devices.allow = c 254:0 rwm |
|||
|
|||
# we don't trust even the root user in the container, better safe than sorry. |
|||
# comment out only if you know what you're doing. |
|||
lxc.cap.drop = sys_module mknod mac_override mac_admin sys_time setfcap setpcap |
|||
|
|||
# you can try also this alternative to the line above, whatever suits you better. |
|||
# lxc.cap.drop=sys_admin |
|||
EOF |
|||
|
|||
if [ $? -ne 0 ]; then |
|||
echo "Failed to add configuration." |
|||
return 1 |
|||
fi |
|||
|
|||
return 0 |
|||
} |
|||
|
|||
clean() |
|||
{ |
|||
if [ ! -e $cache ]; then |
|||
exit 0 |
|||
fi |
|||
|
|||
# lock, so we won't purge while someone is creating a repository |
|||
( |
|||
flock -n -x 200 |
|||
if [ $? != 0 ]; then |
|||
echo "Cache repository is busy." |
|||
exit 1 |
|||
fi |
|||
|
|||
echo -n "Purging the download cache..." |
|||
rm --preserve-root --one-file-system -rf $cache && echo "Done." || exit 1 |
|||
exit 0 |
|||
|
|||
) 200>/var/lock/subsys/lxc |
|||
} |
|||
|
|||
usage() |
|||
{ |
|||
cat <<EOF |
|||
$1 -h|--help -p|--path=<path> --clean |
|||
EOF |
|||
return 0 |
|||
} |
|||
|
|||
options=$(getopt -o hp:n:a:r:c -l help,rootfs:,path:,name:,arch:,release:,clean -- "$@") |
|||
if [ $? -ne 0 ]; then |
|||
usage $(basename $0) |
|||
exit 1 |
|||
fi |
|||
eval set -- "$options" |
|||
|
|||
while true |
|||
do |
|||
case "$1" in |
|||
-h|--help) usage $0 && exit 0;; |
|||
-p|--path) path=$2; shift 2;; |
|||
--rootfs) rootfs=$2; shift 2;; |
|||
-a|--arch) arch=$2; shift 2;; |
|||
-r|--release) release=$2; shift 2;; |
|||
-n|--name) name=$2; shift 2;; |
|||
-c|--clean) clean=$2; shift 2;; |
|||
--) shift 1; break ;; |
|||
*) break ;; |
|||
esac |
|||
done |
|||
|
|||
if [ ! -z "$clean" -a -z "$path" ]; then |
|||
clean || exit 1 |
|||
exit 0 |
|||
fi |
|||
|
|||
type installpkg |
|||
if [ $? -ne 0 ]; then |
|||
echo "'installpkg' command is missing." |
|||
exit 1 |
|||
fi |
|||
|
|||
type slackpkg |
|||
if [ $? -ne 0 ]; then |
|||
echo "'slackpkg' command is missing." |
|||
exit 1 |
|||
fi |
|||
|
|||
if [ -z "$path" ]; then |
|||
echo "'path' parameter is required." |
|||
exit 1 |
|||
fi |
|||
|
|||
if [ "$(id -u)" != "0" ]; then |
|||
echo "This script should be run as 'root'." |
|||
exit 1 |
|||
fi |
|||
|
|||
# If no release version was specified, use current |
|||
release=${release:-current} |
|||
|
|||
if [ -z "$name" ]; then |
|||
# no name given? set a default one |
|||
name=slackwarecontainer |
|||
fi |
|||
|
|||
# detect rootfs |
|||
config="$path/config" |
|||
if [ -z "$rootfs" ]; then |
|||
if grep -q '^lxc.rootfs' $config 2>/dev/null ; then |
|||
rootfs=$(awk -F= '/^lxc.rootfs =/{ print $2 }' $config) |
|||
else |
|||
rootfs=$path/rootfs |
|||
fi |
|||
fi |
|||
|
|||
echo |
|||
|
|||
set -e |
|||
|
|||
install_slackware $rootfs |
|||
if [ $? -ne 0 ]; then |
|||
echo "Failed to install slackware." |
|||
exit 1 |
|||
fi |
|||
|
|||
echo |
|||
|
|||
configure_slackware $cache/rootfs-$release-$arch $name |
|||
if [ $? -ne 0 ]; then |
|||
echo "Failed to configure slackware for a container." |
|||
exit 1 |
|||
fi |
|||
|
|||
echo |
|||
|
|||
rootfs=$path/rootfs |
|||
copy_slackware $rootfs |
|||
if [ $? -ne 0 ]; then |
|||
echo "Failed to copy rootfs." |
|||
exit 1 |
|||
fi |
|||
|
|||
echo |
|||
|
|||
copy_configuration $path $rootfs $name |
|||
if [ $? -ne 0 ]; then |
|||
echo "Failed to write configuration file." |
|||
exit 1 |
|||
fi |
|||
|
|||
if [ ! -z $clean ]; then |
|||
clean || exit 1 |
|||
exit 0 |
|||
fi |
@ -0,0 +1,182 @@ |
|||
#!/bin/sh |
|||
|
|||
# Copyright 2011, 2012, 2013, 2014, 2015, 2016 Patrick J. Volkerding, Sebeka, Minnesota, USA |
|||
# All rights reserved. |
|||
# |
|||
# Redistribution and use of this script, with or without modification, is |
|||
# permitted provided that the following conditions are met: |
|||
# |
|||
# 1. Redistributions of this script must retain the above copyright |
|||
# notice, this list of conditions and the following disclaimer. |
|||
# |
|||
# THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED |
|||
# WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF |
|||
# MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO |
|||
# EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
|||
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, |
|||
# PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; |
|||
# OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, |
|||
# WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR |
|||
# OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF |
|||
# ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
|||
|
|||
# Modified by Matteo Bernardini <ponce@slackbuilds.org> (2014) |
|||
|
|||
PKGNAM=lxc |
|||
VERSION=${VERSION:-$(echo $PKGNAM-*.tar.?z* | rev | cut -f 3- -d . | rev | cut -f 2- -d -)} |
|||
BUILD=${BUILD:-4} |
|||
|
|||
# Automatically determine the architecture we're building on: |
|||
if [ -z "$ARCH" ]; then |
|||
case "$( uname -m )" in |
|||
i?86) export ARCH=i586 ;; |
|||
arm*) export ARCH=arm ;; |
|||
# Unless $ARCH is already set, use uname -m for all other archs: |
|||
*) export ARCH=$( uname -m ) ;; |
|||
esac |
|||
fi |
|||
|
|||
NUMJOBS=${NUMJOBS:-" -j7 "} |
|||
|
|||
if [ "$ARCH" = "i586" ]; then |
|||
SLKCFLAGS="-O2 -march=i586 -mtune=i686" |
|||
LIBDIRSUFFIX="" |
|||
elif [ "$ARCH" = "s390" ]; then |
|||
SLKCFLAGS="-O2" |
|||
LIBDIRSUFFIX="" |
|||
elif [ "$ARCH" = "x86_64" ]; then |
|||
SLKCFLAGS="-O2 -fPIC" |
|||
LIBDIRSUFFIX="64" |
|||
else |
|||
SLKCFLAGS="-O2" |
|||
LIBDIRSUFFIX="" |
|||
fi |
|||
|
|||
CWD=$(pwd) |
|||
TMP=${TMP:-/tmp} |
|||
PKG=$TMP/package-$PKGNAM |
|||
|
|||
rm -rf $PKG |
|||
mkdir -p $TMP $PKG |
|||
|
|||
cd $TMP |
|||
rm -rf $PKGNAM-$VERSION |
|||
tar xvf $CWD/$PKGNAM-$VERSION.tar.?z* || exit 1 |
|||
cd $PKGNAM-$VERSION |
|||
|
|||
chown -R root:root . |
|||
find . \ |
|||
\( -perm 777 -o -perm 775 -o -perm 711 -o -perm 555 -o -perm 511 \) \ |
|||
-exec chmod 755 {} \; -o \ |
|||
\( -perm 666 -o -perm 664 -o -perm 600 -o -perm 444 -o -perm 440 -o -perm 400 \) \ |
|||
-exec chmod 644 {} \; |
|||
|
|||
# Add the template file: |
|||
cat $CWD/lxc-slackware.in > templates/lxc-slackware.in |
|||
|
|||
# Our python package is not split: |
|||
sed -i "s|PKG_CHECK_MODULES(\[PYTHONDEV.*||" configure.ac || exit 1 |
|||
|
|||
autoreconf -fi |
|||
|
|||
# Enable python stuff only if python3 is installed |
|||
python="" |
|||
[ -x /usr/bin/python3 ] && export PYTHON=/usr/bin/python3 && python="--enable-python" |
|||
|
|||
# Configure: |
|||
# lua is autodetected |
|||
CFLAGS="$SLKCFLAGS" \ |
|||
./configure \ |
|||
--prefix=/usr \ |
|||
--sysconfdir=/etc \ |
|||
--libdir=/usr/lib${LIBDIRSUFFIX} \ |
|||
--localstatedir=/var \ |
|||
--mandir=/usr/man \ |
|||
--docdir=/usr/doc/$PKGNAM-$VERSION \ |
|||
--infodir=/usr/info \ |
|||
--with-global-conf=/etc/lxc/lxc.conf \ |
|||
--with-rootfs-path=/var/lib/rootfs-lxc \ |
|||
$python \ |
|||
--build=$ARCH-slackware-linux |
|||
|
|||
# Build and install: |
|||
make $NUMJOBS || make || exit 1 |
|||
make install DESTDIR=$PKG || exit 1 |
|||
|
|||
# Add the modified Slackware startup scripts: |
|||
mkdir -p $PKG/usr/share/lxc/scripts/slackware |
|||
cp -a $CWD/scripts/*.lxc $PKG/usr/share/lxc/scripts/slackware |
|||
chown root:root $PKG/usr/share/lxc/scripts/slackware/* |
|||
chmod 644 $PKG/usr/share/lxc/scripts/slackware/* |
|||
|
|||
# Make the default configuration directories and an empty rootfs folder: |
|||
mkdir -p $PKG/var/lib/lxc $PKG/etc/lxc $PKG/var/lib/rootfs-lxc |
|||
|
|||
# Create a sample default configuration file: |
|||
echo "lxcpath = /var/lib/lxc" > $PKG/etc/lxc/lxc.conf.sample |
|||
|
|||
# Move the other config files to .new: |
|||
mv $PKG/etc/lxc/default.conf $PKG/etc/lxc/default.conf.new |
|||
mv $PKG/etc/default/lxc $PKG/etc/default/lxc.new |
|||
|
|||
# Install an init script (non executable by default): |
|||
install -D -m 0644 $CWD/rc.lxc $PKG/etc/rc.d/rc.lxc.new |
|||
|
|||
# Put bash completion file in system directory: |
|||
mkdir -p $PKG/usr/share/bash-completion/completions/ |
|||
mv $PKG/etc/bash_completion.d/lxc \ |
|||
$PKG/usr/share/bash-completion/completions/lxc |
|||
rmdir --parents $PKG/etc/bash_completion.d 2>/dev/null |
|||
# Replace illegal characters in the bash completion file: |
|||
sed -i "s/lxc-generic-/lxc_generic_/g" $PKG/usr/share/bash-completion/completions/lxc |
|||
|
|||
# Strip binaries: |
|||
( cd $PKG |
|||
find . | xargs file | grep "executable" | grep ELF | cut -f 1 -d : | xargs strip --strip-unneeded 2> /dev/null |
|||
find . | xargs file | grep "shared object" | grep ELF | cut -f 1 -d : | xargs strip --strip-unneeded 2> /dev/null |
|||
) |
|||
|
|||
# Add a documentation directory: |
|||
mkdir -p $PKG/usr/doc/${PKGNAM}-$VERSION |
|||
cp -a \ |
|||
AUTHORS CONTRIBUTING COPYING* INSTALL MAINTAINERS NEWS README* TODO \ |
|||
doc/FAQ.txt \ |
|||
$PKG/usr/doc/${PKGNAM}-$VERSION |
|||
|
|||
mkdir -p $PKG/usr/doc/${PKGNAM}-$VERSION/examples |
|||
cp -a doc/examples/*.conf $PKG/usr/doc/${PKGNAM}-$VERSION/examples |
|||
|
|||
# Fix up man pages to stop 'man' from barfing a warning: |
|||
( cd $PKG/usr/man |
|||
fgrep -lr -- '-*- coding: us-ascii -*-' . | xargs sed -i '/-*- coding: us-ascii -*-/d' ) |
|||
|
|||
# Compress and if needed symlink the man pages: |
|||
if [ -d $PKG/usr/man ]; then |
|||
( cd $PKG/usr/man |
|||
for manpagedir in $(find . -type d -name "man*") ; do |
|||
( cd $manpagedir |
|||
for eachpage in $( find . -type l -maxdepth 1) ; do |
|||
ln -s $( readlink $eachpage ).gz $eachpage.gz |
|||
rm $eachpage |
|||
done |
|||
gzip -9 *.? |
|||
) |
|||
done |
|||
) |
|||
fi |
|||
|
|||
# If there's a ChangeLog, installing at least part of the recent history |
|||
# is useful, but don't let it get totally out of control: |
|||
if [ -r ChangeLog ]; then |
|||
DOCSDIR=$(echo $PKG/usr/doc/${PKGNAM}-$VERSION) |
|||
cat ChangeLog | head -n 1000 > $DOCSDIR/ChangeLog |
|||
touch -r ChangeLog $DOCSDIR/ChangeLog |
|||
fi |
|||
|
|||
mkdir -p $PKG/install |
|||
cat $CWD/slack-desc > $PKG/install/slack-desc |
|||
cat $CWD/doinst.sh > $PKG/install/doinst.sh |
|||
|
|||
cd $PKG |
|||
/sbin/makepkg -l y -c n $TMP/$PKGNAM-$(echo $VERSION | tr - _)-$ARCH-$BUILD.txz |
|||
|
@ -0,0 +1,63 @@ |
|||
#!/bin/sh |
|||
# rc.lxc init script |
|||
# Written by Matteo Bernardini <ponce@slackbuilds.org> |
|||
# |
|||
# This script checks for the presence of the parameter lxc.start.auto |
|||
# in the available container configurations: if it's set to 1 the |
|||
# container is started (in an auto-detached screen session if |
|||
# screen is available) when rc.lxc is called with the "start" param. |
|||
# |
|||
# To stop the container it uses lxc-attach to execute /sbin/halt |
|||
# inside of it. |
|||
|
|||
. /usr/share/lxc/lxc.functions |
|||
|
|||
start_lxc() { |
|||
for CONTAIN in $(/usr/bin/lxc-ls); do |
|||
if [ "$(lxc-info -n $CONTAIN -c lxc.start.auto)" = "lxc.start.auto = 1" ]; then |
|||
if [ "$(/usr/bin/lxc-info -s -n $CONTAIN | grep STOPPED$)" ]; then |
|||
echo "Starting LXC container ${CONTAIN}." |
|||
if [ -x /usr/bin/screen ]; then |
|||
/usr/bin/screen -dmS init-${CONTAIN} /usr/bin/lxc-start -n $CONTAIN |
|||
else |
|||
/usr/bin/lxc-start -n $CONTAIN -d |
|||
fi |
|||
/usr/bin/lxc-wait -n $CONTAIN -s RUNNING |
|||
if [ $? -gt 0 ]; then |
|||
return 2 |
|||
fi |
|||
fi |
|||
fi |
|||
done |
|||
} |
|||
|
|||
stop_lxc() { |
|||
for CONTAIN in $(/usr/bin/lxc-ls --active); do |
|||
echo "Stopping LXC container ${CONTAIN}." |
|||
/usr/bin/lxc-stop -n $CONTAIN |
|||
/usr/bin/lxc-wait -n $CONTAIN -s STOPPED |
|||
if [ $? -gt 0 ]; then |
|||
return 2 |
|||
fi |
|||
done |
|||
} |
|||
|
|||
restart_lxc() { |
|||
stop_lxc |
|||
sleep 2 |
|||
start_lxc |
|||
} |
|||
|
|||
case "$1" in |
|||
'start') |
|||
start_lxc |
|||
;; |
|||
'stop') |
|||
stop_lxc |
|||
;; |
|||
restart) |
|||
restart_lxc |
|||
;; |
|||
*) |
|||
echo "usage $0 start|stop|restart" |
|||
esac |
@ -0,0 +1,11 @@ |
|||
These are modified versions of some sysvinit-scripts and network-scripts for |
|||
Slackware for use in a container (although they should also work for a regular |
|||
non-container system as well). |
|||
|
|||
Versions ending in .lxc are the scripts to be used in a container. |
|||
Versions ending in .orig are the scripts from the sysvinit-scripts and |
|||
network-scripts packages that the .lxc scripts are based on. |
|||
|
|||
Any changes made to the original scripts in sysvinit-scripts or network-scripts |
|||
*may* need to be ported to these versions. |
|||
|
@ -0,0 +1,316 @@ |
|||
#! /bin/sh |
|||
# |
|||
# rc.6 This file is executed by init when it goes into runlevel |
|||
# 0 (halt) or runlevel 6 (reboot). It kills all processes, |
|||
# unmounts file systems and then either halts or reboots. |
|||
# |
|||
# Version: @(#)/etc/rc.d/rc.6 2.47 Sat Jan 13 13:37:26 PST 2001 |
|||
# |
|||
# Author: Miquel van Smoorenburg <miquels@drinkel.nl.mugnet.org> |
|||
# Modified by: Patrick J. Volkerding, <volkerdi@slackware.com> |
|||
# |
|||
|
|||
# Set the path. |
|||
PATH=/sbin:/etc:/bin:/usr/bin |
|||
|
|||
# Set $container variable since this is a modified version of rc.6 with |
|||
# changes for running in an lxc container. A check to see if this variable |
|||
# is set will be used to skip parts of the script that we don't want to run |
|||
# in a container. Thanks to Matteo Bernardini <ponce@slackbuilds.org> and |
|||
# Chris Willing for the initial work making this script lxc compatible. |
|||
container="lxc" |
|||
|
|||
# If there are SystemV init scripts for this runlevel, run them. |
|||
if [ -x /etc/rc.d/rc.sysvinit ]; then |
|||
. /etc/rc.d/rc.sysvinit |
|||
fi |
|||
|
|||
# Set linefeed mode to avoid staircase effect. |
|||
/bin/stty onlcr |
|||
|
|||
echo "Running shutdown script $0:" |
|||
|
|||
# Find out how we were called. |
|||
case "$0" in |
|||
*0) |
|||
shutdown_command="halt" |
|||
;; |
|||
*6) |
|||
shutdown_command=reboot |
|||
;; |
|||
*) |
|||
echo "$0: call me as \"rc.0\" or \"rc.6\" please!" |
|||
exit 1 |
|||
;; |
|||
esac |
|||
|
|||
# Save the system time to the hardware clock using hwclock --systohc. |
|||
# This will also create or update the timestamps in /etc/adjtime. |
|||
if [ -x /sbin/hwclock -a -z "$container" ]; then |
|||
# Check for a broken motherboard RTC clock (where ioports for rtc are |
|||
# unknown) to prevent hwclock causing a hang: |
|||
if ! grep -q " : rtc" /proc/ioports ; then |
|||
CLOCK_OPT="--directisa" |
|||
fi |
|||
if [ /etc/adjtime -nt /etc/hardwareclock ]; then |
|||
if grep -q "^LOCAL" /etc/adjtime ; then |
|||
echo "Saving system time to the hardware clock (localtime)." |
|||
else |
|||
echo "Saving system time to the hardware clock (UTC)." |
|||
fi |
|||
/sbin/hwclock $CLOCK_OPT --systohc |
|||
elif grep -q "^UTC" /etc/hardwareclock 2> /dev/null ; then |
|||
echo "Saving system time to the hardware clock (UTC)." |
|||
if [ ! -r /etc/adjtime ]; then |
|||
echo "Creating system time correction file /etc/adjtime." |
|||
fi |
|||
/sbin/hwclock $CLOCK_OPT --utc --systohc |
|||
else |
|||
echo "Saving system time to the hardware clock (localtime)." |
|||
if [ ! -r /etc/adjtime ]; then |
|||
echo "Creating system time correction file /etc/adjtime." |
|||
fi |
|||
/sbin/hwclock $CLOCK_OPT --localtime --systohc |
|||
fi |
|||
fi |
|||
|
|||
# Run any local shutdown scripts: |
|||
if [ -x /etc/rc.d/rc.local_shutdown ]; then |
|||
/etc/rc.d/rc.local_shutdown stop |
|||
fi |
|||
|
|||
# Stop the Apache web server: |
|||
if [ -x /etc/rc.d/rc.httpd ]; then |
|||
/etc/rc.d/rc.httpd stop |
|||
fi |
|||
|
|||
# Stop the MySQL database: |
|||
if [ -r /var/run/mysql/mysql.pid ]; then |
|||
. /etc/rc.d/rc.mysqld stop |
|||
fi |
|||
|
|||
# Stop the Samba server: |
|||
if [ -x /etc/rc.d/rc.samba ]; then |
|||
. /etc/rc.d/rc.samba stop |
|||
fi |
|||
|
|||
# Shut down the NFS server: |
|||
if [ -x /etc/rc.d/rc.nfsd ]; then |
|||
/etc/rc.d/rc.nfsd stop |
|||
fi |
|||
|
|||
# Shut down the SSH server: |
|||
if [ -x /etc/rc.d/rc.sshd ]; then |
|||
/etc/rc.d/rc.sshd stop |
|||
fi |
|||
|
|||
# Shut down the SASL authentication daemon: |
|||
if [ -x /etc/rc.d/rc.saslauthd ]; then |
|||
/etc/rc.d/rc.saslauthd stop |
|||
fi |
|||
|
|||
# Shut down OpenLDAP: |
|||
if [ -x /etc/rc.d/rc.openldap ]; then |
|||
/etc/rc.d/rc.openldap stop |
|||
fi |
|||
|
|||
# Stop D-Bus: |
|||
if [ -x /etc/rc.d/rc.messagebus ]; then |
|||
sh /etc/rc.d/rc.messagebus stop |
|||
fi |
|||
|
|||
# Kill any processes (typically gam) that would otherwise prevent |
|||
# unmounting NFS volumes: |
|||
unset FUSER_DELAY |
|||
for dir in $(/bin/mount | grep 'type nfs ' | cut -d ' ' -f 3 ) ; do |
|||
echo "Killing processes holding NFS mount $dir open..." |
|||
# Background this to prevent fuser from also blocking shutdown: |
|||
/usr/bin/fuser -k -m $dir & |
|||
FUSER_DELAY=5 |
|||
done |
|||
# If fuser was run, let it have some delay: |
|||
if [ ! -z "$FUSER_DELAY" ]; then |
|||
sleep $FUSER_DELAY |
|||
fi |
|||
|
|||
# Unmount any NFS, SMB, or CIFS filesystems: |
|||
echo "Unmounting remote filesystems:" |
|||
/bin/umount -v -a -l -f -r -t nfs,smbfs,cifs | tr -d ' ' | grep successfully | sed "s/:successfullyunmounted/ has been successfully unmounted./g" |
|||
|
|||
# Try to shut down pppd: |
|||
PS="$(ps ax)" |
|||
if echo "$PS" | /bin/grep -q -w pppd ; then |
|||
if [ -x /usr/sbin/ppp-off ]; then |
|||
/usr/sbin/ppp-off |
|||
fi |
|||
fi |
|||
|
|||
# Shut down YP services: |
|||
if [ -x /etc/rc.d/rc.yp ]; then |
|||
if grep -wq stop /etc/rc.d/rc.yp ; then |
|||
/etc/rc.d/rc.yp stop |
|||
fi |
|||
fi |
|||
|
|||
# Bring down the networking system, but first make sure that this |
|||
# isn't a diskless client with the / partition mounted via NFS: |
|||
if ! /bin/mount | /bin/grep -q 'on / type nfs' ; then |
|||
if [ -x /etc/rc.d/rc.inet1 ]; then |
|||
. /etc/rc.d/rc.inet1 stop |
|||
fi |
|||
fi |
|||
|
|||
# In case dhcpcd might have been manually started on the command line, |
|||
# look for the .pid file, and shut dhcpcd down if it's found: |
|||
if /bin/ls /etc/dhcpc/*.pid 1> /dev/null 2> /dev/null ; then |
|||
/sbin/dhcpcd -k 1> /dev/null 2> /dev/null |
|||
# A little time for /etc/resolv.conf and/or other files to |
|||
# restore themselves. |
|||
sleep 2 |
|||
fi |
|||
|
|||
# Shut down PCMCIA devices: |
|||
if [ -x /etc/rc.d/rc.pcmcia -a -z "$container" ]; then |
|||
. /etc/rc.d/rc.pcmcia stop |
|||
# The cards might need a little extra time here to deactivate: |
|||
/bin/sleep 5 |
|||
fi |
|||
|
|||
# Turn off process accounting: |
|||
if [ -x /sbin/accton -a -r /var/log/pacct ]; then |
|||
/sbin/accton off |
|||
fi |
|||
|
|||
# Terminate acpid before syslog: |
|||
if [ -x /etc/rc.d/rc.acpid -a -r /var/run/acpid.pid -a -z "$container" ]; then # quit |
|||
. /etc/rc.d/rc.acpid stop |
|||
fi |
|||
|
|||
# Stop udev: |
|||
if [ -x /etc/rc.d/rc.udev -a -z "$container" ]; then |
|||
sh /etc/rc.d/rc.udev force-stop |
|||
fi |
|||
|
|||
# Kill all remaining processes. |
|||
OMITPIDS="$(for p in $(pgrep mdmon); do echo -o $p; done)" # Don't kill mdmon |
|||
if [ ! "$1" = "fast" ]; then |
|||
echo "Sending all processes the SIGTERM signal." |
|||
/sbin/killall5 -15 $OMITPIDS |
|||
/bin/sleep 5 |
|||
echo "Sending all processes the SIGKILL signal." |
|||
/sbin/killall5 -9 $OMITPIDS |
|||
fi |
|||
|
|||
# Try to turn off quota. |
|||
if /bin/grep -q quota /etc/fstab ; then |
|||
if [ -x /sbin/quotaoff -a -z "$container" ]; then |
|||
echo "Turning off filesystem quotas." |
|||
/sbin/quotaoff -a |
|||
fi |
|||
fi |
|||
|
|||
# Carry a random seed between reboots. |
|||
echo "Saving random seed from /dev/urandom in /etc/random-seed." |
|||
# Use the pool size from /proc, or 4096 bits: |
|||
if [ -r /proc/sys/kernel/random/poolsize ]; then |
|||
/bin/dd if=/dev/urandom of=/etc/random-seed count=1 bs=$(expr $(cat /proc/sys/kernel/random/poolsize) / 8) 2> /dev/null |
|||
else |
|||
/bin/dd if=/dev/urandom of=/etc/random-seed count=1 bs=512 2> /dev/null |
|||
fi |
|||
/bin/chmod 600 /etc/random-seed |
|||
|
|||
# Before unmounting file systems write a reboot or halt record to wtmp. |
|||
$shutdown_command -w |
|||
|
|||
# Turn off swap: |
|||
if [ -z "$container" ]; then |
|||
echo "Turning off swap." |
|||
/sbin/swapoff -a |
|||
/bin/sync |
|||
fi |
|||
|
|||
# Stop cgmanager and cgproxy: |
|||
if [ -x /etc/rc.d/rc.cgmanager -a -z "$container" ]; then |
|||
sh /etc/rc.d/rc.cgmanager stop |
|||
fi |
|||
|
|||
if [ -z "$container" ]; then |
|||
echo "Unmounting local file systems:" |
|||
/bin/umount -v -a -t no,proc,sysfs | tr -d ' ' | grep successfully | sed "s/:successfullyunmounted/ has been successfully unmounted./g" 2> /dev/null |
|||
echo "Remounting root filesystem read-only:" |
|||
/bin/mount -v -n -o remount,ro / |
|||
fi |
|||
|
|||
# This never hurts: |
|||
/bin/sync |
|||
|
|||
# Close any volumes opened by cryptsetup: |
|||
if [ -f /etc/crypttab -a -x /sbin/cryptsetup ]; then |
|||
cat /etc/crypttab | grep -v "^#" | grep -v "^$" | while read line; do |
|||
# NOTE: we only support LUKS formatted volumes (except for swap)! |
|||
LUKS=$(echo $line | tr '\t' ' ' | tr -s ' ' | cut -f1 -d' ') |
|||
DEV=$(echo $line | tr '\t' ' ' | tr -s ' ' | cut -f2 -d' ') |
|||
OPTS=$(echo $line | tr '\t' ' ' | tr -s ' ' | cut -f4 -d' ') |
|||
if /sbin/cryptsetup isLuks $DEV 2>/dev/null ; then |
|||
echo "Locking LUKS crypt volume '${LUKS}':" |
|||
/sbin/cryptsetup luksClose ${LUKS} |
|||
elif echo $OPTS | grep -wq swap ; then |
|||
# If any of the volumes was used as encrypted swap, |
|||
# then run mkswap on the underlying device - |
|||
# in case other Linux installations on this computer should use it: |
|||
echo "Erasing encrypted swap '${LUKS}' and restoring normal swap on ${DEV}:" |
|||
/sbin/cryptsetup remove ${LUKS} |
|||
mkswap $DEV |
|||
fi |
|||
done |
|||
fi |
|||
|
|||
# Deactivate LVM volume groups: |
|||
if [ -z "$container" ]; then |
|||
if [ -r /etc/lvmtab -o -d /etc/lvm/backup ]; then |
|||
echo "Deactivating LVM volume groups:" |
|||
/sbin/vgchange -an --ignorelockingfailure |
|||
fi |
|||
fi |
|||
|
|||
# This never hurts again (especially since root-on-LVM always fails |
|||
# to deactivate the / logical volume... but at least it was |
|||
# remounted as read-only first) |
|||
/bin/sync |
|||
|
|||
# sleep 3 fixes problems with some hard drives that don't |
|||
# otherwise finish syncing before reboot or poweroff |
|||
/bin/sleep 3 |
|||
|
|||
# This is to ensure all processes have completed on SMP machines: |
|||
wait |
|||
|
|||
if [ -x /sbin/genpowerd -a -z "$container" ]; then |
|||
# See if this is a powerfail situation: |
|||
if /bin/egrep -q "FAIL|SCRAM" /etc/upsstatus 2> /dev/null ; then |
|||
# Signal UPS to shut off the inverter: |
|||
/sbin/genpowerd -k |
|||
if [ ! $? = 0 ]; then |
|||
echo |
|||
echo "There was an error signaling the UPS." |
|||
echo "Perhaps you need to edit /etc/genpowerd.conf to configure" |
|||
echo "the serial line and UPS type." |
|||
# Wasting 15 seconds of precious power: |
|||
/bin/sleep 15 |
|||
fi |
|||
fi |
|||
fi |
|||
|
|||
if [ "$container" = "lxc" ]; then |
|||
# confirm successful shutdown of the container |
|||
echo "LXC container stopped." |
|||
fi |
|||
|
|||
# Now halt (poweroff with APM or ACPI enabled kernels) or reboot. |
|||
if [ "$shutdown_command" = "reboot" ]; then |
|||
echo "Rebooting." |
|||
/sbin/reboot |
|||
else |
|||
/sbin/poweroff |
|||
fi |
|||
|
@ -0,0 +1,299 @@ |
|||
#! /bin/sh |
|||
# |
|||
# rc.6 This file is executed by init when it goes into runlevel |
|||
# 0 (halt) or runlevel 6 (reboot). It kills all processes, |
|||
# unmounts file systems and then either halts or reboots. |
|||
# |
|||
# Version: @(#)/etc/rc.d/rc.6 2.47 Sat Jan 13 13:37:26 PST 2001 |
|||
# |
|||
# Author: Miquel van Smoorenburg <miquels@drinkel.nl.mugnet.org> |
|||
# Modified by: Patrick J. Volkerding, <volkerdi@slackware.com> |
|||
# |
|||
|
|||
# Set the path. |
|||
PATH=/sbin:/etc:/bin:/usr/bin |
|||
|
|||
# If there are SystemV init scripts for this runlevel, run them. |
|||
if [ -x /etc/rc.d/rc.sysvinit ]; then |
|||
. /etc/rc.d/rc.sysvinit |
|||
fi |
|||
|
|||
# Set linefeed mode to avoid staircase effect. |
|||
/bin/stty onlcr |
|||
|
|||
echo "Running shutdown script $0:" |
|||
|
|||
# Find out how we were called. |
|||
case "$0" in |
|||
*0) |
|||
shutdown_command="halt" |
|||
;; |
|||
*6) |
|||
shutdown_command=reboot |
|||
;; |
|||
*) |
|||
echo "$0: call me as \"rc.0\" or \"rc.6\" please!" |
|||
exit 1 |
|||
;; |
|||
esac |
|||
|
|||
# Save the system time to the hardware clock using hwclock --systohc. |
|||
# This will also create or update the timestamps in /etc/adjtime. |
|||
if [ -x /sbin/hwclock ]; then |
|||
# Check for a broken motherboard RTC clock (where ioports for rtc are |
|||
# unknown) to prevent hwclock causing a hang: |
|||
if ! grep -q " : rtc" /proc/ioports ; then |
|||
CLOCK_OPT="--directisa" |
|||
fi |
|||
if [ /etc/adjtime -nt /etc/hardwareclock ]; then |
|||
if grep -q "^LOCAL" /etc/adjtime ; then |
|||
echo "Saving system time to the hardware clock (localtime)." |
|||
else |
|||
echo "Saving system time to the hardware clock (UTC)." |
|||
fi |
|||
/sbin/hwclock $CLOCK_OPT --systohc |
|||
elif grep -q "^UTC" /etc/hardwareclock 2> /dev/null ; then |
|||
echo "Saving system time to the hardware clock (UTC)." |
|||
if [ ! -r /etc/adjtime ]; then |
|||
echo "Creating system time correction file /etc/adjtime." |
|||
fi |
|||
/sbin/hwclock $CLOCK_OPT --utc --systohc |
|||
else |
|||
echo "Saving system time to the hardware clock (localtime)." |
|||
if [ ! -r /etc/adjtime ]; then |
|||
echo "Creating system time correction file /etc/adjtime." |
|||
fi |
|||
/sbin/hwclock $CLOCK_OPT --localtime --systohc |
|||
fi |
|||
fi |
|||
|
|||
# Run any local shutdown scripts: |
|||
if [ -x /etc/rc.d/rc.local_shutdown ]; then |
|||
/etc/rc.d/rc.local_shutdown stop |
|||
fi |
|||
|
|||
# Stop the Apache web server: |
|||
if [ -x /etc/rc.d/rc.httpd ]; then |
|||
/etc/rc.d/rc.httpd stop |
|||
fi |
|||
|
|||
# Stop the MySQL database: |
|||
if [ -r /var/run/mysql/mysql.pid ]; then |
|||
. /etc/rc.d/rc.mysqld stop |
|||
fi |
|||
|
|||
# Stop the Samba server: |
|||
if [ -x /etc/rc.d/rc.samba ]; then |
|||
. /etc/rc.d/rc.samba stop |
|||
fi |
|||
|
|||
# Shut down the NFS server: |
|||
if [ -x /etc/rc.d/rc.nfsd ]; then |
|||
/etc/rc.d/rc.nfsd stop |
|||
fi |
|||
|
|||
# Shut down the SSH server: |
|||
if [ -x /etc/rc.d/rc.sshd ]; then |
|||
/etc/rc.d/rc.sshd stop |
|||
fi |
|||
|
|||
# Shut down the SASL authentication daemon: |
|||
if [ -x /etc/rc.d/rc.saslauthd ]; then |
|||
/etc/rc.d/rc.saslauthd stop |
|||
fi |
|||
|
|||
# Shut down OpenLDAP: |
|||
if [ -x /etc/rc.d/rc.openldap ]; then |
|||
/etc/rc.d/rc.openldap stop |
|||
fi |
|||
|
|||
# Stop D-Bus: |
|||
if [ -x /etc/rc.d/rc.messagebus ]; then |
|||
sh /etc/rc.d/rc.messagebus stop |
|||
fi |
|||
|
|||
# Kill any processes (typically gam) that would otherwise prevent |
|||
# unmounting NFS volumes: |
|||
unset FUSER_DELAY |
|||
for dir in $(/bin/mount | grep 'type nfs ' | cut -d ' ' -f 3 ) ; do |
|||
echo "Killing processes holding NFS mount $dir open..." |
|||
# Background this to prevent fuser from also blocking shutdown: |
|||
/usr/bin/fuser -k -m $dir & |
|||
FUSER_DELAY=5 |
|||
done |
|||
# If fuser was run, let it have some delay: |
|||
if [ ! -z "$FUSER_DELAY" ]; then |
|||
sleep $FUSER_DELAY |
|||
fi |
|||
|
|||
# Unmount any NFS, SMB, or CIFS filesystems: |
|||
echo "Unmounting remote filesystems:" |
|||
/bin/umount -v -a -l -f -r -t nfs,smbfs,cifs | tr -d ' ' | grep successfully | sed "s/:successfullyunmounted/ has been successfully unmounted./g" |
|||
|
|||
# Try to shut down pppd: |
|||
PS="$(ps ax)" |
|||
if echo "$PS" | /bin/grep -q -w pppd ; then |
|||
if [ -x /usr/sbin/ppp-off ]; then |
|||
/usr/sbin/ppp-off |
|||
fi |
|||
fi |
|||
|
|||
# Shut down YP services: |
|||
if [ -x /etc/rc.d/rc.yp ]; then |
|||
if grep -wq stop /etc/rc.d/rc.yp ; then |
|||
/etc/rc.d/rc.yp stop |
|||
fi |
|||
fi |
|||
|
|||
# Bring down the networking system, but first make sure that this |
|||
# isn't a diskless client with the / partition mounted via NFS: |
|||
if ! /bin/mount | /bin/grep -q 'on / type nfs' ; then |
|||
if [ -x /etc/rc.d/rc.inet1 ]; then |
|||
. /etc/rc.d/rc.inet1 stop |
|||
fi |
|||
fi |
|||
|
|||
# In case dhcpcd might have been manually started on the command line, |
|||
# look for the .pid file, and shut dhcpcd down if it's found: |
|||
if /bin/ls /etc/dhcpc/*.pid 1> /dev/null 2> /dev/null ; then |
|||
/sbin/dhcpcd -k 1> /dev/null 2> /dev/null |
|||
# A little time for /etc/resolv.conf and/or other files to |
|||
# restore themselves. |
|||
sleep 2 |
|||
fi |
|||
|
|||
# Shut down PCMCIA devices: |
|||
if [ -x /etc/rc.d/rc.pcmcia ]; then |
|||
. /etc/rc.d/rc.pcmcia stop |
|||
# The cards might need a little extra time here to deactivate: |
|||
/bin/sleep 5 |
|||
fi |
|||
|
|||
# Turn off process accounting: |
|||
if [ -x /sbin/accton -a -r /var/log/pacct ]; then |
|||
/sbin/accton off |
|||
fi |
|||
|
|||
# Terminate acpid before syslog: |
|||
if [ -x /etc/rc.d/rc.acpid -a -r /var/run/acpid.pid ]; then # quit |
|||
. /etc/rc.d/rc.acpid stop |
|||
fi |
|||
|
|||
# Stop udev: |
|||
if [ -x /etc/rc.d/rc.udev ]; then |
|||
sh /etc/rc.d/rc.udev force-stop |
|||
fi |
|||
|
|||
# Kill all remaining processes. |
|||
OMITPIDS="$(for p in $(pgrep mdmon); do echo -o $p; done)" # Don't kill mdmon |
|||
if [ ! "$1" = "fast" ]; then |
|||
echo "Sending all processes the SIGTERM signal." |
|||
/sbin/killall5 -15 $OMITPIDS |
|||
/bin/sleep 5 |
|||
echo "Sending all processes the SIGKILL signal." |
|||
/sbin/killall5 -9 $OMITPIDS |
|||
fi |
|||
|
|||
# Try to turn off quota. |
|||
if /bin/grep -q quota /etc/fstab ; then |
|||
if [ -x /sbin/quotaoff ]; then |
|||
echo "Turning off filesystem quotas." |
|||
/sbin/quotaoff -a |
|||
fi |
|||
fi |
|||
|
|||
# Carry a random seed between reboots. |
|||
echo "Saving random seed from /dev/urandom in /etc/random-seed." |
|||
# Use the pool size from /proc, or 4096 bits: |
|||
if [ -r /proc/sys/kernel/random/poolsize ]; then |
|||
/bin/dd if=/dev/urandom of=/etc/random-seed count=1 bs=$(expr $(cat /proc/sys/kernel/random/poolsize) / 8) 2> /dev/null |
|||
else |
|||
/bin/dd if=/dev/urandom of=/etc/random-seed count=1 bs=512 2> /dev/null |
|||
fi |
|||
/bin/chmod 600 /etc/random-seed |
|||
|
|||
# Before unmounting file systems write a reboot or halt record to wtmp. |
|||
$shutdown_command -w |
|||
|
|||
# Turn off swap: |
|||
echo "Turning off swap." |
|||
/sbin/swapoff -a |
|||
/bin/sync |
|||
|
|||
# Stop cgmanager and cgproxy: |
|||
if [ -x /etc/rc.d/rc.cgmanager ]; then |
|||
sh /etc/rc.d/rc.cgmanager stop |
|||
fi |
|||
|
|||
echo "Unmounting local file systems:" |
|||
/bin/umount -v -a -t no,proc,sysfs | tr -d ' ' | grep successfully | sed "s/:successfullyunmounted/ has been successfully unmounted./g" 2> /dev/null |
|||
|
|||
echo "Remounting root filesystem read-only:" |
|||
/bin/mount -v -n -o remount,ro / |
|||
|
|||
# This never hurts: |
|||
/bin/sync |
|||
|
|||
# Close any volumes opened by cryptsetup: |
|||
if [ -f /etc/crypttab -a -x /sbin/cryptsetup ]; then |
|||
cat /etc/crypttab | grep -v "^#" | grep -v "^$" | while read line; do |
|||
# NOTE: we only support LUKS formatted volumes (except for swap)! |
|||
LUKS=$(echo $line | tr '\t' ' ' | tr -s ' ' | cut -f1 -d' ') |
|||
DEV=$(echo $line | tr '\t' ' ' | tr -s ' ' | cut -f2 -d' ') |
|||
OPTS=$(echo $line | tr '\t' ' ' | tr -s ' ' | cut -f4 -d' ') |
|||
if /sbin/cryptsetup isLuks $DEV 2>/dev/null ; then |
|||
echo "Locking LUKS crypt volume '${LUKS}':" |
|||
/sbin/cryptsetup luksClose ${LUKS} |
|||
elif echo $OPTS | grep -wq swap ; then |
|||
# If any of the volumes was used as encrypted swap, |
|||
# then run mkswap on the underlying device - |
|||
# in case other Linux installations on this computer should use it: |
|||
echo "Erasing encrypted swap '${LUKS}' and restoring normal swap on ${DEV}:" |
|||
/sbin/cryptsetup remove ${LUKS} |
|||
mkswap $DEV |
|||
fi |
|||
done |
|||
fi |
|||
|
|||
# Deactivate LVM volume groups: |
|||
if [ -r /etc/lvmtab -o -d /etc/lvm/backup ]; then |
|||
echo "Deactivating LVM volume groups:" |
|||
/sbin/vgchange -an --ignorelockingfailure |
|||
fi |
|||
|
|||
# This never hurts again (especially since root-on-LVM always fails |
|||
# to deactivate the / logical volume... but at least it was |
|||
# remounted as read-only first) |
|||
/bin/sync |
|||
|
|||
# sleep 3 fixes problems with some hard drives that don't |
|||
# otherwise finish syncing before reboot or poweroff |
|||
/bin/sleep 3 |
|||
|
|||
# This is to ensure all processes have completed on SMP machines: |
|||
wait |
|||
|
|||
if [ -x /sbin/genpowerd ]; then |
|||
# See if this is a powerfail situation: |
|||
if /bin/egrep -q "FAIL|SCRAM" /etc/upsstatus 2> /dev/null ; then |
|||
# Signal UPS to shut off the inverter: |
|||
/sbin/genpowerd -k |
|||
if [ ! $? = 0 ]; then |
|||
echo |
|||
echo "There was an error signaling the UPS." |
|||
echo "Perhaps you need to edit /etc/genpowerd.conf to configure" |
|||
echo "the serial line and UPS type." |
|||
# Wasting 15 seconds of precious power: |
|||
/bin/sleep 15 |
|||
fi |
|||
fi |
|||
fi |
|||
|
|||
# Now halt (poweroff with APM or ACPI enabled kernels) or reboot. |
|||
if [ "$shutdown_command" = "reboot" ]; then |
|||
echo "Rebooting." |
|||
/sbin/reboot |
|||
else |
|||
/sbin/poweroff |
|||
fi |
|||
|
@ -0,0 +1,397 @@ |
|||
#!/bin/sh |
|||
# |
|||
# rc.M This file is executed by init(8) when the system is being |
|||
# initialized for one of the "multi user" run levels (i.e. |
|||
# levels 1 through 6). It usually does mounting of file |
|||
# systems et al. |
|||
# |
|||
# Version: @(#)/etc/rc.d/rc.M 2.23 Wed Feb 26 19:20:58 PST 2003 |
|||
# |
|||
# Author: Fred N. van Kempen, <waltje@uwalt.nl.mugnet.org> |
|||
# Heavily modified by Patrick Volkerding <volkerdi@slackware.com> |
|||
# |
|||
|
|||
# Tell the viewers what's going to happen. |
|||
echo "Going multiuser..." |
|||
|
|||
# Set $container variable since this is a modified version of rc.M with |
|||
# changes for running in an lxc container. A check to see if this variable |
|||
# is set will be used to skip parts of the script that we don't want to run |
|||
# in a container. Thanks to Matteo Bernardini <ponce@slackbuilds.org> and |
|||
# Chris Willing for the initial work making this script lxc compatible. |
|||
container="lxc" |
|||
|
|||
# Update all the shared library links: |
|||
if [ -x /sbin/ldconfig ]; then |
|||
echo "Updating shared library links: /sbin/ldconfig &" |
|||
/sbin/ldconfig & |
|||
fi |
|||
|
|||
# Screen blanks after 15 minutes idle time, and powers down in one hour |
|||
# if the kernel supports APM or ACPI power management: |
|||
if [ -z "$container" ]; then |
|||
/bin/setterm -blank 15 -powersave powerdown -powerdown 60 |
|||
fi |
|||
|
|||
# Set the hostname. |
|||
if [ -z "$container" ]; then |
|||
if [ -r /etc/HOSTNAME ]; then |
|||
/bin/hostname $(cat /etc/HOSTNAME | cut -f1 -d .) |
|||
else |
|||
# fall back on this old default: |
|||
echo "darkstar.example.net" > /etc/HOSTNAME |
|||
/bin/hostname darkstar |
|||
fi |
|||
fi |
|||
|
|||
# Set the permissions on /var/log/dmesg according to whether the kernel |
|||
# permits non-root users to access kernel dmesg information: |
|||
if [ -r /proc/sys/kernel/dmesg_restrict ]; then |
|||
if [ $(cat /proc/sys/kernel/dmesg_restrict) = 1 ]; then |
|||
touch /var/log/dmesg |
|||
chmod 640 /var/log/dmesg |
|||
fi |
|||
else |
|||
touch /var/log/dmesg |
|||
chmod 644 /var/log/dmesg |
|||
fi |
|||
# Save the contents of 'dmesg': |
|||
/bin/dmesg -s 65536 > /var/log/dmesg |
|||
|
|||
# Initialize PCMCIA devices: |
|||
# |
|||
# NOTE: This used to be started near the top of rc.S so that PCMCIA devices |
|||
# could be fsck'ed along with the other drives. This had some unfortunate |
|||
# side effects, however, since root isn't yet read-write, and /var might not |
|||
# even be mounted the .pid files can't be correctly written in /var/run and |
|||
# the pcmcia system can't be correctly shut down. If you want some PCMCIA |
|||
# partition to be mounted at boot (or when the card is inserted) then add |
|||
# the appropriate lines to /etc/pcmcia/scsi.opts. |
|||
# |
|||
# Note that the stuff in /etc/pcmcia/ is only for 2.4.x kernels using |
|||
# 16-bit PCMCIA cards (not 32-bit Cardbus cards!). For example, with a |
|||
# wireless card you might need to set options in /etc/pcmcia OR in |
|||
# /etc/rc.d/rc.wireless.conf, or even in /etc/rc.d/rc.inet1.conf (with |
|||
# extra options if needed for the encryption key, ESSID, etc.) |
|||
# |
|||
# Hopefully this situation will be unified in the future, but for now |
|||
# that's how it is... |
|||
# |
|||
if [ -x /etc/rc.d/rc.pcmcia -a -z "$container" ]; then |
|||
. /etc/rc.d/rc.pcmcia start |
|||
# The cards might need a little extra time here to initialize. |
|||
sleep 5 |
|||
fi |
|||
|
|||
# Start the system logger. |
|||
if [ -x /etc/rc.d/rc.syslog -a -x /usr/sbin/syslogd -a -d /var/log ]; then |
|||
. /etc/rc.d/rc.syslog start |
|||
fi |
|||
|
|||
# Update the X font indexes: |
|||
if [ -x /usr/bin/fc-cache ]; then |
|||
echo "Updating X font indexes: /usr/bin/fc-cache -f &" |
|||
/usr/bin/fc-cache -f & |
|||
fi |
|||
|
|||
# Run rc.udev again. This will start udev if it is not already running |
|||
# (for example, upon return from runlevel 1), otherwise it will trigger it |
|||
# to look for device changes and to generate persistent rules if needed. |
|||
if grep -wq sysfs /proc/mounts && grep -q devtmpfs /proc/filesystems ; then |
|||
if ! grep -wq nohotplug /proc/cmdline ; then |
|||
if [ -x /etc/rc.d/rc.udev -a -z "$container" ]; then |
|||
/bin/sh /etc/rc.d/rc.udev start |
|||
fi |
|||
fi |
|||
fi |
|||
|
|||
# Initialize the networking hardware. |
|||
if [ -x /etc/rc.d/rc.inet1 ]; then |
|||
. /etc/rc.d/rc.inet1 |
|||
fi |
|||
|
|||
# Start D-Bus: |
|||
if [ -x /etc/rc.d/rc.messagebus ]; then |
|||
sh /etc/rc.d/rc.messagebus start |
|||
fi |
|||
|
|||
# Start Bluetooth: |
|||
if [ -x /etc/rc.d/rc.bluetooth ]; then |
|||
sh /etc/rc.d/rc.bluetooth start |
|||
fi |
|||
|
|||
# Start wicd or networkmanager: |
|||
if [ -x /etc/rc.d/rc.wicd -a -x /usr/sbin/wicd ]; then |
|||
sh /etc/rc.d/rc.wicd start |
|||
elif [ -x /etc/rc.d/rc.networkmanager ]; then |
|||
sh /etc/rc.d/rc.networkmanager start |
|||
fi |
|||
|
|||
# Start networking daemons: |
|||
if [ -x /etc/rc.d/rc.inet2 ]; then |
|||
. /etc/rc.d/rc.inet2 |
|||
fi |
|||
|
|||
# Look for additional USB/SCSI/IEEE1394/etc devices on multiple LUNs: |
|||
if [ -x /etc/rc.d/rc.scanluns ]; then |
|||
. /etc/rc.d/rc.scanluns |
|||
fi |
|||
|
|||
# Mount any additional filesystem types that haven't already been mounted: |
|||
mount -a -v 2> /dev/null | grep -v -e "already mounted" -e "ignored" | cut -f 1 -d : | tr -d ' ' | while read dev ; do mount | grep "${dev} " ; done |
|||
|
|||
# Start the Control Script for automounter: |
|||
if [ -x /etc/rc.d/rc.autofs ]; then |
|||
sh /etc/rc.d/rc.autofs start |
|||
fi |
|||
|
|||
# Start the Network Time Protocol daemon: |
|||
if [ -x /etc/rc.d/rc.ntpd ]; then |
|||
sh /etc/rc.d/rc.ntpd start |
|||
fi |
|||
|
|||
# Remove stale locks and junk files (must be done after mount -a!) |
|||
/bin/rm -f /var/lock/* /var/spool/uucp/LCK..* /tmp/.X*lock /tmp/core /core 2> /dev/null |
|||
/bin/rm -rf /var/spool/cron/cron.?????? 2> /dev/null |
|||
|
|||
# Remove stale hunt sockets so the game can start. |
|||
if [ -r /tmp/hunt -o -r /tmp/hunt.stats ]; then |
|||
echo "Removing your stale hunt sockets from /tmp." |
|||
/bin/rm -f /tmp/hunt* |
|||
fi |
|||
|
|||
# Ensure basic filesystem permissions sanity. |
|||
chmod 755 / 2> /dev/null |
|||
chmod 1777 /tmp /var/tmp |
|||
|
|||
# Start ACPI daemon. |
|||
if [ -x /etc/rc.d/rc.acpid -a -z "$container" ]; then |
|||
. /etc/rc.d/rc.acpid start |
|||
fi |
|||
|
|||
# Enable CPU frequency scaling: |
|||
if [ -x /etc/rc.d/rc.cpufreq -a -z "$container" ]; then |
|||
. /etc/rc.d/rc.cpufreq start |
|||
fi |
|||
|
|||
# Update any existing icon cache files: |
|||
if find /usr/share/icons -maxdepth 2 2> /dev/null | grep -q icon-theme.cache ; then |
|||
for theme_dir in /usr/share/icons/* ; do |
|||
if [ -r ${theme_dir}/icon-theme.cache ]; then |
|||
echo "Updating icon-theme.cache in ${theme_dir}..." |
|||
/usr/bin/gtk-update-icon-cache -t -f ${theme_dir} 1> /dev/null 2> /dev/null & |
|||
fi |
|||
done |
|||
# This would be a large file and probably shouldn't be there. |
|||
if [ -r /usr/share/icons/icon-theme.cache ]; then |
|||
echo "Deleting icon-theme.cache in /usr/share/icons..." |
|||
#/usr/bin/gtk-update-icon-cache -t -f /usr/share/icons 1> /dev/null 2> /dev/null & |
|||
rm -f /usr/share/icons/icon-theme.cache |
|||
fi |
|||
fi |
|||
|
|||
# Update mime database: |
|||
if [ -x /usr/bin/update-mime-database -a -d /usr/share/mime ]; then |
|||
echo "Updating MIME database: /usr/bin/update-mime-database /usr/share/mime &" |
|||
/usr/bin/update-mime-database /usr/share/mime 1> /dev/null 2> /dev/null & |
|||
fi |
|||
|
|||
# Start console-kit-daemon: |
|||
if [ -x /etc/rc.d/rc.consolekit ]; then |
|||
sh /etc/rc.d/rc.consolekit start |
|||
fi |
|||
|
|||
# Start HAL: |
|||
if [ -x /etc/rc.d/rc.hald ]; then |
|||
sh /etc/rc.d/rc.hald start |
|||
fi |
|||
|
|||
# Start system-wide PulseAudio daemon (not recommended, nor required in |
|||
# order to use PulseAudio -- see the script for details): |
|||
if [ -x /etc/rc.d/rc.pulseaudio ]; then |
|||
. /etc/rc.d/rc.pulseaudio start |
|||
fi |
|||
|
|||
# These GTK+/pango files need to be kept up to date for |
|||
# proper input method, pixbuf loaders, and font support. |
|||
if [ -x /usr/bin/update-gtk-immodules ]; then |
|||
echo "Updating gtk.immodules:" |
|||
echo " /usr/bin/update-gtk-immodules &" |
|||
/usr/bin/update-gtk-immodules > /dev/null 2>&1 & |
|||
fi |
|||
if [ -x /usr/bin/update-gdk-pixbuf-loaders ]; then |
|||
echo "Updating gdk-pixbuf.loaders:" |
|||
echo " /usr/bin/update-gdk-pixbuf-loaders &" |
|||
/usr/bin/update-gdk-pixbuf-loaders > /dev/null 2>&1 & |
|||
fi |
|||
if [ -x /usr/bin/update-pango-querymodules ]; then |
|||
echo "Updating pango.modules:" |
|||
echo " /usr/bin/update-pango-querymodules &" |
|||
/usr/bin/update-pango-querymodules > /dev/null 2>&1 & |
|||
fi |
|||
if [ -x /usr/bin/glib-compile-schemas ]; then |
|||
echo "Compiling GSettings XML schema files:" |
|||
echo " /usr/bin/glib-compile-schemas /usr/share/glib-2.0/schemas &" |
|||
/usr/bin/glib-compile-schemas /usr/share/glib-2.0/schemas >/dev/null 2>&1 & |
|||
fi |
|||
|
|||
# Start dnsmasq, a simple DHCP/DNS server: |
|||
if [ -x /etc/rc.d/rc.dnsmasq ]; then |
|||
/etc/rc.d/rc.dnsmasq start |
|||
fi |
|||
|
|||
# Start snmpd: |
|||
if [ -x /etc/rc.d/rc.snmpd ]; then |
|||
/etc/rc.d/rc.snmpd start |
|||
fi |
|||
|
|||
# Start the print spooling system. This will usually be LPRng (lpd) or CUPS. |
|||
if [ -x /etc/rc.d/rc.cups ]; then |
|||
# Start CUPS: |
|||
/etc/rc.d/rc.cups start |
|||
elif [ -x /etc/rc.d/rc.lprng ]; then |
|||
# Start LPRng (lpd): |
|||
. /etc/rc.d/rc.lprng start |
|||
fi |
|||
|
|||
# Start netatalk. (a file/print server for Macs using Appletalk) |
|||
if [ -x /etc/rc.d/rc.atalk ]; then |
|||
/etc/rc.d/rc.atalk start |
|||
fi |
|||
|
|||
# Start smartd, which monitors the status of S.M.A.R.T. compatible |
|||
# hard drives and reports any problems. Note some devices (which aren't |
|||
# smart, I guess ;) will hang if probed by smartd, so it's commented out |
|||
# by default. |
|||
#if [ -x /usr/sbin/smartd ]; then |
|||
# /usr/sbin/smartd |
|||
#fi |
|||
|
|||
# Monitor the UPS with genpowerd. |
|||
# To use this, uncomment this section and edit your settings in |
|||
# /etc/genpowerd.conf (serial device, UPS type, etc). For more information, |
|||
# see "man genpowerd" or the extensive documentation in the |
|||
# /usr/doc/genpower-*/ directory. |
|||
# You'll also need to configure a similar block in /etc/rc.d/rc.6 if you want |
|||
# support for stopping the UPS's inverter after the machine halts. |
|||
#if [ -x /sbin/genpowerd ]; then |
|||
# echo "Starting genpowerd daemon..." |
|||
# /sbin/genpowerd |
|||
#fi |
|||
|
|||
# Turn on process accounting. To enable process accounting, make sure the |
|||
# option for BSD process accounting is enabled in your kernel, and then |
|||
# create the file /var/log/pacct (touch /var/log/pacct). By default, process |
|||
# accounting is not enabled (since /var/log/pacct does not exist). This is |
|||
# because the log file can get VERY large. |
|||
if [ -x /sbin/accton -a -r /var/log/pacct ]; then |
|||
chmod 640 /var/log/pacct |
|||
/sbin/accton /var/log/pacct |
|||
fi |
|||
|
|||
# Start crond (Dillon's crond): |
|||
# If you want cron to actually log activity to /var/log/cron, then change |
|||
# -l notice to -l info to increase the logging level. |
|||
if [ -x /usr/sbin/crond ]; then |
|||
/usr/sbin/crond -l notice |
|||
fi |
|||
|
|||
# Start atd (manages jobs scheduled with 'at'): |
|||
if [ -x /usr/sbin/atd ]; then |
|||
/usr/sbin/atd -b 15 -l 1 |
|||
fi |
|||
|
|||
# Slackware-Mini-Quota-HOWTO: |
|||
# To really activate quotas, you'll need to add 'usrquota' and/or 'grpquota' to |
|||
# the appropriate partitions as listed in /etc/fstab. Here's an example: |
|||
# |
|||
# /dev/hda2 /home ext3 defaults,usrquota 1 1 |
|||
# |
|||
# You'll then need to setup initial quota files at the top of the partitions |
|||
# to support quota, like this: |
|||
# touch /home/aquota.user /home/aquota.group |
|||
# chmod 600 /home/aquota.user /home/aquota.group |
|||
# |
|||
# Then, reboot to activate the system. |
|||
# To edit user quotas, use 'edquota'. See 'man edquota'. Also, the |
|||
# official Quota Mini-HOWTO has lots of useful information. That can be found |
|||
# here: /usr/doc/Linux-HOWTOs/Quota |
|||
|
|||
# Check quotas and then turn quota system on: |
|||
if grep -q quota /etc/fstab ; then |
|||
for quotafs in $(awk '/quota/ {print $2}' /etc/fstab) ; do |
|||
/bin/rm -f $quotafs/{a,}quota.{group,user}.new |
|||
done |
|||
if [ -x /sbin/quotacheck ]; then |
|||
echo "Checking filesystem quotas: /sbin/quotacheck -avugm" |
|||
/sbin/quotacheck -avugm |
|||
fi |
|||
if [ -x /sbin/quotaon ]; then |
|||
echo "Activating filesystem quotas: /sbin/quotaon -avug" |
|||
/sbin/quotaon -avug |
|||
fi |
|||
fi |
|||
|
|||
# Start the SASL authentication server. This provides SASL |
|||
# authentication services for sendmail: |
|||
if [ -x /etc/rc.d/rc.saslauthd ]; then |
|||
. /etc/rc.d/rc.saslauthd start |
|||
fi |
|||
|
|||
# Start the sendmail daemon: |
|||
if [ -x /etc/rc.d/rc.sendmail ]; then |
|||
. /etc/rc.d/rc.sendmail start |
|||
fi |
|||
|
|||
# Load ALSA (sound) defaults: |
|||
if [ -x /etc/rc.d/rc.alsa -a -z "$container" ]; then |
|||
. /etc/rc.d/rc.alsa |
|||
fi |
|||
|
|||
# Load a custom screen font if the user has an rc.font script. |
|||
if [ -x /etc/rc.d/rc.font ]; then |
|||
. /etc/rc.d/rc.font |
|||
fi |
|||
|
|||
# Load a custom keymap if the user has an rc.keymap script. |
|||
if [ -x /etc/rc.d/rc.keymap ]; then |
|||
. /etc/rc.d/rc.keymap |
|||
fi |
|||
|
|||
# Start the MySQL database: |
|||
if [ -x /etc/rc.d/rc.mysqld ]; then |
|||
. /etc/rc.d/rc.mysqld start |
|||
fi |
|||
|
|||
# Start Apache web server: |
|||
if [ -x /etc/rc.d/rc.httpd ]; then |
|||
. /etc/rc.d/rc.httpd start |
|||
fi |
|||
|
|||
# Start OpenLDAP: |
|||
if [ -x /etc/rc.d/rc.openldap ]; then |
|||
. /etc/rc.d/rc.openldap start |
|||
fi |
|||
|
|||
# Start Samba (a file/print server for Win95/NT machines). |
|||
# Samba can be started in /etc/inetd.conf instead. |
|||
if [ -x /etc/rc.d/rc.samba ]; then |
|||
. /etc/rc.d/rc.samba start |
|||
fi |
|||
|
|||
# Start the GPM mouse server: |
|||
if [ -x /etc/rc.d/rc.gpm ]; then |
|||
. /etc/rc.d/rc.gpm start |
|||
fi |
|||
|
|||
# If there are SystemV init scripts for this runlevel, run them. |
|||
if [ -x /etc/rc.d/rc.sysvinit ]; then |
|||
. /etc/rc.d/rc.sysvinit |
|||
fi |
|||
|
|||
# Start the local setup procedure. |
|||
if [ -x /etc/rc.d/rc.local ]; then |
|||
. /etc/rc.d/rc.local |
|||
fi |
|||
|
|||
# All done. |
@ -0,0 +1,386 @@ |
|||
#!/bin/sh |
|||
# |
|||
# rc.M This file is executed by init(8) when the system is being |
|||
# initialized for one of the "multi user" run levels (i.e. |
|||
# levels 1 through 6). It usually does mounting of file |
|||
# systems et al. |
|||
# |
|||
# Version: @(#)/etc/rc.d/rc.M 2.23 Wed Feb 26 19:20:58 PST 2003 |
|||
# |
|||
# Author: Fred N. van Kempen, <waltje@uwalt.nl.mugnet.org> |
|||
# Heavily modified by Patrick Volkerding <volkerdi@slackware.com> |
|||
# |
|||
|
|||
# Tell the viewers what's going to happen. |
|||
echo "Going multiuser..." |
|||
|
|||
# Update all the shared library links: |
|||
if [ -x /sbin/ldconfig ]; then |
|||
echo "Updating shared library links: /sbin/ldconfig &" |
|||
/sbin/ldconfig & |
|||
fi |
|||
|
|||
# Screen blanks after 15 minutes idle time, and powers down in one hour |
|||
# if the kernel supports APM or ACPI power management: |
|||
/bin/setterm -blank 15 -powersave powerdown -powerdown 60 |
|||
|
|||
# Set the hostname. |
|||
if [ -r /etc/HOSTNAME ]; then |
|||
/bin/hostname $(cat /etc/HOSTNAME | cut -f1 -d .) |
|||
else |
|||
# fall back on this old default: |
|||
echo "darkstar.example.net" > /etc/HOSTNAME |
|||
/bin/hostname darkstar |
|||
fi |
|||
|
|||
# Set the permissions on /var/log/dmesg according to whether the kernel |
|||
# permits non-root users to access kernel dmesg information: |
|||
if [ -r /proc/sys/kernel/dmesg_restrict ]; then |
|||
if [ $(cat /proc/sys/kernel/dmesg_restrict) = 1 ]; then |
|||
touch /var/log/dmesg |
|||
chmod 640 /var/log/dmesg |
|||
fi |
|||
else |
|||
touch /var/log/dmesg |
|||
chmod 644 /var/log/dmesg |
|||
fi |
|||
# Save the contents of 'dmesg': |
|||
/bin/dmesg -s 65536 > /var/log/dmesg |
|||
|
|||
# Initialize PCMCIA devices: |
|||
# |
|||
# NOTE: This used to be started near the top of rc.S so that PCMCIA devices |
|||
# could be fsck'ed along with the other drives. This had some unfortunate |
|||
# side effects, however, since root isn't yet read-write, and /var might not |
|||
# even be mounted the .pid files can't be correctly written in /var/run and |
|||
# the pcmcia system can't be correctly shut down. If you want some PCMCIA |
|||
# partition to be mounted at boot (or when the card is inserted) then add |
|||
# the appropriate lines to /etc/pcmcia/scsi.opts. |
|||
# |
|||
# Note that the stuff in /etc/pcmcia/ is only for 2.4.x kernels using |
|||
# 16-bit PCMCIA cards (not 32-bit Cardbus cards!). For example, with a |
|||
# wireless card you might need to set options in /etc/pcmcia OR in |
|||
# /etc/rc.d/rc.wireless.conf, or even in /etc/rc.d/rc.inet1.conf (with |
|||
# extra options if needed for the encryption key, ESSID, etc.) |
|||
# |
|||
# Hopefully this situation will be unified in the future, but for now |
|||
# that's how it is... |
|||
# |
|||
if [ -x /etc/rc.d/rc.pcmcia ]; then |
|||
. /etc/rc.d/rc.pcmcia start |
|||
# The cards might need a little extra time here to initialize. |
|||
sleep 5 |
|||
fi |
|||
|
|||
# Start the system logger. |
|||
if [ -x /etc/rc.d/rc.syslog -a -x /usr/sbin/syslogd -a -d /var/log ]; then |
|||
. /etc/rc.d/rc.syslog start |
|||
fi |
|||
|
|||
# Update the X font indexes: |
|||
if [ -x /usr/bin/fc-cache ]; then |
|||
echo "Updating X font indexes: /usr/bin/fc-cache -f &" |
|||
/usr/bin/fc-cache -f & |
|||
fi |
|||
|
|||
# Run rc.udev again. This will start udev if it is not already running |
|||
# (for example, upon return from runlevel 1), otherwise it will trigger it |
|||
# to look for device changes and to generate persistent rules if needed. |
|||
if grep -wq sysfs /proc/mounts && grep -q devtmpfs /proc/filesystems ; then |
|||
if ! grep -wq nohotplug /proc/cmdline ; then |
|||
if [ -x /etc/rc.d/rc.udev ]; then |
|||
/bin/sh /etc/rc.d/rc.udev start |
|||
fi |
|||
fi |
|||
fi |
|||
|
|||
# Initialize the networking hardware. |
|||
if [ -x /etc/rc.d/rc.inet1 ]; then |
|||
. /etc/rc.d/rc.inet1 |
|||
fi |
|||
|
|||
# Start D-Bus: |
|||
if [ -x /etc/rc.d/rc.messagebus ]; then |
|||
sh /etc/rc.d/rc.messagebus start |
|||
fi |
|||
|
|||
# Start Bluetooth: |
|||
if [ -x /etc/rc.d/rc.bluetooth ]; then |
|||
sh /etc/rc.d/rc.bluetooth start |
|||
fi |
|||
|
|||
# Start wicd or networkmanager: |
|||
if [ -x /etc/rc.d/rc.wicd -a -x /usr/sbin/wicd ]; then |
|||
sh /etc/rc.d/rc.wicd start |
|||
elif [ -x /etc/rc.d/rc.networkmanager ]; then |
|||
sh /etc/rc.d/rc.networkmanager start |
|||
fi |
|||
|
|||
# Start networking daemons: |
|||
if [ -x /etc/rc.d/rc.inet2 ]; then |
|||
. /etc/rc.d/rc.inet2 |
|||
fi |
|||
|
|||
# Look for additional USB/SCSI/IEEE1394/etc devices on multiple LUNs: |
|||
if [ -x /etc/rc.d/rc.scanluns ]; then |
|||
. /etc/rc.d/rc.scanluns |
|||
fi |
|||
|
|||
# Mount any additional filesystem types that haven't already been mounted: |
|||
mount -a -v 2> /dev/null | grep -v -e "already mounted" -e "ignored" | cut -f 1 -d : | tr -d ' ' | while read dev ; do mount | grep "${dev} " ; done |
|||
|
|||
# Start the Control Script for automounter: |
|||
if [ -x /etc/rc.d/rc.autofs ]; then |
|||
sh /etc/rc.d/rc.autofs start |
|||
fi |
|||
|
|||
# Start the Network Time Protocol daemon: |
|||
if [ -x /etc/rc.d/rc.ntpd ]; then |
|||
sh /etc/rc.d/rc.ntpd start |
|||
fi |
|||
|
|||
# Remove stale locks and junk files (must be done after mount -a!) |
|||
/bin/rm -f /var/lock/* /var/spool/uucp/LCK..* /tmp/.X*lock /tmp/core /core 2> /dev/null |
|||
/bin/rm -rf /var/spool/cron/cron.?????? 2> /dev/null |
|||
|
|||
# Remove stale hunt sockets so the game can start. |
|||
if [ -r /tmp/hunt -o -r /tmp/hunt.stats ]; then |
|||
echo "Removing your stale hunt sockets from /tmp." |
|||
/bin/rm -f /tmp/hunt* |
|||
fi |
|||
|
|||
# Ensure basic filesystem permissions sanity. |
|||
chmod 755 / 2> /dev/null |
|||
chmod 1777 /tmp /var/tmp |
|||
|
|||
# Start ACPI daemon. |
|||
if [ -x /etc/rc.d/rc.acpid ]; then |
|||
. /etc/rc.d/rc.acpid start |
|||
fi |
|||
|
|||
# Enable CPU frequency scaling: |
|||
if [ -x /etc/rc.d/rc.cpufreq ]; then |
|||
. /etc/rc.d/rc.cpufreq start |
|||
fi |
|||
|
|||
# Update any existing icon cache files: |
|||
if find /usr/share/icons -maxdepth 2 2> /dev/null | grep -q icon-theme.cache ; then |
|||
for theme_dir in /usr/share/icons/* ; do |
|||
if [ -r ${theme_dir}/icon-theme.cache ]; then |
|||
echo "Updating icon-theme.cache in ${theme_dir}..." |
|||
/usr/bin/gtk-update-icon-cache -t -f ${theme_dir} 1> /dev/null 2> /dev/null & |
|||
fi |
|||
done |
|||
# This would be a large file and probably shouldn't be there. |
|||
if [ -r /usr/share/icons/icon-theme.cache ]; then |
|||
echo "Deleting icon-theme.cache in /usr/share/icons..." |
|||
#/usr/bin/gtk-update-icon-cache -t -f /usr/share/icons 1> /dev/null 2> /dev/null & |
|||
rm -f /usr/share/icons/icon-theme.cache |
|||
fi |
|||
fi |
|||
|
|||
# Update mime database: |
|||
if [ -x /usr/bin/update-mime-database -a -d /usr/share/mime ]; then |
|||
echo "Updating MIME database: /usr/bin/update-mime-database /usr/share/mime &" |
|||
/usr/bin/update-mime-database /usr/share/mime 1> /dev/null 2> /dev/null & |
|||
fi |
|||
|
|||
# Start console-kit-daemon: |
|||
if [ -x /etc/rc.d/rc.consolekit ]; then |
|||
sh /etc/rc.d/rc.consolekit start |
|||
fi |
|||
|
|||
# Start HAL: |
|||
if [ -x /etc/rc.d/rc.hald ]; then |
|||
sh /etc/rc.d/rc.hald start |
|||
fi |
|||
|
|||
# Start system-wide PulseAudio daemon (not recommended, nor required in |
|||
# order to use PulseAudio -- see the script for details): |
|||
if [ -x /etc/rc.d/rc.pulseaudio ]; then |
|||
. /etc/rc.d/rc.pulseaudio start |
|||
fi |
|||
|
|||
# These GTK+/pango files need to be kept up to date for |
|||
# proper input method, pixbuf loaders, and font support. |
|||
if [ -x /usr/bin/update-gtk-immodules ]; then |
|||
echo "Updating gtk.immodules:" |
|||
echo " /usr/bin/update-gtk-immodules &" |
|||
/usr/bin/update-gtk-immodules > /dev/null 2>&1 & |
|||
fi |
|||
if [ -x /usr/bin/update-gdk-pixbuf-loaders ]; then |
|||
echo "Updating gdk-pixbuf.loaders:" |
|||
echo " /usr/bin/update-gdk-pixbuf-loaders &" |
|||
/usr/bin/update-gdk-pixbuf-loaders > /dev/null 2>&1 & |
|||
fi |
|||
if [ -x /usr/bin/update-pango-querymodules ]; then |
|||
echo "Updating pango.modules:" |
|||
echo " /usr/bin/update-pango-querymodules &" |
|||
/usr/bin/update-pango-querymodules > /dev/null 2>&1 & |
|||
fi |
|||
if [ -x /usr/bin/glib-compile-schemas ]; then |
|||
echo "Compiling GSettings XML schema files:" |
|||
echo " /usr/bin/glib-compile-schemas /usr/share/glib-2.0/schemas &" |
|||
/usr/bin/glib-compile-schemas /usr/share/glib-2.0/schemas >/dev/null 2>&1 & |
|||
fi |
|||
|
|||
# Start dnsmasq, a simple DHCP/DNS server: |
|||
if [ -x /etc/rc.d/rc.dnsmasq ]; then |
|||
/etc/rc.d/rc.dnsmasq start |
|||
fi |
|||
|
|||
# Start snmpd: |
|||
if [ -x /etc/rc.d/rc.snmpd ]; then |
|||
/etc/rc.d/rc.snmpd start |
|||
fi |
|||
|
|||
# Start the print spooling system. This will usually be LPRng (lpd) or CUPS. |
|||
if [ -x /etc/rc.d/rc.cups ]; then |
|||
# Start CUPS: |
|||
/etc/rc.d/rc.cups start |
|||
elif [ -x /etc/rc.d/rc.lprng ]; then |
|||
# Start LPRng (lpd): |
|||
. /etc/rc.d/rc.lprng start |
|||
fi |
|||
|
|||
# Start netatalk. (a file/print server for Macs using Appletalk) |
|||
if [ -x /etc/rc.d/rc.atalk ]; then |
|||
/etc/rc.d/rc.atalk start |
|||
fi |
|||
|
|||
# Start smartd, which monitors the status of S.M.A.R.T. compatible |
|||
# hard drives and reports any problems. Note some devices (which aren't |
|||
# smart, I guess ;) will hang if probed by smartd, so it's commented out |
|||
# by default. |
|||
#if [ -x /usr/sbin/smartd ]; then |
|||
# /usr/sbin/smartd |
|||
#fi |
|||
|
|||
# Monitor the UPS with genpowerd. |
|||
# To use this, uncomment this section and edit your settings in |
|||
# /etc/genpowerd.conf (serial device, UPS type, etc). For more information, |
|||
# see "man genpowerd" or the extensive documentation in the |
|||
# /usr/doc/genpower-*/ directory. |
|||
# You'll also need to configure a similar block in /etc/rc.d/rc.6 if you want |
|||
# support for stopping the UPS's inverter after the machine halts. |
|||
#if [ -x /sbin/genpowerd ]; then |
|||
# echo "Starting genpowerd daemon..." |
|||
# /sbin/genpowerd |
|||
#fi |
|||
|
|||
# Turn on process accounting. To enable process accounting, make sure the |
|||
# option for BSD process accounting is enabled in your kernel, and then |
|||
# create the file /var/log/pacct (touch /var/log/pacct). By default, process |
|||
# accounting is not enabled (since /var/log/pacct does not exist). This is |
|||
# because the log file can get VERY large. |
|||
if [ -x /sbin/accton -a -r /var/log/pacct ]; then |
|||
chmod 640 /var/log/pacct |
|||
/sbin/accton /var/log/pacct |
|||
fi |
|||
|
|||
# Start crond (Dillon's crond): |
|||
# If you want cron to actually log activity to /var/log/cron, then change |
|||
# -l notice to -l info to increase the logging level. |
|||
if [ -x /usr/sbin/crond ]; then |
|||
/usr/sbin/crond -l notice |
|||
fi |
|||
|
|||
# Start atd (manages jobs scheduled with 'at'): |
|||
if [ -x /usr/sbin/atd ]; then |
|||
/usr/sbin/atd -b 15 -l 1 |
|||
fi |
|||
|
|||
# Slackware-Mini-Quota-HOWTO: |
|||
# To really activate quotas, you'll need to add 'usrquota' and/or 'grpquota' to |
|||
# the appropriate partitions as listed in /etc/fstab. Here's an example: |
|||
# |
|||
# /dev/hda2 /home ext3 defaults,usrquota 1 1 |
|||
# |
|||
# You'll then need to setup initial quota files at the top of the partitions |
|||
# to support quota, like this: |
|||
# touch /home/aquota.user /home/aquota.group |
|||
# chmod 600 /home/aquota.user /home/aquota.group |
|||
# |
|||
# Then, reboot to activate the system. |
|||
# To edit user quotas, use 'edquota'. See 'man edquota'. Also, the |
|||
# official Quota Mini-HOWTO has lots of useful information. That can be found |
|||
# here: /usr/doc/Linux-HOWTOs/Quota |
|||
|
|||
# Check quotas and then turn quota system on: |
|||
if grep -q quota /etc/fstab ; then |
|||
for quotafs in $(awk '/quota/ {print $2}' /etc/fstab) ; do |
|||
/bin/rm -f $quotafs/{a,}quota.{group,user}.new |
|||
done |
|||
if [ -x /sbin/quotacheck ]; then |
|||
echo "Checking filesystem quotas: /sbin/quotacheck -avugm" |
|||
/sbin/quotacheck -avugm |
|||
fi |
|||
if [ -x /sbin/quotaon ]; then |
|||
echo "Activating filesystem quotas: /sbin/quotaon -avug" |
|||
/sbin/quotaon -avug |
|||
fi |
|||
fi |
|||
|
|||
# Start the SASL authentication server. This provides SASL |
|||
# authentication services for sendmail: |
|||
if [ -x /etc/rc.d/rc.saslauthd ]; then |
|||
. /etc/rc.d/rc.saslauthd start |
|||
fi |
|||
|
|||
# Start the sendmail daemon: |
|||
if [ -x /etc/rc.d/rc.sendmail ]; then |
|||
. /etc/rc.d/rc.sendmail start |
|||
fi |
|||
|
|||
# Load ALSA (sound) defaults: |
|||
if [ -x /etc/rc.d/rc.alsa ]; then |
|||
. /etc/rc.d/rc.alsa |
|||
fi |
|||
|
|||
# Load a custom screen font if the user has an rc.font script. |
|||
if [ -x /etc/rc.d/rc.font ]; then |
|||
. /etc/rc.d/rc.font |
|||
fi |
|||
|
|||
# Load a custom keymap if the user has an rc.keymap script. |
|||
if [ -x /etc/rc.d/rc.keymap ]; then |
|||
. /etc/rc.d/rc.keymap |
|||
fi |
|||
|
|||
# Start the MySQL database: |
|||
if [ -x /etc/rc.d/rc.mysqld ]; then |
|||
. /etc/rc.d/rc.mysqld start |
|||
fi |
|||
|
|||
# Start Apache web server: |
|||
if [ -x /etc/rc.d/rc.httpd ]; then |
|||
. /etc/rc.d/rc.httpd start |
|||
fi |
|||
|
|||
# Start OpenLDAP: |
|||
if [ -x /etc/rc.d/rc.openldap ]; then |
|||
. /etc/rc.d/rc.openldap start |
|||
fi |
|||
|
|||
# Start Samba (a file/print server for Win95/NT machines). |
|||
# Samba can be started in /etc/inetd.conf instead. |
|||
if [ -x /etc/rc.d/rc.samba ]; then |
|||
. /etc/rc.d/rc.samba start |
|||
fi |
|||
|
|||
# Start the GPM mouse server: |
|||
if [ -x /etc/rc.d/rc.gpm ]; then |
|||
. /etc/rc.d/rc.gpm start |
|||
fi |
|||
|
|||
# If there are SystemV init scripts for this runlevel, run them. |
|||
if [ -x /etc/rc.d/rc.sysvinit ]; then |
|||
. /etc/rc.d/rc.sysvinit |
|||
fi |
|||
|
|||
# Start the local setup procedure. |
|||
if [ -x /etc/rc.d/rc.local ]; then |
|||
. /etc/rc.d/rc.local |
|||
fi |
|||
|
|||
# All done. |
@ -0,0 +1,474 @@ |
|||
#!/bin/sh |
|||
# |
|||
# /etc/rc.d/rc.S: System initialization script. |
|||
# |
|||
# Mostly written by: Patrick J. Volkerding, <volkerdi@slackware.com> |
|||
# |
|||
|
|||
# Set $container variable since this is a modified version of rc.S with |
|||
# changes for running in an lxc container. A check to see if this variable |
|||
# is set will be used to skip parts of the script that we don't want to run |
|||
# in a container. Thanks to Matteo Bernardini <ponce@slackbuilds.org> and |
|||
# Chris Willing for the initial work making this script lxc compatible. |
|||
container="lxc" |
|||
|
|||
PATH=/sbin:/usr/sbin:/bin:/usr/bin |
|||
|
|||
# Try to mount /proc: |
|||
if [ -z "$container" ]; then |
|||
/sbin/mount -v proc /proc -n -t proc 2> /dev/null |
|||
fi |
|||
|
|||
# Mount sysfs next, if the kernel supports it: |
|||
if [ -d /sys -a -z "$container" ]; then |
|||
if grep -wq sysfs /proc/filesystems ; then |
|||
if ! grep -wq sysfs /proc/mounts ; then |
|||
/sbin/mount -v sysfs /sys -n -t sysfs |
|||
fi |
|||
fi |
|||
fi |
|||
|
|||
# If /run exists, mount a tmpfs on it (unless the |
|||
# initrd has already done so): |
|||
if [ -d /run -a -z "$container" ]; then |
|||
if ! grep -wq "tmpfs /run tmpfs" /proc/mounts ; then |
|||
/sbin/mount -v -n -t tmpfs tmpfs /run -o mode=0755 |
|||
fi |
|||
fi |
|||
|
|||
# Load the loop device kernel module: |
|||
if [ -x /etc/rc.d/rc.loop -a -z "$container" ]; then |
|||
. /etc/rc.d/rc.loop start |
|||
fi |
|||
|
|||
# Initialize udev to manage /dev entries and hotplugging. |
|||
# You may turn off udev by making the /etc/rc.d/rc.udev file non-executable |
|||
# or giving the "nohotplug" option at boot, but realize that if you turn off |
|||
# udev that you will have to load all the kernel modules that you need |
|||
# yourself (possibly in /etc/rc.d/rc.modules.local), and make any additional |
|||
# device nodes that you need in the /dev directory. Even USB and IEEE1394 |
|||
# devices will need to have the modules loaded by hand if udev is not used. |
|||
# So use it. :-) |
|||
if grep -wq sysfs /proc/mounts && grep -q devtmpfs /proc/filesystems ; then |
|||
if ! grep -wq nohotplug /proc/cmdline ; then |
|||
if [ -x /etc/rc.d/rc.udev -a -z "$container" ]; then |
|||
/bin/sh /etc/rc.d/rc.udev start |
|||
fi |
|||
fi |
|||
fi |
|||
|
|||
# Mount Control Groups filesystem interface: |
|||
if [ -z "$container" ]; then |
|||
if grep -wq cgroup /proc/filesystems ; then |
|||
if [ -d /sys/fs/cgroup ]; then |
|||
# See linux-*/Documentation/cgroups/cgroups.txt (section 1.6) |
|||
# Check if we have some tools to autodetect the available cgroup controllers |
|||
if [ -x /bin/cut -a -x /bin/tail ]; then |
|||
# Mount a tmpfs as the cgroup filesystem root |
|||
mount -t tmpfs -o mode=0755 cgroup_root /sys/fs/cgroup |
|||
# Autodetect available controllers and mount them in subfolders |
|||
controllers="$(/bin/cut -f 1 /proc/cgroups | /bin/tail -n +2)" |
|||
for i in $controllers; do |
|||
mkdir /sys/fs/cgroup/$i |
|||
mount -t cgroup -o $i $i /sys/fs/cgroup/$i |
|||
done |
|||
unset i controllers |
|||
else |
|||
# We can't use autodetection so fall back mounting them all together |
|||
mount -t cgroup cgroup /sys/fs/cgroup |
|||
fi |
|||
else |
|||
mkdir -p /dev/cgroup |
|||
mount -t cgroup cgroup /dev/cgroup |
|||
fi |
|||
fi |
|||
fi |
|||
|
|||
# Initialize the Logical Volume Manager. |
|||
# This won't start unless we find /etc/lvmtab (LVM1) or |
|||
# /etc/lvm/backup/ (LVM2). This is created by /sbin/vgscan, so to |
|||
# use LVM you must run /sbin/vgscan yourself the first time (and |
|||
# create some VGs and LVs). |
|||
if [ -z "$container" ]; then |
|||
# Create LVM lock/run directories: |
|||
mkdir -p -m 0700 /run/lvm /run/lock /run/lock/lvm |
|||
if [ -r /etc/lvmtab -o -d /etc/lvm/backup ]; then |
|||
echo "Initializing LVM (Logical Volume Manager):" |
|||
# Check for device-mapper support. |
|||
if ! grep -wq device-mapper /proc/devices ; then |
|||
# Try to load a device-mapper kernel module: |
|||
/sbin/modprobe -q dm-mod |
|||
fi |
|||
# Scan for new volume groups: |
|||
/sbin/vgscan --mknodes --ignorelockingfailure 2> /dev/null |
|||
if [ $? = 0 ]; then |
|||
# Make volume groups available to the kernel. |
|||
# This should also make logical volumes available. |
|||
/sbin/vgchange -ay --ignorelockingfailure |
|||
fi |
|||
fi |
|||
fi |
|||
|
|||
# Open any volumes created by cryptsetup. |
|||
# |
|||
# Some notes on /etc/crypttab in Slackware: |
|||
# Only LUKS formatted volumes are supported (except for swap) |
|||
# crypttab follows the following format: |
|||
# <luks_name> <device> <password> <options> |
|||
# |
|||
# <luks_name>: This is the name of your LUKS volume. |
|||
# For example: crypt-home |
|||
# |
|||
# <device>: This is the device containing your LUKS volume. |
|||
# For example: /dev/sda2 |
|||
# |
|||
# <password>: This is either the volume password in plain text, or the name of |
|||
# a key file. Use 'none' to interactively enter password on boot. |
|||
# |
|||
# <options>: Comma-separated list of options. Note that there must be a |
|||
# password field for any options to be picked up (use a password of 'none' to |
|||
# get a password prompt at boot). The following options are supported: |
|||
# |
|||
# discard -- this will cause --allow-discards to be passed to the cryptsetup |
|||
# program while opening the LUKS volume. |
|||
# |
|||
# ro -- this will cause --readonly to be passed to the cryptsetup program while |
|||
# opening the LUKS volume. |
|||
# |
|||
# swap -- this option cannot be used with other options. The device given will |
|||
# be formatted as a new encrypted volume with a random key on boot, and used as |
|||
# swap. |
|||
# |
|||
if [ -f /etc/crypttab -a -x /sbin/cryptsetup -a -z "$container" ]; then |
|||
# First, check for device-mapper support. |
|||
if ! grep -wq device-mapper /proc/devices ; then |
|||
# If device-mapper exists as a module, try to load it. |
|||
# Try to load a device-mapper kernel module: |
|||
/sbin/modprobe -q dm-mod |
|||
fi |
|||
# NOTE: we only support LUKS formatted volumes (except for swap)! |
|||
cat /etc/crypttab | grep -v "^#" | grep -v "^$" | while read line; do |
|||
eval LUKSARRAY=( $line ) |
|||
LUKS="${LUKSARRAY[0]}" |
|||
DEV="${LUKSARRAY[1]}" |
|||
PASS="${LUKSARRAY[2]}" |
|||
OPTS="${LUKSARRAY[3]}" |
|||
LUKSOPTS="" |
|||
if echo $OPTS | grep -wq ro ; then LUKSOPTS="${LUKSOPTS} --readonly" ; fi |
|||
if echo $OPTS | grep -wq discard ; then LUKSOPTS="${LUKSOPTS} --allow-discards" ; fi |
|||
# Skip LUKS volumes that were already unlocked (in the initrd): |
|||
/sbin/cryptsetup status $LUKS 2>/dev/null | head -n 1 | grep -q "is active" && continue |
|||
if /sbin/cryptsetup isLuks $DEV 2>/dev/null ; then |
|||
if [ -z "${LUKSOPTS}" ]; then |
|||
echo "Unlocking LUKS encrypted volume '${LUKS}' on device '$DEV':" |
|||
else |
|||
echo "Unlocking LUKS encrypted volume '${LUKS}' on device '$DEV' with options '${LUKSOPTS}':" |
|||
fi |
|||
if [ -n "${PASS}" -a "${PASS}" != "none" ]; then |
|||
if [ -f "${PASS}" ]; then |
|||
# A password was given a key-file filename |
|||
/sbin/cryptsetup ${LUKSOPTS} --key-file=${PASS} luksOpen $DEV $LUKS |
|||
else |
|||
# A password was provided in plain text |
|||
echo "${PASS}" | /sbin/cryptsetup ${LUKSOPTS} luksOpen $DEV $LUKS |
|||
fi |
|||
else |
|||
# No password was given, or a password of 'none' was given |
|||
/sbin/cryptsetup ${LUKSOPTS} luksOpen $DEV $LUKS </dev/tty0 >/dev/tty0 2>&1 |
|||
fi |
|||
elif echo $OPTS | grep -wq swap ; then |
|||
# If any of the volumes is to be used as encrypted swap, |
|||
# then encrypt it using a random key and run mkswap: |
|||
echo "Creating encrypted swap volume '${LUKS}' on device '$DEV':" |
|||
/sbin/cryptsetup --cipher=aes --key-file=/dev/urandom --key-size=256 create $LUKS $DEV |
|||
mkswap /dev/mapper/$LUKS |
|||
fi |
|||
done |
|||
fi |
|||
|
|||
# Enable swapping: |
|||
if [ -z "$container" ]; then |
|||
/sbin/swapon -a 2> /dev/null |
|||
fi |
|||
|
|||
# Start FUSE, if requested: |
|||
if [ -x /etc/rc.d/rc.fuse -a -z "$container" ]; then |
|||
sh /etc/rc.d/rc.fuse start |
|||
fi |
|||
|
|||
# Set the tick and frequency for the system clock. |
|||
# Default values are: TICK=10000 and FREQ=0 |
|||
if [ -z "$container" ]; then |
|||
TICK=10000 |
|||
FREQ=0 |
|||
# If there's a /etc/default/adjtimex config file, source it to override |
|||
# the default TICK and FREQ: |
|||
if [ -r /etc/default/adjtimex ]; then |
|||
. /etc/default/adjtimex |
|||
fi |
|||
if /sbin/adjtimex --tick $TICK --frequency $FREQ; then |
|||
echo "Setting the system clock rate: /sbin/adjtimex --tick $TICK --frequency $FREQ" |
|||
else |
|||
echo "Failed to set system clock with adjtimex, possibly invalid parameters? (TICK=$TICK FREQ=$FREQ)" |
|||
fi |
|||
fi |
|||
|
|||
# Set the system time from the hardware clock using hwclock --hctosys. |
|||
if [ -x /sbin/hwclock -a -z "$container" ]; then |
|||
# Check for a broken motherboard RTC clock (where ioports for rtc are |
|||
# unknown) to prevent hwclock causing a hang: |
|||
if ! grep -q " : rtc" /proc/ioports ; then |
|||
CLOCK_OPT="--directisa" |
|||
fi |
|||
if [ /etc/adjtime -nt /etc/hardwareclock ]; then |
|||
if grep -q "^LOCAL" /etc/adjtime ; then |
|||
echo -n "Setting system time from the hardware clock (localtime): " |
|||
else |
|||
echo -n "Setting system time from the hardware clock (UTC): " |
|||
fi |
|||
/sbin/hwclock $CLOCK_OPT --hctosys |
|||
elif grep -wq "^localtime" /etc/hardwareclock 2> /dev/null ; then |
|||
echo -n "Setting system time from the hardware clock (localtime): " |
|||
/sbin/hwclock $CLOCK_OPT --localtime --hctosys |
|||
else |
|||
echo -n "Setting system time from the hardware clock (UTC): " |
|||
/sbin/hwclock $CLOCK_OPT --utc --hctosys |
|||
fi |
|||
date |
|||
fi |
|||
|
|||
# Test to see if the root partition is read-only, like it ought to be. |
|||
if [ -z "$container" ]; then |
|||
READWRITE=no |
|||
if touch /fsrwtestfile 2>/dev/null; then |
|||
rm -f /fsrwtestfile |
|||
READWRITE=yes |
|||
else |
|||
echo "Testing root filesystem status: read-only filesystem" |
|||
fi |
|||
fi |
|||
|
|||
# See if a forced filesystem check was requested at shutdown: |
|||
if [ -r /etc/forcefsck -a -z "$container" ]; then |
|||
FORCEFSCK="-f" |
|||
fi |
|||
|
|||
# Check the root filesystem: |
|||
if [ -z "$container" ]; then |
|||
if [ ! $READWRITE = yes ]; then |
|||
RETVAL=0 |
|||
if [ ! -r /etc/fastboot ]; then |
|||
echo "Checking root filesystem:" |
|||
/sbin/fsck $FORCEFSCK -C -a / |
|||
RETVAL=$? |
|||
fi |
|||
# An error code of 2 or higher will require a reboot. |
|||
if [ $RETVAL -ge 2 ]; then |
|||
# An error code equal to or greater than 4 means that some errors |
|||
# could not be corrected. This requires manual attention, so we |
|||
# offer a chance to try to fix the problem in single-user mode: |
|||
if [ $RETVAL -ge 4 ]; then |
|||
echo |
|||
echo "***********************************************************" |
|||
echo "*** An error occurred during the root filesystem check. ***" |
|||
echo "*** You will now be given a chance to log into the ***" |
|||
echo "*** system in single-user mode to fix the problem. ***" |
|||
echo "*** ***" |
|||
echo "*** If you are using the ext2 filesystem, running ***" |
|||
echo "*** 'e2fsck -v -y <partition>' might help. ***" |
|||
echo "***********************************************************" |
|||
echo |
|||
echo "Once you exit the single-user shell, the system will reboot." |
|||
echo |
|||
PS1="(Repair filesystem) \#"; export PS1 |
|||
sulogin |
|||
else # With an error code of 2 or 3, reboot the machine automatically: |
|||
echo |
|||
echo "***********************************" |
|||
echo "*** The filesystem was changed. ***" |
|||
echo "*** The system will now reboot. ***" |
|||
echo "***********************************" |
|||
echo |
|||
fi |
|||
echo "Unmounting file systems." |
|||
/sbin/umount -a -r |
|||
/sbin/mount -n -o remount,ro / |
|||
echo "Rebooting system." |
|||
sleep 2 |
|||
reboot -f |
|||
fi |
|||
# Remount the root filesystem in read-write mode |
|||
echo "Remounting root device with read-write enabled." |
|||
/sbin/mount -w -v -n -o remount / |
|||
if [ $? -gt 0 ] ; then |
|||
echo "FATAL: Attempt to remount root device as read-write failed! This is going to" |
|||
echo "cause serious problems." |
|||
fi |
|||
else |
|||
echo "Testing root filesystem status: read-write filesystem" |
|||
echo |
|||
echo "ERROR: Root partition has already been mounted read-write. Cannot check!" |
|||
echo |
|||
echo "For filesystem checking to work properly, your system must initially mount" |
|||
echo "the root partition as read only. If you're booting with LILO, add a line:" |
|||
echo |
|||
echo " read-only" |
|||
echo |
|||
echo "to the Linux section in your /etc/lilo.conf and type 'lilo' to reinstall it." |
|||
fi |
|||
fi # Done checking root filesystem |
|||
|
|||
# Any /etc/mtab that exists here is old, so we start with a new one: |
|||
/bin/rm -f /etc/mtab{,~,.tmp} && /bin/touch /etc/mtab |
|||
|
|||
# Add entry for / to /etc/mtab: |
|||
if [ -z "$container" ]; then |
|||
/sbin/mount -f -w / |
|||
fi |
|||
|
|||
# Add /proc, /sys, and /dev/shm mounts to /etc/mtab: |
|||
if [ -z "$container" ]; then |
|||
if [ -d /proc/sys ]; then |
|||
/sbin/mount -f -t proc proc /proc |
|||
fi |
|||
if [ -d /sys/bus ]; then |
|||
/sbin/mount -f -t sysfs sysfs /sys |
|||
fi |
|||
if grep -q '^[^ ]\+ /dev/shm ' /proc/mounts 2> /dev/null ; then |
|||
/sbin/mount -f -t tmpfs tmpfs /dev/shm |
|||
fi |
|||
fi |
|||
|
|||
# Configure ISA Plug-and-Play devices: |
|||
if [ -r /etc/isapnp.conf -a -z "$container" ]; then |
|||
if [ -x /sbin/isapnp ]; then |
|||
/sbin/isapnp /etc/isapnp.conf |
|||
fi |
|||
fi |
|||
|
|||
# Run the kernel module script. This updates the module dependencies and |
|||
# also supports manually loading kernel modules through rc.modules.local. |
|||
if [ -x /etc/rc.d/rc.modules -a -z "$container" ]; then |
|||
. /etc/rc.d/rc.modules |
|||
fi |
|||
|
|||
# Configure kernel parameters: |
|||
if [ -x /sbin/sysctl -a -r /etc/sysctl.conf -a -z "$container" ]; then |
|||
echo "Configuring kernel parameters: /sbin/sysctl -e --system" |
|||
/sbin/sysctl -e --system |
|||
elif [ -x /sbin/sysctl -a -z "$container" ]; then |
|||
echo "Configuring kernel parameters: /sbin/sysctl -e --system" |
|||
# Don't say "Applying /etc/sysctl.conf" or complain if the file doesn't exist |
|||
/sbin/sysctl -e --system 2> /dev/null | grep -v "Applying /etc/sysctl.conf" |
|||
fi |
|||
|
|||
# Check all the non-root filesystems: |
|||
if [ ! -r /etc/fastboot -a -z "$container" ]; then |
|||
echo "Checking non-root filesystems:" |
|||
/sbin/fsck $FORCEFSCK -C -R -A -a |
|||
fi |
|||
|
|||
# Mount usbfs only if it is found in /etc/fstab: |
|||
if [ -z "$container" ]; then |
|||
if grep -wq usbfs /proc/filesystems; then |
|||
if ! grep -wq usbfs /proc/mounts ; then |
|||
if grep -wq usbfs /etc/fstab; then |
|||
/sbin/mount -v /proc/bus/usb |
|||
fi |
|||
fi |
|||
fi |
|||
fi |
|||
|
|||
# Mount non-root file systems in fstab, but not NFS or SMB |
|||
# because TCP/IP is not yet configured, and not proc or sysfs |
|||
# because those have already been mounted. Also check that |
|||
# devpts is not already mounted before attempting to mount |
|||
# it. With a 2.6.x or newer kernel udev mounts devpts. |
|||
# We also need to wait a little bit to let USB and other |
|||
# hotplugged devices settle (sorry to slow down the boot): |
|||
if [ -z "$container" ]; then |
|||
echo "Mounting non-root local filesystems:" |
|||
sleep 3 |
|||
if /bin/grep -wq devpts /proc/mounts ; then |
|||
# This pipe after the mount command is just to convert the new |
|||
# mount verbose output back to the old format that contained |
|||
# more useful information: |
|||
/sbin/mount -a -v -t nonfs,nosmbfs,nocifs,noproc,nosysfs,nodevpts | grep successfully | cut -f 1 -d : | tr -d ' ' | while read dev ; do mount | grep "${dev} " ; done |
|||
else |
|||
/sbin/mount -a -v -t nonfs,nosmbfs,nocifs,noproc,nosysfs | grep successfully | cut -f 1 -d : | tr -d ' ' | while read dev ; do mount | grep "${dev} " ; done |
|||
fi |
|||
fi |
|||
|
|||
# Enable swapping again. This is needed in case a swapfile is used, |
|||
# as it can't be enabled until the filesystem it resides on has been |
|||
# mounted read-write. |
|||
if [ -z "$container" ]; then |
|||
/sbin/swapon -a 2> /dev/null |
|||
fi |
|||
|
|||
# Start cgmanager (or cgproxy in a container): |
|||
if [ -x /etc/rc.d/rc.cgmanager -a -d /sys/fs/cgroup ]; then |
|||
sh /etc/rc.d/rc.cgmanager start |
|||
fi |
|||
|
|||
# Clean up some temporary files: |
|||
rm -f /var/run/* /var/run/*/* /var/run/*/*/* /etc/nologin \ |
|||
/etc/dhcpc/*.pid /etc/forcefsck /etc/fastboot \ |
|||
/var/state/saslauthd/saslauthd.pid \ |
|||
/tmp/.Xauth* 1> /dev/null 2> /dev/null |
|||
( cd /var/log/setup/tmp && rm -rf * ) |
|||
( cd /tmp && rm -rf kde-[a-zA-Z]* ksocket-[a-zA-Z]* hsperfdata_[a-zA-Z]* plugtmp* ) |
|||
|
|||
# Clear /var/lock/subsys: |
|||
if [ -d /var/lock/subsys ]; then |
|||
rm -f /var/lock/subsys/* |
|||
fi |
|||
|
|||
# Create /tmp/{.ICE-unix,.X11-unix} if they are not present: |
|||
if [ ! -e /tmp/.ICE-unix ]; then |
|||
mkdir -p /tmp/.ICE-unix |
|||
chmod 1777 /tmp/.ICE-unix |
|||
fi |
|||
if [ ! -e /tmp/.X11-unix ]; then |
|||
mkdir -p /tmp/.X11-unix |
|||
chmod 1777 /tmp/.X11-unix |
|||
fi |
|||
|
|||
# Create a fresh utmp file: |
|||
touch /var/run/utmp |
|||
chown root:utmp /var/run/utmp |
|||
chmod 664 /var/run/utmp |
|||
|
|||
# Update the current kernel level in the /etc/motd (Message Of The Day) file, |
|||
# if the first line of that file begins with the word 'Linux'. |
|||
# You are free to modify the rest of the file as you see fit. |
|||
if [ -x /bin/sed ]; then |
|||
/bin/sed -i "{1s/^Linux.*/$(/bin/uname -sr)\./}" /etc/motd |
|||
fi |
|||
|
|||
# If there are SystemV init scripts for this runlevel, run them. |
|||
if [ -x /etc/rc.d/rc.sysvinit ]; then |
|||
. /etc/rc.d/rc.sysvinit |
|||
fi |
|||
|
|||
# Run serial port setup script: |
|||
# CAREFUL! This can make some systems hang if the rc.serial script isn't |
|||
# set up correctly. If this happens, you may have to edit the file from a |
|||
# boot disk, and/or set it as non-executable: |
|||
if [ -x /etc/rc.d/rc.serial -a -z "$container" ]; then |
|||
sh /etc/rc.d/rc.serial start |
|||
fi |
|||
|
|||
# Carry an entropy pool between reboots to improve randomness. |
|||
if [ -f /etc/random-seed ]; then |
|||
echo "Using /etc/random-seed to initialize /dev/urandom." |
|||
cat /etc/random-seed > /dev/urandom |
|||
fi |
|||
# Use the pool size from /proc, or 4096 bits: |
|||
if [ -r /proc/sys/kernel/random/poolsize ]; then |
|||
dd if=/dev/urandom of=/etc/random-seed count=1 bs=$(expr $(cat /proc/sys/kernel/random/poolsize) / 8) 2> /dev/null |
|||
else |
|||
dd if=/dev/urandom of=/etc/random-seed count=1 bs=512 2> /dev/null |
|||
fi |
|||
chmod 600 /etc/random-seed |
|||
|
@ -0,0 +1,445 @@ |
|||
#!/bin/sh |
|||
# |
|||
# /etc/rc.d/rc.S: System initialization script. |
|||
# |
|||
# Mostly written by: Patrick J. Volkerding, <volkerdi@slackware.com> |
|||
# |
|||
|
|||
PATH=/sbin:/usr/sbin:/bin:/usr/bin |
|||
|
|||
# Try to mount /proc: |
|||
/sbin/mount -v proc /proc -n -t proc 2> /dev/null |
|||
|
|||
# Mount sysfs next, if the kernel supports it: |
|||
if [ -d /sys ]; then |
|||
if grep -wq sysfs /proc/filesystems ; then |
|||
if ! grep -wq sysfs /proc/mounts ; then |
|||
/sbin/mount -v sysfs /sys -n -t sysfs |
|||
fi |
|||
fi |
|||
fi |
|||
|
|||
# If /run exists, mount a tmpfs on it (unless the |
|||
# initrd has already done so): |
|||
if [ -d /run ]; then |
|||
if ! grep -wq "tmpfs /run tmpfs" /proc/mounts ; then |
|||
/sbin/mount -v -n -t tmpfs tmpfs /run -o mode=0755 |
|||
fi |
|||
fi |
|||
|
|||
# Load the loop device kernel module: |
|||
if [ -x /etc/rc.d/rc.loop ]; then |
|||
. /etc/rc.d/rc.loop start |
|||
fi |
|||
|
|||
# Initialize udev to manage /dev entries and hotplugging. |
|||
# You may turn off udev by making the /etc/rc.d/rc.udev file non-executable |
|||
# or giving the "nohotplug" option at boot, but realize that if you turn off |
|||
# udev that you will have to load all the kernel modules that you need |
|||
# yourself (possibly in /etc/rc.d/rc.modules.local), and make any additional |
|||
# device nodes that you need in the /dev directory. Even USB and IEEE1394 |
|||
# devices will need to have the modules loaded by hand if udev is not used. |
|||
# So use it. :-) |
|||
if grep -wq sysfs /proc/mounts && grep -q devtmpfs /proc/filesystems ; then |
|||
if ! grep -wq nohotplug /proc/cmdline ; then |
|||
if [ -x /etc/rc.d/rc.udev ]; then |
|||
/bin/sh /etc/rc.d/rc.udev start |
|||
fi |
|||
fi |
|||
fi |
|||
|
|||
# Mount Control Groups filesystem interface: |
|||
if grep -wq cgroup /proc/filesystems ; then |
|||
if [ -d /sys/fs/cgroup ]; then |
|||
# See linux-*/Documentation/cgroups/cgroups.txt (section 1.6) |
|||
# Check if we have some tools to autodetect the available cgroup controllers |
|||
if [ -x /bin/cut -a -x /bin/tail ]; then |
|||
# Mount a tmpfs as the cgroup filesystem root |
|||
mount -t tmpfs -o mode=0755 cgroup_root /sys/fs/cgroup |
|||
# Autodetect available controllers and mount them in subfolders |
|||
controllers="$(/bin/cut -f 1 /proc/cgroups | /bin/tail -n +2)" |
|||
for i in $controllers; do |
|||
mkdir /sys/fs/cgroup/$i |
|||
mount -t cgroup -o $i $i /sys/fs/cgroup/$i |
|||
done |
|||
unset i controllers |
|||
else |
|||
# We can't use autodetection so fall back mounting them all together |
|||
mount -t cgroup cgroup /sys/fs/cgroup |
|||
fi |
|||
else |
|||
mkdir -p /dev/cgroup |
|||
mount -t cgroup cgroup /dev/cgroup |
|||
fi |
|||
fi |
|||
|
|||
|
|||
# Initialize the Logical Volume Manager. |
|||
# This won't start unless we find /etc/lvmtab (LVM1) or |
|||
# /etc/lvm/backup/ (LVM2). This is created by /sbin/vgscan, so to |
|||
# use LVM you must run /sbin/vgscan yourself the first time (and |
|||
# create some VGs and LVs). |
|||
# Create LVM lock/run directories: |
|||
mkdir -p -m 0700 /run/lvm /run/lock /run/lock/lvm |
|||
if [ -r /etc/lvmtab -o -d /etc/lvm/backup ]; then |
|||
echo "Initializing LVM (Logical Volume Manager):" |
|||
# Check for device-mapper support. |
|||
if ! grep -wq device-mapper /proc/devices ; then |
|||
# Try to load a device-mapper kernel module: |
|||
/sbin/modprobe -q dm-mod |
|||
fi |
|||
# Scan for new volume groups: |
|||
/sbin/vgscan --mknodes --ignorelockingfailure 2> /dev/null |
|||
if [ $? = 0 ]; then |
|||
# Make volume groups available to the kernel. |
|||
# This should also make logical volumes available. |
|||
/sbin/vgchange -ay --ignorelockingfailure |
|||
fi |
|||
fi |
|||
|
|||
# Open any volumes created by cryptsetup. |
|||
# |
|||
# Some notes on /etc/crypttab in Slackware: |
|||
# Only LUKS formatted volumes are supported (except for swap) |
|||
# crypttab follows the following format: |
|||
# <luks_name> <device> <password> <options> |
|||
# |
|||
# <luks_name>: This is the name of your LUKS volume. |
|||
# For example: crypt-home |
|||
# |
|||
# <device>: This is the device containing your LUKS volume. |
|||
# For example: /dev/sda2 |
|||
# |
|||
# <password>: This is either the volume password in plain text, or the name of |
|||
# a key file. Use 'none' to interactively enter password on boot. |
|||
# |
|||
# <options>: Comma-separated list of options. Note that there must be a |
|||
# password field for any options to be picked up (use a password of 'none' to |
|||
# get a password prompt at boot). The following options are supported: |
|||
# |
|||
# discard -- this will cause --allow-discards to be passed to the cryptsetup |
|||
# program while opening the LUKS volume. |
|||
# |
|||
# ro -- this will cause --readonly to be passed to the cryptsetup program while |
|||
# opening the LUKS volume. |
|||
# |
|||
# swap -- this option cannot be used with other options. The device given will |
|||
# be formatted as a new encrypted volume with a random key on boot, and used as |
|||
# swap. |
|||
# |
|||
if [ -f /etc/crypttab -a -x /sbin/cryptsetup ]; then |
|||
# First, check for device-mapper support. |
|||
if ! grep -wq device-mapper /proc/devices ; then |
|||
# If device-mapper exists as a module, try to load it. |
|||
# Try to load a device-mapper kernel module: |
|||
/sbin/modprobe -q dm-mod |
|||
fi |
|||
# NOTE: we only support LUKS formatted volumes (except for swap)! |
|||
cat /etc/crypttab | grep -v "^#" | grep -v "^$" | while read line; do |
|||
eval LUKSARRAY=( $line ) |
|||
LUKS="${LUKSARRAY[0]}" |
|||
DEV="${LUKSARRAY[1]}" |
|||
PASS="${LUKSARRAY[2]}" |
|||
OPTS="${LUKSARRAY[3]}" |
|||
LUKSOPTS="" |
|||
if echo $OPTS | grep -wq ro ; then LUKSOPTS="${LUKSOPTS} --readonly" ; fi |
|||
if echo $OPTS | grep -wq discard ; then LUKSOPTS="${LUKSOPTS} --allow-discards" ; fi |
|||
# Skip LUKS volumes that were already unlocked (in the initrd): |
|||
/sbin/cryptsetup status $LUKS 2>/dev/null | head -n 1 | grep -q "is active" && continue |
|||
if /sbin/cryptsetup isLuks $DEV 2>/dev/null ; then |
|||
if [ -z "${LUKSOPTS}" ]; then |
|||
echo "Unlocking LUKS encrypted volume '${LUKS}' on device '$DEV':" |
|||
else |
|||
echo "Unlocking LUKS encrypted volume '${LUKS}' on device '$DEV' with options '${LUKSOPTS}':" |
|||
fi |
|||
if [ -n "${PASS}" -a "${PASS}" != "none" ]; then |
|||
if [ -f "${PASS}" ]; then |
|||
# A password was given a key-file filename |
|||
/sbin/cryptsetup ${LUKSOPTS} --key-file=${PASS} luksOpen $DEV $LUKS |
|||
else |
|||
# A password was provided in plain text |
|||
echo "${PASS}" | /sbin/cryptsetup ${LUKSOPTS} luksOpen $DEV $LUKS |
|||
fi |
|||
else |
|||
# No password was given, or a password of 'none' was given |
|||
/sbin/cryptsetup ${LUKSOPTS} luksOpen $DEV $LUKS </dev/tty0 >/dev/tty0 2>&1 |
|||
fi |
|||
elif echo $OPTS | grep -wq swap ; then |
|||
# If any of the volumes is to be used as encrypted swap, |
|||
# then encrypt it using a random key and run mkswap: |
|||
echo "Creating encrypted swap volume '${LUKS}' on device '$DEV':" |
|||
/sbin/cryptsetup --cipher=aes --key-file=/dev/urandom --key-size=256 create $LUKS $DEV |
|||
mkswap /dev/mapper/$LUKS |
|||
fi |
|||
done |
|||
fi |
|||
|
|||
# Enable swapping: |
|||
/sbin/swapon -a 2> /dev/null |
|||
|
|||
# Start FUSE, if requested: |
|||
if [ -x /etc/rc.d/rc.fuse ]; then |
|||
sh /etc/rc.d/rc.fuse start |
|||
fi |
|||
|
|||
# Set the tick and frequency for the system clock. |
|||
# Default values are: TICK=10000 and FREQ=0 |
|||
TICK=10000 |
|||
FREQ=0 |
|||
# If there's a /etc/default/adjtimex config file, source it to override |
|||
# the default TICK and FREQ: |
|||
if [ -r /etc/default/adjtimex ]; then |
|||
. /etc/default/adjtimex |
|||
fi |
|||
if /sbin/adjtimex --tick $TICK --frequency $FREQ; then |
|||
echo "Setting the system clock rate: /sbin/adjtimex --tick $TICK --frequency $FREQ" |
|||
else |
|||
echo "Failed to set system clock with adjtimex, possibly invalid parameters? (TICK=$TICK FREQ=$FREQ)" |
|||
fi |
|||
|
|||
# Set the system time from the hardware clock using hwclock --hctosys. |
|||
if [ -x /sbin/hwclock ]; then |
|||
# Check for a broken motherboard RTC clock (where ioports for rtc are |
|||
# unknown) to prevent hwclock causing a hang: |
|||
if ! grep -q " : rtc" /proc/ioports ; then |
|||
CLOCK_OPT="--directisa" |
|||
fi |
|||
if [ /etc/adjtime -nt /etc/hardwareclock ]; then |
|||
if grep -q "^LOCAL" /etc/adjtime ; then |
|||
echo -n "Setting system time from the hardware clock (localtime): " |
|||
else |
|||
echo -n "Setting system time from the hardware clock (UTC): " |
|||
fi |
|||
/sbin/hwclock $CLOCK_OPT --hctosys |
|||
elif grep -wq "^localtime" /etc/hardwareclock 2> /dev/null ; then |
|||
echo -n "Setting system time from the hardware clock (localtime): " |
|||
/sbin/hwclock $CLOCK_OPT --localtime --hctosys |
|||
else |
|||
echo -n "Setting system time from the hardware clock (UTC): " |
|||
/sbin/hwclock $CLOCK_OPT --utc --hctosys |
|||
fi |
|||
date |
|||
fi |
|||
|
|||
# Test to see if the root partition is read-only, like it ought to be. |
|||
READWRITE=no |
|||
if touch /fsrwtestfile 2>/dev/null; then |
|||
rm -f /fsrwtestfile |
|||
READWRITE=yes |
|||
else |
|||
echo "Testing root filesystem status: read-only filesystem" |
|||
fi |
|||
|
|||
# See if a forced filesystem check was requested at shutdown: |
|||
if [ -r /etc/forcefsck ]; then |
|||
FORCEFSCK="-f" |
|||
fi |
|||
|
|||
# Check the root filesystem: |
|||
if [ ! $READWRITE = yes ]; then |
|||
RETVAL=0 |
|||
if [ ! -r /etc/fastboot ]; then |
|||
echo "Checking root filesystem:" |
|||
/sbin/fsck $FORCEFSCK -C -a / |
|||
RETVAL=$? |
|||
fi |
|||
# An error code of 2 or higher will require a reboot. |
|||
if [ $RETVAL -ge 2 ]; then |
|||
# An error code equal to or greater than 4 means that some errors |
|||
# could not be corrected. This requires manual attention, so we |
|||
# offer a chance to try to fix the problem in single-user mode: |
|||
if [ $RETVAL -ge 4 ]; then |
|||
echo |
|||
echo "***********************************************************" |
|||
echo "*** An error occurred during the root filesystem check. ***" |
|||
echo "*** You will now be given a chance to log into the ***" |
|||
echo "*** system in single-user mode to fix the problem. ***" |
|||
echo "*** ***" |
|||
echo "*** If you are using the ext2 filesystem, running ***" |
|||
echo "*** 'e2fsck -v -y <partition>' might help. ***" |
|||
echo "***********************************************************" |
|||
echo |
|||
echo "Once you exit the single-user shell, the system will reboot." |
|||
echo |
|||
PS1="(Repair filesystem) \#"; export PS1 |
|||
sulogin |
|||
else # With an error code of 2 or 3, reboot the machine automatically: |
|||
echo |
|||
echo "***********************************" |
|||
echo "*** The filesystem was changed. ***" |
|||
echo "*** The system will now reboot. ***" |
|||
echo "***********************************" |
|||
echo |
|||
fi |
|||
echo "Unmounting file systems." |
|||
/sbin/umount -a -r |
|||
/sbin/mount -n -o remount,ro / |
|||
echo "Rebooting system." |
|||
sleep 2 |
|||
reboot -f |
|||
fi |
|||
# Remount the root filesystem in read-write mode |
|||
echo "Remounting root device with read-write enabled." |
|||
/sbin/mount -w -v -n -o remount / |
|||
if [ $? -gt 0 ] ; then |
|||
echo "FATAL: Attempt to remount root device as read-write failed! This is going to" |
|||
echo "cause serious problems." |
|||
fi |
|||
else |
|||
echo "Testing root filesystem status: read-write filesystem" |
|||
echo |
|||
echo "ERROR: Root partition has already been mounted read-write. Cannot check!" |
|||
echo |
|||
echo "For filesystem checking to work properly, your system must initially mount" |
|||
echo "the root partition as read only. If you're booting with LILO, add a line:" |
|||
echo |
|||
echo " read-only" |
|||
echo |
|||
echo "to the Linux section in your /etc/lilo.conf and type 'lilo' to reinstall it." |
|||
fi # Done checking root filesystem |
|||
|
|||
|
|||
# Any /etc/mtab that exists here is old, so we start with a new one: |
|||
/bin/rm -f /etc/mtab{,~,.tmp} && /bin/touch /etc/mtab |
|||
|
|||
# Add entry for / to /etc/mtab: |
|||
/sbin/mount -f -w / |
|||
|
|||
# Add /proc, /sys, and /dev/shm mounts to /etc/mtab: |
|||
if [ -d /proc/sys ]; then |
|||
/sbin/mount -f -t proc proc /proc |
|||
fi |
|||
if [ -d /sys/bus ]; then |
|||
/sbin/mount -f -t sysfs sysfs /sys |
|||
fi |
|||
if grep -q '^[^ ]\+ /dev/shm ' /proc/mounts 2> /dev/null ; then |
|||
/sbin/mount -f -t tmpfs tmpfs /dev/shm |
|||
fi |
|||
|
|||
# Configure ISA Plug-and-Play devices: |
|||
if [ -r /etc/isapnp.conf ]; then |
|||
if [ -x /sbin/isapnp ]; then |
|||
/sbin/isapnp /etc/isapnp.conf |
|||
fi |
|||
fi |
|||
|
|||
# Run the kernel module script. This updates the module dependencies and |
|||
# also supports manually loading kernel modules through rc.modules.local. |
|||
if [ -x /etc/rc.d/rc.modules ]; then |
|||
. /etc/rc.d/rc.modules |
|||
fi |
|||
|
|||
# Configure kernel parameters: |
|||
if [ -x /sbin/sysctl -a -r /etc/sysctl.conf ]; then |
|||
echo "Configuring kernel parameters: /sbin/sysctl -e --system" |
|||
/sbin/sysctl -e --system |
|||
elif [ -x /sbin/sysctl ]; then |
|||
echo "Configuring kernel parameters: /sbin/sysctl -e --system" |
|||
# Don't say "Applying /etc/sysctl.conf" or complain if the file doesn't exist |
|||
/sbin/sysctl -e --system 2> /dev/null | grep -v "Applying /etc/sysctl.conf" |
|||
fi |
|||
|
|||
# Check all the non-root filesystems: |
|||
if [ ! -r /etc/fastboot ]; then |
|||
echo "Checking non-root filesystems:" |
|||
/sbin/fsck $FORCEFSCK -C -R -A -a |
|||
fi |
|||
|
|||
# Mount usbfs only if it is found in /etc/fstab: |
|||
if grep -wq usbfs /proc/filesystems; then |
|||
if ! grep -wq usbfs /proc/mounts ; then |
|||
if grep -wq usbfs /etc/fstab; then |
|||
/sbin/mount -v /proc/bus/usb |
|||
fi |
|||
fi |
|||
fi |
|||
|
|||
# Mount non-root file systems in fstab, but not NFS or SMB |
|||
# because TCP/IP is not yet configured, and not proc or sysfs |
|||
# because those have already been mounted. Also check that |
|||
# devpts is not already mounted before attempting to mount |
|||
# it. With a 2.6.x or newer kernel udev mounts devpts. |
|||
# We also need to wait a little bit to let USB and other |
|||
# hotplugged devices settle (sorry to slow down the boot): |
|||
echo "Mounting non-root local filesystems:" |
|||
sleep 3 |
|||
if /bin/grep -wq devpts /proc/mounts ; then |
|||
# This pipe after the mount command is just to convert the new |
|||
# mount verbose output back to the old format that contained |
|||
# more useful information: |
|||
/sbin/mount -a -v -t nonfs,nosmbfs,nocifs,noproc,nosysfs,nodevpts | grep successfully | cut -f 1 -d : | tr -d ' ' | while read dev ; do mount | grep "${dev} " ; done |
|||
else |
|||
/sbin/mount -a -v -t nonfs,nosmbfs,nocifs,noproc,nosysfs | grep successfully | cut -f 1 -d : | tr -d ' ' | while read dev ; do mount | grep "${dev} " ; done |
|||
fi |
|||
|
|||
# Enable swapping again. This is needed in case a swapfile is used, |
|||
# as it can't be enabled until the filesystem it resides on has been |
|||
# mounted read-write. |
|||
/sbin/swapon -a 2> /dev/null |
|||
|
|||
# Start cgmanager (or cgproxy in a container): |
|||
if [ -x /etc/rc.d/rc.cgmanager -a -d /sys/fs/cgroup ]; then |
|||
sh /etc/rc.d/rc.cgmanager start |
|||
fi |
|||
|
|||
# Clean up some temporary files: |
|||
rm -f /var/run/* /var/run/*/* /var/run/*/*/* /etc/nologin \ |
|||
/etc/dhcpc/*.pid /etc/forcefsck /etc/fastboot \ |
|||
/var/state/saslauthd/saslauthd.pid \ |
|||
/tmp/.Xauth* 1> /dev/null 2> /dev/null |
|||
( cd /var/log/setup/tmp && rm -rf * ) |
|||
( cd /tmp && rm -rf kde-[a-zA-Z]* ksocket-[a-zA-Z]* hsperfdata_[a-zA-Z]* plugtmp* ) |
|||
|
|||
# Clear /var/lock/subsys: |
|||
if [ -d /var/lock/subsys ]; then |
|||
rm -f /var/lock/subsys/* |
|||
fi |
|||
|
|||
# Create /tmp/{.ICE-unix,.X11-unix} if they are not present: |
|||
if [ ! -e /tmp/.ICE-unix ]; then |
|||
mkdir -p /tmp/.ICE-unix |
|||
chmod 1777 /tmp/.ICE-unix |
|||
fi |
|||
if [ ! -e /tmp/.X11-unix ]; then |
|||
mkdir -p /tmp/.X11-unix |
|||
chmod 1777 /tmp/.X11-unix |
|||
fi |
|||
|
|||
# Create a fresh utmp file: |
|||
touch /var/run/utmp |
|||
chown root:utmp /var/run/utmp |
|||
chmod 664 /var/run/utmp |
|||
|
|||
# Update the current kernel level in the /etc/motd (Message Of The Day) file, |
|||
# if the first line of that file begins with the word 'Linux'. |
|||
# You are free to modify the rest of the file as you see fit. |
|||
if [ -x /bin/sed ]; then |
|||
/bin/sed -i "{1s/^Linux.*/$(/bin/uname -sr)\./}" /etc/motd |
|||
fi |
|||
|
|||
# If there are SystemV init scripts for this runlevel, run them. |
|||
if [ -x /etc/rc.d/rc.sysvinit ]; then |
|||
. /etc/rc.d/rc.sysvinit |
|||
fi |
|||
|
|||
# Run serial port setup script: |
|||
# CAREFUL! This can make some systems hang if the rc.serial script isn't |
|||
# set up correctly. If this happens, you may have to edit the file from a |
|||
# boot disk, and/or set it as non-executable: |
|||
if [ -x /etc/rc.d/rc.serial ]; then |
|||
sh /etc/rc.d/rc.serial start |
|||
fi |
|||
|
|||
# Carry an entropy pool between reboots to improve randomness. |
|||
if [ -f /etc/random-seed ]; then |
|||
echo "Using /etc/random-seed to initialize /dev/urandom." |
|||
cat /etc/random-seed > /dev/urandom |
|||
fi |
|||
# Use the pool size from /proc, or 4096 bits: |
|||
if [ -r /proc/sys/kernel/random/poolsize ]; then |
|||
dd if=/dev/urandom of=/etc/random-seed count=1 bs=$(expr $(cat /proc/sys/kernel/random/poolsize) / 8) 2> /dev/null |
|||
else |
|||
dd if=/dev/urandom of=/etc/random-seed count=1 bs=512 2> /dev/null |
|||
fi |
|||
chmod 600 /etc/random-seed |
|||
|
@ -0,0 +1,331 @@ |
|||
#! /bin/sh |
|||
# /etc/rc.d/rc.inet1 |
|||
# This script is used to bring up the various network interfaces. |
|||
# |
|||
# @(#)/etc/rc.d/rc.inet1 10.2 Sun Jul 24 12:45:56 PDT 2005 (pjv) |
|||
|
|||
# Set $container variable since this is a modified version of rc.inet1 with |
|||
# changes for running in an lxc container. A check to see if this variable |
|||
# is set will be used to skip parts of the script that we don't want to run |
|||
# in a container. Thanks to Matteo Bernardini <ponce@slackbuilds.org> and |
|||
# Chris Willing for the initial work making this script lxc compatible. |
|||
container="lxc" |
|||
|
|||
############################ |
|||
# READ NETWORK CONFIG FILE # |
|||
############################ |
|||
|
|||
# Get the configuration information from /etc/rc.d/rc.inet1.conf: |
|||
. /etc/rc.d/rc.inet1.conf |
|||
|
|||
########### |
|||
# LOGGING # |
|||
########### |
|||
|
|||
# If possible, log events in /var/log/messages: |
|||
if [ -f /var/run/syslogd.pid -a -x /usr/bin/logger ]; then |
|||
LOGGER=/usr/bin/logger |
|||
else # output to stdout/stderr: |
|||
LOGGER=/bin/cat |
|||
fi |
|||
|
|||
############################ |
|||
# DETERMINE INTERFACE LIST # |
|||
############################ |
|||
|
|||
# Compose a list of interfaces from /etc/rc.d/rc.inet1.conf (with a maximum |
|||
# of 6 interfaces, but you can easily enlarge the interface limit |
|||
# - send me a picture of such a box :-). |
|||
# If a value for IFNAME[n] is not set, we assume it is an eth'n' interface. |
|||
# This way, the new script is compatible with older rc.inet1.conf files. |
|||
# The IFNAME array will be used to determine which interfaces to bring up/down. |
|||
MAXNICS=${MAXNICS:-6} |
|||
i=0 |
|||
while [ $i -lt $MAXNICS ]; |
|||
do |
|||
IFNAME[$i]=${IFNAME[$i]:=eth${i}} |
|||
i=$(($i+1)) |
|||
done |
|||
if [ "$DEBUG_ETH_UP" = "yes" ]; then |
|||
echo "/etc/rc.d/rc.inet1: List of interfaces: '${IFNAME[@]}'" | $LOGGER |
|||
fi |
|||
|
|||
###################### |
|||
# LOOPBACK FUNCTIONS # |
|||
###################### |
|||
|
|||
# Function to bring up the loopback interface. If loopback is |
|||
# already up, do nothing. |
|||
lo_up() { |
|||
if grep lo: /proc/net/dev 1> /dev/null ; then |
|||
if ! /sbin/ifconfig | grep "^lo" 1> /dev/null ; then |
|||
echo "/etc/rc.d/rc.inet1: /sbin/ifconfig lo 127.0.0.1" | $LOGGER |
|||
/sbin/ifconfig lo 127.0.0.1 |
|||
echo "/etc/rc.d/rc.inet1: /sbin/route add -net 127.0.0.0 netmask 255.0.0.0 lo" | $LOGGER |
|||
/sbin/route add -net 127.0.0.0 netmask 255.0.0.0 lo |
|||
fi |
|||
fi |
|||
} |
|||
|
|||
# Function to take down the loopback interface: |
|||
lo_down() { |
|||
if grep lo: /proc/net/dev 1> /dev/null ; then |
|||
echo "/etc/rc.d/rc.inet1: /sbin/ifconfig lo down" | $LOGGER |
|||
/sbin/ifconfig lo down |
|||
fi |
|||
} |
|||
|
|||
####################### |
|||
# INTERFACE FUNCTIONS # |
|||
####################### |
|||
|
|||
# Function to assemble a bridge interface. |
|||
br_open() { |
|||
# argument is 'i' - the position of this interface in the IFNAME array. |
|||
/sbin/brctl addbr ${IFNAME[$1]} |
|||
for BRIF in $(echo ${BRNICS[$1]}); do |
|||
/sbin/ifconfig $BRIF down |
|||
/sbin/ifconfig $BRIF 0.0.0.0 promisc up |
|||
/sbin/brctl addif ${IFNAME[$1]} $BRIF |
|||
done |
|||
} |
|||
|
|||
# Function to disassemble a bridge interface. |
|||
br_close() { |
|||
# argument is 'i' - the position of this interface in the IFNAME array. |
|||
#for BRIF in $(echo ${BRNICS[$1]}); do |
|||
for BRIF in $(ls --indicator-style=none /sys/class/net/${IFNAME[$1]}/brif/) |
|||
do |
|||
/sbin/brctl delif ${IFNAME[$1]} $BRIF |
|||
done |
|||
/sbin/ifconfig ${IFNAME[$1]} down |
|||
/sbin/brctl delbr ${IFNAME[$1]} |
|||
} |
|||
|
|||
# Function to bring up a network interface. If the interface is |
|||
# already up or does not yet exist (perhaps because the kernel driver |
|||
# is not loaded yet), do nothing. |
|||
if_up() { |
|||
# Determine position 'i' of this interface in the IFNAME array: |
|||
i=0 |
|||
while [ $i -lt $MAXNICS ]; do |
|||
[ "${IFNAME[$i]}" = "${1}" ] && break |
|||
i=$(($i+1)) |
|||
done |
|||
|
|||
if [ -z "$container" ]; then |
|||
# If the interface is a bridge, then create it first: |
|||
[ -n "${BRNICS[$i]}" ] && br_open $i |
|||
# If the interface isn't in the kernel yet (but there's an alias for it in |
|||
# modules.conf), then it should be loaded first: |
|||
if ! grep `echo ${1}: | cut -f 1 -d :`: /proc/net/dev 1> /dev/null ; then # no interface yet |
|||
if /sbin/modprobe -c | grep -v "^#" | grep -w "alias ${1}" | grep -vw "alias ${1} off" > /dev/null ; then |
|||
echo "/etc/rc.d/rc.inet1: /sbin/modprobe ${1}" | $LOGGER |
|||
/sbin/modprobe ${1} |
|||
fi |
|||
fi |
|||
fi # end check container |
|||
|
|||
if grep `echo ${1}: | cut -f 1 -d :`: /proc/net/dev 1> /dev/null ; then # interface exists |
|||
if ! /sbin/ifconfig | grep -w "${1}" 1>/dev/null || \ |
|||
! /sbin/ifconfig ${1} | grep -w inet 1> /dev/null ; then # interface not up or not configured |
|||
if [ ! "${HWADDR[$i]}" = "" ]; then # Set hardware address _before_ the interface goes up: |
|||
echo "/etc/rc.d/rc.inet1: /sbin/ifconfig ${1} hw ether ${HWADDR[$i]}" | $LOGGER |
|||
/sbin/ifconfig ${1} hw ether ${HWADDR[$i]} |
|||
fi |
|||
if [ ! "${MTU[$i]}" = "" ]; then # Set MTU to something else than 1500 |
|||
echo "/etc/rc.d/rc.inet1: /sbin/ifconfig ${1} mtu ${MTU[$i]}" | $LOGGER |
|||
/sbin/ifconfig ${1} mtu ${MTU[$i]} |
|||
fi |
|||
if [ -x /etc/rc.d/rc.wireless ]; then |
|||
. /etc/rc.d/rc.wireless ${1} start # Initialize any wireless parameters |
|||
fi |
|||
if [ "${USE_DHCP[$i]}" = "yes" ]; then # use DHCP to bring interface up |
|||
# Clear DHCP_OPTIONS before adding new options to it: |
|||
unset DHCP_OPTIONS |
|||
# Set DHCP_OPTIONS for this interface: |
|||
[ ${DHCP_HOSTNAME[$i]} ] && DHCP_OPTIONS="-h ${DHCP_HOSTNAME[$i]}" |
|||
[ "${DHCP_KEEPRESOLV[$i]}" = "yes" ] && DHCP_OPTIONS="$DHCP_OPTIONS -C resolv.conf" |
|||
[ "${DHCP_KEEPNTP[$i]}" = "yes" ] && DHCP_OPTIONS="$DHCP_OPTIONS -C ntp.conf" |
|||
[ "${DHCP_KEEPGW[$i]}" = "yes" ] && DHCP_OPTIONS="$DHCP_OPTIONS -G" |
|||
[ "${DHCP_DEBUG[$i]}" = "yes" ] && DHCP_OPTIONS="$DHCP_OPTIONS -d" |
|||
[ "${DHCP_NOIPV4LL[$i]}" = "yes" ] && DHCP_OPTIONS="$DHCP_OPTIONS -L" |
|||
[ ${DHCP_IPADDR[$i]} ] && DHCP_OPTIONS="$DHCP_OPTIONS -r ${DHCP_IPADDR[$i]}" |
|||
echo "Polling for DHCP server on interface ${1}:" |
|||
# If you set a timeout, you get one, even if the kernel doesn't think that |
|||
# your device is connected, in case /sys isn't right (which it usually isn't |
|||
# except right after the device is loaded, when it usually is): |
|||
#### (start commented out) |
|||
# This is deactivated for now since the kernel has been returning incorrect |
|||
# results concerning whether the interface carrier is detected. |
|||
#if [ "${DHCP_TIMEOUT[$i]}" = "" ]; then |
|||
# ifconfig ${1} up && sleep 1 |
|||
# CONNSTATUS="$(cat /sys/class/net/${1}/carrier 2> /dev/null)" |
|||
# ifconfig ${1} down |
|||
# if [ "$CONNSTATUS" = "0" ]; then |
|||
# # The kernel has just told us the cable isn't even plugged in, but we will |
|||
# # give any DHCP server a short chance to reply anyway: |
|||
# echo "No carrier detected on ${1}. Reducing DHCP timeout to 10 seconds." |
|||
# DHCP_TIMEOUT[$i]=10 |
|||
# fi |
|||
#fi |
|||
#### (end commented out) |
|||
# 10 seconds should be a reasonable default DHCP timeout. 30 was too much. |
|||
echo "/etc/rc.d/rc.inet1: /sbin/dhcpcd -t ${DHCP_TIMEOUT[$i]:-10} ${DHCP_OPTIONS} ${1}" | $LOGGER |
|||
/sbin/dhcpcd -t ${DHCP_TIMEOUT[$i]:-10} ${DHCP_OPTIONS} ${1} |
|||
else # bring up interface using a static IP address |
|||
if [ ! "${IPADDR[$i]}" = "" ]; then # skip unconfigured interfaces |
|||
# Determine broadcast address from the IP address and netmask: |
|||
BROADCAST[$i]=`/bin/ipmask ${NETMASK[$i]} ${IPADDR[$i]}|cut -f1 -d' '` |
|||
# Set up the network card: |
|||
echo "/etc/rc.d/rc.inet1: /sbin/ifconfig ${1} ${IPADDR[$i]} broadcast ${BROADCAST[$i]} netmask ${NETMASK[$i]}" | $LOGGER |
|||
/sbin/ifconfig ${1} ${IPADDR[$i]} broadcast ${BROADCAST[$i]} netmask ${NETMASK[$i]} |
|||
else |
|||
if [ "$DEBUG_ETH_UP" = "yes" ]; then |
|||
echo "/etc/rc.d/rc.inet1: ${1} interface is not configured in /etc/rc.d/rc.inet1.conf" | $LOGGER |
|||
fi |
|||
fi |
|||
fi |
|||
else |
|||
if [ "$DEBUG_ETH_UP" = "yes" ]; then |
|||
echo "/etc/rc.d/rc.inet1: ${1} is already up, skipping" | $LOGGER |
|||
fi |
|||
fi |
|||
else |
|||
if [ "$DEBUG_ETH_UP" = "yes" ]; then |
|||
echo "/etc/rc.d/rc.inet1: ${1} interface does not exist (yet)" | $LOGGER |
|||
fi |
|||
fi |
|||
} |
|||
|
|||
# Function to take down a network interface: |
|||
if_down() { |
|||
# Determine position 'i' of this interface in the IFNAME array: |
|||
i=0 |
|||
while [ $i -lt $MAXNICS ]; do |
|||
[ "${IFNAME[$i]}" = "${1}" ] && break |
|||
i=$(($i+1)) |
|||
done |
|||
if grep `echo ${1}: | cut -f 1 -d :`: /proc/net/dev 1> /dev/null ; then |
|||
if [ "${USE_DHCP[$i]}" = "yes" ]; then |
|||
echo "/etc/rc.d/rc.inet1: /sbin/dhcpcd -k -d ${1}" | $LOGGER |
|||
/sbin/dhcpcd -k -d ${1} 2> /dev/null || /sbin/ifconfig ${1} down |
|||
sleep 1 |
|||
else |
|||
echo "/etc/rc.d/rc.inet1: /sbin/ifconfig ${1} down" | $LOGGER |
|||
/sbin/ifconfig ${1} down |
|||
fi |
|||
if [ -x /etc/rc.d/rc.wireless ]; then |
|||
. /etc/rc.d/rc.wireless ${1} stop # Kill wireless daemons if any. |
|||
fi |
|||
# If the interface is a bridge, then destroy it now: |
|||
if [ -n "${BRNICS[$i]}" ]; then |
|||
br_close $i |
|||
fi |
|||
fi |
|||
} |
|||
|
|||
##################### |
|||
# GATEWAY FUNCTIONS # |
|||
##################### |
|||
|
|||
# Function to bring up the gateway if there is not yet a default route: |
|||
gateway_up() { |
|||
if ! /sbin/route -n | grep "^0.0.0.0" 1> /dev/null ; then |
|||
if [ ! "$GATEWAY" = "" ]; then |
|||
echo "/etc/rc.d/rc.inet1: /sbin/route add default gw ${GATEWAY} metric 1" | $LOGGER |
|||
/sbin/route add default gw ${GATEWAY} metric 1 2>&1 | $LOGGER |
|||
fi |
|||
fi |
|||
} |
|||
|
|||
# Function to take down an existing default gateway: |
|||
gateway_down() { |
|||
if /sbin/route -n | grep "^0.0.0.0" 1> /dev/null ; then |
|||
echo "/etc/rc.d/rc.inet1: /sbin/route del default" | $LOGGER |
|||
/sbin/route del default |
|||
fi |
|||
} |
|||
|
|||
# Function to start the network: |
|||
start() { |
|||
lo_up |
|||
for i in ${IFNAME[@]} ; do |
|||
if_up $i |
|||
done |
|||
gateway_up |
|||
} |
|||
|
|||
# Function to stop the network: |
|||
stop() { |
|||
gateway_down |
|||
for i in ${IFNAME[@]} ; do |
|||
if_down $i |
|||
done |
|||
lo_down |
|||
} |
|||
|
|||
|
|||
############ |
|||
### MAIN ### |
|||
############ |
|||
|
|||
case "$1" in |
|||
'start') # "start" brings up all configured interfaces: |
|||
start |
|||
;; |
|||
'stop') # "stop" takes down all configured interfaces: |
|||
stop |
|||
;; |
|||
'restart') # "restart" restarts the network: |
|||
stop |
|||
start |
|||
;; |
|||
'lo_start') # Start the loopback interface: |
|||
lo_up |
|||
;; |
|||
*_start) # Example: "eth1_start" will start the specified interface 'eth1' |
|||
INTERFACE=`echo $1 | /bin/cut -d '_' -f 1` |
|||
if_up $INTERFACE |
|||
gateway_up |
|||
;; |
|||
'lo_stop') # Stop the loopback interface: |
|||
lo_down |
|||
;; |
|||
*_stop) # Example: "eth0_stop" will stop the specified interface 'eth0' |
|||
INTERFACE=`echo $1 | /bin/cut -d '_' -f 1` |
|||
if_down $INTERFACE |
|||
;; |
|||
*_restart) # Example: "wlan0_restart" will take 'wlan0' down and up again |
|||
INTERFACE=`echo $1 | /bin/cut -d '_' -f 1` |
|||
if_down $INTERFACE |
|||
sleep 1 |
|||
if_up $INTERFACE |
|||
gateway_up |
|||
;; |
|||
'up') # "up" does the same thing as "start" |
|||
start |
|||
;; |
|||
'down') # "down" does the same thing as "stop" |
|||
stop |
|||
;; |
|||
'lo_up') # Start the loopback interface: |
|||
lo_up |
|||
;; |
|||
*_up) # "*_up" does the same thing as "*_start" |
|||
INTERFACE=`echo $1 | /bin/cut -d '_' -f 1` |
|||
if_up $INTERFACE |
|||
gateway_up |
|||
;; |
|||
'lo_down') # Stop the loopback interface: |
|||
lo_down |
|||
;; |
|||
*_down) # "*_down" does the same thing as "*_stop" |
|||
INTERFACE=`echo $1 | /bin/cut -d '_' -f 1` |
|||
if_down $INTERFACE |
|||
;; |
|||
*) # The default is to bring up all configured interfaces: |
|||
start |
|||
esac |
|||
|
|||
# End of /etc/rc.d/rc.inet1 |
@ -0,0 +1,320 @@ |
|||
#! /bin/sh |
|||
# /etc/rc.d/rc.inet1 |
|||
# This script is used to bring up the various network interfaces. |
|||
# |
|||
# @(#)/etc/rc.d/rc.inet1 10.2 Sun Jul 24 12:45:56 PDT 2005 (pjv) |
|||
|
|||
############################ |
|||
# READ NETWORK CONFIG FILE # |
|||
############################ |
|||
|
|||
# Get the configuration information from /etc/rc.d/rc.inet1.conf: |
|||
. /etc/rc.d/rc.inet1.conf |
|||
|
|||
########### |
|||
# LOGGING # |
|||
########### |
|||
|
|||
# If possible, log events in /var/log/messages: |
|||
if [ -f /var/run/syslogd.pid -a -x /usr/bin/logger ]; then |
|||
LOGGER=/usr/bin/logger |
|||
else # output to stdout/stderr: |
|||
LOGGER=/bin/cat |
|||
fi |
|||
|
|||
############################ |
|||
# DETERMINE INTERFACE LIST # |
|||
############################ |
|||
|
|||
# Compose a list of interfaces from /etc/rc.d/rc.inet1.conf (with a maximum |
|||
# of 6 interfaces, but you can easily enlarge the interface limit |
|||
# - send me a picture of such a box :-). |
|||
# If a value for IFNAME[n] is not set, we assume it is an eth'n' interface. |
|||
# This way, the new script is compatible with older rc.inet1.conf files. |
|||
# The IFNAME array will be used to determine which interfaces to bring up/down. |
|||
MAXNICS=${MAXNICS:-6} |
|||
i=0 |
|||
while [ $i -lt $MAXNICS ]; |
|||
do |
|||
IFNAME[$i]=${IFNAME[$i]:=eth${i}} |
|||
i=$(($i+1)) |
|||
done |
|||
if [ "$DEBUG_ETH_UP" = "yes" ]; then |
|||
echo "/etc/rc.d/rc.inet1: List of interfaces: '${IFNAME[@]}'" | $LOGGER |
|||
fi |
|||
|
|||
###################### |
|||
# LOOPBACK FUNCTIONS # |
|||
###################### |
|||
|
|||
# Function to bring up the loopback interface. If loopback is |
|||
# already up, do nothing. |
|||
lo_up() { |
|||
if grep lo: /proc/net/dev 1> /dev/null ; then |
|||
if ! /sbin/ifconfig | grep "^lo" 1> /dev/null ; then |
|||
echo "/etc/rc.d/rc.inet1: /sbin/ifconfig lo 127.0.0.1" | $LOGGER |
|||
/sbin/ifconfig lo 127.0.0.1 |
|||
echo "/etc/rc.d/rc.inet1: /sbin/route add -net 127.0.0.0 netmask 255.0.0.0 lo" | $LOGGER |
|||
/sbin/route add -net 127.0.0.0 netmask 255.0.0.0 lo |
|||
fi |
|||
fi |
|||
} |
|||
|
|||
# Function to take down the loopback interface: |
|||
lo_down() { |
|||
if grep lo: /proc/net/dev 1> /dev/null ; then |
|||
echo "/etc/rc.d/rc.inet1: /sbin/ifconfig lo down" | $LOGGER |
|||
/sbin/ifconfig lo down |
|||
fi |
|||
} |
|||
|
|||
####################### |
|||
# INTERFACE FUNCTIONS # |
|||
####################### |
|||
|
|||
# Function to assemble a bridge interface. |
|||
br_open() { |
|||
# argument is 'i' - the position of this interface in the IFNAME array. |
|||
/sbin/brctl addbr ${IFNAME[$1]} |
|||
for BRIF in $(echo ${BRNICS[$1]}); do |
|||
/sbin/ifconfig $BRIF down |
|||
/sbin/ifconfig $BRIF 0.0.0.0 promisc up |
|||
/sbin/brctl addif ${IFNAME[$1]} $BRIF |
|||
done |
|||
} |
|||
|
|||
# Function to disassemble a bridge interface. |
|||
br_close() { |
|||
# argument is 'i' - the position of this interface in the IFNAME array. |
|||
#for BRIF in $(echo ${BRNICS[$1]}); do |
|||
for BRIF in $(ls --indicator-style=none /sys/class/net/${IFNAME[$1]}/brif/) |
|||
do |
|||
/sbin/brctl delif ${IFNAME[$1]} $BRIF |
|||
done |
|||
/sbin/ifconfig ${IFNAME[$1]} down |
|||
/sbin/brctl delbr ${IFNAME[$1]} |
|||
} |
|||
|
|||
# Function to bring up a network interface. If the interface is |
|||
# already up or does not yet exist (perhaps because the kernel driver |
|||
# is not loaded yet), do nothing. |
|||
if_up() { |
|||
# Determine position 'i' of this interface in the IFNAME array: |
|||
i=0 |
|||
while [ $i -lt $MAXNICS ]; do |
|||
[ "${IFNAME[$i]}" = "${1}" ] && break |
|||
i=$(($i+1)) |
|||
done |
|||
# If the interface is a bridge, then create it first: |
|||
[ -n "${BRNICS[$i]}" ] && br_open $i |
|||
# If the interface isn't in the kernel yet (but there's an alias for it in |
|||
# modules.conf), then it should be loaded first: |
|||
if ! grep `echo ${1}: | cut -f 1 -d :`: /proc/net/dev 1> /dev/null ; then # no interface yet |
|||
if /sbin/modprobe -c | grep -v "^#" | grep -w "alias ${1}" | grep -vw "alias ${1} off" > /dev/null ; then |
|||
echo "/etc/rc.d/rc.inet1: /sbin/modprobe ${1}" | $LOGGER |
|||
/sbin/modprobe ${1} |
|||
fi |
|||
fi |
|||
if grep `echo ${1}: | cut -f 1 -d :`: /proc/net/dev 1> /dev/null ; then # interface exists |
|||
if ! /sbin/ifconfig | grep -w "${1}" 1>/dev/null || \ |
|||
! /sbin/ifconfig ${1} | grep -w inet 1> /dev/null ; then # interface not up or not configured |
|||
if [ ! "${HWADDR[$i]}" = "" ]; then # Set hardware address _before_ the interface goes up: |
|||
echo "/etc/rc.d/rc.inet1: /sbin/ifconfig ${1} hw ether ${HWADDR[$i]}" | $LOGGER |
|||
/sbin/ifconfig ${1} hw ether ${HWADDR[$i]} |
|||
fi |
|||
if [ ! "${MTU[$i]}" = "" ]; then # Set MTU to something else than 1500 |
|||
echo "/etc/rc.d/rc.inet1: /sbin/ifconfig ${1} mtu ${MTU[$i]}" | $LOGGER |
|||
/sbin/ifconfig ${1} mtu ${MTU[$i]} |
|||
fi |
|||
if [ -x /etc/rc.d/rc.wireless ]; then |
|||
. /etc/rc.d/rc.wireless ${1} start # Initialize any wireless parameters |
|||
fi |
|||
if [ "${USE_DHCP[$i]}" = "yes" ]; then # use DHCP to bring interface up |
|||
# Clear DHCP_OPTIONS before adding new options to it: |
|||
unset DHCP_OPTIONS |
|||
# Set DHCP_OPTIONS for this interface: |
|||
[ ${DHCP_HOSTNAME[$i]} ] && DHCP_OPTIONS="-h ${DHCP_HOSTNAME[$i]}" |
|||
[ "${DHCP_KEEPRESOLV[$i]}" = "yes" ] && DHCP_OPTIONS="$DHCP_OPTIONS -C resolv.conf" |
|||
[ "${DHCP_KEEPNTP[$i]}" = "yes" ] && DHCP_OPTIONS="$DHCP_OPTIONS -C ntp.conf" |
|||
[ "${DHCP_KEEPGW[$i]}" = "yes" ] && DHCP_OPTIONS="$DHCP_OPTIONS -G" |
|||
[ "${DHCP_DEBUG[$i]}" = "yes" ] && DHCP_OPTIONS="$DHCP_OPTIONS -d" |
|||
[ "${DHCP_NOIPV4LL[$i]}" = "yes" ] && DHCP_OPTIONS="$DHCP_OPTIONS -L" |
|||
[ ${DHCP_IPADDR[$i]} ] && DHCP_OPTIONS="$DHCP_OPTIONS -r ${DHCP_IPADDR[$i]}" |
|||
echo "Polling for DHCP server on interface ${1}:" |
|||
# If you set a timeout, you get one, even if the kernel doesn't think that |
|||
# your device is connected, in case /sys isn't right (which it usually isn't |
|||
# except right after the device is loaded, when it usually is): |
|||
#### (start commented out) |
|||
# This is deactivated for now since the kernel has been returning incorrect |
|||
# results concerning whether the interface carrier is detected. |
|||
#if [ "${DHCP_TIMEOUT[$i]}" = "" ]; then |
|||
# ifconfig ${1} up && sleep 1 |
|||
# CONNSTATUS="$(cat /sys/class/net/${1}/carrier 2> /dev/null)" |
|||
# ifconfig ${1} down |
|||
# if [ "$CONNSTATUS" = "0" ]; then |
|||
# # The kernel has just told us the cable isn't even plugged in, but we will |
|||
# # give any DHCP server a short chance to reply anyway: |
|||
# echo "No carrier detected on ${1}. Reducing DHCP timeout to 10 seconds." |
|||
# DHCP_TIMEOUT[$i]=10 |
|||
# fi |
|||
#fi |
|||
#### (end commented out) |
|||
# 10 seconds should be a reasonable default DHCP timeout. 30 was too much. |
|||
echo "/etc/rc.d/rc.inet1: /sbin/dhcpcd -t ${DHCP_TIMEOUT[$i]:-10} ${DHCP_OPTIONS} ${1}" | $LOGGER |
|||
/sbin/dhcpcd -t ${DHCP_TIMEOUT[$i]:-10} ${DHCP_OPTIONS} ${1} |
|||
else # bring up interface using a static IP address |
|||
if [ ! "${IPADDR[$i]}" = "" ]; then # skip unconfigured interfaces |
|||
# Determine broadcast address from the IP address and netmask: |
|||
BROADCAST[$i]=`/bin/ipmask ${NETMASK[$i]} ${IPADDR[$i]}|cut -f1 -d' '` |
|||
# Set up the network card: |
|||
echo "/etc/rc.d/rc.inet1: /sbin/ifconfig ${1} ${IPADDR[$i]} broadcast ${BROADCAST[$i]} netmask ${NETMASK[$i]}" | $LOGGER |
|||
/sbin/ifconfig ${1} ${IPADDR[$i]} broadcast ${BROADCAST[$i]} netmask ${NETMASK[$i]} |
|||
else |
|||
if [ "$DEBUG_ETH_UP" = "yes" ]; then |
|||
echo "/etc/rc.d/rc.inet1: ${1} interface is not configured in /etc/rc.d/rc.inet1.conf" | $LOGGER |
|||
fi |
|||
fi |
|||
fi |
|||
else |
|||
if [ "$DEBUG_ETH_UP" = "yes" ]; then |
|||
echo "/etc/rc.d/rc.inet1: ${1} is already up, skipping" | $LOGGER |
|||
fi |
|||
fi |
|||
else |
|||
if [ "$DEBUG_ETH_UP" = "yes" ]; then |
|||
echo "/etc/rc.d/rc.inet1: ${1} interface does not exist (yet)" | $LOGGER |
|||
fi |
|||
fi |
|||
} |
|||
|
|||
# Function to take down a network interface: |
|||
if_down() { |
|||
# Determine position 'i' of this interface in the IFNAME array: |
|||
i=0 |
|||
while [ $i -lt $MAXNICS ]; do |
|||
[ "${IFNAME[$i]}" = "${1}" ] && break |
|||
i=$(($i+1)) |
|||
done |
|||
if grep `echo ${1}: | cut -f 1 -d :`: /proc/net/dev 1> /dev/null ; then |
|||
if [ "${USE_DHCP[$i]}" = "yes" ]; then |
|||
echo "/etc/rc.d/rc.inet1: /sbin/dhcpcd -k -d ${1}" | $LOGGER |
|||
/sbin/dhcpcd -k -d ${1} 2> /dev/null || /sbin/ifconfig ${1} down |
|||
sleep 1 |
|||
else |
|||
echo "/etc/rc.d/rc.inet1: /sbin/ifconfig ${1} down" | $LOGGER |
|||
/sbin/ifconfig ${1} down |
|||
fi |
|||
if [ -x /etc/rc.d/rc.wireless ]; then |
|||
. /etc/rc.d/rc.wireless ${1} stop # Kill wireless daemons if any. |
|||
fi |
|||
# If the interface is a bridge, then destroy it now: |
|||
if [ -n "${BRNICS[$i]}" ]; then |
|||
br_close $i |
|||
fi |
|||
fi |
|||
} |
|||
|
|||
##################### |
|||
# GATEWAY FUNCTIONS # |
|||
##################### |
|||
|
|||
# Function to bring up the gateway if there is not yet a default route: |
|||
gateway_up() { |
|||
if ! /sbin/route -n | grep "^0.0.0.0" 1> /dev/null ; then |
|||
if [ ! "$GATEWAY" = "" ]; then |
|||
echo "/etc/rc.d/rc.inet1: /sbin/route add default gw ${GATEWAY} metric 1" | $LOGGER |
|||
/sbin/route add default gw ${GATEWAY} metric 1 2>&1 | $LOGGER |
|||
fi |
|||
fi |
|||
} |
|||
|
|||
# Function to take down an existing default gateway: |
|||
gateway_down() { |
|||
if /sbin/route -n | grep "^0.0.0.0" 1> /dev/null ; then |
|||
echo "/etc/rc.d/rc.inet1: /sbin/route del default" | $LOGGER |
|||
/sbin/route del default |
|||
fi |
|||
} |
|||
|
|||
# Function to start the network: |
|||
start() { |
|||
lo_up |
|||
for i in ${IFNAME[@]} ; do |
|||
if_up $i |
|||
done |
|||
gateway_up |
|||
} |
|||
|
|||
# Function to stop the network: |
|||
stop() { |
|||
gateway_down |
|||
for i in ${IFNAME[@]} ; do |
|||
if_down $i |
|||
done |
|||
lo_down |
|||
} |
|||
|
|||
|
|||
############ |
|||
### MAIN ### |
|||
############ |
|||
|
|||
case "$1" in |
|||
'start') # "start" brings up all configured interfaces: |
|||
start |
|||
;; |
|||
'stop') # "stop" takes down all configured interfaces: |
|||
stop |
|||
;; |
|||
'restart') # "restart" restarts the network: |
|||
stop |
|||
start |
|||
;; |
|||
'lo_start') # Start the loopback interface: |
|||
lo_up |
|||
;; |
|||
*_start) # Example: "eth1_start" will start the specified interface 'eth1' |
|||
INTERFACE=`echo $1 | /bin/cut -d '_' -f 1` |
|||
if_up $INTERFACE |
|||
gateway_up |
|||
;; |
|||
'lo_stop') # Stop the loopback interface: |
|||
lo_down |
|||
;; |
|||
*_stop) # Example: "eth0_stop" will stop the specified interface 'eth0' |
|||
INTERFACE=`echo $1 | /bin/cut -d '_' -f 1` |
|||
if_down $INTERFACE |
|||
;; |
|||
*_restart) # Example: "wlan0_restart" will take 'wlan0' down and up again |
|||
INTERFACE=`echo $1 | /bin/cut -d '_' -f 1` |
|||
if_down $INTERFACE |
|||
sleep 1 |
|||
if_up $INTERFACE |
|||
gateway_up |
|||
;; |
|||
'up') # "up" does the same thing as "start" |
|||
start |
|||
;; |
|||
'down') # "down" does the same thing as "stop" |
|||
stop |
|||
;; |
|||
'lo_up') # Start the loopback interface: |
|||
lo_up |
|||
;; |
|||
*_up) # "*_up" does the same thing as "*_start" |
|||
INTERFACE=`echo $1 | /bin/cut -d '_' -f 1` |
|||
if_up $INTERFACE |
|||
gateway_up |
|||
;; |
|||
'lo_down') # Stop the loopback interface: |
|||
lo_down |
|||
;; |
|||
*_down) # "*_down" does the same thing as "*_stop" |
|||
INTERFACE=`echo $1 | /bin/cut -d '_' -f 1` |
|||
if_down $INTERFACE |
|||
;; |
|||
*) # The default is to bring up all configured interfaces: |
|||
start |
|||
esac |
|||
|
|||
# End of /etc/rc.d/rc.inet1 |
@ -0,0 +1,19 @@ |
|||
# HOW TO EDIT THIS FILE: |
|||
# The "handy ruler" below makes it easier to edit a package description. Line |
|||
# up the first '|' above the ':' following the base package name, and the '|' |
|||
# on the right side marks the last column you can put a character in. You must |
|||
# make exactly 11 lines for the formatting to be correct. It's also |
|||
# customary to leave one space after the ':'. |
|||
|
|||
|-----handy-ruler------------------------------------------------------| |
|||
lxc: lxc (Linux Containers) |
|||
lxc: |
|||
lxc: Linux Containers (LXC) are an operating system-level virtualization |
|||
lxc: method for running multiple isolated server installs (containers) on |
|||
lxc: a single control host. LXC does not provide a virtual machine, but |
|||
lxc: rather provides a virtual environment that has its own process and |
|||
lxc: network space. It is similar to a chroot, but offers more isolation. |
|||
lxc: |
|||
lxc: Daniel Lezcano is the primary developer of lxc. |
|||
lxc: Homepage: https://linuxcontainers.org |
|||
lxc: |
Loading…
Reference in new issue