From: whitequark Date: Wed, 26 Aug 2020 03:19:13 +0000 (+0000) Subject: lib.cdc: in AsyncFFSynchronizer(), rename domain= to o_domain=. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=0802f943ba5c0919b07659c3cad4da14c32f3264;p=nmigen.git lib.cdc: in AsyncFFSynchronizer(), rename domain= to o_domain=. This is for consistency with other synchronizers. Fixes #467. --- diff --git a/nmigen/lib/cdc.py b/nmigen/lib/cdc.py index 698534b..233483a 100644 --- a/nmigen/lib/cdc.py +++ b/nmigen/lib/cdc.py @@ -109,7 +109,7 @@ class AsyncFFSynchronizer(Elaboratable): Asynchronous input signal, to be synchronized. o : Signal(1), out Synchronously released output signal. - domain : str + o_domain : str Name of clock domain to synchronize to. stages : int, >=2 Number of synchronization stages between input and output. The lowest safe number is 2, @@ -125,13 +125,13 @@ class AsyncFFSynchronizer(Elaboratable): Define the ``get_async_ff_sync`` platform method to override the implementation of :class:`AsyncFFSynchronizer`, e.g. to instantiate library cells directly. """ - def __init__(self, i, o, *, domain="sync", stages=2, async_edge="pos", max_input_delay=None): + def __init__(self, i, o, *, o_domain="sync", stages=2, async_edge="pos", max_input_delay=None): _check_stages(stages) self.i = i self.o = o - self._domain = domain + self._o_domain = o_domain self._stages = stages if async_edge not in ("pos", "neg"): @@ -164,7 +164,7 @@ class AsyncFFSynchronizer(Elaboratable): m.d.comb += ResetSignal("async_ff").eq(~self.i) m.d.comb += [ - ClockSignal("async_ff").eq(ClockSignal(self._domain)), + ClockSignal("async_ff").eq(ClockSignal(self._o_domain)), self.o.eq(flops[-1]) ] @@ -212,7 +212,7 @@ class ResetSynchronizer(Elaboratable): self._max_input_delay = max_input_delay def elaborate(self, platform): - return AsyncFFSynchronizer(self.arst, ResetSignal(self._domain), domain=self._domain, + return AsyncFFSynchronizer(self.arst, ResetSignal(self._domain), o_domain=self._domain, stages=self._stages, max_input_delay=self._max_input_delay) diff --git a/nmigen/lib/fifo.py b/nmigen/lib/fifo.py index d94012f..fa5b265 100644 --- a/nmigen/lib/fifo.py +++ b/nmigen/lib/fifo.py @@ -413,10 +413,10 @@ class AsyncFIFO(Elaboratable, FIFOInterface): # full discussion. w_rst = ResetSignal(domain=self._w_domain, allow_reset_less=True) r_rst = Signal() - + # Async-set-sync-release synchronizer avoids CDC hazards rst_cdc = m.submodules.rst_cdc = \ - AsyncFFSynchronizer(w_rst, r_rst, domain=self._r_domain) + AsyncFFSynchronizer(w_rst, r_rst, o_domain=self._r_domain) # Decode Gray code counter synchronized from write domain to overwrite binary # counter in read domain. diff --git a/nmigen/test/test_lib_cdc.py b/nmigen/test/test_lib_cdc.py index 5a169ac..3647bfa 100644 --- a/nmigen/test/test_lib_cdc.py +++ b/nmigen/test/test_lib_cdc.py @@ -66,7 +66,7 @@ class AsyncFFSynchronizerTestCase(FHDLTestCase): def test_edge_wrong(self): with self.assertRaisesRegex(ValueError, r"^AsyncFFSynchronizer async edge must be one of 'pos' or 'neg', not 'xxx'$"): - AsyncFFSynchronizer(Signal(), Signal(), domain="sync", async_edge="xxx") + AsyncFFSynchronizer(Signal(), Signal(), o_domain="sync", async_edge="xxx") def test_pos_edge(self): i = Signal() diff --git a/nmigen/vendor/intel.py b/nmigen/vendor/intel.py index 19a54da..92157f6 100644 --- a/nmigen/vendor/intel.py +++ b/nmigen/vendor/intel.py @@ -402,7 +402,7 @@ class IntelPlatform(TemplatedPlatform): if async_ff_sync._edge == "pos": m.submodules += Instance("altera_std_synchronizer", p_depth=async_ff_sync._stages, - i_clk=ClockSignal(async_ff_sync._domain), + i_clk=ClockSignal(async_ff_sync._o_domain), i_reset_n=~async_ff_sync.i, i_din=Const(1), o_dout=sync_output, @@ -410,7 +410,7 @@ class IntelPlatform(TemplatedPlatform): else: m.submodules += Instance("altera_std_synchronizer", p_depth=async_ff_sync._stages, - i_clk=ClockSignal(async_ff_sync._domain), + i_clk=ClockSignal(async_ff_sync._o_domain), i_reset_n=async_ff_sync.i, i_din=Const(1), o_dout=sync_output, diff --git a/nmigen/vendor/xilinx_7series.py b/nmigen/vendor/xilinx_7series.py index 800b528..5c35469 100644 --- a/nmigen/vendor/xilinx_7series.py +++ b/nmigen/vendor/xilinx_7series.py @@ -613,7 +613,7 @@ class Xilinx7SeriesPlatform(TemplatedPlatform): m.d.comb += ResetSignal("async_ff").eq(~async_ff_sync.i) m.d.comb += [ - ClockSignal("async_ff").eq(ClockSignal(async_ff_sync._domain)), + ClockSignal("async_ff").eq(ClockSignal(async_ff_sync._o_domain)), async_ff_sync.o.eq(flops[-1]) ] diff --git a/nmigen/vendor/xilinx_spartan_3_6.py b/nmigen/vendor/xilinx_spartan_3_6.py index 745dd54..9b10733 100644 --- a/nmigen/vendor/xilinx_spartan_3_6.py +++ b/nmigen/vendor/xilinx_spartan_3_6.py @@ -456,7 +456,7 @@ class XilinxSpartan3Or6Platform(TemplatedPlatform): m.d.comb += ResetSignal("async_ff").eq(~async_ff_sync.i) m.d.comb += [ - ClockSignal("async_ff").eq(ClockSignal(async_ff_sync._domain)), + ClockSignal("async_ff").eq(ClockSignal(async_ff_sync._o_domain)), async_ff_sync.o.eq(flops[-1]) ] diff --git a/nmigen/vendor/xilinx_ultrascale.py b/nmigen/vendor/xilinx_ultrascale.py index 3a74d54..937b346 100644 --- a/nmigen/vendor/xilinx_ultrascale.py +++ b/nmigen/vendor/xilinx_ultrascale.py @@ -429,7 +429,7 @@ class XilinxUltraScalePlatform(TemplatedPlatform): m.d.comb += ResetSignal("async_ff").eq(~async_ff_sync.i) m.d.comb += [ - ClockSignal("async_ff").eq(ClockSignal(async_ff_sync._domain)), + ClockSignal("async_ff").eq(ClockSignal(async_ff_sync._o_domain)), async_ff_sync.o.eq(flops[-1]) ]