diff options
Diffstat (limited to 'frontends/ast')
| -rw-r--r-- | frontends/ast/ast.cc | 2 | ||||
| -rw-r--r-- | frontends/ast/simplify.cc | 7 | 
2 files changed, 7 insertions, 2 deletions
| diff --git a/frontends/ast/ast.cc b/frontends/ast/ast.cc index 2b6002548..245a53611 100644 --- a/frontends/ast/ast.cc +++ b/frontends/ast/ast.cc @@ -1153,6 +1153,7 @@ void AST::process(RTLIL::Design *design, AstNode *ast, bool dump_ast1, bool dump  		bool nolatches, bool nomeminit, bool nomem2reg, bool mem2reg, bool noblackbox, bool lib, bool nowb, bool noopt, bool icells, bool pwires, bool nooverwrite, bool overwrite, bool defer, bool autowire)  {  	current_ast = ast; +	current_ast_mod = nullptr;  	flag_dump_ast1 = dump_ast1;  	flag_dump_ast2 = dump_ast2;  	flag_no_dump_ptr = no_dump_ptr; @@ -1219,6 +1220,7 @@ void AST::process(RTLIL::Design *design, AstNode *ast, bool dump_ast1, bool dump  			}  			design->add(process_module(*it, defer)); +			current_ast_mod = nullptr;  		}  		else if ((*it)->type == AST_PACKAGE) {  			// process enum/other declarations diff --git a/frontends/ast/simplify.cc b/frontends/ast/simplify.cc index cb89f58ba..372dcf95c 100644 --- a/frontends/ast/simplify.cc +++ b/frontends/ast/simplify.cc @@ -1169,7 +1169,8 @@ bool AstNode::simplify(bool const_fold, bool at_zero, bool in_lvalue, int stage,  	// annotate identifiers using scope resolution and create auto-wires as needed  	if (type == AST_IDENTIFIER) {  		if (current_scope.count(str) == 0) { -			for (auto node : current_ast_mod->children) { +			AstNode *current_scope_ast = (current_ast_mod == nullptr) ? current_ast : current_ast_mod; +			for (auto node : current_scope_ast->children) {  				//log("looking at mod scope child %s\n", type2str(node->type).c_str());  				switch (node->type) {  				case AST_PARAMETER: @@ -1203,7 +1204,9 @@ bool AstNode::simplify(bool const_fold, bool at_zero, bool in_lvalue, int stage,  			}  		}  		if (current_scope.count(str) == 0) { -			if (flag_autowire || str == "\\$global_clock") { +			if (current_ast_mod == nullptr) { +				log_file_error(filename, location.first_line, "Identifier `%s' is implicitly declared outside of a module.\n", str.c_str()); +			} else if (flag_autowire || str == "\\$global_clock") {  				AstNode *auto_wire = new AstNode(AST_AUTOWIRE);  				auto_wire->str = str;  				current_ast_mod->children.push_back(auto_wire); | 
