aboutsummaryrefslogtreecommitdiffstats
path: root/fpga
diff options
context:
space:
mode:
authorMax Köhler <max.koehler@ni.com>2019-12-18 11:18:46 +0100
committerMartin Braun <martin.braun@ettus.com>2020-01-28 09:35:37 -0800
commit3538fccfc0d9d493d767dcc445593074d3edc86d (patch)
tree219a05e7f8e35d90a17df0cd8f578e40c5d14cf6 /fpga
parentbafa9d95453387814ef25e6b6256ba8db2df612f (diff)
downloaduhd-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.v25
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