mirror of
https://github.com/YosysHQ/yosys
synced 2025-04-06 01:24:10 +00:00
Add support for "yosys -E"
Signed-off-by: Clifford Wolf <clifford@clifford.at>
This commit is contained in:
parent
446ccf1f05
commit
a96c775a73
|
@ -2638,6 +2638,7 @@ AstNode *AstNode::readmem(bool is_readmemh, std::string mem_filename, AstNode *m
|
||||||
|
|
||||||
std::ifstream f;
|
std::ifstream f;
|
||||||
f.open(mem_filename.c_str());
|
f.open(mem_filename.c_str());
|
||||||
|
yosys_input_files.insert(mem_filename);
|
||||||
|
|
||||||
if (f.fail())
|
if (f.fail())
|
||||||
log_error("Can not open file `%s` for %s at %s:%d.\n", mem_filename.c_str(), str.c_str(), filename.c_str(), linenum);
|
log_error("Can not open file `%s` for %s at %s:%d.\n", mem_filename.c_str(), str.c_str(), filename.c_str(), linenum);
|
||||||
|
|
|
@ -400,10 +400,12 @@ std::string frontend_verilog_preproc(std::istream &f, std::string filename, cons
|
||||||
if (!ff.fail()) break;
|
if (!ff.fail()) break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (ff.fail())
|
if (ff.fail()) {
|
||||||
output_code.push_back("`file_notfound " + fn);
|
output_code.push_back("`file_notfound " + fn);
|
||||||
else
|
} else {
|
||||||
input_file(ff, fixed_fn);
|
input_file(ff, fixed_fn);
|
||||||
|
yosys_input_files.insert(fixed_fn);
|
||||||
|
}
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -160,6 +160,7 @@ int main(int argc, char **argv)
|
||||||
std::vector<std::string> plugin_filenames;
|
std::vector<std::string> plugin_filenames;
|
||||||
std::string output_filename = "";
|
std::string output_filename = "";
|
||||||
std::string scriptfile = "";
|
std::string scriptfile = "";
|
||||||
|
std::string depsfile = "";
|
||||||
bool scriptfile_tcl = false;
|
bool scriptfile_tcl = false;
|
||||||
bool got_output_filename = false;
|
bool got_output_filename = false;
|
||||||
bool print_banner = true;
|
bool print_banner = true;
|
||||||
|
@ -256,6 +257,9 @@ int main(int argc, char **argv)
|
||||||
printf(" if a warning message matches the regex, it is printes as regular\n");
|
printf(" if a warning message matches the regex, it is printes as regular\n");
|
||||||
printf(" message instead.\n");
|
printf(" message instead.\n");
|
||||||
printf("\n");
|
printf("\n");
|
||||||
|
printf(" -E <depsfile>\n");
|
||||||
|
printf(" write a Makefile dependencies file with in- and output file names\n");
|
||||||
|
printf("\n");
|
||||||
printf(" -V\n");
|
printf(" -V\n");
|
||||||
printf(" print version information and exit\n");
|
printf(" print version information and exit\n");
|
||||||
printf("\n");
|
printf("\n");
|
||||||
|
@ -276,7 +280,7 @@ int main(int argc, char **argv)
|
||||||
}
|
}
|
||||||
|
|
||||||
int opt;
|
int opt;
|
||||||
while ((opt = getopt(argc, argv, "MXAQTVSm:f:Hh:b:o:p:l:L:qv:tds:c:W:w:D:")) != -1)
|
while ((opt = getopt(argc, argv, "MXAQTVSm:f:Hh:b:o:p:l:L:qv:tds:c:W:w:D:E:")) != -1)
|
||||||
{
|
{
|
||||||
switch (opt)
|
switch (opt)
|
||||||
{
|
{
|
||||||
|
@ -392,6 +396,9 @@ int main(int argc, char **argv)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case 'E':
|
||||||
|
depsfile = optarg;
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
fprintf(stderr, "Run '%s -h' for help.\n", argv[0]);
|
fprintf(stderr, "Run '%s -h' for help.\n", argv[0]);
|
||||||
exit(1);
|
exit(1);
|
||||||
|
@ -442,6 +449,24 @@ int main(int argc, char **argv)
|
||||||
if (!backend_command.empty())
|
if (!backend_command.empty())
|
||||||
run_backend(output_filename, backend_command);
|
run_backend(output_filename, backend_command);
|
||||||
|
|
||||||
|
if (!depsfile.empty())
|
||||||
|
{
|
||||||
|
FILE *f = fopen(depsfile.c_str(), "wt");
|
||||||
|
if (f == nullptr)
|
||||||
|
log_error("Can't open dependencies file for writing: %s\n", strerror(errno));
|
||||||
|
bool first = true;
|
||||||
|
for (auto fn : yosys_output_files) {
|
||||||
|
fprintf(f, "%s%s", first ? "" : " ", fn.c_str());
|
||||||
|
first = false;
|
||||||
|
}
|
||||||
|
fprintf(f, ":");
|
||||||
|
for (auto fn : yosys_input_files) {
|
||||||
|
if (yosys_output_files.count(fn) == 0)
|
||||||
|
fprintf(f, " %s", fn.c_str());
|
||||||
|
}
|
||||||
|
fprintf(f, "\n");
|
||||||
|
}
|
||||||
|
|
||||||
if (print_stats)
|
if (print_stats)
|
||||||
{
|
{
|
||||||
std::string hash = log_hasher->final().substr(0, 10);
|
std::string hash = log_hasher->final().substr(0, 10);
|
||||||
|
|
|
@ -428,6 +428,7 @@ void Frontend::extra_args(std::istream *&f, std::string &filename, std::vector<s
|
||||||
}
|
}
|
||||||
std::ifstream *ff = new std::ifstream;
|
std::ifstream *ff = new std::ifstream;
|
||||||
ff->open(filename.c_str());
|
ff->open(filename.c_str());
|
||||||
|
yosys_input_files.insert(filename);
|
||||||
if (ff->fail())
|
if (ff->fail())
|
||||||
delete ff;
|
delete ff;
|
||||||
else
|
else
|
||||||
|
@ -543,6 +544,7 @@ void Backend::extra_args(std::ostream *&f, std::string &filename, std::vector<st
|
||||||
filename = arg;
|
filename = arg;
|
||||||
std::ofstream *ff = new std::ofstream;
|
std::ofstream *ff = new std::ofstream;
|
||||||
ff->open(filename.c_str(), std::ofstream::trunc);
|
ff->open(filename.c_str(), std::ofstream::trunc);
|
||||||
|
yosys_output_files.insert(filename);
|
||||||
if (ff->fail()) {
|
if (ff->fail()) {
|
||||||
delete ff;
|
delete ff;
|
||||||
log_cmd_error("Can't open output file `%s' for writing: %s\n", filename.c_str(), strerror(errno));
|
log_cmd_error("Can't open output file `%s' for writing: %s\n", filename.c_str(), strerror(errno));
|
||||||
|
|
|
@ -64,6 +64,8 @@ CellTypes yosys_celltypes;
|
||||||
Tcl_Interp *yosys_tcl_interp = NULL;
|
Tcl_Interp *yosys_tcl_interp = NULL;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
std::set<std::string> yosys_input_files, yosys_output_files;
|
||||||
|
|
||||||
bool memhasher_active = false;
|
bool memhasher_active = false;
|
||||||
uint32_t memhasher_rng = 123456;
|
uint32_t memhasher_rng = 123456;
|
||||||
std::vector<void*> memhasher_store;
|
std::vector<void*> memhasher_store;
|
||||||
|
@ -831,8 +833,10 @@ void run_frontend(std::string filename, std::string command, std::string *backen
|
||||||
|
|
||||||
FILE *f = stdin;
|
FILE *f = stdin;
|
||||||
|
|
||||||
if (filename != "-")
|
if (filename != "-") {
|
||||||
f = fopen(filename.c_str(), "r");
|
f = fopen(filename.c_str(), "r");
|
||||||
|
yosys_input_files.insert(filename);
|
||||||
|
}
|
||||||
|
|
||||||
if (f == NULL)
|
if (f == NULL)
|
||||||
log_error("Can't open script file `%s' for reading: %s\n", filename.c_str(), strerror(errno));
|
log_error("Can't open script file `%s' for reading: %s\n", filename.c_str(), strerror(errno));
|
||||||
|
|
|
@ -305,6 +305,9 @@ void run_frontend(std::string filename, std::string command, RTLIL::Design *desi
|
||||||
void run_backend(std::string filename, std::string command, RTLIL::Design *design = nullptr);
|
void run_backend(std::string filename, std::string command, RTLIL::Design *design = nullptr);
|
||||||
void shell(RTLIL::Design *design);
|
void shell(RTLIL::Design *design);
|
||||||
|
|
||||||
|
// journal of all input and output files read (for "yosys -E")
|
||||||
|
extern std::set<std::string> yosys_input_files, yosys_output_files;
|
||||||
|
|
||||||
// from kernel/version_*.o (cc source generated from Makefile)
|
// from kernel/version_*.o (cc source generated from Makefile)
|
||||||
extern const char *yosys_version_str;
|
extern const char *yosys_version_str;
|
||||||
|
|
||||||
|
|
|
@ -835,6 +835,7 @@ struct QwpPass : public Pass {
|
||||||
}
|
}
|
||||||
if (args[argidx] == "-dump" && argidx+1 < args.size()) {
|
if (args[argidx] == "-dump" && argidx+1 < args.size()) {
|
||||||
config.dump_file.open(args[++argidx], std::ofstream::trunc);
|
config.dump_file.open(args[++argidx], std::ofstream::trunc);
|
||||||
|
yosys_output_files.insert(args[argidx]);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -1263,6 +1263,7 @@ struct SelectPass : public Pass {
|
||||||
log_cmd_error("Option -read can not be combined with a selection expression.\n");
|
log_cmd_error("Option -read can not be combined with a selection expression.\n");
|
||||||
|
|
||||||
std::ifstream f(read_file);
|
std::ifstream f(read_file);
|
||||||
|
yosys_input_files.insert(read_file);
|
||||||
if (f.fail())
|
if (f.fail())
|
||||||
log_error("Can't open '%s' for reading: %s\n", read_file.c_str(), strerror(errno));
|
log_error("Can't open '%s' for reading: %s\n", read_file.c_str(), strerror(errno));
|
||||||
|
|
||||||
|
@ -1331,6 +1332,7 @@ struct SelectPass : public Pass {
|
||||||
FILE *f = NULL;
|
FILE *f = NULL;
|
||||||
if (!write_file.empty()) {
|
if (!write_file.empty()) {
|
||||||
f = fopen(write_file.c_str(), "w");
|
f = fopen(write_file.c_str(), "w");
|
||||||
|
yosys_output_files.insert(write_file);
|
||||||
if (f == NULL)
|
if (f == NULL)
|
||||||
log_error("Can't open '%s' for writing: %s\n", write_file.c_str(), strerror(errno));
|
log_error("Can't open '%s' for writing: %s\n", write_file.c_str(), strerror(errno));
|
||||||
}
|
}
|
||||||
|
|
|
@ -681,6 +681,7 @@ struct ShowPass : public Pass {
|
||||||
bool flag_enum = false;
|
bool flag_enum = false;
|
||||||
bool flag_abbreviate = true;
|
bool flag_abbreviate = true;
|
||||||
bool flag_notitle = false;
|
bool flag_notitle = false;
|
||||||
|
bool custom_prefix = false;
|
||||||
RTLIL::IdString colorattr;
|
RTLIL::IdString colorattr;
|
||||||
|
|
||||||
size_t argidx;
|
size_t argidx;
|
||||||
|
@ -697,6 +698,7 @@ struct ShowPass : public Pass {
|
||||||
}
|
}
|
||||||
if (arg == "-prefix" && argidx+1 < args.size()) {
|
if (arg == "-prefix" && argidx+1 < args.size()) {
|
||||||
prefix = args[++argidx];
|
prefix = args[++argidx];
|
||||||
|
custom_prefix = true;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (arg == "-color" && argidx+2 < args.size()) {
|
if (arg == "-color" && argidx+2 < args.size()) {
|
||||||
|
@ -782,6 +784,7 @@ struct ShowPass : public Pass {
|
||||||
for (auto filename : libfiles) {
|
for (auto filename : libfiles) {
|
||||||
std::ifstream f;
|
std::ifstream f;
|
||||||
f.open(filename.c_str());
|
f.open(filename.c_str());
|
||||||
|
yosys_input_files.insert(filename);
|
||||||
if (f.fail())
|
if (f.fail())
|
||||||
log_error("Can't open lib file `%s'.\n", filename.c_str());
|
log_error("Can't open lib file `%s'.\n", filename.c_str());
|
||||||
RTLIL::Design *lib = new RTLIL::Design;
|
RTLIL::Design *lib = new RTLIL::Design;
|
||||||
|
@ -797,6 +800,8 @@ struct ShowPass : public Pass {
|
||||||
|
|
||||||
log("Writing dot description to `%s'.\n", dot_file.c_str());
|
log("Writing dot description to `%s'.\n", dot_file.c_str());
|
||||||
FILE *f = fopen(dot_file.c_str(), "w");
|
FILE *f = fopen(dot_file.c_str(), "w");
|
||||||
|
if (custom_prefix)
|
||||||
|
yosys_output_files.insert(dot_file);
|
||||||
if (f == NULL) {
|
if (f == NULL) {
|
||||||
for (auto lib : libs)
|
for (auto lib : libs)
|
||||||
delete lib;
|
delete lib;
|
||||||
|
|
|
@ -190,6 +190,7 @@ void read_liberty_cellarea(dict<IdString, double> &cell_area, string liberty_fil
|
||||||
{
|
{
|
||||||
std::ifstream f;
|
std::ifstream f;
|
||||||
f.open(liberty_file.c_str());
|
f.open(liberty_file.c_str());
|
||||||
|
yosys_input_files.insert(liberty_file);
|
||||||
if (f.fail())
|
if (f.fail())
|
||||||
log_cmd_error("Can't open liberty file `%s': %s\n", liberty_file.c_str(), strerror(errno));
|
log_cmd_error("Can't open liberty file `%s': %s\n", liberty_file.c_str(), strerror(errno));
|
||||||
LibertyParser libparser(f);
|
LibertyParser libparser(f);
|
||||||
|
|
|
@ -65,6 +65,7 @@ struct TeePass : public Pass {
|
||||||
if ((args[argidx] == "-o" || args[argidx] == "-a") && argidx+1 < args.size()) {
|
if ((args[argidx] == "-o" || args[argidx] == "-a") && argidx+1 < args.size()) {
|
||||||
const char *open_mode = args[argidx] == "-o" ? "w" : "a+";
|
const char *open_mode = args[argidx] == "-o" ? "w" : "a+";
|
||||||
FILE *f = fopen(args[++argidx].c_str(), open_mode);
|
FILE *f = fopen(args[++argidx].c_str(), open_mode);
|
||||||
|
yosys_input_files.insert(args[argidx]);
|
||||||
if (f == NULL) {
|
if (f == NULL) {
|
||||||
for (auto cf : files_to_close)
|
for (auto cf : files_to_close)
|
||||||
fclose(cf);
|
fclose(cf);
|
||||||
|
|
|
@ -67,6 +67,7 @@ struct WriteFileFrontend : public Frontend {
|
||||||
extra_args(f, filename, args, argidx);
|
extra_args(f, filename, args, argidx);
|
||||||
|
|
||||||
FILE *of = fopen(output_filename.c_str(), append_mode ? "a" : "w");
|
FILE *of = fopen(output_filename.c_str(), append_mode ? "a" : "w");
|
||||||
|
yosys_output_files.insert(output_filename);
|
||||||
char buffer[64 * 1024];
|
char buffer[64 * 1024];
|
||||||
int bytes;
|
int bytes;
|
||||||
|
|
||||||
|
|
|
@ -1095,6 +1095,7 @@ struct TechmapPass : public Pass {
|
||||||
std::ifstream f;
|
std::ifstream f;
|
||||||
rewrite_filename(fn);
|
rewrite_filename(fn);
|
||||||
f.open(fn.c_str());
|
f.open(fn.c_str());
|
||||||
|
yosys_input_files.insert(fn);
|
||||||
if (f.fail())
|
if (f.fail())
|
||||||
log_cmd_error("Can't open map file `%s'\n", fn.c_str());
|
log_cmd_error("Can't open map file `%s'\n", fn.c_str());
|
||||||
Frontend::frontend_call(map, &f, fn, (fn.size() > 3 && fn.substr(fn.size()-3) == ".il") ? "ilang" : verilog_frontend);
|
Frontend::frontend_call(map, &f, fn, (fn.size() > 3 && fn.substr(fn.size()-3) == ".il") ? "ilang" : verilog_frontend);
|
||||||
|
|
Loading…
Reference in a new issue