aboutsummaryrefslogtreecommitdiffstats
path: root/frontends/verilog/verilog_parser.y
diff options
context:
space:
mode:
authorClifford Wolf <clifford@clifford.at>2016-04-21 15:31:54 +0200
committerClifford Wolf <clifford@clifford.at>2016-04-21 15:31:54 +0200
commit5a09fa45535ffceae90359be727d2ff6e0ac2c58 (patch)
treed41d328e4dcf94154bbbec0124a94b0d2f8f3894 /frontends/verilog/verilog_parser.y
parentf38ca3e18fb27472595d59be8c0cea7ef50b7c4c (diff)
downloadyosys-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/verilog_parser.y')
-rw-r--r--frontends/verilog/verilog_parser.y8
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 {