aboutsummaryrefslogtreecommitdiffstats
path: root/frontends
diff options
context:
space:
mode:
authorClifford Wolf <clifford@clifford.at>2019-04-23 22:18:04 +0200
committerClifford Wolf <clifford@clifford.at>2019-04-23 22:18:04 +0200
commit4575e4ad86494e99dd05200f7242dfa632053c78 (patch)
tree7e9d7b41dc8d873a6e6b1d2b927802dbffccdb8f /frontends
parent71c38d9de527e1a8b55ba295df459fbcf2a0fe47 (diff)
downloadyosys-4575e4ad86494e99dd05200f7242dfa632053c78.tar.gz
yosys-4575e4ad86494e99dd05200f7242dfa632053c78.tar.bz2
yosys-4575e4ad86494e99dd05200f7242dfa632053c78.zip
Improve $specrule interface
Signed-off-by: Clifford Wolf <clifford@clifford.at>
Diffstat (limited to 'frontends')
-rw-r--r--frontends/verilog/verilog_parser.y38
1 files changed, 18 insertions, 20 deletions
diff --git a/frontends/verilog/verilog_parser.y b/frontends/verilog/verilog_parser.y
index 0a41ba581..13ff1d38b 100644
--- a/frontends/verilog/verilog_parser.y
+++ b/frontends/verilog/verilog_parser.y
@@ -817,12 +817,7 @@ specify_item:
delete timing;
} |
TOK_ID '(' specify_edge expr specify_condition ',' specify_edge expr specify_condition ',' expr ')' ';' {
- bool limit_gt = false;
- if (*$1 == "$setup" || *$1 == "$hold")
- limit_gt = true;
- else if (*$1 == "$skew")
- limit_gt = false;
- else
+ if (*$1 != "$setup" && *$1 != "$hold" && *$1 != "$skew")
frontend_verilog_yyerror("Unsupported specify rule type: %s\n", $1->c_str());
AstNode *src_pen = AstNode::mkconst_int($3 != 0, false, 1);
@@ -841,11 +836,14 @@ specify_item:
cell->children.push_back(new AstNode(AST_CELLTYPE));
cell->children.back()->str = "$specrule";
- cell->children.push_back(new AstNode(AST_ARGUMENT, src_en));
- cell->children.back()->str = "\\SRC_EN";
+ cell->children.push_back(new AstNode(AST_PARASET, AstNode::mkconst_int(*$1 == "$skew", false, 1)));
+ cell->children.back()->str = "\\SKEW";
- cell->children.push_back(new AstNode(AST_ARGUMENT, src_expr));
- cell->children.back()->str = "\\SRC";
+ cell->children.push_back(new AstNode(AST_PARASET, AstNode::mkconst_int(*$1 == "$hold", false, 1)));
+ cell->children.back()->str = "\\HOLD";
+
+ cell->children.push_back(new AstNode(AST_PARASET, limit));
+ cell->children.back()->str = "\\T_LIMIT";
cell->children.push_back(new AstNode(AST_PARASET, src_pen));
cell->children.back()->str = "\\SRC_PEN";
@@ -853,23 +851,23 @@ specify_item:
cell->children.push_back(new AstNode(AST_PARASET, src_pol));
cell->children.back()->str = "\\SRC_POL";
- cell->children.push_back(new AstNode(AST_ARGUMENT, dst_en));
- cell->children.back()->str = "\\DST_EN";
-
- cell->children.push_back(new AstNode(AST_ARGUMENT, dst_expr));
- cell->children.back()->str = "\\DST";
-
cell->children.push_back(new AstNode(AST_PARASET, dst_pen));
cell->children.back()->str = "\\DST_PEN";
cell->children.push_back(new AstNode(AST_PARASET, dst_pol));
cell->children.back()->str = "\\DST_POL";
- cell->children.push_back(new AstNode(AST_PARASET, AstNode::mkconst_int(limit_gt, false, 1)));
- cell->children.back()->str = "\\LIMIT_GT";
+ cell->children.push_back(new AstNode(AST_ARGUMENT, src_en));
+ cell->children.back()->str = "\\SRC_EN";
- cell->children.push_back(new AstNode(AST_PARASET, limit));
- cell->children.back()->str = "\\T_LIMIT";
+ cell->children.push_back(new AstNode(AST_ARGUMENT, src_expr));
+ cell->children.back()->str = "\\SRC";
+
+ cell->children.push_back(new AstNode(AST_ARGUMENT, dst_en));
+ cell->children.back()->str = "\\DST_EN";
+
+ cell->children.push_back(new AstNode(AST_ARGUMENT, dst_expr));
+ cell->children.back()->str = "\\DST";
delete $1;
};