| // 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); | 
 |     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)); | 
 | endmodule | 
 |  | 
 | module \$_DFFSRE_NNNP_ (C, S, R, E, D, Q); | 
 |     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)); | 
 | endmodule | 
 |  | 
 | // DFF, synchronous set or reset, enable | 
 | module \$_SDFFE_PN0P_ (D, C, R, E, Q); | 
 |     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)); | 
 | endmodule | 
 |  | 
 | module \$_SDFFE_PN1P_ (D, C, R, E, Q); | 
 |     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)); | 
 | endmodule | 
 |  | 
 | module \$_SDFFE_NN0P_ (D, C, R, E, Q); | 
 |     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)); | 
 | endmodule | 
 |  | 
 | module \$_SDFFE_NN1P_ (D, C, R, E, Q); | 
 |     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)); | 
 | endmodule | 
 |  | 
 | // Latch, no set/reset, no enable | 
 | module  \$_DLATCH_P_ (input E, D, output Q); | 
 |     latchsre  _TECHMAP_REPLACE_ (.D(D), .Q(Q), .E(1'b1), .G(E), .R(1'b1), .S(1'b1)); | 
 | endmodule | 
 |  | 
 | module  \$_DLATCH_N_ (input E, D, output Q); | 
 |     latchnsre _TECHMAP_REPLACE_ (.D(D), .Q(Q), .E(1'b1), .G(E), .R(1'b1), .S(1'b1)); | 
 | endmodule | 
 |  | 
 | // Latch with async set and reset and enable | 
 | module  \$_DLATCHSR_PPP_ (input E, S, R, D, output Q); | 
 |     latchsre  _TECHMAP_REPLACE_ (.D(D), .Q(Q), .E(1'b1), .G(E),  .R(!R), .S(!S)); | 
 | endmodule | 
 |  | 
 | module  \$_DLATCHSR_NPP_ (input E, S, R, D, output Q); | 
 |     latchnsre _TECHMAP_REPLACE_ (.D(D), .Q(Q), .E(1'b1), .G(E),  .R(!R), .S(!S)); | 
 | endmodule | 
 |  | 
 | module \$__SHREG_DFF_P_ (D, Q, C); | 
 |     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 | 
 |    end: slice | 
 |    endgenerate | 
 |  | 
 | endmodule | 
 |  |