File: synchronizer_impl.v

package info (click to toggle)
uhd 3.9.5-2
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 107,272 kB
  • ctags: 57,231
  • sloc: cpp: 66,160; ansic: 59,349; python: 13,245; vhdl: 7,651; tcl: 2,668; sh: 1,634; makefile: 1,031; xml: 557; pascal: 230; csh: 94; asm: 20; perl: 11
file content (31 lines) | stat: -rw-r--r-- 629 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
//
// Copyright 2014 Ettus Research LLC
//

module synchronizer_impl #(
   parameter STAGES      = 2,
   parameter INITIAL_VAL = 1'b0
)(
   input    clk,
   input    rst,
   input    in,
   output   out
);

   (* ASYNC_REG = "TRUE" *) reg [STAGES-1:0] value = {STAGES{INITIAL_VAL}};

   genvar i;
   generate
      for (i=0; i<STAGES; i=i+1) begin: stages
         always @(posedge clk) begin
            if (rst)
               value[i] <= INITIAL_VAL;
            else
               value[i] <= (i==0) ? in : value[i-1];
         end
      end
   endgenerate

   assign out = value[STAGES-1];

endmodule   //synchronizer_impl