aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/driver.cc
diff options
context:
space:
mode:
Diffstat (limited to 'kernel/driver.cc')
-rw-r--r--kernel/driver.cc79
1 files changed, 72 insertions, 7 deletions
diff --git a/kernel/driver.cc b/kernel/driver.cc
index f8f940e89..ef8e77924 100644
--- a/kernel/driver.cc
+++ b/kernel/driver.cc
@@ -33,6 +33,10 @@
#include <string.h>
#include <limits.h>
#include <errno.h>
+#ifndef __STDC_FORMAT_MACROS
+# define __STDC_FORMAT_MACROS
+#endif
+#include <inttypes.h>
#if defined (__linux__) || defined(__FreeBSD__)
# include <sys/resource.h>
@@ -192,6 +196,19 @@ void yosys_atexit()
#endif
}
+#if defined(__OpenBSD__)
+namespace Yosys {
+extern char *yosys_argv0;
+extern char yosys_path[PATH_MAX];
+};
+#endif
+#ifdef YOSYS_ENABLE_TCL
+namespace Yosys {
+ extern int yosys_tcl_iterp_init(Tcl_Interp *interp);
+ extern void yosys_tcl_activate_repl();
+};
+#endif
+
int main(int argc, char **argv)
{
std::string frontend_command = "auto";
@@ -203,12 +220,14 @@ int main(int argc, char **argv)
std::string scriptfile = "";
std::string depsfile = "";
std::string topmodule = "";
+ std::string perffile = "";
bool scriptfile_tcl = false;
bool print_banner = true;
bool print_stats = true;
bool call_abort = false;
bool timing_details = false;
bool run_shell = true;
+ bool run_tcl_shell = false;
bool mode_v = false;
bool mode_q = false;
@@ -272,10 +291,13 @@ int main(int argc, char **argv)
printf("\n");
printf(" -c tcl_scriptfile\n");
printf(" execute the commands in the tcl script file (see 'help tcl' for details)\n");
+ printf("\n");
+ printf(" -C\n");
+ printf(" enters TCL interatcive shell mode\n");
#endif
printf("\n");
printf(" -p command\n");
- printf(" execute the commands\n");
+ printf(" execute the commands (to chain commands, separate them with semicolon + whitespace: 'cmd1; cmd2')\n");
printf("\n");
printf(" -m module_file\n");
printf(" load the specified module (aka plugin)\n");
@@ -346,7 +368,7 @@ int main(int argc, char **argv)
}
int opt;
- while ((opt = getopt(argc, argv, "MXAQTVSgm:f:Hh:b:o:p:l:L:qv:tds:c:W:w:e:r:D:P:E:x:")) != -1)
+ while ((opt = getopt(argc, argv, "MXAQTVCSgm:f:Hh:b:o:p:l:L:qv:tds:c:W:w:e:r:D:P:E:x:B:")) != -1)
{
switch (opt)
{
@@ -481,6 +503,12 @@ int main(int argc, char **argv)
case 'x':
log_experimentals_ignored.insert(optarg);
break;
+ case 'B':
+ perffile = optarg;
+ break;
+ case 'C':
+ run_tcl_shell = true;
+ break;
default:
fprintf(stderr, "Run '%s -h' for help.\n", argv[0]);
exit(1);
@@ -498,6 +526,12 @@ int main(int argc, char **argv)
if (print_stats)
log_hasher = new SHA1;
+#if defined(__OpenBSD__)
+ // save the executable origin for proc_self_dirname()
+ yosys_argv0 = argv[0];
+ realpath(yosys_argv0, yosys_path);
+#endif
+
#if defined(__linux__)
// set stack size to >= 128 MB
{
@@ -549,10 +583,19 @@ int main(int argc, char **argv)
for (auto it = passes_commands.begin(); it != passes_commands.end(); it++)
run_pass(*it);
- if (run_shell)
- shell(yosys_design);
- else
- run_backend(output_filename, backend_command);
+ if (run_tcl_shell) {
+#ifdef YOSYS_ENABLE_TCL
+ yosys_tcl_activate_repl();
+ Tcl_Main(argc, argv, yosys_tcl_iterp_init);
+#else
+ log_error("Can't exectue TCL shell: this version of yosys is not built with TCL support enabled.\n");
+#endif
+ } else {
+ if (run_shell)
+ shell(yosys_design);
+ else
+ run_backend(output_filename, backend_command);
+ }
yosys_design->check();
for (auto it : saved_designs)
@@ -661,6 +704,29 @@ int main(int argc, char **argv)
}
log("%s\n", out_count ? "" : " no commands executed");
}
+ if(!perffile.empty())
+ {
+ FILE *f = fopen(perffile.c_str(), "wt");
+ if (f == nullptr)
+ log_error("Can't open performance log file for writing: %s\n", strerror(errno));
+
+ fprintf(f, "{\n");
+ fprintf(f, " \"generator\": \"%s\",\n", yosys_version_str);
+ fprintf(f, " \"total_ns\": %" PRIu64 ",\n", total_ns);
+ fprintf(f, " \"passes\": {");
+
+ bool first = true;
+ for (auto it = timedat.rbegin(); it != timedat.rend(); it++) {
+ if (!first)
+ fprintf(f, ",");
+ fprintf(f, "\n \"%s\": {\n", std::get<2>(*it).c_str());
+ fprintf(f, " \"runtime_ns\": %" PRIu64 ",\n", std::get<0>(*it));
+ fprintf(f, " \"num_calls\": %u\n", std::get<1>(*it));
+ fprintf(f, " }");
+ first = false;
+ }
+ fprintf(f, "\n }\n}\n");
+ }
}
#if defined(YOSYS_ENABLE_COVER) && (defined(__linux__) || defined(__FreeBSD__))
@@ -711,4 +777,3 @@ int main(int argc, char **argv)
}
#endif /* EMSCRIPTEN */
-