mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
merge migen ee0e709 changes
This commit is contained in:
parent
c6f6d7b491
commit
fe535db5ab
1 changed files with 11 additions and 10 deletions
|
@ -19,7 +19,8 @@ class MultiRegImpl(Module):
|
|||
self.odomain = odomain
|
||||
|
||||
w, signed = value_bits_sign(self.i)
|
||||
self.regs = [Signal((w, signed)) for i in range(n)]
|
||||
self.regs = [Signal((w, signed), reset_less=True)
|
||||
for i in range(n)]
|
||||
|
||||
###
|
||||
|
||||
|
@ -67,9 +68,9 @@ class PulseSynchronizer(Module):
|
|||
|
||||
###
|
||||
|
||||
toggle_i = Signal()
|
||||
toggle_o = Signal()
|
||||
toggle_o_r = Signal()
|
||||
toggle_i = Signal(reset_less=True)
|
||||
toggle_o = Signal() # registered reset_less by MultiReg
|
||||
toggle_o_r = Signal(reset_less=True)
|
||||
|
||||
sync_i = getattr(self.sync, idomain)
|
||||
sync_o = getattr(self.sync, odomain)
|
||||
|
@ -88,7 +89,7 @@ class BusSynchronizer(Module):
|
|||
``MultiReg``)."""
|
||||
def __init__(self, width, idomain, odomain, timeout=128):
|
||||
self.i = Signal(width)
|
||||
self.o = Signal(width)
|
||||
self.o = Signal(width, reset_less=True)
|
||||
|
||||
if width == 1:
|
||||
self.specials += MultiReg(self.i, self.o, odomain)
|
||||
|
@ -108,8 +109,8 @@ class BusSynchronizer(Module):
|
|||
self._pong.i.eq(self._ping.i)
|
||||
]
|
||||
|
||||
ibuffer = Signal(width)
|
||||
obuffer = Signal(width)
|
||||
ibuffer = Signal(width, reset_less=True)
|
||||
obuffer = Signal(width) # registered reset_less by MultiReg
|
||||
sync_i += If(self._pong.o, ibuffer.eq(self.i))
|
||||
ibuffer.attr.add("no_retiming")
|
||||
self.specials += MultiReg(ibuffer, obuffer, odomain)
|
||||
|
@ -143,7 +144,7 @@ class GrayCounter(Module):
|
|||
class GrayDecoder(Module):
|
||||
def __init__(self, width):
|
||||
self.i = Signal(width)
|
||||
self.o = Signal(width)
|
||||
self.o = Signal(width, reset_less=True)
|
||||
|
||||
# # #
|
||||
|
||||
|
@ -206,7 +207,7 @@ def lcm(a, b):
|
|||
class Gearbox(Module):
|
||||
def __init__(self, iwidth, idomain, owidth, odomain):
|
||||
self.i = Signal(iwidth)
|
||||
self.o = Signal(owidth)
|
||||
self.o = Signal(owidth, reset_less=True)
|
||||
|
||||
# # #
|
||||
|
||||
|
@ -224,7 +225,7 @@ class Gearbox(Module):
|
|||
]
|
||||
self.clock_domains += cd_write, cd_read
|
||||
|
||||
storage = Signal(2*lcm(iwidth, owidth))
|
||||
storage = Signal(2*lcm(iwidth, owidth), reset_less=True)
|
||||
wrchunks = len(storage)//iwidth
|
||||
rdchunks = len(storage)//owidth
|
||||
wrpointer = Signal(max=wrchunks, reset=0 if iwidth > owidth else wrchunks//2)
|
||||
|
|
Loading…
Reference in a new issue