Merge pull request #2104 from whitequark/simplify-techmap

techmap: simplify
This commit is contained in:
whitequark 2020-06-03 12:45:02 +00:00 committed by GitHub
commit 577859fbdb
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 8 additions and 40 deletions

View File

@ -1 +0,0 @@
techmap.inc

View File

@ -45,18 +45,6 @@ OBJS += passes/techmap/flowmap.o
OBJS += passes/techmap/extractinv.o OBJS += passes/techmap/extractinv.o
endif endif
GENFILES += passes/techmap/techmap.inc
passes/techmap/techmap.inc: techlibs/common/techmap.v
$(Q) mkdir -p $(dir $@)
$(P) echo "// autogenerated from $<" > $@.new
$(Q) echo "static char stdcells_code[] = {" >> $@.new
$(Q) od -v -td1 -An $< | $(SED) -e 's/[0-9][0-9]*/&,/g' >> $@.new
$(Q) echo "0};" >> $@.new
$(Q) mv $@.new $@
passes/techmap/techmap.o: passes/techmap/techmap.inc
ifeq ($(DISABLE_SPAWN),0) ifeq ($(DISABLE_SPAWN),0)
TARGETS += $(PROGRAM_PREFIX)yosys-filterlib$(EXE) TARGETS += $(PROGRAM_PREFIX)yosys-filterlib$(EXE)
EXTRA_OBJS += passes/techmap/filterlib.o EXTRA_OBJS += passes/techmap/filterlib.o

View File

@ -27,7 +27,6 @@
#include <string.h> #include <string.h>
#include "simplemap.h" #include "simplemap.h"
#include "passes/techmap/techmap.inc"
YOSYS_NAMESPACE_BEGIN YOSYS_NAMESPACE_BEGIN
@ -81,22 +80,12 @@ struct TechmapWorker
typedef dict<IdString, std::vector<TechmapWireData>> TechmapWires; typedef dict<IdString, std::vector<TechmapWireData>> TechmapWires;
bool extern_mode; bool extern_mode = false;
bool assert_mode; bool assert_mode = false;
bool flatten_mode; bool flatten_mode = false;
bool recursive_mode; bool recursive_mode = false;
bool autoproc_mode; bool autoproc_mode = false;
bool ignore_wb; bool ignore_wb = false;
TechmapWorker()
{
extern_mode = false;
assert_mode = false;
flatten_mode = false;
recursive_mode = false;
autoproc_mode = false;
ignore_wb = false;
}
std::string constmap_tpl_name(SigMap &sigmap, RTLIL::Module *tpl, RTLIL::Cell *cell, bool verbose) std::string constmap_tpl_name(SigMap &sigmap, RTLIL::Module *tpl, RTLIL::Cell *cell, bool verbose)
{ {
@ -279,7 +268,6 @@ struct TechmapWorker
tpl_written_bits.insert(bit); tpl_written_bits.insert(bit);
SigMap port_signal_map; SigMap port_signal_map;
SigSig port_signal_assign;
for (auto &it : cell->connections()) for (auto &it : cell->connections())
{ {
@ -1282,8 +1270,7 @@ struct TechmapPass : public Pass {
RTLIL::Design *map = new RTLIL::Design; RTLIL::Design *map = new RTLIL::Design;
if (map_files.empty()) { if (map_files.empty()) {
std::istringstream f(stdcells_code); Frontend::frontend_call(map, nullptr, "+/techmap.v", verilog_frontend);
Frontend::frontend_call(map, &f, "<techmap.v>", verilog_frontend);
} else { } else {
for (auto &fn : map_files) for (auto &fn : map_files)
if (fn.compare(0, 1, "%") == 0) { if (fn.compare(0, 1, "%") == 0) {
@ -1295,13 +1282,7 @@ struct TechmapPass : public Pass {
if (!map->module(mod->name)) if (!map->module(mod->name))
map->add(mod->clone()); map->add(mod->clone());
} else { } else {
std::ifstream f; Frontend::frontend_call(map, nullptr, fn, (fn.size() > 3 && fn.compare(fn.size()-3, std::string::npos, ".il") == 0 ? "ilang" : verilog_frontend));
rewrite_filename(fn);
f.open(fn.c_str());
yosys_input_files.insert(fn);
if (f.fail())
log_cmd_error("Can't open map file `%s'\n", fn.c_str());
Frontend::frontend_call(map, &f, fn, (fn.size() > 3 && fn.compare(fn.size()-3, std::string::npos, ".il") == 0 ? "ilang" : verilog_frontend));
} }
} }