- kernel/register.h, kernel/driver.cc: refactor rewrite_yosys_exe()/get_share_file_name() to portable proc_self_dirname()/proc_share_dirname().

This refactoring improves robustness and allows OSX support with only 7 new lines of code, and easy extension for other systems.
 - passes/abc/abc.cc, passes/cmds/show.cc, passes/techmap/techmap.cc: use new, refactored semantics.
 - Makefile: no need to add $(PWD) to $(PATH) anymore.
This commit is contained in:
Siesh1oo 2014-03-12 18:33:37 +01:00
parent 50423e3935
commit 5a50760e2c
6 changed files with 44 additions and 39 deletions

View File

@ -26,8 +26,6 @@ CXXFLAGS = -Wall -Wextra -ggdb -I"$(shell pwd)" -I${DESTDIR}/include -MD -D_YOSY
LDFLAGS = -L${DESTDIR}/lib LDFLAGS = -L${DESTDIR}/lib
LDLIBS = -lstdc++ -lreadline -lm -ldl LDLIBS = -lstdc++ -lreadline -lm -ldl
export PATH := $(PWD):$(DESTDIR)/bin:$(PATH)
ifeq (Darwin,$(findstring Darwin,$(shell uname))) ifeq (Darwin,$(findstring Darwin,$(shell uname)))
# add macports include and library path to search directories, don't use '-rdynamic' and '-lrt': # add macports include and library path to search directories, don't use '-rdynamic' and '-lrt':
CXXFLAGS += -I/opt/local/include CXXFLAGS += -I/opt/local/include

View File

@ -24,6 +24,7 @@
#include <unistd.h> #include <unistd.h>
#include <libgen.h> #include <libgen.h>
#include <dlfcn.h> #include <dlfcn.h>
#include <limits.h>
#include <errno.h> #include <errno.h>
#include <algorithm> #include <algorithm>
@ -427,42 +428,46 @@ extern RTLIL::Design *yosys_get_design()
return yosys_design; return yosys_design;
} }
std::string rewrite_yosys_exe(std::string exe) #if defined(__linux__)
std::string proc_self_dirname ()
{ {
char buffer[1024]; char path [PATH_MAX];
ssize_t buflen = readlink("/proc/self/exe", buffer, sizeof(buffer)-1); ssize_t buflen = readlink("/proc/self/exe", path, sizeof(path));
if (buflen < 0) {
if (buflen < 0) log_cmd_error("readlink(\"/proc/self/exe\") failed: %s", strerror(errno));
return exe; log_abort();
}
buffer[buflen] = 0; while (buflen > 0 && path[buflen-1] != '/')
std::string newexe = stringf("%s/%s", dirname(buffer), exe.c_str()); buflen--;
if (access(newexe.c_str(), X_OK) == 0) return std::string(path, buflen);
return newexe;
return exe;
} }
#elif defined(__APPLE__)
std::string get_share_file_name(std::string file) #include <mach-o/dyld.h>
std::string proc_self_dirname ()
{ {
char buffer[1024]; char * path = NULL;
ssize_t buflen = readlink("/proc/self/exe", buffer, sizeof(buffer)-1); uint32_t buflen = 0;
while (_NSGetExecutablePath(path, &buflen) != 0)
path = (char *) realloc((void *) path, buflen);
while (buflen > 0 && path[buflen-1] != '/')
buflen--;
return std::string(path, buflen);
}
#else
#error Dont know how to determine process executable base path!
#endif
if (buflen < 0) std::string proc_share_dirname ()
log_error("Can't find file `%s': reading of /proc/self/exe failed!\n", file.c_str()); {
std::string proc_self_path = proc_self_dirname();
buffer[buflen] = 0; std::string proc_share_path = proc_self_path + "share/";
const char *dir = dirname(buffer); if (access(proc_share_path.c_str(), X_OK) == 0)
return proc_share_path;
std::string newfile_inplace = stringf("%s/share/%s", dir, file.c_str()); proc_share_path = proc_self_path + "../share/yosys/";
if (access(newfile_inplace.c_str(), F_OK) == 0) if (access(proc_share_path.c_str(), X_OK) == 0)
return newfile_inplace; return proc_share_path;
log_cmd_error("proc_share_dirname: unable to determine share/ directory!");
std::string newfile_system = stringf("%s/../share/yosys/%s", dir, file.c_str()); log_abort();
if (access(newfile_system.c_str(), F_OK) == 0)
return newfile_system;
log_error("Can't find file `%s': no `%s' and no `%s' found!\n", file.c_str(), newfile_inplace.c_str(), newfile_system.c_str());
} }
int main(int argc, char **argv) int main(int argc, char **argv)

