forked from perasmo/vstuff
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvisdn-init
executable file
·193 lines (168 loc) · 4.65 KB
/
visdn-init
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
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
#! /bin/sh
# Copyright (c) 2004 Lele Forzani, Windmill Media, <[email protected]>
# All rights reserved.
#
# Author: Lele Forzani
#
# /etc/init.d/visdn
# and its symbolic link
# /sbin/visdn
### BEGIN INIT INFO
# Provides: visdn
# Required-Start: $syslog
# Should-Start:
# Required-Stop: $syslog
# Should-Stop:
# Default-Start: 3 5
# Default-Stop: 0 1 2 6
# Short-Description: vISDN Telephony Interface
# Description: Starts vISDN Telephony Subsystem drivers
# vISDN is an ISDN Subsystem for Linux
#
### END INIT INFO
# Check for missing binaries (stale symlinks should not happen)
# Note: Special treatment of stop for LSB conformance
VISDNCFG_BIN=/usr/sbin/visdn_configurator
test -x $VISDNCFG_BIN || { echo "$VISDNCFG_BIN not installed";
if [ "$1" = "stop" ]; then exit 0;
else exit 5; fi; }
# Check for existence of needed config file and read it
VISDN_CONFIG=/etc/sysconfig/visdn
test -r $VISDN_CONFIG || { echo "$VISDN_CONFIG not existing";
if [ "$1" = "stop" ]; then exit 0;
else exit 6; fi; }
# Read config
. $VISDN_CONFIG
. /etc/rc.status
# Reset status of this service
rc_reset
# Check that telephony is up.
if [ "${TELEPHONY}" = "no" ]; then
exit 0
fi
if [ "${DEBUG}" = "yes" ]; then
ARGS="debug=1"
fi
case "$1" in
start)
echo -n "Starting vISDN Subsystem. "
modprobe visdn-netdev
modprobe visdn-streamport
modprobe visdn-ppp
modprobe visdn-timer-system
modprobe visdn-ec
# Load drivers
echo
echo -n "Loading visdn hardware modules: "
for x in $MODULES; do
if modprobe visdn_${x} ${ARGS} >& /dev/null; then
echo -n "$x "
fi
done
i=0
while [ ! -e /dev/zap/ctl ] && [ $i -lt 50 ]; do
echo -n .
: $((i++))
usleep 200000
done
echo
echo "Configuring visdn "
$VISDNCFG_BIN
# Remember status and be verbose
rc_status -v
;;
stop)
echo -n "Shutting down visdn hardware modules: "
for x in $RMODULES; do
if rmmod visdn_${x} >& /dev/null; then
echo -n "$x "
fi
done
echo
echo -n "Shutting down visdn Subsystem "
rmmod visdn-ec
rmmod visdn-timer-system
rmmod visdn-ppp
rmmod visdn-streamport
rmmod visdn-netdev
rmmod visdn_softcxc
rmmod visdn_core
# Remember status and be verbose
rc_status -v
;;
try-restart|condrestart)
## Do a restart only if the service was active before.
## Note: try-restart is now part of LSB (as of 1.9).
## RH has a similar command named condrestart.
if test "$1" = "condrestart"; then
echo "${attn} Use try-restart ${done}(LSB)${attn} rather than condrestart ${warn}(RH)${norm}"
fi
$0 status
if test $? = 0; then
$0 restart
else
rc_reset # Not running is not a failure.
fi
# Remember status and be quiet
rc_status
;;
restart)
## Stop the service and regardless of whether it was
## running or not, start it again.
$0 stop
$0 start
# Remember status and be quiet
rc_status
;;
force-reload)
## Signal the daemon to reload its config. Most daemons
## do this on signal 1 (SIGHUP).
## If it does not support it, restart.
echo -n "Reload service zaptel "
## if it supports it:
$VISDNCFG_BIN
rc_status -v
## Otherwise:
#$0 try-restart
#rc_status
;;
reload)
## Like force-reload, but if daemon does not support
## signaling, do nothing (!)
# If it supports signaling:
echo -n "Reload service zaptel "
$VISDNCFG_BIN
rc_status -v
## Otherwise if it does not support reload:
#rc_failed 3
#rc_status -v
;;
status)
echo -n "Checking for service FOO "
## Check status with checkproc(8), if process is running
## checkproc will return with exit status 0.
# Return value is slightly different for the status command:
# 0 - service up and running
# 1 - service dead, but /var/run/ pid file exists
# 2 - service dead, but /var/lock/ lock file exists
# 3 - service not running (unused)
# 4 - service status unknown :-(
# 5--199 reserved (5--99 LSB, 100--149 distro, 150--199 appl.)
# NOTE: checkproc returns LSB compliant status values.
#checkproc $FOO_BIN
# NOTE: rc_status knows that we called this init script with
# "status" option and adapts its messages accordingly.
rc_status -v
;;
probe)
## Optional: Probe for the necessity of a reload, print out the
## argument to this init script which is required for a reload.
## Note: probe is not (yet) part of LSB (as of 1.9)
#test /etc/zaptel.conf -nt /var/run/FOO.pid && echo reload
;;
*)
echo "Usage: $0 {start|stop|status|try-restart|restart|force-reload|reload|probe}"
exit 1
;;
esac
rc_exit