2022-10-26 10:13:47 +00:00
|
|
|
{
|
|
|
|
"auxiliaryInputRequested":
|
|
|
|
{
|
|
|
|
"smtlib2queries":
|
|
|
|
{
|
|
|
|
"0xb91b28779c6db8b1a6ceecabfa97788476fbb427474cd132376917103e4bc9d9": "(set-option :produce-models true)
|
2021-01-19 11:56:22 +00:00
|
|
|
(set-logic ALL)
|
|
|
|
(declare-fun |error_0| () Int)
|
|
|
|
(declare-fun |this_0| () Int)
|
|
|
|
(declare-datatypes ((|state_type| 0)) (((|state_type| (|balances| (Array Int Int))))))
|
|
|
|
(declare-fun |state_0| () |state_type|)
|
|
|
|
(declare-datatypes ((|bytes_tuple| 0)) (((|bytes_tuple| (|bytes_tuple_accessor_array| (Array Int Int)) (|bytes_tuple_accessor_length| Int)))))
|
2021-08-12 13:57:44 +00:00
|
|
|
(declare-datatypes ((|tx_type| 0)) (((|tx_type| (|block.basefee| Int) (|block.chainid| Int) (|block.coinbase| Int) (|block.difficulty| Int) (|block.gaslimit| Int) (|block.number| Int) (|block.timestamp| Int) (|blockhash| (Array Int Int)) (|msg.data| |bytes_tuple|) (|msg.sender| Int) (|msg.sig| Int) (|msg.value| Int) (|tx.gasprice| Int) (|tx.origin| Int)))))
|
2021-01-19 11:56:22 +00:00
|
|
|
(declare-fun |tx_0| () |tx_type|)
|
|
|
|
(declare-datatypes ((|ecrecover_input_type| 0)) (((|ecrecover_input_type| (|hash| Int) (|v| Int) (|r| Int) (|s| Int)))))
|
|
|
|
(declare-datatypes ((|crypto_type| 0)) (((|crypto_type| (|ecrecover| (Array |ecrecover_input_type| Int)) (|keccak256| (Array |bytes_tuple| Int)) (|ripemd160| (Array |bytes_tuple| Int)) (|sha256| (Array |bytes_tuple| Int))))))
|
|
|
|
(declare-fun |crypto_0| () |crypto_type|)
|
|
|
|
(declare-datatypes ((|abi_type| 0)) (((|abi_type|))))
|
|
|
|
(declare-fun |abi_0| () |abi_type|)
|
2021-05-18 18:15:31 +00:00
|
|
|
(declare-datatypes ((|uint_array_tuple| 0)) (((|uint_array_tuple| (|uint_array_tuple_accessor_array| (Array Int Int)) (|uint_array_tuple_accessor_length| Int)))))
|
|
|
|
(declare-fun |arr_4_length_pair_0| () |uint_array_tuple|)
|
2021-03-31 15:31:23 +00:00
|
|
|
(declare-fun |a_6_0| () Int)
|
|
|
|
(declare-fun |x_8_0| () Int)
|
2021-05-18 18:15:31 +00:00
|
|
|
(declare-fun |arr_4_length_pair_1| () |uint_array_tuple|)
|
2021-03-31 15:31:23 +00:00
|
|
|
(declare-fun |expr_12_0| () Int)
|
2021-01-19 11:56:22 +00:00
|
|
|
(declare-fun |expr_13_0| () Int)
|
2021-03-31 15:31:23 +00:00
|
|
|
(declare-fun |expr_14_1| () Bool)
|
|
|
|
(declare-fun |expr_17_0| () Int)
|
|
|
|
(declare-fun |expr_18_1| () Int)
|
|
|
|
(declare-fun |x_8_1| () Int)
|
|
|
|
(declare-fun |expr_20_0| () Int)
|
|
|
|
(declare-fun |expr_25_1| () Int)
|
2021-01-19 11:56:22 +00:00
|
|
|
(declare-fun |expr_26_1| () Int)
|
2021-03-31 15:31:23 +00:00
|
|
|
(declare-fun |expr_28_0| () Int)
|
2021-01-19 11:56:22 +00:00
|
|
|
(declare-fun |expr_29_0| () Int)
|
|
|
|
(declare-fun |d_div_mod_0_0| () Int)
|
|
|
|
(declare-fun |r_div_mod_0_0| () Int)
|
2021-03-31 15:31:23 +00:00
|
|
|
(declare-fun |expr_30_1| () Int)
|
|
|
|
(declare-fun |expr_32_0| () Int)
|
|
|
|
(declare-fun |expr_35_0| () Int)
|
2021-01-19 11:56:22 +00:00
|
|
|
(declare-fun |state_1| () |state_type|)
|
|
|
|
(declare-fun |state_2| () |state_type|)
|
|
|
|
(declare-fun |state_3| () |state_type|)
|
2021-03-31 15:31:23 +00:00
|
|
|
(declare-fun |expr_39_0| () Int)
|
2021-01-19 11:56:22 +00:00
|
|
|
(declare-fun |expr_40_0| () Int)
|
2021-03-31 15:31:23 +00:00
|
|
|
(declare-fun |expr_41_1| () Bool)
|
2021-05-18 18:15:31 +00:00
|
|
|
(declare-fun |expr_44_length_pair_0| () |uint_array_tuple|)
|
|
|
|
(declare-fun |expr_44_length_pair_1| () |uint_array_tuple|)
|
|
|
|
(declare-fun |arr_4_length_pair_2| () |uint_array_tuple|)
|
|
|
|
(declare-fun |expr_49_length_pair_0| () |uint_array_tuple|)
|
2021-03-31 15:31:23 +00:00
|
|
|
(declare-fun |expr_50_0| () Int)
|
|
|
|
(declare-fun |expr_51_1| () Int)
|
2021-01-19 11:56:22 +00:00
|
|
|
|
2021-08-12 13:57:44 +00:00
|
|
|
(assert (and (and (and true true) (and (=> (and true true) (and (>= expr_25_1 0) (<= expr_25_1 115792089237316195423570985008687907853269984665640564039457584007913129639935))) (and (= expr_25_1 115792089237316195423570985008687907853269984665640564039457584007913129639935) (and (=> (and true true) (and (>= expr_20_0 0) (<= expr_20_0 115792089237316195423570985008687907853269984665640564039457584007913129639935))) (and (= expr_20_0 x_8_1) (and (ite (and true true) (= x_8_1 (- expr_17_0 1)) (= x_8_1 x_8_0)) (and (=> (and true true) (and (>= expr_18_1 0) (<= expr_18_1 115792089237316195423570985008687907853269984665640564039457584007913129639935))) (and (= expr_18_1 (- expr_17_0 1)) (and (=> (and true true) (and (>= expr_17_0 0) (<= expr_17_0 115792089237316195423570985008687907853269984665640564039457584007913129639935))) (and (= expr_17_0 x_8_0) (and (=> (and true true) expr_14_1) (and (= expr_14_1 (>= expr_12_0 expr_13_0)) (and (=> (and true true) true) (and (= expr_13_0 0) (and (=> (and true true) (and (>= expr_12_0 0) (<= expr_12_0 115792089237316195423570985008687907853269984665640564039457584007913129639935))) (and (= expr_12_0 x_8_0) (and (and (>= x_8_0 0) (<= x_8_0 115792089237316195423570985008687907853269984665640564039457584007913129639935)) (and (and (>= a_6_0 0) (<= a_6_0 1461501637330902918203684832716283019655932542975)) (and (>= (|uint_array_tuple_accessor_length| arr_4_length_pair_1) 0) (and (and (and (and (and (and (and (and (and (and (and (and (and (>= (|block.basefee| tx_0) 0) (<= (|block.basefee| tx_0) 115792089237316195423570985008687907853269984665640564039457584007913129639935)) (and (>= (|block.chainid| tx_0) 0) (<= (|block.chainid| tx_0) 115792089237316195423570985008687907853269984665640564039457584007913129639935))) (and (>= (|block.coinbase| tx_0) 0) (<= (|block.coinbase| tx_0) 1461501637330902918203684832716283019655932542975))) (and (>= (|block.difficulty| tx_0) 0) (<= (|block.difficulty| tx_0) 115792089237316195423570985008687907853269984665640564039457584007913129639935))) (and (>= (|block.gaslimit| tx_0) 0) (<= (|block.gaslimit| tx_0) 115792089237316195423570985008687907853269984665640564039457584007913129639935))) (and (>= (|block.number| tx_0) 0) (<= (|block.number| tx_0) 115792089237316195423570985008687907853269984665640564039457584007913129639935))) (and (>= (|block.timestamp| tx_0) 0) (<= (|block.timestamp| tx_0) 115792089237316195423570985008687907853269984665640564039457584007913129639935))) (and (>= (|msg.sender| tx_0) 0) (<= (|msg.sender| tx_0) 1461501637330902918203684832716283019655932542975))) (and (>= (|msg.value| tx_0) 0) (<= (|msg.value| tx_0) 115792089237316195423570985008687907853269984665640564039457584007913129639935))) (and (>= (|tx.origin| tx_0) 0) (<= (|tx.origin| tx_0) 1461501637330902918203684832716283019655932542975))) (and (>= (|tx.gasprice| tx_0) 0) (<= (|tx.gasprice| tx_0) 115792089237316195423570985008687907853269984665640564039457584007913129639935))) (and (and (and (and (and (and (= (|msg.value| tx_0) 0) (= (|msg.sig| tx_0) 1917212865)) (= (select (|bytes_tuple_accessor_array| (|msg.data| tx_0)) 0) 114)) (= (select (|bytes_tuple_accessor_array| (|msg.data| tx_0)) 1) 70)) (= (select (|bytes_tuple_accessor_array| (|msg.data| tx_0)) 2) 88)) (= (select (|bytes_tuple_accessor_array| (|msg.data| tx_0)) 3) 193)) (>= (|bytes_tuple_accessor_length| (|msg.data| tx_0)) 4))) true)))))))))))))))))))) (> (+ expr_20_0 expr_25_1) 115792089237316195423570985008687907853269984665640564039457584007913129639935)))
|
2021-01-19 11:56:22 +00:00
|
|
|
(declare-const |EVALEXPR_0| Int)
|
2021-03-31 15:31:23 +00:00
|
|
|
(assert (= |EVALEXPR_0| a_6_0))
|
2021-01-19 11:56:22 +00:00
|
|
|
(declare-const |EVALEXPR_1| Int)
|
2021-03-31 15:31:23 +00:00
|
|
|
(assert (= |EVALEXPR_1| x_8_1))
|
2021-01-19 11:56:22 +00:00
|
|
|
(declare-const |EVALEXPR_2| Int)
|
2021-03-31 15:31:23 +00:00
|
|
|
(assert (= |EVALEXPR_2| (+ expr_20_0 expr_25_1)))
|
2021-01-19 11:56:22 +00:00
|
|
|
(check-sat)
|
|
|
|
(get-value (|EVALEXPR_0| |EVALEXPR_1| |EVALEXPR_2| ))
|
2022-10-26 10:13:47 +00:00
|
|
|
"
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"errors":
|
|
|
|
[
|
|
|
|
{
|
|
|
|
"component": "general",
|
|
|
|
"errorCode": "2661",
|
|
|
|
"formattedMessage": "Warning: BMC: Overflow (resulting value larger than 2**256 - 1) happens here.
|
2021-01-19 11:56:22 +00:00
|
|
|
--> A:9:7:
|
|
|
|
|
|
|
|
|
9 | \t\t\t\t\t\tx + type(uint).max;
|
|
|
|
| \t\t\t\t\t\t^^^^^^^^^^^^^^^^^^
|
|
|
|
Note: Counterexample:
|
|
|
|
<result> = 2**256
|
|
|
|
a = 0
|
|
|
|
x = 1
|
|
|
|
|
|
|
|
Note: Callstack:
|
|
|
|
Note:
|
|
|
|
|
2022-10-26 10:13:47 +00:00
|
|
|
",
|
|
|
|
"message": "BMC: Overflow (resulting value larger than 2**256 - 1) happens here.",
|
|
|
|
"secondarySourceLocations":
|
|
|
|
[
|
|
|
|
{
|
|
|
|
"message": "Counterexample:
|
2021-01-19 11:56:22 +00:00
|
|
|
<result> = 2**256
|
|
|
|
a = 0
|
|
|
|
x = 1
|
2022-10-26 10:13:47 +00:00
|
|
|
"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"message": "Callstack:"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"message": ""
|
|
|
|
}
|
|
|
|
],
|
|
|
|
"severity": "warning",
|
|
|
|
"sourceLocation":
|
|
|
|
{
|
|
|
|
"end": 203,
|
|
|
|
"file": "A",
|
|
|
|
"start": 185
|
|
|
|
},
|
|
|
|
"type": "Warning"
|
|
|
|
}
|
|
|
|
],
|
|
|
|
"sources":
|
|
|
|
{
|
|
|
|
"A":
|
|
|
|
{
|
|
|
|
"id": 0
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|