summaryrefslogtreecommitdiff
path: root/init.d/modules.in
diff options
context:
space:
mode:
authorRoy Marples <roy@marples.name>2008-03-25 14:06:05 +0000
committerRoy Marples <roy@marples.name>2008-03-25 14:06:05 +0000
commit55eb3794fb4ad563102d5ab30c1d5337a599b2e5 (patch)
tree0d052faeb050c1e18ba56f6f6189bff3ffca28c9 /init.d/modules.in
parent08aff6ef44ac5dc438d916b53aa61385f6d299f3 (diff)
downloadopenrc-55eb3794fb4ad563102d5ab30c1d5337a599b2e5.tar.gz
openrc-55eb3794fb4ad563102d5ab30c1d5337a599b2e5.tar.bz2
openrc-55eb3794fb4ad563102d5ab30c1d5337a599b2e5.tar.xz
Rework our folder structure so that we don't have OS specific dirs, making it easier to share init and conf files per OS.
Diffstat (limited to 'init.d/modules.in')
-rw-r--r--init.d/modules.in59
1 files changed, 59 insertions, 0 deletions
diff --git a/init.d/modules.in b/init.d/modules.in
new file mode 100644
index 0000000..1a0c745
--- /dev/null
+++ b/init.d/modules.in
@@ -0,0 +1,59 @@
+#!@PREFIX@/sbin/runscript
+# Copyright 2007-2008 Roy Marples <roy@marples.name>
+# All rights reserved. Released under the 2-clause BSD license.
+
+description="Loads a user defined list of kernel modules."
+
+depend()
+{
+ use isapnp
+ keyword noopenvz noprefix novserver
+}
+
+start()
+{
+ # Should not fail if kernel do not have module
+ # support compiled in ...
+ [ ! -f /proc/modules ] && return 0
+
+ local KV=$(uname -r)
+ local KV_MAJOR=${KV%%.*}
+ local x=${KV#*.}
+ local KV_MINOR=${x%%.*}
+ x=${KV#*.*.}
+ local KV_MICRO=${x%%-*}
+
+ local list= x= xx= y= args= cnt=0
+ for x in "${KV}" \
+ ${KV_MAJOR}.${KV_MINOR}.${KV_MICRO} \
+ ${KV_MAJOR}.${KV_MINOR} \
+ ; do
+ eval list=\$modules_$(shell_var "${x}")
+ [ -n "${list}" ] && break
+ done
+ [ -z "${list}" ] && list=${modules}
+
+ for x in ${list}; do
+ ebegin "Loading module ${x}"
+ xx=$(shell_var "${x}")
+ for y in "${KV}" \
+ ${KV_MAJOR}.${KV_MINOR}.${KV_MICRO} \
+ ${KV_MAJOR}.${KV_MINOR} \
+ ; do
+ eval args=\$module_${xx}_args_$(shell_var "${y}")
+ [ -n "${args}" ] && break
+ done
+ done
+ [ -z "${args}" ] && eval args=\$module_${xx}_args
+ eval modprobe -q "${x}" "${args}"
+ eend $? "Failed to load ${x}" && cnt=$((${cnt} + 1))
+ done
+ einfo "Autoloaded ${cnt} module(s)"
+
+ # Just in case a sysadmin prefers generic symbolic links in
+ # /lib/modules/boot for boot time modules we will load these modules
+ [ -n "$(modprobe -l -t boot)" ] && modprobe -a -t boot \* 2>/dev/null
+
+ # Above test clobbers the return
+ return 0
+}