aboutsummaryrefslogtreecommitdiffstats
path: root/fpga/usrp3/lib/control/synchronizer_impl.v
diff options
context:
space:
mode:
Diffstat (limited to 'fpga/usrp3/lib/control/synchronizer_impl.v')
-rw-r--r--fpga/usrp3/lib/control/synchronizer_impl.v47
1 files changed, 47 insertions, 0 deletions
diff --git a/fpga/usrp3/lib/control/synchronizer_impl.v b/fpga/usrp3/lib/control/synchronizer_impl.v
new file mode 100644
index 000000000..1c4f77707
--- /dev/null
+++ b/fpga/usrp3/lib/control/synchronizer_impl.v
@@ -0,0 +1,47 @@
+//
+// Copyright 2014 Ettus Research LLC
+// Copyright 2018 Ettus Research, a National Instruments Company
+//
+// SPDX-License-Identifier: LGPL-3.0-or-later
+//
+
+module synchronizer_impl #(
+ parameter WIDTH = 1,
+ parameter STAGES = 2,
+ parameter INITIAL_VAL = 0
+)(
+ input clk,
+ input rst,
+ input [WIDTH-1:0] in,
+ output [WIDTH-1:0] out
+);
+
+ (* ASYNC_REG = "TRUE" *) reg [WIDTH-1:0] value[0:STAGES-1];
+
+ integer k;
+ initial begin
+ for (k = 0; k < STAGES; k = k + 1) begin
+ value[k] = INITIAL_VAL;
+ end
+ end
+
+ genvar i;
+ generate
+ for (i=0; i<STAGES; i=i+1) begin: stages
+ always @(posedge clk) begin
+ if (rst) begin
+ value[i] <= INITIAL_VAL;
+ end else begin
+ if (i == 0) begin
+ value[i] <= in;
+ end else begin
+ value[i] <= value[i-1];
+ end
+ end
+ end
+ end
+ endgenerate
+
+ assign out = value[STAGES-1];
+
+endmodule //synchronizer_impl