mirror of
https://github.com/YosysHQ/yosys
synced 2025-10-24 00:14:36 +00:00
Gate POSIX-only signals and resource module to only run on POSIX Python implementations.
This commit is contained in:
parent
8b92ddb9d2
commit
0caa62802c
1 changed files with 12 additions and 9 deletions
|
@ -17,7 +17,9 @@
|
||||||
#
|
#
|
||||||
|
|
||||||
import sys, re, os, signal
|
import sys, re, os, signal
|
||||||
import resource, subprocess
|
import subprocess
|
||||||
|
if os.name == "posix":
|
||||||
|
import resource
|
||||||
from copy import deepcopy
|
from copy import deepcopy
|
||||||
from select import select
|
from select import select
|
||||||
from time import time
|
from time import time
|
||||||
|
@ -27,12 +29,13 @@ from threading import Thread
|
||||||
|
|
||||||
# This is needed so that the recursive SMT2 S-expression parser
|
# This is needed so that the recursive SMT2 S-expression parser
|
||||||
# does not run out of stack frames when parsing large expressions
|
# does not run out of stack frames when parsing large expressions
|
||||||
smtio_reclimit = 64 * 1024
|
if os.name == "posix":
|
||||||
smtio_stacksize = 128 * 1024 * 1024
|
smtio_reclimit = 64 * 1024
|
||||||
if sys.getrecursionlimit() < smtio_reclimit:
|
smtio_stacksize = 128 * 1024 * 1024
|
||||||
sys.setrecursionlimit(smtio_reclimit)
|
if sys.getrecursionlimit() < smtio_reclimit:
|
||||||
if resource.getrlimit(resource.RLIMIT_STACK)[0] < smtio_stacksize:
|
sys.setrecursionlimit(smtio_reclimit)
|
||||||
resource.setrlimit(resource.RLIMIT_STACK, (smtio_stacksize, -1))
|
if resource.getrlimit(resource.RLIMIT_STACK)[0] < smtio_stacksize:
|
||||||
|
resource.setrlimit(resource.RLIMIT_STACK, (smtio_stacksize, -1))
|
||||||
|
|
||||||
|
|
||||||
# currently running solvers (so we can kill them)
|
# currently running solvers (so we can kill them)
|
||||||
|
@ -51,8 +54,9 @@ def force_shutdown(signum, frame):
|
||||||
os.kill(p.pid, signal.SIGTERM)
|
os.kill(p.pid, signal.SIGTERM)
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
|
if os.name == "posix":
|
||||||
|
signal.signal(signal.SIGHUP, force_shutdown)
|
||||||
signal.signal(signal.SIGINT, force_shutdown)
|
signal.signal(signal.SIGINT, force_shutdown)
|
||||||
signal.signal(signal.SIGHUP, force_shutdown)
|
|
||||||
signal.signal(signal.SIGTERM, force_shutdown)
|
signal.signal(signal.SIGTERM, force_shutdown)
|
||||||
|
|
||||||
def except_hook(exctype, value, traceback):
|
def except_hook(exctype, value, traceback):
|
||||||
|
@ -1053,4 +1057,3 @@ class MkVcd:
|
||||||
print("b0 %s" % self.nets[path][0], file=self.f)
|
print("b0 %s" % self.nets[path][0], file=self.f)
|
||||||
else:
|
else:
|
||||||
print("b1 %s" % self.nets[path][0], file=self.f)
|
print("b1 %s" % self.nets[path][0], file=self.f)
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue