mirror of
https://github.com/Z3Prover/z3
synced 2025-04-23 09:05:31 +00:00
parent
2551631957
commit
913b90f7aa
1 changed files with 4 additions and 1 deletions
|
@ -2828,7 +2828,10 @@ br_status bv_rewriter::mk_bvsmul_no_overflow(unsigned num, expr * const * args,
|
|||
if (sign1) a1_val = rational::power_of_two(bv_sz) - a1_val;
|
||||
rational lim = rational::power_of_two(bv_sz-1);
|
||||
rational r = a0_val * a1_val;
|
||||
result = m().mk_bool_val((is_overflow == (sign0 != sign1)) || r < lim);
|
||||
if (is_overflow)
|
||||
result = m().mk_bool_val(sign0 != sign1 || r < lim);
|
||||
else
|
||||
result = m().mk_bool_val(sign0 == sign1 || r <= lim);
|
||||
return BR_DONE;
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue