From 546725dff001404b6069f8a308d1d150e28a3f60 Mon Sep 17 00:00:00 2001 From: linuswck Date: Tue, 7 Jan 2025 10:51:48 +0800 Subject: [PATCH] gateware: Add pipeline to fast_chain calculation - Fix timing violations at 125MHz sys frequency --- .../linien-gateware-chain-pipeline.patch | 35 +++++++++++++++++++ flake.nix | 1 + 2 files changed, 36 insertions(+) create mode 100644 fast-servo/linien-gateware-chain-pipeline.patch diff --git a/fast-servo/linien-gateware-chain-pipeline.patch b/fast-servo/linien-gateware-chain-pipeline.patch new file mode 100644 index 0000000..7837a2b --- /dev/null +++ b/fast-servo/linien-gateware-chain-pipeline.patch @@ -0,0 +1,35 @@ +diff --git a/gateware/logic/chains.py b/gateware/logic/chains.py +index a890849..3461a78 100644 +--- a/gateware/logic/chains.py ++++ b/gateware/logic/chains.py +@@ -93,7 +93,6 @@ class FastChain(Module, AutoCSR): + + self.comb += [ + x_limit.x.eq(([self.demod.i, self.demod.q][sub_channel_idx] << s) + dx), +- iir_c.x.eq(x_limit.y), + iir_c.hold.eq(0), + iir_c.clear.eq(0), + iir_d.x.eq(iir_c.y), +@@ -101,14 +100,20 @@ class FastChain(Module, AutoCSR): + iir_d.clear.eq(0), + ] + ++ self.sync += [ ++ iir_c.x.eq(x_limit.y) ++ ] ++ + ys = Array([iir_c.x, iir_c.y, iir_d.y]) + + output_signal_this_channel = (self.out_i, self.out_q)[sub_channel_idx] +- self.comb += [ ++ self.sync += [ + y_limit.x.eq( + Mux(self.invert.storage, -1, 1) + * (ys[self.y_tap.storage] + (ya << s) + (offset_signal << s)) +- ), ++ ) ++ ] ++ self.comb += [ + output_signal_this_channel.eq(y_limit.y), + ] + diff --git a/flake.nix b/flake.nix index 4574054..b11e2e3 100644 --- a/flake.nix +++ b/flake.nix @@ -39,6 +39,7 @@ ./fast-servo/linien_module_pipeline.patch ./fast-servo/pid_pipeline.patch ./fast-servo/pid_err_sig_pipeline.patch + ./fast-servo/linien-gateware-chain-pipeline.patch ]; };