mirror of https://github.com/YosysHQ/yosys.git
Behavior should be identical now to rev. 0b4a64ac6a
(next: testing before constfold fixes)
This commit is contained in:
parent
f912e029de
commit
ada80545fa
|
@ -570,6 +570,8 @@ void AstNode::detectSignWidthWorker(int &width_hint, bool &sign_hint)
|
||||||
this_width = range->range_left - range->range_right + 1;
|
this_width = range->range_left - range->range_right + 1;
|
||||||
} else
|
} else
|
||||||
width_hint = std::max(width_hint, this_width);
|
width_hint = std::max(width_hint, this_width);
|
||||||
|
if (!id2ast->is_signed)
|
||||||
|
sign_hint = false;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case AST_TO_SIGNED:
|
case AST_TO_SIGNED:
|
||||||
|
|
|
@ -920,8 +920,10 @@ skip_dynamic_range_lvalue_expansion:;
|
||||||
if (0) { case AST_POS: const_func = RTLIL::const_pos; }
|
if (0) { case AST_POS: const_func = RTLIL::const_pos; }
|
||||||
if (0) { case AST_NEG: const_func = RTLIL::const_neg; }
|
if (0) { case AST_NEG: const_func = RTLIL::const_neg; }
|
||||||
if (children[0]->type == AST_CONSTANT) {
|
if (children[0]->type == AST_CONSTANT) {
|
||||||
RTLIL::Const y = const_func(children[0]->bitsAsConst(width_hint), dummy_arg, sign_hint, false, width_hint);
|
RTLIL::Const y = const_func(RTLIL::Const(children[0]->bits), dummy_arg, children[0]->is_signed, false, -1);
|
||||||
newNode = mkconst_bits(y.bits, sign_hint);
|
newNode = mkconst_bits(y.bits, children[0]->is_signed);
|
||||||
|
// RTLIL::Const y = const_func(children[0]->bitsAsConst(width_hint), dummy_arg, sign_hint, false, width_hint);
|
||||||
|
// newNode = mkconst_bits(y.bits, sign_hint);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case AST_TERNARY:
|
case AST_TERNARY:
|
||||||
|
|
|
@ -73,10 +73,10 @@ module test10(a, b, c, y);
|
||||||
assign y = ^(a ? b : c);
|
assign y = ^(a ? b : c);
|
||||||
endmodule
|
endmodule
|
||||||
|
|
||||||
module test11(a, b, y);
|
// module test11(a, b, y);
|
||||||
input signed [3:0] a;
|
// input signed [3:0] a;
|
||||||
input signed [3:0] b;
|
// input signed [3:0] b;
|
||||||
output signed [5:0] y;
|
// output signed [5:0] y;
|
||||||
assign y = -(5'd27);
|
// assign y = -(5'd27);
|
||||||
endmodule
|
// endmodule
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue