diff options
author | Clifford Wolf <clifford@clifford.at> | 2016-04-21 15:31:54 +0200 |
---|---|---|
committer | Clifford Wolf <clifford@clifford.at> | 2016-04-21 15:31:54 +0200 |
commit | 5a09fa45535ffceae90359be727d2ff6e0ac2c58 (patch) | |
tree | d41d328e4dcf94154bbbec0124a94b0d2f8f3894 /frontends/verilog | |
parent | f38ca3e18fb27472595d59be8c0cea7ef50b7c4c (diff) | |
download | yosys-5a09fa45535ffceae90359be727d2ff6e0ac2c58.tar.gz yosys-5a09fa45535ffceae90359be727d2ff6e0ac2c58.tar.bz2 yosys-5a09fa45535ffceae90359be727d2ff6e0ac2c58.zip |
Fixed handling of parameters and const functions in casex/casez pattern
Diffstat (limited to 'frontends/verilog')
-rw-r--r-- | frontends/verilog/verilog_parser.y | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/frontends/verilog/verilog_parser.y b/frontends/verilog/verilog_parser.y index 568cadd94..f95849133 100644 --- a/frontends/verilog/verilog_parser.y +++ b/frontends/verilog/verilog_parser.y @@ -1094,7 +1094,9 @@ case_body: case_item: { - AstNode *node = new AstNode(AST_COND); + AstNode *node = new AstNode( + case_type_stack.size() && case_type_stack.back() == 'x' ? AST_CONDX : + case_type_stack.size() && case_type_stack.back() == 'z' ? AST_CONDZ : AST_COND); ast_stack.back()->children.push_back(node); ast_stack.push_back(node); } case_select { @@ -1114,7 +1116,9 @@ gen_case_body: gen_case_item: { - AstNode *node = new AstNode(AST_COND); + AstNode *node = new AstNode( + case_type_stack.size() && case_type_stack.back() == 'x' ? AST_CONDX : + case_type_stack.size() && case_type_stack.back() == 'z' ? AST_CONDZ : AST_COND); ast_stack.back()->children.push_back(node); ast_stack.push_back(node); } case_select { |