mirror of
https://github.com/YosysHQ/yosys
synced 2025-10-24 00:14:36 +00:00
add MUX support
This commit is contained in:
parent
ae93c034ad
commit
3eff2271d0
3 changed files with 17 additions and 0 deletions
|
@ -5,6 +5,9 @@ module \$__DFFS_PN0_ (input D, C, R, output Q); DFFR _TECHMAP_REPLACE_ (.D(D),
|
||||||
module \$__DFFS_PP0_ (input D, C, R, output Q); DFFR _TECHMAP_REPLACE_ (.D(D), .Q(Q), .CLK(C), .RESET(R)); endmodule
|
module \$__DFFS_PP0_ (input D, C, R, output Q); DFFR _TECHMAP_REPLACE_ (.D(D), .Q(Q), .CLK(C), .RESET(R)); endmodule
|
||||||
module \$__DFFS_PP1_ (input D, C, R, output Q); DFFR _TECHMAP_REPLACE_ (.D(D), .Q(Q), .CLK(C), .RESET(R)); endmodule
|
module \$__DFFS_PP1_ (input D, C, R, output Q); DFFR _TECHMAP_REPLACE_ (.D(D), .Q(Q), .CLK(C), .RESET(R)); endmodule
|
||||||
|
|
||||||
|
module \$_MUX_ (input A, B, S, output Y); MUX2 _TECHMAP_REPLACE_ (.I0(A), .I1(B), .S0(S), .O(Y)); endmodule
|
||||||
|
module \$_MUX4_ (input A, B, C, D, S, T, output Y); MUX4 _TECHMAP_REPLACE_ (.I0(A), .I1(B), .I2(C), .I3(D), .S0(S), .S1(T), .O(Y)); endmodule
|
||||||
|
|
||||||
module \$lut (A, Y);
|
module \$lut (A, Y);
|
||||||
parameter WIDTH = 0;
|
parameter WIDTH = 0;
|
||||||
parameter LUT = 0;
|
parameter LUT = 0;
|
||||||
|
|
|
@ -24,6 +24,19 @@ module LUT4(output F, input I0, I1, I2, I3);
|
||||||
assign F = I0 ? s1[1] : s1[0];
|
assign F = I0 ? s1[1] : s1[0];
|
||||||
endmodule
|
endmodule
|
||||||
|
|
||||||
|
module MUX2 (I0, I1, S0, O);
|
||||||
|
input I0, I1, S0;
|
||||||
|
output O;
|
||||||
|
assign O = S0 ? I1 : I0;
|
||||||
|
endmodule
|
||||||
|
|
||||||
|
module MUX4 (I0, I1, I2, I3, S0, S1, O);
|
||||||
|
input I0, I1, I2, I3, S0, S1;
|
||||||
|
output O;
|
||||||
|
assign O = S1 ? (S0 ? I3 : I2) :
|
||||||
|
(S0 ? I1 : I0);
|
||||||
|
endmodule
|
||||||
|
|
||||||
module DFF (output reg Q, input CLK, D);
|
module DFF (output reg Q, input CLK, D);
|
||||||
parameter [0:0] INIT = 1'b0;
|
parameter [0:0] INIT = 1'b0;
|
||||||
initial Q = INIT;
|
initial Q = INIT;
|
||||||
|
|
|
@ -196,6 +196,7 @@ struct SynthGowinPass : public ScriptPass
|
||||||
run("opt_clean");
|
run("opt_clean");
|
||||||
if (!nodffe)
|
if (!nodffe)
|
||||||
run("dff2dffe -direct-match $_DFF_* -direct-match $__DFFS_*");
|
run("dff2dffe -direct-match $_DFF_* -direct-match $__DFFS_*");
|
||||||
|
run("muxcover -mux4");
|
||||||
run("techmap -map +/gowin/cells_map.v");
|
run("techmap -map +/gowin/cells_map.v");
|
||||||
run("opt_expr -mux_undef");
|
run("opt_expr -mux_undef");
|
||||||
run("simplemap");
|
run("simplemap");
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue