ovsdb: Fix double free in ovsdb_file_open_log().
[openvswitch] / debian / openvswitch-switch.init
1 #! /bin/sh
2 #
3 # /etc/init.d/openvswitch-switch
4 #
5 # Written by Miquel van Smoorenburg <miquels@cistron.nl>.
6 # Modified for Debian by Ian Murdock <imurdock@gnu.ai.mit.edu>.
7 # Further changes by Javier Fernandez-Sanguino <jfs@debian.org>
8 # Modified for openvswitch-switch.
9 #
10 # Version:      @(#)skeleton  1.9  26-Feb-2001  miquels@cistron.nl
11 #
12 ### BEGIN INIT INFO
13 # Provides:          openvswitch-switch
14 # Required-Start:    $network $named $remote_fs $syslog
15 # Required-Stop:     $remote_fs
16 # Default-Start:     2 3 4 5
17 # Default-Stop:      0 1 6
18 # Short-Description: Open vSwitch switch
19 ### END INIT INFO
20
21 PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
22 ovs_vswitchd=/usr/sbin/ovs-vswitchd
23 ovsdb_server=/usr/bin/ovsdb-server
24
25 (test -x $ovsdb_server && test -x $ovs_vswitchd) || exit 0
26
27 DODTIME=1                   # Time to wait for the server to die, in seconds
28                             # If this value is set too low you might not
29                             # let some servers to die gracefully and
30                             # 'restart' will not work
31
32 # Include openvswitch-switch defaults if available
33 unset OVSDB_SERVER_OPTS
34 unset OVS_VSWITCHD_OPTS
35 unset CORE_LIMIT
36 unset ENABLE_MONITOR
37 default=/etc/default/openvswitch-switch
38 if [ -f $default ] ; then
39     . $default
40 fi
41
42 : ${ENABLE_MONITOR:=y}
43
44 set -e
45
46 # running_pid pid name
47 #
48 # Check if 'pid' is a process named 'name'
49 running_pid()
50 {
51     local pid=$1 name=$2
52     [ -z "$pid" ] && return 1 
53     [ ! -d /proc/$pid ] &&  return 1
54     cmd=`cat /proc/$pid/cmdline | tr "\000" "\n"|head -n 1 |cut -d : -f 1`
55     # Is this the expected child?
56     case $cmd in
57         $name|*/$name)
58             return 0
59             ;;
60         *)
61             return 1
62             ;;
63     esac
64 }
65
66 # running name
67 #
68 # Checks for a running process named 'name' by looking for a pidfile
69 # named /var/run/openvswitch/${name}.pid
70 running()
71 {
72     local name=$1
73     local pidfile=/var/run/openvswitch/${name}.pid
74
75     # No pidfile, probably no daemon present
76     [ ! -f "$pidfile" ] && return 1
77
78     # Obtain the pid and check it against the binary name
79     pid=`cat $pidfile`
80     running_pid $pid $name || return 1
81     return 0
82 }
83
84 # force_stop name
85 #
86 # Checks for a running process named 'name', by looking for a pidfile
87 # named /var/run/openvswitch/${name}.pid, and then kills it and waits 
88 # for it to die.
89 force_stop() {
90     local name=$1
91     local pidfile=/var/run/openvswitch/${name}.pid
92
93     [ ! -f "$pidfile" ] && return
94     if running $name; then
95         kill $pid
96         [ -n "$DODTIME" ] && sleep "$DODTIME"
97         if running $name; then
98             kill -KILL $pid
99             [ -n "$DODTIME" ] && sleep "$DODTIME"
100             if running $name; then
101                 echo "Cannot kill $name (pid=$pid)!"
102                 exit 1
103             fi
104         fi
105     fi
106     rm -f $pidfile
107     return 0
108 }
109
110 must_succeed() {
111     echo -n "$1: "
112     shift
113     if "$@"; then
114         echo "success."
115     else
116         echo " ERROR."
117         exit 1
118     fi
119 }
120
121 check_op() {
122     echo -n "$1: "
123     shift
124     if "$@"; then
125         echo "success."
126     else
127         echo " ERROR."
128     fi
129 }
130
131 # is_module_loaded module
132 #
133 # Returns 0 if 'module' is loaded, 1 otherwise.
134
135 is_module_loaded() {
136     local module=$1
137     grep -q "^$module " /proc/modules
138 }
139
140 # load_module module
141 #
142 # Loads 'module' into the running kernel, if it is not already loaded.
143 load_module() {
144     local module=$1
145     echo -n "Loading $module: "
146     if is_module_loaded $module; then
147         echo "already loaded, nothing to do."
148     elif modprobe $module; then
149         echo "success."
150     else
151         echo "ERROR."
152         echo "$module has probably not been built for this kernel."
153         if ! test -d /usr/share/doc/openvswitch-datapath-source; then
154             echo "Install the openvswitch-datapath-source package, then read"
155             echo "/usr/share/doc/openvswitch-datapath-source/README.Debian"
156         else
157             echo "For instructions, read"
158             echo "/usr/share/doc/openvswitch-datapath-source/README.Debian"
159         fi
160         exit 0
161     fi
162 }
163
164 # unload_module module
165 #
166 # Unloads 'module' from the running kernel, if it is loaded.
167 unload_module() {
168     local module=$1
169     echo -n "Unloading $module: "
170     if is_module_loaded $module; then
171         if rmmod $module; then
172             echo "success."
173         else
174             echo "ERROR."
175             exit 1
176         fi
177     else
178         echo "not loaded, nothing to do."
179     fi
180 }
181
182 unload_modules() {
183     if is_module_loaded openvswitch_mod; then
184         for dp in $(ovs-dpctl dump-dps); do
185             echo -n "Deleting datapath $dp: "
186             if ovs-dpctl del-dp $dp; then
187                 echo "success."
188             else
189                 echo "ERROR."
190             fi
191         done
192     fi
193     unload_module openvswitch_mod
194 }
195
196 set_system_info() {
197     ovs_version=`ovs-vswitchd --version | sed 's/.*) //;1q'`
198     ovs-vsctl --no-wait --timeout=5 set Open_vSwitch . \
199         ovs-version="$ovs_version"
200
201     if (lsb_release --id) >/dev/null 2>&1; then
202         system_type=`lsb_release --id -s`
203         system_release=`lsb_release --release -s`
204         system_codename=`lsb_release --codename -s`
205         system_version="${system_release}-${system_codename}"
206
207         ovs-vsctl --no-wait --timeout=5 set Open_vSwitch . \
208             system-type="$system_type" \
209             system-version="$system_version"
210     fi
211 }
212
213 case "$1" in
214     start)
215         conf_file=/etc/openvswitch/conf.db
216         schema_file=/usr/share/openvswitch/vswitch.ovsschema
217         schema_ver=`ovsdb-tool schema-version "$schema_file"`
218
219         load_module openvswitch_mod
220
221         if test -n "$CORE_LIMIT"; then
222             check_op "Setting core limit to $CORE_LIMIT" ulimit -c "$CORE_LIMIT"
223         fi
224
225         # Create an empty configuration database if it doesn't exist.
226         if test ! -e $conf_file; then
227             # Create configuration database.
228             ovsdb-tool -vANY:console:emer create $conf_file $schema_file
229         elif test "X`ovsdb-tool needs-conversion $conf_file $schema_file`" != Xno; then
230             # Back up the old version.
231             version=`ovsdb-tool db-version "$conf_file"`
232             cksum=`ovsdb-tool db-cksum "$conf_file" | awk '{print $1}'`
233             cp "$conf_file" "$conf_file.backup$version-$cksum"
234             
235             # Upgrade or downgrade schema and compact database.
236             ovsdb-tool -vANY:console:emer convert $conf_file $schema_file
237         fi
238
239         if test "$ENABLE_MONITOR" = y; then
240             monitor_opt=--monitor
241         else
242             monitor_opt=
243         fi
244
245         if [ ! -d /var/run/openvswitch ]; then
246             install -d -m 755 -o root -g root /var/run/openvswitch
247         fi
248
249         if [ ! -d /var/log/openvswitch ]; then
250             install -d -m 755 -o root -g root /var/log/openvswitch
251         fi
252
253         if [ ! -d /var/log/openvswitch/cores ]; then
254             install -d -m 755 -o root -g root /var/log/openvswitch/cores
255         fi
256
257         # Start ovsdb-server.
258         set --
259         set -- "$@" $conf_file
260         set -- "$@" --verbose=ANY:console:emer --verbose=ANY:syslog:err
261         set -- "$@" --log-file=/var/log/openvswitch/ovsdb-server.log
262         set -- "$@" --detach --no-chdir --pidfile $monitor_opt
263         set -- "$@" --remote punix:/var/run/openvswitch/db.sock
264         set -- "$@" --remote db:Open_vSwitch,manager_options
265         set -- "$@" --private-key=db:SSL,private_key
266         set -- "$@" --certificate=db:SSL,certificate
267         set -- "$@" --bootstrap-ca-cert=db:SSL,ca_cert
268         set -- "$@" $OVSDB_SERVER_OPTS
269         echo -n "Starting ovsdb-server: "
270         start-stop-daemon --start --quiet --oknodo \
271             --pidfile /var/run/openvswitch/ovsdb-server.pid \
272             --chdir /var/log/openvswitch/cores              \
273             --exec $ovsdb_server -- "$@"
274         if running ovsdb-server; then
275             echo "ovsdb-server."
276         else
277             echo " ERROR."
278         fi
279
280         ovs-vsctl --no-wait --timeout=5 init -- set Open_vSwitch . db-version="$schema_ver"
281
282         set_system_info
283
284         # Start ovs-vswitchd.
285         set --
286         set -- "$@" --verbose=ANY:console:emer --verbose=ANY:syslog:err
287         set -- "$@" --log-file=/var/log/openvswitch/ovs-vswitchd.log
288         set -- "$@" --detach --no-chdir --pidfile $monitor_opt
289         set -- "$@" unix:/var/run/openvswitch/db.sock
290         set -- "$@" $OVS_VSWITCHD_OPTS
291         echo -n "Starting ovs-vswitchd: "
292         start-stop-daemon --start --quiet --oknodo \
293             --pidfile /var/run/openvswitch/ovs-vswitchd.pid \
294             --chdir /var/log/openvswitch/cores              \
295             --exec $ovs_vswitchd -- "$@"
296         if running ovs-vswitchd; then
297             echo "ovs-vswitchd."
298         else
299             echo " ERROR."
300         fi
301         ;;
302     stop)
303         echo -n "Stopping ovs-vswitchd: "
304         start-stop-daemon --stop --quiet --oknodo --retry 5 \
305             --pidfile /var/run/openvswitch/ovs-vswitchd.pid \
306             --chdir /var/log/openvswitch/cores              \
307             --exec $ovs_vswitchd
308         echo "ovs-vswitchd."
309
310         echo -n "Stopping ovsdb-server: "
311         start-stop-daemon --stop --quiet --oknodo --retry 5 \
312             --pidfile /var/run/openvswitch/ovsdb-server.pid \
313             --chdir /var/log/openvswitch/cores              \
314             --exec $ovsdb_server
315         echo "ovsdb-server."
316         ;;
317     force-stop)
318         echo -n "Forcefully stopping ovs-vswitchd: "
319         force_stop ovs-vswitchd
320         if ! running ovs-vswitchd; then
321             echo "ovs-vswitchd."
322         else
323             echo " ERROR."
324         fi
325
326         echo -n "Forcefully stopping ovsdb-server: "
327         force_stop ovsdb-server
328         if ! running ovsdb-server; then
329             echo "ovsdb-server."
330         else
331             echo " ERROR."
332         fi
333         ;;
334     unload)
335         unload_modules
336         ;;
337     reload)
338         ;;
339     force-reload)
340         # Nothing to do, since ovs-vswitchd automatically reloads
341         # whenever its configuration changes, and ovsdb-server doesn't
342         # have anything to reload.
343         ;;
344     restart)
345         $0 stop || true
346         $0 start
347         ;;
348     status)
349         for daemon in ovs-vswitchd ovsdb-server; do
350             echo -n "$daemon is "
351             if running $daemon;  then
352                 echo "running"
353             else
354                 echo "not running."
355                 exit 1
356             fi
357         done
358         ;;
359     *)
360         N=/etc/init.d/openvswitch-switch
361         echo "Usage: $N {start|stop|restart|force-reload|status|force-stop|unload}" >&2
362         exit 1
363         ;;
364 esac
365
366 exit 0