solidity/test/formal/exp_neg_one.py

18 lines
412 B
Python
Raw Permalink Normal View History

from opcodes import AND, ISZERO, MOD, SUB
2020-09-25 15:05:15 +00:00
from rule import Rule
from util import BVUnsignedMax
from z3 import BitVec, BitVecVal, If
2020-09-25 15:05:15 +00:00
"""
Checking conversion of exp(-1, X) to sub(isZero(and(X, 1)), and(X, 1))
"""
rule = Rule()
n_bits = 256
X = BitVec('X', n_bits)
exp_neg_one = If(MOD(X, 2) == 0, BitVecVal(1, n_bits), BVUnsignedMax(n_bits, n_bits))
rule.check(SUB(ISZERO(AND(X, 1)), AND(X, 1)), exp_neg_one)