View File

@ -36,8 +36,8 @@ extern const char *yosys_version_str;
// implemented in driver.cc // implemented in driver.cc
extern RTLIL::Design *yosys_get_design(); extern RTLIL::Design *yosys_get_design();
std::string rewrite_yosys_exe(std::string exe); extern std::string proc_self_dirname();
std::string get_share_file_name(std::string file); extern std::string proc_share_dirname();
const char *create_prompt(RTLIL::Design *design, int recursion_counter); const char *create_prompt(RTLIL::Design *design, int recursion_counter);
// from passes/cmds/design.cc // from passes/cmds/design.cc

View File

@ -969,7 +969,7 @@ struct AbcPass : public Pass {
log_header("Executing ABC pass (technology mapping using ABC).\n"); log_header("Executing ABC pass (technology mapping using ABC).\n");
log_push(); log_push();
std::string exe_file = rewrite_yosys_exe("yosys-abc"); std::string exe_file = proc_self_dirname() + "yosys-abc";
std::string script_file, liberty_file, constr_file, clk_str; std::string script_file, liberty_file, constr_file, clk_str;
bool dff_mode = false, keepff = false, cleanup = true; bool dff_mode = false, keepff = false, cleanup = true;
int lut_mode = 0; int lut_mode = 0;

View File

@ -751,7 +751,8 @@ struct ShowPass : public Pass {
log_cmd_error("Shell command failed!\n"); log_cmd_error("Shell command failed!\n");
} else } else
if (format.empty()) { if (format.empty()) {
std::string cmd = stringf("fuser -s '%s' || '%s' '%s' &", out_file.c_str(), rewrite_yosys_exe("yosys-svgviewer").c_str(), out_file.c_str()); std::string svgviewer = proc_self_dirname() + "yosys-svgviewer";
std::string cmd = stringf("fuser -s '%s' || '%s' '%s' &", out_file.c_str(), svgviewer.c_str(), out_file.c_str());
log("Exec: %s\n", cmd.c_str()); log("Exec: %s\n", cmd.c_str());
if (system(cmd.c_str()) != 0) if (system(cmd.c_str()) != 0)
log_cmd_error("Shell command failed!\n"); log_cmd_error("Shell command failed!\n");

View File

@ -548,13 +548,14 @@ struct TechmapPass : public Pass {
int max_iter = -1; int max_iter = -1;
size_t argidx; size_t argidx;
std::string proc_share_path = proc_share_dirname();
for (argidx = 1; argidx < args.size(); argidx++) { for (argidx = 1; argidx < args.size(); argidx++) {
if (args[argidx] == "-map" && argidx+1 < args.size()) { if (args[argidx] == "-map" && argidx+1 < args.size()) {
map_files.push_back(args[++argidx]); map_files.push_back(args[++argidx]);
continue; continue;
} }
if (args[argidx] == "-share_map" && argidx+1 < args.size()) { if (args[argidx] == "-share_map" && argidx+1 < args.size()) {
map_files.push_back(get_share_file_name(args[++argidx])); map_files.push_back(proc_share_path + args[++argidx]);
continue; continue;
} }
if (args[argidx] == "-max_iter" && argidx+1 < args.size()) { if (args[argidx] == "-max_iter" && argidx+1 < args.size()) {