2014-12-14 22:21:01 -05:00
|
|
|
module ODDR (/*AUTOARG*/
|
|
|
|
// Outputs
|
|
|
|
Q,
|
|
|
|
// Inputs
|
|
|
|
C, CE, D1, D2, R, S
|
|
|
|
);
|
|
|
|
|
2015-04-15 17:54:19 -04:00
|
|
|
parameter DDR_CLK_EDGE=0; //clock recovery mode
|
|
|
|
parameter INIT=0; //Q init value
|
|
|
|
parameter SRTYPE=0;//"SYNC", "ASYNC"
|
2014-12-14 22:21:01 -05:00
|
|
|
|
2015-04-15 17:54:19 -04:00
|
|
|
input C; // Clock input
|
|
|
|
input CE; // Clock enable input
|
|
|
|
input D1; // Data input1
|
|
|
|
input D2; // Data input2
|
|
|
|
input R; // Reset (depends on SRTYPE)
|
|
|
|
input S; // Active high asynchronous pin
|
|
|
|
output Q; // Data Output that connects to the IOB pad
|
2015-04-08 23:40:16 -04:00
|
|
|
|
2015-04-15 17:54:19 -04:00
|
|
|
reg Q1,Q2;
|
|
|
|
|
|
|
|
//Generate different logic based on parameters
|
|
|
|
|
|
|
|
//Only doing same edge and async reset for now
|
|
|
|
|
|
|
|
always @ (posedge C or posedge R)
|
|
|
|
if (R)
|
|
|
|
Q1 <= 1'b0;
|
|
|
|
else
|
|
|
|
Q1 <= D1;
|
|
|
|
|
|
|
|
always @ (posedge C or posedge R)
|
|
|
|
if (R)
|
|
|
|
Q2 <= 1'b0;
|
|
|
|
else
|
|
|
|
Q2 <= D2;
|
2014-12-14 22:21:01 -05:00
|
|
|
|
2015-04-15 17:54:19 -04:00
|
|
|
assign Q = C ? Q1 : Q2;
|
|
|
|
|
2014-12-14 22:21:01 -05:00
|
|
|
endmodule // ODDR
|
|
|
|
|