From 3538fccfc0d9d493d767dcc445593074d3edc86d Mon Sep 17 00:00:00 2001 From: Max Köhler Date: Wed, 18 Dec 2019 11:18:46 +0100 Subject: lib: add option for output register in pps generator The pps_generator module receives a new parameter (PIPELINE) which can optionally add a register on the output. The default behaviour is unchanged. --- fpga/usrp3/lib/timing/pps_generator.v | 25 +++++++++++++++++++++++-- 1 file changed, 23 insertions(+), 2 deletions(-) (limited to 'fpga/usrp3/lib') diff --git a/fpga/usrp3/lib/timing/pps_generator.v b/fpga/usrp3/lib/timing/pps_generator.v index 9142c3a48..288fdccb9 100644 --- a/fpga/usrp3/lib/timing/pps_generator.v +++ b/fpga/usrp3/lib/timing/pps_generator.v @@ -7,7 +7,8 @@ module pps_generator #( parameter CLK_FREQ = 32'd10_000_000, //Min:10kHz, Max:4GHz - parameter DUTY_CYCLE = 25 + parameter DUTY_CYCLE = 25, + parameter PIPELINE = "NONE" // Optional register on output? {"NONE", "OUT"} ) ( input clk, input reset, @@ -25,5 +26,25 @@ module pps_generator #( end end - assign pps = (count < ((CLK_FREQ / 100) * DUTY_CYCLE)); + wire pps_int; + assign pps_int = (count < ((CLK_FREQ / 100) * DUTY_CYCLE)); + + generate + if (PIPELINE == "OUT") begin : gen_pipeline_out + // create output register and assign to output + reg pps_reg = 1'b0; + assign pps = pps_reg; + + always @(posedge clk) begin + if (reset) begin + pps_reg <= 1'b0; + end else begin + pps_reg <= pps_int; + end + end + end else begin : gen_pipeline_none + // no output register + assign pps = pps_int; + end + endgenerate endmodule //pps_generator -- cgit v1.2.3