mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
fhdl: allow use of ResetSignal() on resetless clock domains
This commit is contained in:
parent
5a535ef347
commit
cc6877df9e
2 changed files with 14 additions and 2 deletions
|
@ -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
|
||||
|
||||
|
|
|
@ -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):
|
||||
|
|
Loading…
Reference in a new issue