mirror of https://github.com/YosysHQ/yosys.git
Add _nowide variants of LUT libraries in -nowidelut flows
This commit is contained in:
parent
741ebba70a
commit
988e6163ab
|
@ -0,0 +1,12 @@
|
||||||
|
# ECP5-5G LUT library for ABC
|
||||||
|
# Note that ECP5 architecture assigns difference
|
||||||
|
# in LUT input delay to interconnect, so this is
|
||||||
|
# considered too
|
||||||
|
|
||||||
|
|
||||||
|
# Simple LUTs
|
||||||
|
# area D C B A
|
||||||
|
1 1 141
|
||||||
|
2 1 141 275
|
||||||
|
3 1 141 275 379
|
||||||
|
4 1 141 275 379 379
|
|
@ -273,7 +273,10 @@ struct SynthEcp5Pass : public ScriptPass
|
||||||
}
|
}
|
||||||
run("techmap -map +/ecp5/latches_map.v");
|
run("techmap -map +/ecp5/latches_map.v");
|
||||||
if (abc9) {
|
if (abc9) {
|
||||||
run("abc9 -lut +/ecp5/abc_5g.lut -box +/ecp5/abc_5g.box -W 200");
|
if (nowidelut)
|
||||||
|
run("abc9 -lut +/ecp5/abc_5g_nowide.lut -box +/ecp5/abc_5g.box -W 200");
|
||||||
|
else
|
||||||
|
run("abc9 -lut +/ecp5/abc_5g.lut -box +/ecp5/abc_5g.box -W 200");
|
||||||
} else {
|
} else {
|
||||||
if (nowidelut)
|
if (nowidelut)
|
||||||
run("abc -lut 4 -dress");
|
run("abc -lut 4 -dress");
|
||||||
|
|
|
@ -0,0 +1,10 @@
|
||||||
|
# Max delays from https://github.com/SymbiFlow/prjxray-db/blob/82bf5f158cd8e9a11ac4d04f1aeef48ed1a528a5/artix7/timings/CLBLL_L.sdf
|
||||||
|
# and https://github.com/SymbiFlow/prjxray-db/blob/82bf5f158cd8e9a11ac4d04f1aeef48ed1a528a5/artix7/tile_type_CLBLL_L.json
|
||||||
|
|
||||||
|
# K area delay
|
||||||
|
1 1 127
|
||||||
|
2 2 127 238
|
||||||
|
3 3 127 238 407
|
||||||
|
4 3 127 238 407 472
|
||||||
|
5 3 127 238 407 472 631
|
||||||
|
6 5 127 238 407 472 631 642
|
|
@ -100,14 +100,14 @@ struct SynthXilinxPass : public ScriptPass
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string top_opt, edif_file, blif_file, abc, arch;
|
std::string top_opt, edif_file, blif_file, abc, arch;
|
||||||
bool flatten, retime, vpr, nobram, nodram, nosrl, nocarry, nowidelut;
|
bool flatten, retime, vpr, nobram, nodram, nosrl, nocarry, nowidelut, abc9;
|
||||||
|
|
||||||
void clear_flags() YS_OVERRIDE
|
void clear_flags() YS_OVERRIDE
|
||||||
{
|
{
|
||||||
top_opt = "-auto-top";
|
top_opt = "-auto-top";
|
||||||
edif_file.clear();
|
edif_file.clear();
|
||||||
blif_file.clear();
|
blif_file.clear();
|
||||||
abc = "abc";
|
arch = "xc7";
|
||||||
flatten = false;
|
flatten = false;
|
||||||
retime = false;
|
retime = false;
|
||||||
vpr = false;
|
vpr = false;
|
||||||
|
@ -117,7 +117,7 @@ struct SynthXilinxPass : public ScriptPass
|
||||||
nosrl = false;
|
nosrl = false;
|
||||||
nocarry = false;
|
nocarry = false;
|
||||||
nowidelut = false;
|
nowidelut = false;
|
||||||
arch = "xc7";
|
abc9 = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void execute(std::vector<std::string> args, RTLIL::Design *design) YS_OVERRIDE
|
void execute(std::vector<std::string> args, RTLIL::Design *design) YS_OVERRIDE
|
||||||
|
@ -189,7 +189,7 @@ struct SynthXilinxPass : public ScriptPass
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (args[argidx] == "-abc9") {
|
if (args[argidx] == "-abc9") {
|
||||||
abc = "abc9";
|
abc9 = true;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -284,7 +284,7 @@ struct SynthXilinxPass : public ScriptPass
|
||||||
techmap_files += " -map +/xilinx/arith_map.v";
|
techmap_files += " -map +/xilinx/arith_map.v";
|
||||||
if (vpr)
|
if (vpr)
|
||||||
techmap_files += " -D _EXPLICIT_CARRY";
|
techmap_files += " -D _EXPLICIT_CARRY";
|
||||||
else if (abc == "abc9")
|
else if (abc9)
|
||||||
techmap_files += " -D _CLB_CARRY";
|
techmap_files += " -D _CLB_CARRY";
|
||||||
}
|
}
|
||||||
run("techmap " + techmap_files);
|
run("techmap " + techmap_files);
|
||||||
|
@ -298,14 +298,20 @@ struct SynthXilinxPass : public ScriptPass
|
||||||
|
|
||||||
if (check_label("map_luts")) {
|
if (check_label("map_luts")) {
|
||||||
run("opt_expr -mux_undef");
|
run("opt_expr -mux_undef");
|
||||||
if (abc == "abc9")
|
if (help_mode)
|
||||||
run(abc + " -lut +/xilinx/abc_xc7.lut -box +/xilinx/abc_xc7.box -W " + XC7_WIRE_DELAY + string(retime ? " -dff" : ""));
|
|
||||||
else if (help_mode)
|
|
||||||
run("abc -luts 2:2,3,6:5[,10,20] [-dff]", "(skip if 'nowidelut', only for '-retime')");
|
run("abc -luts 2:2,3,6:5[,10,20] [-dff]", "(skip if 'nowidelut', only for '-retime')");
|
||||||
else if (nowidelut)
|
else if (abc9) {
|
||||||
run("abc -luts 2:2,3,6:5" + string(retime ? " -dff" : ""));
|
if (nowidelut)
|
||||||
else
|
run("abc9 -lut +/xilinx/abc_xc7_nowide.lut -box +/xilinx/abc_xc7.box -W " + std::string(XC7_WIRE_DELAY) + string(retime ? " -dff" : ""));
|
||||||
run(abc + " -luts 2:2,3,6:5,10,20" + string(retime ? " -dff" : ""));
|
else
|
||||||
|
run("abc9 -lut +/xilinx/abc_xc7.lut -box +/xilinx/abc_xc7.box -W " + std::string(XC7_WIRE_DELAY) + string(retime ? " -dff" : ""));
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
if (nowidelut)
|
||||||
|
run("abc -luts 2:2,3,6:5" + string(retime ? " -dff" : ""));
|
||||||
|
else
|
||||||
|
run("abc -luts 2:2,3,6:5,10,20" + string(retime ? " -dff" : ""));
|
||||||
|
}
|
||||||
run("clean");
|
run("clean");
|
||||||
|
|
||||||
// This shregmap call infers fixed length shift registers after abc
|
// This shregmap call infers fixed length shift registers after abc
|
||||||
|
|
Loading…
Reference in New Issue