aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAndrew Zonenberg <azonenberg@drawersteak.com>2016-03-30 20:38:18 -0700
committerAndrew Zonenberg <azonenberg@drawersteak.com>2016-03-30 20:38:18 -0700
commitd16d05e41587a282a53eda59af837b7d264498fc (patch)
tree01febb97bddc8cefa1352916d1b1c5baca21b101
parent94a6923e7dd363c5b11116e9bd85aa012fed512a (diff)
parent0db53284fd610cac1e956a87c7eec7df3d8564c5 (diff)
downloadyosys-d16d05e41587a282a53eda59af837b7d264498fc.tar.gz
yosys-d16d05e41587a282a53eda59af837b7d264498fc.tar.bz2
yosys-d16d05e41587a282a53eda59af837b7d264498fc.zip
Merge https://github.com/cliffordwolf/yosys
-rw-r--r--README2
-rw-r--r--kernel/yosys.cc4
-rw-r--r--passes/cmds/plugin.cc8
3 files changed, 10 insertions, 4 deletions
diff --git a/README b/README
index 5c649a4e8..f0dcd3c07 100644
--- a/README
+++ b/README
@@ -3,7 +3,7 @@
| |
| yosys -- Yosys Open SYnthesis Suite |
| |
- | Copyright (C) 2012 - 2015 Clifford Wolf <clifford@clifford.at> |
+ | Copyright (C) 2012 - 2016 Clifford Wolf <clifford@clifford.at> |
| |
| Permission to use, copy, modify, and/or distribute this software for any |
| purpose with or without fee is hereby granted, provided that the above |
diff --git a/kernel/yosys.cc b/kernel/yosys.cc
index a69a85447..501d94224 100644
--- a/kernel/yosys.cc
+++ b/kernel/yosys.cc
@@ -104,7 +104,7 @@ void yosys_banner()
log(" | |\n");
log(" | yosys -- Yosys Open SYnthesis Suite |\n");
log(" | |\n");
- log(" | Copyright (C) 2012 - 2015 Clifford Wolf <clifford@clifford.at> |\n");
+ log(" | Copyright (C) 2012 - 2016 Clifford Wolf <clifford@clifford.at> |\n");
log(" | |\n");
log(" | Permission to use, copy, modify, and/or distribute this software for any |\n");
log(" | purpose with or without fee is hereby granted, provided that the above |\n");
@@ -763,6 +763,8 @@ void run_frontend(std::string filename, std::string command, std::string *backen
command = "verilog";
else if (filename.size() > 2 && filename.substr(filename.size()-3) == ".sv")
command = "verilog -sv";
+ else if (filename.size() > 2 && filename.substr(filename.size()-4) == ".vhd")
+ command = "vhdl";
else if (filename.size() > 4 && filename.substr(filename.size()-5) == ".blif")
command = "blif";
else if (filename.size() > 3 && filename.substr(filename.size()-3) == ".il")
diff --git a/passes/cmds/plugin.cc b/passes/cmds/plugin.cc
index e2d80d9bf..828c671de 100644
--- a/passes/cmds/plugin.cc
+++ b/passes/cmds/plugin.cc
@@ -31,19 +31,23 @@ std::map<std::string, std::string> loaded_plugin_aliases;
#ifdef YOSYS_ENABLE_PLUGINS
void load_plugin(std::string filename, std::vector<std::string> aliases)
{
+ std::string orig_filename = filename;
+
if (filename.find('/') == std::string::npos)
filename = "./" + filename;
if (!loaded_plugins.count(filename)) {
void *hdl = dlopen(filename.c_str(), RTLD_LAZY|RTLD_LOCAL);
+ if (hdl == NULL && orig_filename.find('/') == std::string::npos)
+ hdl = dlopen((proc_share_dirname() + "plugins/" + orig_filename + ".so").c_str(), RTLD_LAZY|RTLD_LOCAL);
if (hdl == NULL)
log_cmd_error("Can't load module `%s': %s\n", filename.c_str(), dlerror());
- loaded_plugins[filename] = hdl;
+ loaded_plugins[orig_filename] = hdl;
Pass::init_register();
}
for (auto &alias : aliases)
- loaded_plugin_aliases[alias] = filename;
+ loaded_plugin_aliases[alias] = orig_filename;
}
#else
void load_plugin(std::string, std::vector<std::string>)