diff options
author | Clifford Wolf <clifford@clifford.at> | 2013-11-24 19:57:42 +0100 |
---|---|---|
committer | Clifford Wolf <clifford@clifford.at> | 2013-11-24 19:57:42 +0100 |
commit | 7d9a90396d119375567b42eb0ff4bb120c355d9a (patch) | |
tree | 288b3027be14d0e2d42d394a86a57aaa45d65b67 /frontends/verilog/verilog_frontend.cc | |
parent | 20175afd298be717aa91a96c9d8654859cf2dd2d (diff) | |
download | yosys-7d9a90396d119375567b42eb0ff4bb120c355d9a.tar.gz yosys-7d9a90396d119375567b42eb0ff4bb120c355d9a.tar.bz2 yosys-7d9a90396d119375567b42eb0ff4bb120c355d9a.zip |
Added verilog frontend -ignore_redef option
Diffstat (limited to 'frontends/verilog/verilog_frontend.cc')
-rw-r--r-- | frontends/verilog/verilog_frontend.cc | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/frontends/verilog/verilog_frontend.cc b/frontends/verilog/verilog_frontend.cc index 1ef2f6608..dcccb4e9a 100644 --- a/frontends/verilog/verilog_frontend.cc +++ b/frontends/verilog/verilog_frontend.cc @@ -96,6 +96,10 @@ struct VerilogFrontend : public Frontend { log(" don't perform basic optimizations (such as const folding) in the\n"); log(" high-level front-end.\n"); log("\n"); + log(" -ignore_redef\n"); + log(" ignore re-definitions of modules. (the default behavior is to\n"); + log(" create an error message.)\n"); + log("\n"); log(" -Dname[=definition]\n"); log(" define the preprocessor symbol 'name' and set its optional value\n"); log(" 'definition'\n"); @@ -117,6 +121,7 @@ struct VerilogFrontend : public Frontend { bool flag_nopp = false; bool flag_lib = false; bool flag_noopt = false; + bool flag_ignore_redef = false; std::map<std::string, std::string> defines_map; std::list<std::string> include_dirs; frontend_verilog_yydebug = false; @@ -170,6 +175,10 @@ struct VerilogFrontend : public Frontend { flag_noopt = true; continue; } + if (arg == "-ignore_redef") { + flag_ignore_redef = true; + continue; + } if (arg.compare(0,2,"-D") == 0) { size_t equal = arg.find('=',2); // returns string::npos it not found std::string name = arg.substr(2,equal-2); @@ -211,7 +220,7 @@ struct VerilogFrontend : public Frontend { frontend_verilog_yyparse(); frontend_verilog_yylex_destroy(); - AST::process(design, current_ast, flag_dump_ast1, flag_dump_ast2, flag_dump_vlog, flag_nolatches, flag_nomem2reg, flag_mem2reg, flag_lib, flag_noopt); + AST::process(design, current_ast, flag_dump_ast1, flag_dump_ast2, flag_dump_vlog, flag_nolatches, flag_nomem2reg, flag_mem2reg, flag_lib, flag_noopt, flag_ignore_redef); if (!flag_nopp) fclose(fp); |