#!@PREFIX@/sbin/runscript # Copyright (c) 2007-2009 Roy Marples # Released under the 2-clause BSD license. description="Mount the sys filesystem." depend() { keyword -prefix -vserver } mount_sys() { grep -Eq "[[:space:]]+sysfs$" /proc/filesystems || return 1 mountinfo -q /sys && return 0 if [ ! -d /sys ]; then if ! mkdir -m 0755 /sys; then ewarn "Could not create /sys!" return 1 fi fi ebegin "Mounting /sys" if ! fstabinfo --mount /sys; then mount -n -t sysfs -o noexec,nosuid,nodev sysfs /sys fi eend $? } mount_misc() { # Setup Kernel Support for securityfs if [ -d /sys/kernel/security ] && \ ! mountinfo -q /sys/kernel/security; then if grep -qs securityfs /proc/filesystems; then ebegin "Mounting security filesystem" mount -n -t securityfs -o nodev,noexec,nosuid \ securityfs /sys/kernel/security eend $? fi fi # Setup Kernel Support for debugfs if [ -d /sys/kernel/debug ] && ! mountinfo -q /sys/kernel/debug; then if grep -qs debugfs /proc/filesystems; then ebegin "Mounting debug filesystem" mount -n -t debugfs -o nodev,noexec,nosuid \ debugfs /sys/kernel/debug eend $? fi fi # Setup Kernel Support for configfs if [ -d /sys/kernel/config ] && ! mountinfo -q /sys/kernel/config; then if grep -qs configfs /proc/filesystems; then ebegin "Mounting config filesystem" mount -n -t configfs -o nodev,noexec,nosuid \ configfs /sys/kernel/config eend $? fi fi # Setup Kernel Support for cgroup if [ -d /sys/fs/cgroup ]; then if grep -qs cgroup /proc/filesystems && \ ! mountinfo -q /sys/fs/cgroup; then ebegin "Mounting cgroup filesystem" mount -n -t tmpfs -o nodev,noexec,nosuid \ cgroup /sys/fs/cgroup eend $? fi if ! mountinfo -q /sys/fs/cgroup/openrc; then ebegin "creating openrc control group" mkdir /sys/fs/cgroup/openrc mount -n -t cgroup -o nodev,noexec,nosuid \ openrc /sys/fs/cgroup/openrc echo 1 > /sys/fs/cgroup/openrc/notify_on_release echo @LIBEXECDIR@/sh/cgroup-release-agent.sh \ > /sys/fs/cgroup/openrc/release_agent eend fi fi } start() { local retval mount_sys retval=$? if [ $retval -eq 0 ]; then mount_misc fi return $retval }