fhdl: allow use of ResetSignal() on resetless clock domains

This commit is contained in:
Sebastien Bourdeauducq 2015-07-27 01:51:52 +08:00
parent 5a535ef347
commit cc6877df9e
2 changed files with 14 additions and 2 deletions

View file

@ -327,10 +327,14 @@ class ResetSignal(Value):
----------
cd : str
Clock domain to obtain a reset signal for. Defaults to `"sys"`.
allow_resetless : bool
If the clock domain is resetless, return 0 instead of reporting an
error.
"""
def __init__(self, cd="sys"):
def __init__(self, cd="sys", allow_resetless=False):
Value.__init__(self)
self.cd = cd
self.allow_resetless = allow_resetless
# statements

View file

@ -191,7 +191,15 @@ class _BasicLowerer(_Lowerer):
return self.clock_domains[node.cd].clk
def visit_ResetSignal(self, node):
return self.clock_domains[node.cd].rst
rst = self.clock_domains[node.cd].rst
if rst is None:
if node.allow_resetless:
return 0
else:
raise ValueError("Attempted to get reset signal of resetless"
" domain '{}'".format(node.cd))
else:
return rst
class _ComplexSliceLowerer(_Lowerer):