aboutsummaryrefslogtreecommitdiffstats
path: root/lsb-bootscripts/etc/init.d/modules
blob: 18febfbc0fcff805b799a6b2ff8423129c43934e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
#!/bin/sh
# Begin /etc/init.d/modules

### BEGIN INIT INFO
# Provides:            modules
# Required-Start:      mountvirtfs sysctl
# Should-Start:
# Required-Stop:
# Should-Stop:
# Default-Start:       S
# Default-Stop:
# Short-Description:   Loads required modules.
# Description:         Loads modules listed in /etc/default/modules.
# X-LFS-Provided-By:   LFS
### END INIT INFO

. /lib/lsb/init-functions

# Assure that the kernel has module support.
[ -e /proc/ksyms -o -e /proc/modules ] || exit 0

case "${1}" in
    start)

        # Exit if there's no modules file or there are no
        # valid entries
        [ -r /etc/default/modules ] &&
            egrep -qv '^($|#)' /etc/default/modules ||
            exit 0

        # If proc is mounted, find the current kernel
        # message level 
        if [ -f /proc/sys/kernel/printk ]; then
            prev_msg=`cat /proc/sys/kernel/printk | \
                sed 'l 1' | sed -n '2~0p' | \
                sed 's/\\\//'`
        else 
            prev_msg="6"
        fi

        # Now set the message level to 1 so not to make too 
        # much noise when loading modules
        dmesg -n 1

        # Only try to load modules if the user has actually given us
        # some modules to load.
        if egrep -qv '^(#|$)' /etc/default/modules 2>/dev/null
        then

            # Read in the configuration file.
            exec 9>&0 < /etc/default/modules

                message="${INFO}Loading modules:"

                while read module args
                do
                    # Ignore comments and blank lines.
                    case "${module}" in
                        ""|\#*) continue ;;
                    esac

                    # Attempt to load the module, making
                    # sure to pass any arguments provided.
                    modprobe ${module} ${args} > /dev/null

                    # Print the module name if successful,
                    # otherwise take note.
                    if [ ${?} -eq 0 ]; then
                        message="${message}${NORMAL} ${module}"
                    else
                        failedmod="${failedmod} ${module}"
                    fi
                done

                # Print a message about successfully loaded
                # modules on the correct line.
                log_success_msg "${message}"

                # Print a failure message with a list of any
                # modules that may have failed to load.
                if [ "${failedmod}" ]; then
                    log_failure_msg "${FAILURE}Failed to load modules:${failedmod}"
                fi

            exec 0>&9 9>&-

        fi
        # Set the kernel message level back to it's previous value.
        dmesg -n "${prev_msg}"
        ;;
    *)
        echo "Usage: ${0} {start}"
        exit 1
        ;;
esac

# End /etc/init.d/modules