aboutsummaryrefslogtreecommitdiffstats
path: root/kernel
diff options
context:
space:
mode:
authorN. Engelhardt <nak@yosyshq.com>2022-08-16 16:03:23 +0200
committerN. Engelhardt <nakengelhardt@gmail.com>2022-08-25 13:36:51 +0200
commit7e92e80741890e87bf50817495fb2c808b083617 (patch)
tree1b2bb5122f504788f0aa312a26d82e88755736ed /kernel
parent8e640663d6b7ff84043068f48ed5f3cf7bff4321 (diff)
downloadyosys-7e92e80741890e87bf50817495fb2c808b083617.tar.gz
yosys-7e92e80741890e87bf50817495fb2c808b083617.tar.bz2
yosys-7e92e80741890e87bf50817495fb2c808b083617.zip
dump runtime information for passes to json
Diffstat (limited to 'kernel')
-rw-r--r--kernel/driver.cc29
1 files changed, 28 insertions, 1 deletions
diff --git a/kernel/driver.cc b/kernel/driver.cc
index e52e1fb0e..d25b5faa8 100644
--- a/kernel/driver.cc
+++ b/kernel/driver.cc
@@ -210,6 +210,7 @@ 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;
@@ -353,7 +354,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, "MXAQTVSgm:f:Hh:b:o:p:l:L:qv:tds:c:W:w:e:r:D:P:E:x:B:")) != -1)
{
switch (opt)
{
@@ -488,6 +489,9 @@ int main(int argc, char **argv)
case 'x':
log_experimentals_ignored.insert(optarg);
break;
+ case 'B':
+ perffile = optarg;
+ break;
default:
fprintf(stderr, "Run '%s -h' for help.\n", argv[0]);
exit(1);
@@ -674,6 +678,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\": %lu,\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\": %lu,\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__))