mirror of
https://github.com/YosysHQ/yosys
synced 2025-10-24 08:24:35 +00:00
224 lines
4.9 KiB
Verilog
224 lines
4.9 KiB
Verilog
module myDFF (output reg Q, input CLK, D);
|
|
parameter [0:0] INIT = 1'b0;
|
|
initial Q = INIT;
|
|
always @(posedge CLK)
|
|
Q <= D;
|
|
endmodule
|
|
|
|
module myDFFE (output reg Q, input D, CLK, CE);
|
|
parameter [0:0] INIT = 1'b0;
|
|
initial Q = INIT;
|
|
always @(posedge CLK) begin
|
|
if (CE)
|
|
Q <= D;
|
|
end
|
|
endmodule // DFFE (positive clock edge; clock enable)
|
|
|
|
|
|
module myDFFS (output reg Q, input D, CLK, SET);
|
|
parameter [0:0] INIT = 1'b1;
|
|
initial Q = INIT;
|
|
always @(posedge CLK) begin
|
|
if (SET)
|
|
Q <= 1'b1;
|
|
else
|
|
Q <= D;
|
|
end
|
|
endmodule // DFFS (positive clock edge; synchronous set)
|
|
|
|
|
|
module myDFFSE (output reg Q, input D, CLK, CE, SET);
|
|
parameter [0:0] INIT = 1'b1;
|
|
initial Q = INIT;
|
|
always @(posedge CLK) begin
|
|
if (SET)
|
|
Q <= 1'b1;
|
|
else if (CE)
|
|
Q <= D;
|
|
end
|
|
endmodule // DFFSE (positive clock edge; synchronous set takes precedence over clock enable)
|
|
|
|
|
|
module myDFFR (output reg Q, input D, CLK, RESET);
|
|
parameter [0:0] INIT = 1'b0;
|
|
initial Q = INIT;
|
|
always @(posedge CLK) begin
|
|
if (RESET)
|
|
Q <= 1'b0;
|
|
else
|
|
Q <= D;
|
|
end
|
|
endmodule // DFFR (positive clock edge; synchronous reset)
|
|
|
|
|
|
module myDFFRE (output reg Q, input D, CLK, CE, RESET);
|
|
parameter [0:0] INIT = 1'b0;
|
|
initial Q = INIT;
|
|
always @(posedge CLK) begin
|
|
if (RESET)
|
|
Q <= 1'b0;
|
|
else if (CE)
|
|
Q <= D;
|
|
end
|
|
endmodule // DFFRE (positive clock edge; synchronous reset takes precedence over clock enable)
|
|
|
|
|
|
module myDFFP (output reg Q, input D, CLK, PRESET);
|
|
parameter [0:0] INIT = 1'b1;
|
|
initial Q = INIT;
|
|
always @(posedge CLK or posedge PRESET) begin
|
|
if(PRESET)
|
|
Q <= 1'b1;
|
|
else
|
|
Q <= D;
|
|
end
|
|
endmodule // DFFP (positive clock edge; asynchronous preset)
|
|
|
|
|
|
module myDFFPE (output reg Q, input D, CLK, CE, PRESET);
|
|
parameter [0:0] INIT = 1'b1;
|
|
initial Q = INIT;
|
|
always @(posedge CLK or posedge PRESET) begin
|
|
if(PRESET)
|
|
Q <= 1'b1;
|
|
else if (CE)
|
|
Q <= D;
|
|
end
|
|
endmodule // DFFPE (positive clock edge; asynchronous preset; clock enable)
|
|
|
|
|
|
module myDFFC (output reg Q, input D, CLK, CLEAR);
|
|
parameter [0:0] INIT = 1'b0;
|
|
initial Q = INIT;
|
|
always @(posedge CLK or posedge CLEAR) begin
|
|
if(CLEAR)
|
|
Q <= 1'b0;
|
|
else
|
|
Q <= D;
|
|
end
|
|
endmodule // DFFC (positive clock edge; asynchronous clear)
|
|
|
|
|
|
module myDFFCE (output reg Q, input D, CLK, CE, CLEAR);
|
|
parameter [0:0] INIT = 1'b0;
|
|
initial Q = INIT;
|
|
always @(posedge CLK or posedge CLEAR) begin
|
|
if(CLEAR)
|
|
Q <= 1'b0;
|
|
else if (CE)
|
|
Q <= D;
|
|
end
|
|
endmodule // DFFCE (positive clock edge; asynchronous clear; clock enable)
|
|
|
|
|
|
module myDFFN (output reg Q, input CLK, D);
|
|
parameter [0:0] INIT = 1'b0;
|
|
initial Q = INIT;
|
|
always @(negedge CLK)
|
|
Q <= D;
|
|
endmodule
|
|
|
|
module myDFFNE (output reg Q, input D, CLK, CE);
|
|
parameter [0:0] INIT = 1'b0;
|
|
initial Q = INIT;
|
|
always @(negedge CLK) begin
|
|
if (CE)
|
|
Q <= D;
|
|
end
|
|
endmodule // DFFNE (negative clock edge; clock enable)
|
|
|
|
|
|
module myDFFNS (output reg Q, input D, CLK, SET);
|
|
parameter [0:0] INIT = 1'b1;
|
|
initial Q = INIT;
|
|
always @(negedge CLK) begin
|
|
if (SET)
|
|
Q <= 1'b1;
|
|
else
|
|
Q <= D;
|
|
end
|
|
endmodule // DFFNS (negative clock edge; synchronous set)
|
|
|
|
|
|
module myDFFNSE (output reg Q, input D, CLK, CE, SET);
|
|
parameter [0:0] INIT = 1'b1;
|
|
initial Q = INIT;
|
|
always @(negedge CLK) begin
|
|
if (SET)
|
|
Q <= 1'b1;
|
|
else if (CE)
|
|
Q <= D;
|
|
end
|
|
endmodule // DFFNSE (negative clock edge; synchronous set takes precedence over clock enable)
|
|
|
|
|
|
module myDFFNR (output reg Q, input D, CLK, RESET);
|
|
parameter [0:0] INIT = 1'b0;
|
|
initial Q = INIT;
|
|
always @(negedge CLK) begin
|
|
if (RESET)
|
|
Q <= 1'b0;
|
|
else
|
|
Q <= D;
|
|
end
|
|
endmodule // DFFNR (negative clock edge; synchronous reset)
|
|
|
|
|
|
module myDFFNRE (output reg Q, input D, CLK, CE, RESET);
|
|
parameter [0:0] INIT = 1'b0;
|
|
initial Q = INIT;
|
|
always @(negedge CLK) begin
|
|
if (RESET)
|
|
Q <= 1'b0;
|
|
else if (CE)
|
|
Q <= D;
|
|
end
|
|
endmodule // DFFNRE (negative clock edge; synchronous reset takes precedence over clock enable)
|
|
|
|
|
|
module myDFFNP (output reg Q, input D, CLK, PRESET);
|
|
parameter [0:0] INIT = 1'b1;
|
|
initial Q = INIT;
|
|
always @(negedge CLK or posedge PRESET) begin
|
|
if(PRESET)
|
|
Q <= 1'b1;
|
|
else
|
|
Q <= D;
|
|
end
|
|
endmodule // DFFNP (negative clock edge; asynchronous preset)
|
|
|
|
|
|
module myDFFNPE (output reg Q, input D, CLK, CE, PRESET);
|
|
parameter [0:0] INIT = 1'b1;
|
|
initial Q = INIT;
|
|
always @(negedge CLK or posedge PRESET) begin
|
|
if(PRESET)
|
|
Q <= 1'b1;
|
|
else if (CE)
|
|
Q <= D;
|
|
end
|
|
endmodule // DFFNPE (negative clock edge; asynchronous preset; clock enable)
|
|
|
|
|
|
module myDFFNC (output reg Q, input D, CLK, CLEAR);
|
|
parameter [0:0] INIT = 1'b0;
|
|
initial Q = INIT;
|
|
always @(negedge CLK or posedge CLEAR) begin
|
|
if(CLEAR)
|
|
Q <= 1'b0;
|
|
else
|
|
Q <= D;
|
|
end
|
|
endmodule // DFFNC (negative clock edge; asynchronous clear)
|
|
|
|
|
|
module myDFFNCE (output reg Q, input D, CLK, CE, CLEAR);
|
|
parameter [0:0] INIT = 1'b0;
|
|
initial Q = INIT;
|
|
always @(negedge CLK or posedge CLEAR) begin
|
|
if(CLEAR)
|
|
Q <= 1'b0;
|
|
else if (CE)
|
|
Q <= D;
|
|
end
|
|
endmodule // DFFNCE (negative clock edge; asynchronous clear; clock enable)
|