mirror of https://github.com/YosysHQ/yosys.git
gate2lut: new techlib, for converting Yosys gates to FPGA LUTs.
This commit is contained in:
parent
12596b5003
commit
9ef078848a
|
@ -25,5 +25,6 @@ $(eval $(call add_share_file,share,techlibs/common/techmap.v))
|
|||
$(eval $(call add_share_file,share,techlibs/common/pmux2mux.v))
|
||||
$(eval $(call add_share_file,share,techlibs/common/adff2dff.v))
|
||||
$(eval $(call add_share_file,share,techlibs/common/dff2ff.v))
|
||||
$(eval $(call add_share_file,share,techlibs/common/gate2lut.v))
|
||||
$(eval $(call add_share_file,share,techlibs/common/cells.lib))
|
||||
|
||||
|
|
|
@ -0,0 +1,87 @@
|
|||
(* techmap_celltype = "$_NOT_" *)
|
||||
module _90_lut_not (A, Y);
|
||||
input A;
|
||||
output Y;
|
||||
|
||||
wire [`LUT_WIDTH-1:0] AA;
|
||||
assign AA = {A};
|
||||
|
||||
\$lut #(
|
||||
.WIDTH(`LUT_WIDTH),
|
||||
.LUT(4'b01)
|
||||
) lut (
|
||||
.A(AA),
|
||||
.Y(Y)
|
||||
);
|
||||
endmodule
|
||||
|
||||
(* techmap_celltype = "$_OR_" *)
|
||||
module _90_lut_or (A, B, Y);
|
||||
input A, B;
|
||||
output Y;
|
||||
|
||||
wire [`LUT_WIDTH-1:0] AA;
|
||||
assign AA = {B, A};
|
||||
|
||||
\$lut #(
|
||||
.WIDTH(`LUT_WIDTH),
|
||||
.LUT(4'b1110)
|
||||
) lut (
|
||||
.A(AA),
|
||||
.Y(Y)
|
||||
);
|
||||
endmodule
|
||||
|
||||
(* techmap_celltype = "$_AND_" *)
|
||||
module _90_lut_and (A, B, Y);
|
||||
input A, B;
|
||||
output Y;
|
||||
|
||||
wire [`LUT_WIDTH-1:0] AA;
|
||||
assign AA = {B, A};
|
||||
|
||||
\$lut #(
|
||||
.WIDTH(`LUT_WIDTH),
|
||||
.LUT(4'b1000)
|
||||
) lut (
|
||||
.A(AA),
|
||||
.Y(Y)
|
||||
);
|
||||
endmodule
|
||||
|
||||
(* techmap_celltype = "$_XOR_" *)
|
||||
module _90_lut_xor (A, B, Y);
|
||||
input A, B;
|
||||
output Y;
|
||||
|
||||
wire [`LUT_WIDTH-1:0] AA;
|
||||
assign AA = {B, A};
|
||||
|
||||
\$lut #(
|
||||
.WIDTH(`LUT_WIDTH),
|
||||
.LUT(4'b0110)
|
||||
) lut (
|
||||
.A(AA),
|
||||
.Y(Y)
|
||||
);
|
||||
endmodule
|
||||
|
||||
(* techmap_celltype = "$_MUX_" *)
|
||||
module _90_lut_mux (A, B, S, Y);
|
||||
input A, B, S;
|
||||
output Y;
|
||||
|
||||
wire [`LUT_WIDTH-1:0] AA;
|
||||
assign AA = {S, B, A};
|
||||
|
||||
\$lut #(
|
||||
.WIDTH(`LUT_WIDTH),
|
||||
// A 1010 1010
|
||||
// B 1100 1100
|
||||
// S 1111 0000
|
||||
.LUT(8'b_1100_1010)
|
||||
) lut (
|
||||
.A(AA),
|
||||
.Y(Y)
|
||||
);
|
||||
endmodule
|
|
@ -0,0 +1 @@
|
|||
*.log
|
|
@ -0,0 +1,13 @@
|
|||
design -save preopt
|
||||
|
||||
simplemap
|
||||
techmap -map +/gate2lut.v -D LUT_WIDTH=4
|
||||
select -assert-count 1 t:$lut
|
||||
design -stash postopt
|
||||
|
||||
design -copy-from preopt -as preopt top
|
||||
design -copy-from postopt -as postopt top
|
||||
equiv_make preopt postopt equiv
|
||||
prep -flatten -top equiv
|
||||
equiv_induct
|
||||
equiv_status -assert
|
|
@ -0,0 +1,5 @@
|
|||
module top(...);
|
||||
input a, b;
|
||||
output y;
|
||||
assign y = a&b;
|
||||
endmodule
|
|
@ -0,0 +1,5 @@
|
|||
module top(...);
|
||||
input a, b, s;
|
||||
output y;
|
||||
assign y = s?a:b;
|
||||
endmodule
|
|
@ -0,0 +1,5 @@
|
|||
module top(...);
|
||||
input a;
|
||||
output y;
|
||||
assign y = ~a;
|
||||
endmodule
|
|
@ -0,0 +1,5 @@
|
|||
module top(...);
|
||||
input a, b;
|
||||
output y;
|
||||
assign y = a|b;
|
||||
endmodule
|
|
@ -0,0 +1,5 @@
|
|||
module top(...);
|
||||
input a, b;
|
||||
output y;
|
||||
assign y = a^b;
|
||||
endmodule
|
|
@ -0,0 +1,6 @@
|
|||
#!/bin/bash
|
||||
set -e
|
||||
for x in *.v; do
|
||||
echo "Running $x.."
|
||||
../../yosys -q -s check_map.ys -l ${x%.v}.log $x
|
||||
done
|
Loading…
Reference in New Issue