2023-11-27 02:42:40 -06:00
|
|
|
// Copyright 2020-2022 F4PGA Authors
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
//
|
|
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
|
|
|
|
// DFF, asynchronous set/reset, enable
|
|
|
|
module \$_DFFSRE_PNNP_ (C, S, R, E, D, Q);
|
2023-08-14 09:20:36 -05:00
|
|
|
input C;
|
|
|
|
input S;
|
|
|
|
input R;
|
|
|
|
input E;
|
|
|
|
input D;
|
|
|
|
output Q;
|
|
|
|
dffsre _TECHMAP_REPLACE_ (.Q(Q), .D(D), .C(C), .E(E), .R(R), .S(S));
|
2023-11-27 02:42:40 -06:00
|
|
|
endmodule
|
|
|
|
|
|
|
|
module \$_DFFSRE_NNNP_ (C, S, R, E, D, Q);
|
2023-08-14 09:20:36 -05:00
|
|
|
input C;
|
|
|
|
input S;
|
|
|
|
input R;
|
|
|
|
input E;
|
|
|
|
input D;
|
|
|
|
output Q;
|
|
|
|
dffnsre _TECHMAP_REPLACE_ (.Q(Q), .D(D), .C(C), .E(E), .R(R), .S(S));
|
2023-11-27 02:42:40 -06:00
|
|
|
endmodule
|
|
|
|
|
|
|
|
// DFF, synchronous set or reset, enable
|
|
|
|
module \$_SDFFE_PN0P_ (D, C, R, E, Q);
|
2023-08-14 09:20:36 -05:00
|
|
|
input D;
|
|
|
|
input C;
|
|
|
|
input R;
|
|
|
|
input E;
|
|
|
|
output Q;
|
|
|
|
sdffsre _TECHMAP_REPLACE_ (.Q(Q), .D(D), .C(C), .E(E), .R(R), .S(1'b1));
|
2023-11-27 02:42:40 -06:00
|
|
|
endmodule
|
|
|
|
|
|
|
|
module \$_SDFFE_PN1P_ (D, C, R, E, Q);
|
2023-08-14 09:20:36 -05:00
|
|
|
input D;
|
|
|
|
input C;
|
|
|
|
input R;
|
|
|
|
input E;
|
|
|
|
output Q;
|
|
|
|
sdffsre _TECHMAP_REPLACE_ (.Q(Q), .D(D), .C(C), .E(E), .R(1'b1), .S(R));
|
2023-11-27 02:42:40 -06:00
|
|
|
endmodule
|
|
|
|
|
|
|
|
module \$_SDFFE_NN0P_ (D, C, R, E, Q);
|
2023-08-14 09:20:36 -05:00
|
|
|
input D;
|
|
|
|
input C;
|
|
|
|
input R;
|
|
|
|
input E;
|
|
|
|
output Q;
|
|
|
|
sdffnsre _TECHMAP_REPLACE_ (.Q(Q), .D(D), .C(C), .E(E), .R(R), .S(1'b1));
|
2023-11-27 02:42:40 -06:00
|
|
|
endmodule
|
|
|
|
|
|
|
|
module \$_SDFFE_NN1P_ (D, C, R, E, Q);
|
2023-08-14 09:20:36 -05:00
|
|
|
input D;
|
|
|
|
input C;
|
|
|
|
input R;
|
|
|
|
input E;
|
|
|
|
output Q;
|
|
|
|
sdffnsre _TECHMAP_REPLACE_ (.Q(Q), .D(D), .C(C), .E(E), .R(1'b1), .S(R));
|
2023-11-27 02:42:40 -06:00
|
|
|
endmodule
|
|
|
|
|
|
|
|
// Latch, no set/reset, no enable
|
|
|
|
module \$_DLATCH_P_ (input E, D, output Q);
|
2023-08-14 09:20:36 -05:00
|
|
|
latchsre _TECHMAP_REPLACE_ (.D(D), .Q(Q), .E(1'b1), .G(E), .R(1'b1), .S(1'b1));
|
2023-11-27 02:42:40 -06:00
|
|
|
endmodule
|
|
|
|
|
|
|
|
module \$_DLATCH_N_ (input E, D, output Q);
|
2023-08-14 09:20:36 -05:00
|
|
|
latchnsre _TECHMAP_REPLACE_ (.D(D), .Q(Q), .E(1'b1), .G(E), .R(1'b1), .S(1'b1));
|
2023-11-27 02:42:40 -06:00
|
|
|
endmodule
|
|
|
|
|
|
|
|
// Latch with async set and reset and enable
|
|
|
|
module \$_DLATCHSR_PPP_ (input E, S, R, D, output Q);
|
2023-08-14 09:20:36 -05:00
|
|
|
latchsre _TECHMAP_REPLACE_ (.D(D), .Q(Q), .E(1'b1), .G(E), .R(!R), .S(!S));
|
2023-11-27 02:42:40 -06:00
|
|
|
endmodule
|
|
|
|
|
|
|
|
module \$_DLATCHSR_NPP_ (input E, S, R, D, output Q);
|
2023-08-14 09:20:36 -05:00
|
|
|
latchnsre _TECHMAP_REPLACE_ (.D(D), .Q(Q), .E(1'b1), .G(E), .R(!R), .S(!S));
|
2023-11-27 02:42:40 -06:00
|
|
|
endmodule
|
|
|
|
|
|
|
|
module \$__SHREG_DFF_P_ (D, Q, C);
|
2023-08-14 09:20:36 -05:00
|
|
|
input D;
|
|
|
|
input C;
|
|
|
|
output Q;
|
|
|
|
|
|
|
|
parameter DEPTH = 2;
|
|
|
|
|
|
|
|
reg [DEPTH-2:0] q;
|
|
|
|
|
|
|
|
genvar i;
|
|
|
|
generate for (i = 0; i < DEPTH; i = i + 1) begin: slice
|
|
|
|
|
|
|
|
// First in chain
|
|
|
|
generate if (i == 0) begin
|
|
|
|
sh_dff #() shreg_beg (
|
|
|
|
.Q(q[i]),
|
|
|
|
.D(D),
|
|
|
|
.C(C)
|
|
|
|
);
|
|
|
|
end endgenerate
|
|
|
|
// Middle in chain
|
|
|
|
generate if (i > 0 && i != DEPTH-1) begin
|
|
|
|
sh_dff #() shreg_mid (
|
|
|
|
.Q(q[i]),
|
|
|
|
.D(q[i-1]),
|
|
|
|
.C(C)
|
|
|
|
);
|
|
|
|
end endgenerate
|
|
|
|
// Last in chain
|
|
|
|
generate if (i == DEPTH-1) begin
|
|
|
|
sh_dff #() shreg_end (
|
|
|
|
.Q(Q),
|
|
|
|
.D(q[i-1]),
|
|
|
|
.C(C)
|
|
|
|
);
|
|
|
|
end endgenerate
|
2023-11-27 02:42:40 -06:00
|
|
|
end: slice
|
|
|
|
endgenerate
|
|
|
|
|
|
|
|
endmodule
|
|
|
|
|