diff options
author | Clifford Wolf <clifford@clifford.at> | 2013-08-20 09:48:12 +0200 |
---|---|---|
committer | Clifford Wolf <clifford@clifford.at> | 2013-08-20 09:48:12 +0200 |
commit | 485e870bcd563c843a257b4c8178589c9c3a3e66 (patch) | |
tree | ec48f1cccfe68d2b74e0959038a827189af6b181 | |
parent | 1af1cebb64b5d8d3f0a66d01d05762a15b3bc0db (diff) | |
download | yosys-485e870bcd563c843a257b4c8178589c9c3a3e66.tar.gz yosys-485e870bcd563c843a257b4c8178589c9c3a3e66.tar.bz2 yosys-485e870bcd563c843a257b4c8178589c9c3a3e66.zip |
Added version info to yosys command and added -V option
-rw-r--r-- | .gitignore | 1 | ||||
-rw-r--r-- | Makefile | 8 | ||||
-rw-r--r-- | kernel/driver.cc | 15 |
3 files changed, 22 insertions, 2 deletions
diff --git a/.gitignore b/.gitignore index 4089e554f..72c0f2f62 100644 --- a/.gitignore +++ b/.gitignore @@ -15,3 +15,4 @@ /yosys-config /yosys-filterlib /yosys-svgviewer +/kernel/version_*.cc @@ -20,6 +20,10 @@ LDFLAGS = -rdynamic LDLIBS = -lstdc++ -lreadline -lm -ldl QMAKE = qmake-qt4 +YOSYS_VER := 0.0.x +GIT_REV := $(shell git rev-parse --short HEAD || echo UNKOWN) +OBJS = kernel/version_$(GIT_REV).o + -include Makefile.conf ifeq ($(CONFIG),clang-debug) @@ -76,6 +80,9 @@ top-all: $(TARGETS) $(EXTRA_TARGETS) yosys: $(OBJS) $(CXX) -o yosys $(LDFLAGS) $(OBJS) $(LDLIBS) +kernel/version_$(GIT_REV).cc: + echo "extern const char *yosys_version_str; const char *yosys_version_str=\"Yosys $(YOSYS_VER) (git sha1 $(GIT_REV))\";" > kernel/version_$(GIT_REV).cc + yosys-config: yosys-config.in sed 's,@CXX@,$(CXX),; s,@CXXFLAGS@,$(CXXFLAGS),; s,@LDFLAGS@,$(LDFLAGS),; s,@LDLIBS@,$(LDLIBS),;' < yosys-config.in > yosys-config chmod +x yosys-config @@ -105,6 +112,7 @@ manual: clean: rm -f $(OBJS) $(GENFILES) $(TARGETS) + rm -f kernel/version_*.o kernel/version_*.cc rm -f libs/*/*.d frontends/*/*.d passes/*/*.d backends/*/*.d kernel/*.d cd manual && rm -f *.aux *.bbl *.blg *.idx *.log *.out *.pdf *.toc test ! -f libs/svgviewer/Makefile || make -C libs/svgviewer distclean diff --git a/kernel/driver.cc b/kernel/driver.cc index 8765c8b87..8d8f29e77 100644 --- a/kernel/driver.cc +++ b/kernel/driver.cc @@ -31,6 +31,9 @@ #include "kernel/register.h" #include "kernel/log.h" +// from kernel/version_*.o (cc source generated from Makefile) +extern const char *yosys_version_str; + bool fgetline(FILE *f, std::string &buffer) { buffer = ""; @@ -438,10 +441,13 @@ int main(int argc, char **argv) } int opt; - while ((opt = getopt(argc, argv, "Sm:f:b:o:p:l:qts:c:")) != -1) + while ((opt = getopt(argc, argv, "VSm:f:b:o:p:l:qts:c:")) != -1) { switch (opt) { + case 'V': + printf("%s\n", yosys_version_str); + exit(0); case 'S': backend_command = "verilog -noattr"; passes_commands.push_back("hierarchy"); @@ -494,7 +500,7 @@ int main(int argc, char **argv) break; default: fprintf(stderr, "\n"); - fprintf(stderr, "Usage: %s [-S] [-q] [-t] [-l logfile] [-o <outfile>] [-f <frontend>] [{-s|-c} <scriptfile>]\n", argv[0]); + fprintf(stderr, "Usage: %s [-V] [-S] [-q] [-t] [-l logfile] [-o <outfile>] [-f <frontend>] [{-s|-c} <scriptfile>]\n", argv[0]); fprintf(stderr, " %*s[-p <pass> [-p ..]] [-b <backend>] [-m <module_file>] [<infile> [..]]\n", int(strlen(argv[0])+1), ""); fprintf(stderr, "\n"); fprintf(stderr, " -q\n"); @@ -527,6 +533,9 @@ int main(int argc, char **argv) fprintf(stderr, " -m module_file\n"); fprintf(stderr, " load the specified module (aka plugin)\n"); fprintf(stderr, "\n"); + fprintf(stderr, " -V\n"); + fprintf(stderr, " print version information and exit\n"); + fprintf(stderr, "\n"); fprintf(stderr, "The option -S is an alias for the following options that perform a simple\n"); fprintf(stderr, "transformation of the input to a gate-level netlist. This can be helpful when\n"); fprintf(stderr, "e.g. using yosys as a pre-processor for a tool that can't understand full verilog.\n"); @@ -569,6 +578,8 @@ int main(int argc, char **argv) log(" | |\n"); log(" \\-----------------------------------------------------------------------------/\n"); log("\n"); + log(" %s\n", yosys_version_str); + log("\n"); Pass::init_register(); |