2021-07-27 22:24:40 -04:00
|
|
|
//#############################################################################
|
|
|
|
//# Function: Data Syncrhonizer #
|
|
|
|
//#############################################################################
|
|
|
|
//# Author: Andreas Olofsson #
|
|
|
|
//# License: MIT (see LICENSE file in OH! repository) #
|
|
|
|
//#############################################################################
|
|
|
|
|
2021-07-27 22:55:45 -04:00
|
|
|
module asic_dsync #(parameter PROP = "DEFAULT") (
|
2021-07-27 22:24:40 -04:00
|
|
|
input clk, // clock
|
|
|
|
input nreset, // async active low reset
|
|
|
|
input in, // input data
|
|
|
|
output out // synchronized data
|
|
|
|
);
|
|
|
|
|
|
|
|
localparam SYNCPIPE=2;
|
|
|
|
|
|
|
|
reg [SYNCPIPE-1:0] sync_pipe;
|
|
|
|
always @ (posedge clk or negedge nreset)
|
|
|
|
if(!nreset)
|
|
|
|
sync_pipe[SYNCPIPE-1:0] <= 'b0;
|
|
|
|
else
|
|
|
|
sync_pipe[SYNCPIPE-1:0] <= {sync_pipe[SYNCPIPE-1:0],in};
|
|
|
|
|
|
|
|
assign out = sync_pipe[SYNCPIPE-1];
|
|
|
|
|
|
|
|
endmodule
|