@@ -15,7 +15,7 @@
import atexit
import os
import signal
-
+import sys
import ovs.vlog
_hooks = []
@@ -134,3 +134,25 @@ def _init():
if signal.getsignal(signr) == signal.SIG_DFL:
signal.signal(signr, _signal_handler)
atexit.register(_atexit_handler)
+
+
+def signal_alarm(timeout):
+ if sys.platform == "win32":
+ import os
+ import time
+ import threading
+
+ class Alarm (threading.Thread):
+ def __init__(self, timeout):
+ super(Alarm, self).__init__()
+ self.timeout = timeout
+ self.setDaemon(True)
+
+ def run(self):
+ time.sleep(self.timeout)
+ os._exit(1)
+
+ alarm = Alarm(timeout)
+ alarm.start()
+ else:
+ signal.alarm(timeout)
@@ -13,7 +13,6 @@
# limitations under the License.
import argparse
-import signal
import sys
import ovs.daemon
@@ -21,6 +20,7 @@ import ovs.unixctl
import ovs.unixctl.client
import ovs.util
import ovs.vlog
+from ovs.fatal_signal import signal_alarm
def connect_to_target(target):
@@ -52,7 +52,7 @@ def main():
args = parser.parse_args()
if args.timeout:
- signal.alarm(int(args.timeout))
+ signal_alarm(int(args.timeout))
ovs.vlog.Vlog.init()
target = args.target
@@ -17,7 +17,6 @@ from __future__ import print_function
import getopt
import re
import os
-import signal
import sys
import uuid
@@ -29,6 +28,7 @@ import ovs.db.types
import ovs.ovsuuid
import ovs.poller
import ovs.util
+from ovs.fatal_signal import signal_alarm
import six
@@ -647,7 +647,7 @@ def main(argv):
except TypeError:
raise error.Error("value %s on -t or --timeout is not at "
"least 1" % value)
- signal.alarm(timeout)
+ signal_alarm(timeout)
else:
sys.exit(0)
@@ -19,6 +19,7 @@ import socket
import sys
import ovs.socket_util
+from ovs.fatal_signal import signal_alarm
def main(argv):
@@ -33,7 +34,7 @@ def main(argv):
sockname2 = sockname1
signal.signal(signal.SIGALRM, signal.SIG_DFL)
- signal.alarm(5)
+ signal_alarm(5)
# Create a listening socket under name 'sockname1'.
error, sock1 = ovs.socket_util.make_unix_socket(socket.SOCK_STREAM, False,