mirror of https://github.com/YosysHQ/yosys.git
77 lines
1.8 KiB
Verilog
77 lines
1.8 KiB
Verilog
(* abc9_lut=1, lib_whitebox *)
|
|
module LUT1 (
|
|
output O,
|
|
input I0
|
|
);
|
|
parameter [1:0] INIT = 0;
|
|
parameter EQN = "(I0)";
|
|
|
|
// These timings are for PolarPro 3E; other families will need updating.
|
|
specify
|
|
(I0 => O) = 698; // FS -> FZ
|
|
endspecify
|
|
|
|
assign O = I0 ? INIT[1] : INIT[0];
|
|
endmodule
|
|
|
|
// TZ TSL TAB
|
|
(* abc9_lut=2, lib_whitebox *)
|
|
module LUT2 (
|
|
output O,
|
|
input I0, I1
|
|
);
|
|
parameter [3:0] INIT = 4'h0;
|
|
parameter EQN = "(I0)";
|
|
|
|
// These timings are for PolarPro 3E; other families will need updating.
|
|
specify
|
|
(I0 => O) = 1251; // TAB -> TZ
|
|
(I1 => O) = 1406; // TSL -> TZ
|
|
endspecify
|
|
|
|
wire [1:0] s1 = I1 ? INIT[3:2] : INIT[1:0];
|
|
assign O = I0 ? s1[1] : s1[0];
|
|
endmodule
|
|
|
|
(* abc9_lut=2, lib_whitebox *)
|
|
module LUT3 (
|
|
output O,
|
|
input I0, I1, I2
|
|
);
|
|
parameter [7:0] INIT = 8'h0;
|
|
parameter EQN = "(I0)";
|
|
|
|
// These timings are for PolarPro 3E; other families will need updating.
|
|
specify
|
|
(I0 => O) = 1251; // TAB -> TZ
|
|
(I1 => O) = 1406; // TSL -> TZ
|
|
(I2 => O) = 1699; // ('TA1', 'TA2', 'TB1', 'TB2') -> TZ
|
|
endspecify
|
|
|
|
wire [3:0] s2 = I2 ? INIT[7:4] : INIT[3:0];
|
|
wire [1:0] s1 = I1 ? s2[3:2] : s2[1:0];
|
|
assign O = I0 ? s1[1] : s1[0];
|
|
endmodule
|
|
|
|
(* abc9_lut=4, lib_whitebox *)
|
|
module LUT4 (
|
|
output O,
|
|
input I0, I1, I2, I3
|
|
);
|
|
parameter [15:0] INIT = 16'h0;
|
|
parameter EQN = "(I0)";
|
|
|
|
// These timings are for PolarPro 3E; other families will need updating.
|
|
specify
|
|
(I0 => O) = 995; // TBS -> CZ
|
|
(I1 => O) = 1437; // ('TAB', 'BAB') -> CZ
|
|
(I2 => O) = 1593; // ('TSL', 'BSL') -> CZ
|
|
(I3 => O) = 1887; // ('TA1', 'TA2', 'TB1', 'TB2', 'BA1', 'BA2', 'BB1', 'BB2') -> CZ
|
|
endspecify
|
|
|
|
wire [7:0] s3 = I3 ? INIT[15:8] : INIT[7:0];
|
|
wire [3:0] s2 = I2 ? s3[7:4] : s3[3:0];
|
|
wire [1:0] s1 = I1 ? s2[3:2] : s2[1:0];
|
|
assign O = I0 ? s1[1] : s1[0];
|
|
endmodule
|