mirror of https://github.com/YosysHQ/yosys.git
87 lines
3.4 KiB
Coq
87 lines
3.4 KiB
Coq
|
`ifndef NO_LUT
|
||
|
module \$lut (A, Y);
|
||
|
parameter WIDTH = 0;
|
||
|
parameter LUT = 0;
|
||
|
|
||
|
input [WIDTH-1:0] A;
|
||
|
output Y;
|
||
|
|
||
|
generate
|
||
|
if (WIDTH == 1) begin
|
||
|
LUT4 #(.INIT(LUT)) _TECHMAP_REPLACE_ (.Z(Y),
|
||
|
.A(A[0]), .B(1'b0), .C(1'b0), .D(1'b0));
|
||
|
end else
|
||
|
if (WIDTH == 2) begin
|
||
|
LUT4 #(.INIT(LUT)) _TECHMAP_REPLACE_ (.Z(Y),
|
||
|
.A(A[0]), .B(A[1]), .C(1'b0), .D(1'b0));
|
||
|
end else
|
||
|
if (WIDTH == 3) begin
|
||
|
LUT4 #(.INIT(LUT)) _TECHMAP_REPLACE_ (.Z(Y),
|
||
|
.A(A[0]), .B(A[1]), .C(A[2]), .D(1'b0));
|
||
|
end else
|
||
|
if (WIDTH == 4) begin
|
||
|
LUT4 #(.INIT(LUT)) _TECHMAP_REPLACE_ (.Z(Y),
|
||
|
.A(A[0]), .B(A[1]), .C(A[2]), .D(A[3]));
|
||
|
`ifndef NO_PFUMUX
|
||
|
end else
|
||
|
if (WIDTH == 5) begin
|
||
|
wire f0, f1;
|
||
|
LUT4 #(.INIT(LUT[15: 0])) lut0 (.Z(f0),
|
||
|
.A(A[0]), .B(A[1]), .C(A[2]), .D(A[3]));
|
||
|
LUT4 #(.INIT(LUT[31:16])) lut1 (.Z(f1),
|
||
|
.A(A[0]), .B(A[1]), .C(A[2]), .D(A[3]));
|
||
|
PFUMX mux5(.ALUT(f1), .BLUT(f0), .SD(A[4]), .Z(Y));
|
||
|
end else
|
||
|
if (WIDTH == 6) begin
|
||
|
wire f0, f1, f2, f3, g0, g1;
|
||
|
LUT4 #(.INIT(LUT[15: 0])) lut0 (.Z(f0),
|
||
|
.A(A[0]), .B(A[1]), .C(A[2]), .D(A[3]));
|
||
|
LUT4 #(.INIT(LUT[31:16])) lut1 (.Z(f1),
|
||
|
.A(A[0]), .B(A[1]), .C(A[2]), .D(A[3]));
|
||
|
|
||
|
LUT4 #(.INIT(LUT[47:32])) lut2 (.Z(f2),
|
||
|
.A(A[0]), .B(A[1]), .C(A[2]), .D(A[3]));
|
||
|
LUT4 #(.INIT(LUT[63:48])) lut3 (.Z(f3),
|
||
|
.A(A[0]), .B(A[1]), .C(A[2]), .D(A[3]));
|
||
|
|
||
|
PFUMX mux50(.ALUT(f1), .BLUT(f0), .SD(A[4]), .Z(g0));
|
||
|
PFUMX mux51(.ALUT(f3), .BLUT(f2), .SD(A[4]), .Z(g1));
|
||
|
L6MUX21 mux6 (.D0(g0), .D1(g1), .SD(A[5]), .Z(Y));
|
||
|
end else
|
||
|
if (WIDTH == 7) begin
|
||
|
wire f0, f1, f2, f3, f4, f5, f6, f7, g0, g1, g2, g3, h0, h1;
|
||
|
LUT4 #(.INIT(LUT[15: 0])) lut0 (.Z(f0),
|
||
|
.A(A[0]), .B(A[1]), .C(A[2]), .D(A[3]));
|
||
|
LUT4 #(.INIT(LUT[31:16])) lut1 (.Z(f1),
|
||
|
.A(A[0]), .B(A[1]), .C(A[2]), .D(A[3]));
|
||
|
|
||
|
LUT4 #(.INIT(LUT[47:32])) lut2 (.Z(f2),
|
||
|
.A(A[0]), .B(A[1]), .C(A[2]), .D(A[3]));
|
||
|
LUT4 #(.INIT(LUT[63:48])) lut3 (.Z(f3),
|
||
|
.A(A[0]), .B(A[1]), .C(A[2]), .D(A[3]));
|
||
|
|
||
|
LUT4 #(.INIT(LUT[79:64])) lut4 (.Z(f4),
|
||
|
.A(A[0]), .B(A[1]), .C(A[2]), .D(A[3]));
|
||
|
LUT4 #(.INIT(LUT[95:80])) lut5 (.Z(f5),
|
||
|
.A(A[0]), .B(A[1]), .C(A[2]), .D(A[3]));
|
||
|
|
||
|
LUT4 #(.INIT(LUT[111: 96])) lut6 (.Z(f6),
|
||
|
.A(A[0]), .B(A[1]), .C(A[2]), .D(A[3]));
|
||
|
LUT4 #(.INIT(LUT[127:112])) lut7 (.Z(f7),
|
||
|
.A(A[0]), .B(A[1]), .C(A[2]), .D(A[3]));
|
||
|
|
||
|
PFUMX mux50(.ALUT(f1), .BLUT(f0), .SD(A[4]), .Z(g0));
|
||
|
PFUMX mux51(.ALUT(f3), .BLUT(f2), .SD(A[4]), .Z(g1));
|
||
|
PFUMX mux52(.ALUT(f5), .BLUT(f4), .SD(A[4]), .Z(g2));
|
||
|
PFUMX mux53(.ALUT(f7), .BLUT(f6), .SD(A[4]), .Z(g3));
|
||
|
L6MUX21 mux60 (.D0(g0), .D1(g1), .SD(A[5]), .Z(h0));
|
||
|
L6MUX21 mux61 (.D0(g2), .D1(g3), .SD(A[5]), .Z(h1));
|
||
|
L6MUX21 mux7 (.D0(h0), .D1(h1), .SD(A[6]), .Z(Y));
|
||
|
`endif
|
||
|
end else begin
|
||
|
wire _TECHMAP_FAIL_ = 1;
|
||
|
end
|
||
|
endgenerate
|
||
|
endmodule
|
||
|
`endif
|