mirror of
https://github.com/YosysHQ/yosys
synced 2025-10-24 00:14:36 +00:00
Fixed supply0/supply1 with many wires
This commit is contained in:
parent
032511fac8
commit
1282a113da
1 changed files with 15 additions and 3 deletions
|
@ -655,21 +655,33 @@ wire_decl:
|
||||||
delete astbuf2;
|
delete astbuf2;
|
||||||
free_attr(albuf);
|
free_attr(albuf);
|
||||||
} ';' |
|
} ';' |
|
||||||
attr TOK_SUPPLY0 TOK_ID ';' {
|
attr TOK_SUPPLY0 TOK_ID {
|
||||||
ast_stack.back()->children.push_back(new AstNode(AST_WIRE));
|
ast_stack.back()->children.push_back(new AstNode(AST_WIRE));
|
||||||
ast_stack.back()->children.back()->str = *$3;
|
ast_stack.back()->children.back()->str = *$3;
|
||||||
append_attr(ast_stack.back()->children.back(), $1);
|
append_attr(ast_stack.back()->children.back(), $1);
|
||||||
ast_stack.back()->children.push_back(new AstNode(AST_ASSIGN, new AstNode(AST_IDENTIFIER), AstNode::mkconst_int(0, false, 1)));
|
ast_stack.back()->children.push_back(new AstNode(AST_ASSIGN, new AstNode(AST_IDENTIFIER), AstNode::mkconst_int(0, false, 1)));
|
||||||
ast_stack.back()->children.back()->children[0]->str = *$3;
|
ast_stack.back()->children.back()->children[0]->str = *$3;
|
||||||
delete $3;
|
delete $3;
|
||||||
} |
|
} opt_supply_wires ';' |
|
||||||
attr TOK_SUPPLY1 TOK_ID ';' {
|
attr TOK_SUPPLY1 TOK_ID {
|
||||||
ast_stack.back()->children.push_back(new AstNode(AST_WIRE));
|
ast_stack.back()->children.push_back(new AstNode(AST_WIRE));
|
||||||
ast_stack.back()->children.back()->str = *$3;
|
ast_stack.back()->children.back()->str = *$3;
|
||||||
append_attr(ast_stack.back()->children.back(), $1);
|
append_attr(ast_stack.back()->children.back(), $1);
|
||||||
ast_stack.back()->children.push_back(new AstNode(AST_ASSIGN, new AstNode(AST_IDENTIFIER), AstNode::mkconst_int(1, false, 1)));
|
ast_stack.back()->children.push_back(new AstNode(AST_ASSIGN, new AstNode(AST_IDENTIFIER), AstNode::mkconst_int(1, false, 1)));
|
||||||
ast_stack.back()->children.back()->children[0]->str = *$3;
|
ast_stack.back()->children.back()->children[0]->str = *$3;
|
||||||
delete $3;
|
delete $3;
|
||||||
|
} opt_supply_wires ';';
|
||||||
|
|
||||||
|
opt_supply_wires:
|
||||||
|
/* empty */ |
|
||||||
|
opt_supply_wires ',' TOK_ID {
|
||||||
|
AstNode *wire_node = ast_stack.back()->children.at(GetSize(ast_stack.back()->children)-2)->clone();
|
||||||
|
AstNode *assign_node = ast_stack.back()->children.at(GetSize(ast_stack.back()->children)-1)->clone();
|
||||||
|
wire_node->str = *$3;
|
||||||
|
assign_node->children[0]->str = *$3;
|
||||||
|
ast_stack.back()->children.push_back(wire_node);
|
||||||
|
ast_stack.back()->children.push_back(assign_node);
|
||||||
|
delete $3;
|
||||||
};
|
};
|
||||||
|
|
||||||
wire_name_list:
|
wire_name_list:
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue