From f2f942a8b4eb18a38a87c133181238aa2e91365d Mon Sep 17 00:00:00 2001 From: hartytp Date: Tue, 6 Oct 2020 15:59:05 +0100 Subject: [PATCH] wrpll.ddmtd: remove CSRs from DDMTD We will gather then from the collector output so we can get all tags on the same cycle --- artiq/gateware/drtio/wrpll/ddmtd.py | 22 +--------------------- 1 file changed, 1 insertion(+), 21 deletions(-) diff --git a/artiq/gateware/drtio/wrpll/ddmtd.py b/artiq/gateware/drtio/wrpll/ddmtd.py index 0ed3de69f..7f13134de 100644 --- a/artiq/gateware/drtio/wrpll/ddmtd.py +++ b/artiq/gateware/drtio/wrpll/ddmtd.py @@ -88,10 +88,8 @@ class DDMTDDeglitcherFirstEdge(Module): ] -class DDMTD(Module, AutoCSR): +class DDMTD(Module): def __init__(self, counter, input_signal): - self.arm = CSR() - self.tag = CSRStatus(len(counter)) # in helper clock domain self.h_tag = Signal(len(counter)) @@ -110,24 +108,6 @@ class DDMTD(Module, AutoCSR): ) ] - tag_update_ps = PulseSynchronizer("helper", "sys") - self.submodules += tag_update_ps - self.comb += tag_update_ps.i.eq(self.h_tag_update) - tag_update = Signal() - self.sync += tag_update.eq(tag_update_ps.o) - - tag = Signal(len(counter)) - self.h_tag.attr.add("no_retiming") - self.specials += MultiReg(self.h_tag, tag) - - self.sync += [ - If(self.arm.re & self.arm.r, self.arm.w.eq(1)), - If(tag_update, - If(self.arm.w, self.tag.status.eq(tag)), - self.arm.w.eq(0), - ) - ] - class Collector(Module): """Generates loop filter inputs from DDMTD outputs.