diff options
author | Max Köhler <max.koehler@ni.com> | 2019-12-18 11:18:46 +0100 |
---|---|---|
committer | Martin Braun <martin.braun@ettus.com> | 2020-01-28 09:35:37 -0800 |
commit | 3538fccfc0d9d493d767dcc445593074d3edc86d (patch) | |
tree | 219a05e7f8e35d90a17df0cd8f578e40c5d14cf6 /fpga | |
parent | bafa9d95453387814ef25e6b6256ba8db2df612f (diff) | |
download | uhd-3538fccfc0d9d493d767dcc445593074d3edc86d.tar.gz uhd-3538fccfc0d9d493d767dcc445593074d3edc86d.tar.bz2 uhd-3538fccfc0d9d493d767dcc445593074d3edc86d.zip |
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.
Diffstat (limited to 'fpga')
-rw-r--r-- | fpga/usrp3/lib/timing/pps_generator.v | 25 |
1 files changed, 23 insertions, 2 deletions
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 |