mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Do not optimize zero literals if PUSH0 iz available
cmdline tests
This commit is contained in:
parent
83fe3d4011
commit
22c679b981
@ -25,6 +25,7 @@
|
||||
#include <libyul/optimiser/BlockHasher.h>
|
||||
#include <libyul/optimiser/CallGraphGenerator.h>
|
||||
#include <libyul/optimiser/Semantics.h>
|
||||
#include <libyul/backends/evm/EVMDialect.h>
|
||||
#include <libyul/SideEffects.h>
|
||||
#include <libyul/Exceptions.h>
|
||||
#include <libyul/AST.h>
|
||||
@ -110,14 +111,22 @@ void CommonSubexpressionEliminator::visit(Expression& _e)
|
||||
if (AssignedValue const* value = variableValue(variable))
|
||||
{
|
||||
assertThrow(value->value, OptimizerException, "");
|
||||
// Prevent using the default value of return variables
|
||||
// instead of literal zeros.
|
||||
if (
|
||||
m_returnVariables.count(variable) &&
|
||||
holds_alternative<Literal>(*value->value) &&
|
||||
valueOfLiteral(get<Literal>(*value->value)) == 0
|
||||
)
|
||||
continue;
|
||||
{
|
||||
// Prevent using the default value of return variables
|
||||
// instead of literal zeros.
|
||||
if (m_returnVariables.count(variable))
|
||||
continue;
|
||||
// Do not replace literal zeros when PUSH0 command is available.
|
||||
if (auto&& evmDialect = dynamic_cast<EVMDialect const*>(&m_dialect))
|
||||
{
|
||||
if (evmDialect->evmVersion().hasPush0())
|
||||
continue;
|
||||
}
|
||||
}
|
||||
// We check for syntactic equality again because the value might have changed.
|
||||
if (inScope(variable) && SyntacticallyEqual{}(_e, *value->value))
|
||||
{
|
||||
|
@ -815,7 +815,7 @@ Optimized IR AST:
|
||||
[
|
||||
{
|
||||
"kind": "number",
|
||||
"nativeSrc": "650:1:0",
|
||||
"nativeSrc": "647:1:0",
|
||||
"nodeType": "YulLiteral",
|
||||
"src": "60:13:0",
|
||||
"type": "",
|
||||
@ -1028,7 +1028,59 @@ Optimized IR AST:
|
||||
[
|
||||
{
|
||||
"kind": "number",
|
||||
"nativeSrc": "1490:1:0",
|
||||
"nativeSrc": "996:2:0",
|
||||
"nodeType": "YulLiteral",
|
||||
"src": "60:13:0",
|
||||
"type": "",
|
||||
"value": "64"
|
||||
},
|
||||
{
|
||||
"arguments":
|
||||
[
|
||||
{
|
||||
"kind": "number",
|
||||
"nativeSrc": "1012:3:0",
|
||||
"nodeType": "YulLiteral",
|
||||
"src": "60:13:0",
|
||||
"type": "",
|
||||
"value": "0x80"
|
||||
}
|
||||
],
|
||||
"functionName":
|
||||
{
|
||||
"name": "memoryguard",
|
||||
"nativeSrc": "1000:11:0",
|
||||
"nodeType": "YulIdentifier",
|
||||
"src": "60:13:0"
|
||||
},
|
||||
"nativeSrc": "1000:16:0",
|
||||
"nodeType": "YulFunctionCall",
|
||||
"src": "60:13:0"
|
||||
}
|
||||
],
|
||||
"functionName":
|
||||
{
|
||||
"name": "mstore",
|
||||
"nativeSrc": "989:6:0",
|
||||
"nodeType": "YulIdentifier",
|
||||
"src": "60:13:0"
|
||||
},
|
||||
"nativeSrc": "989:28:0",
|
||||
"nodeType": "YulFunctionCall",
|
||||
"src": "60:13:0"
|
||||
},
|
||||
"nativeSrc": "989:28:0",
|
||||
"nodeType": "YulExpressionStatement",
|
||||
"src": "60:13:0"
|
||||
},
|
||||
{
|
||||
"expression":
|
||||
{
|
||||
"arguments":
|
||||
[
|
||||
{
|
||||
"kind": "number",
|
||||
"nativeSrc": "1487:1:0",
|
||||
"nodeType": "YulLiteral",
|
||||
"src": "60:13:0",
|
||||
"type": "",
|
||||
|
@ -20,6 +20,7 @@ object "C_12" {
|
||||
code {
|
||||
{
|
||||
/// @src 0:61:418 "contract C {..."
|
||||
mstore(64, memoryguard(0x80))
|
||||
if callvalue() { revert(0, 0) }
|
||||
/// @src 0:279:410 "assembly {..."
|
||||
sstore(0, 0x1000000000000000000000000000000000000000000000)
|
||||
|
@ -187,14 +187,14 @@ object "C_6" {
|
||||
code {
|
||||
{
|
||||
/// @src 0:60:101 "contract C {..."
|
||||
mstore(64, memoryguard(0x80))
|
||||
if iszero(lt(calldatasize(), 4))
|
||||
{
|
||||
let _1 := 0
|
||||
if eq(0x26121ff0, shr(224, calldataload(_1)))
|
||||
if eq(0x26121ff0, shr(224, calldataload(0)))
|
||||
{
|
||||
if callvalue() { revert(_1, _1) }
|
||||
if slt(add(calldatasize(), not(3)), _1) { revert(_1, _1) }
|
||||
return(_1, _1)
|
||||
if callvalue() { revert(0, 0) }
|
||||
if slt(add(calldatasize(), not(3)), 0) { revert(0, 0) }
|
||||
return(0, 0)
|
||||
}
|
||||
}
|
||||
revert(0, 0)
|
||||
|
@ -186,14 +186,14 @@ object "C_6" {
|
||||
code {
|
||||
{
|
||||
/// @src 0:60:101
|
||||
mstore(64, memoryguard(0x80))
|
||||
if iszero(lt(calldatasize(), 4))
|
||||
{
|
||||
let _1 := 0
|
||||
if eq(0x26121ff0, shr(224, calldataload(_1)))
|
||||
if eq(0x26121ff0, shr(224, calldataload(0)))
|
||||
{
|
||||
if callvalue() { revert(_1, _1) }
|
||||
if slt(add(calldatasize(), not(3)), _1) { revert(_1, _1) }
|
||||
return(_1, _1)
|
||||
if callvalue() { revert(0, 0) }
|
||||
if slt(add(calldatasize(), not(3)), 0) { revert(0, 0) }
|
||||
return(0, 0)
|
||||
}
|
||||
}
|
||||
revert(0, 0)
|
||||
|
@ -175,14 +175,14 @@ object "C_6" {
|
||||
object "C_6_deployed" {
|
||||
code {
|
||||
{
|
||||
mstore(64, memoryguard(0x80))
|
||||
if iszero(lt(calldatasize(), 4))
|
||||
{
|
||||
let _1 := 0
|
||||
if eq(0x26121ff0, shr(224, calldataload(_1)))
|
||||
if eq(0x26121ff0, shr(224, calldataload(0)))
|
||||
{
|
||||
if callvalue() { revert(_1, _1) }
|
||||
if slt(add(calldatasize(), not(3)), _1) { revert(_1, _1) }
|
||||
return(_1, _1)
|
||||
if callvalue() { revert(0, 0) }
|
||||
if slt(add(calldatasize(), not(3)), 0) { revert(0, 0) }
|
||||
return(0, 0)
|
||||
}
|
||||
}
|
||||
revert(0, 0)
|
||||
|
@ -81,6 +81,7 @@ object "C_2" {
|
||||
code {
|
||||
{
|
||||
/// @src 0:265:278 "contract C {}"
|
||||
mstore(64, memoryguard(0x80))
|
||||
revert(0, 0)
|
||||
}
|
||||
}
|
||||
@ -434,65 +435,64 @@ object "D_27" {
|
||||
mstore(_2, _1)
|
||||
if iszero(lt(calldatasize(), 4))
|
||||
{
|
||||
let _3 := 0
|
||||
if eq(0x26121ff0, shr(224, calldataload(_3)))
|
||||
if eq(0x26121ff0, shr(224, calldataload(0)))
|
||||
{
|
||||
if callvalue() { revert(_3, _3) }
|
||||
if slt(add(calldatasize(), not(3)), _3) { revert(_3, _3) }
|
||||
if callvalue() { revert(0, 0) }
|
||||
if slt(add(calldatasize(), not(3)), 0) { revert(0, 0) }
|
||||
/// @src 0:446:491 "new /// @src 0:149:156 \"new C()\"..."
|
||||
let _4 := datasize("C_2")
|
||||
let _5 := add(_1, _4)
|
||||
let _6 := 0xffffffffffffffff
|
||||
if or(gt(_5, _6), lt(_5, _1))
|
||||
let _3 := datasize("C_2")
|
||||
let _4 := add(_1, _3)
|
||||
let _5 := 0xffffffffffffffff
|
||||
if or(gt(_4, _5), lt(_4, _1))
|
||||
{
|
||||
/// @src 0:279:599 "contract D /** @src 0:96:165 \"contract D {...\" *\/ {..."
|
||||
mstore(_3, shl(224, 0x4e487b71))
|
||||
mstore(0, shl(224, 0x4e487b71))
|
||||
mstore(4, 0x41)
|
||||
revert(_3, 0x24)
|
||||
revert(0, 0x24)
|
||||
}
|
||||
/// @src 0:446:491 "new /// @src 0:149:156 \"new C()\"..."
|
||||
datacopy(_1, dataoffset("C_2"), _4)
|
||||
if iszero(create(/** @src 0:279:599 "contract D /** @src 0:96:165 \"contract D {...\" *\/ {..." */ _3, /** @src 0:446:491 "new /// @src 0:149:156 \"new C()\"..." */ _1, sub(_5, _1)))
|
||||
datacopy(_1, dataoffset("C_2"), _3)
|
||||
if iszero(create(0, _1, sub(_4, _1)))
|
||||
{
|
||||
/// @src 0:279:599 "contract D /** @src 0:96:165 \"contract D {...\" *\/ {..."
|
||||
let pos := mload(_2)
|
||||
returndatacopy(pos, _3, returndatasize())
|
||||
returndatacopy(pos, 0, returndatasize())
|
||||
revert(pos, returndatasize())
|
||||
}
|
||||
let memPtr := mload(_2)
|
||||
let newFreePtr := add(memPtr, _2)
|
||||
if or(gt(newFreePtr, /** @src 0:446:491 "new /// @src 0:149:156 \"new C()\"..." */ _6), /** @src 0:279:599 "contract D /** @src 0:96:165 \"contract D {...\" *\/ {..." */ lt(newFreePtr, memPtr))
|
||||
if or(gt(newFreePtr, /** @src 0:446:491 "new /// @src 0:149:156 \"new C()\"..." */ _5), /** @src 0:279:599 "contract D /** @src 0:96:165 \"contract D {...\" *\/ {..." */ lt(newFreePtr, memPtr))
|
||||
{
|
||||
mstore(_3, shl(224, 0x4e487b71))
|
||||
mstore(0, shl(224, 0x4e487b71))
|
||||
mstore(4, 0x41)
|
||||
revert(_3, 0x24)
|
||||
revert(0, 0x24)
|
||||
}
|
||||
mstore(_2, newFreePtr)
|
||||
mstore(memPtr, 2)
|
||||
let _7 := 32
|
||||
mstore(add(memPtr, _7), "/*")
|
||||
let _6 := 32
|
||||
mstore(add(memPtr, _6), "/*")
|
||||
let memPtr_1 := mload(_2)
|
||||
let newFreePtr_1 := add(memPtr_1, 96)
|
||||
if or(gt(newFreePtr_1, /** @src 0:446:491 "new /// @src 0:149:156 \"new C()\"..." */ _6), /** @src 0:279:599 "contract D /** @src 0:96:165 \"contract D {...\" *\/ {..." */ lt(newFreePtr_1, memPtr_1))
|
||||
if or(gt(newFreePtr_1, /** @src 0:446:491 "new /// @src 0:149:156 \"new C()\"..." */ _5), /** @src 0:279:599 "contract D /** @src 0:96:165 \"contract D {...\" *\/ {..." */ lt(newFreePtr_1, memPtr_1))
|
||||
{
|
||||
mstore(_3, shl(224, 0x4e487b71))
|
||||
mstore(0, shl(224, 0x4e487b71))
|
||||
mstore(4, 0x41)
|
||||
revert(_3, 0x24)
|
||||
revert(0, 0x24)
|
||||
}
|
||||
mstore(_2, newFreePtr_1)
|
||||
mstore(memPtr_1, 39)
|
||||
mstore(add(memPtr_1, _7), 0x2f2a2a204073726320303a39363a313635202022636f6e74726163742044207b)
|
||||
mstore(add(memPtr_1, _6), 0x2f2a2a204073726320303a39363a313635202022636f6e74726163742044207b)
|
||||
mstore(add(memPtr_1, _2), shl(200, 0x2e2e2e22202a2f))
|
||||
let memPos := mload(_2)
|
||||
mstore(memPos, _7)
|
||||
mstore(memPos, _6)
|
||||
let length := mload(memPtr_1)
|
||||
mstore(add(memPos, _7), length)
|
||||
let i := _3
|
||||
for { } lt(i, length) { i := add(i, _7) }
|
||||
mstore(add(memPos, _6), length)
|
||||
let i := 0
|
||||
for { } lt(i, length) { i := add(i, _6) }
|
||||
{
|
||||
mstore(add(add(memPos, i), _2), mload(add(add(memPtr_1, i), _7)))
|
||||
mstore(add(add(memPos, i), _2), mload(add(add(memPtr_1, i), _6)))
|
||||
}
|
||||
mstore(add(add(memPos, length), _2), _3)
|
||||
mstore(add(add(memPos, length), _2), 0)
|
||||
return(memPos, add(sub(add(memPos, and(add(length, 31), not(31))), memPos), _2))
|
||||
}
|
||||
}
|
||||
@ -517,6 +517,7 @@ object "D_27" {
|
||||
code {
|
||||
{
|
||||
/// @src 0:265:278 "contract C {}"
|
||||
mstore(64, memoryguard(0x80))
|
||||
revert(0, 0)
|
||||
}
|
||||
}
|
||||
|
@ -17,6 +17,7 @@ object "C_7" {
|
||||
code {
|
||||
{
|
||||
/// @src 0:82:117 "contract C {..."
|
||||
mstore(64, memoryguard(0x80))
|
||||
revert(0, 0)
|
||||
}
|
||||
}
|
||||
@ -43,6 +44,7 @@ object "D_10" {
|
||||
code {
|
||||
{
|
||||
/// @src 0:118:137 "contract D is C {..."
|
||||
mstore(64, memoryguard(0x80))
|
||||
revert(0, 0)
|
||||
}
|
||||
}
|
||||
|
@ -17,6 +17,7 @@ object "C_3" {
|
||||
code {
|
||||
{
|
||||
/// @src 0:82:95 "contract C {}"
|
||||
mstore(64, memoryguard(0x80))
|
||||
revert(0, 0)
|
||||
}
|
||||
}
|
||||
@ -47,31 +48,30 @@ object "D_16" {
|
||||
mstore(64, _1)
|
||||
if iszero(lt(calldatasize(), 4))
|
||||
{
|
||||
let _2 := 0
|
||||
if eq(0x26121ff0, shr(224, calldataload(_2)))
|
||||
if eq(0x26121ff0, shr(224, calldataload(0)))
|
||||
{
|
||||
if callvalue() { revert(_2, _2) }
|
||||
if slt(add(calldatasize(), not(3)), _2) { revert(_2, _2) }
|
||||
if callvalue() { revert(0, 0) }
|
||||
if slt(add(calldatasize(), not(3)), 0) { revert(0, 0) }
|
||||
/// @src 0:149:156 "new C()"
|
||||
let _3 := datasize("C_3")
|
||||
let _4 := add(_1, _3)
|
||||
if or(gt(_4, 0xffffffffffffffff), lt(_4, _1))
|
||||
let _2 := datasize("C_3")
|
||||
let _3 := add(_1, _2)
|
||||
if or(gt(_3, 0xffffffffffffffff), lt(_3, _1))
|
||||
{
|
||||
/// @src 0:96:165 "contract D {..."
|
||||
mstore(_2, shl(224, 0x4e487b71))
|
||||
mstore(0, shl(224, 0x4e487b71))
|
||||
mstore(4, 0x41)
|
||||
revert(_2, 0x24)
|
||||
revert(0, 0x24)
|
||||
}
|
||||
/// @src 0:149:156 "new C()"
|
||||
datacopy(_1, dataoffset("C_3"), _3)
|
||||
if iszero(create(/** @src 0:96:165 "contract D {..." */ _2, /** @src 0:149:156 "new C()" */ _1, sub(_4, _1)))
|
||||
datacopy(_1, dataoffset("C_3"), _2)
|
||||
if iszero(create(0, _1, sub(_3, _1)))
|
||||
{
|
||||
/// @src 0:96:165 "contract D {..."
|
||||
let pos := mload(64)
|
||||
returndatacopy(pos, _2, returndatasize())
|
||||
returndatacopy(pos, 0, returndatasize())
|
||||
revert(pos, returndatasize())
|
||||
}
|
||||
return(_2, _2)
|
||||
return(0, 0)
|
||||
}
|
||||
}
|
||||
revert(0, 0)
|
||||
@ -95,6 +95,7 @@ object "D_16" {
|
||||
code {
|
||||
{
|
||||
/// @src 0:82:95 "contract C {}"
|
||||
mstore(64, memoryguard(0x80))
|
||||
revert(0, 0)
|
||||
}
|
||||
}
|
||||
|
@ -4,7 +4,11 @@ object "D_12" {
|
||||
code {
|
||||
{
|
||||
/// @src 0:82:175 "contract D {..."
|
||||
mstore(64, 128)
|
||||
if callvalue() { revert(0, 0) }
|
||||
/// @src 0:115:139 "assembly { mstore(0,0) }"
|
||||
mstore(0, 0)
|
||||
/// @src 0:82:175 "contract D {..."
|
||||
let _1 := datasize("D_12_deployed")
|
||||
codecopy(128, dataoffset("D_12_deployed"), _1)
|
||||
return(128, _1)
|
||||
@ -15,14 +19,14 @@ object "D_12" {
|
||||
code {
|
||||
{
|
||||
/// @src 0:82:175 "contract D {..."
|
||||
mstore(64, memoryguard(0x80))
|
||||
if iszero(lt(calldatasize(), 4))
|
||||
{
|
||||
let _1 := 0
|
||||
if eq(0x26121ff0, shr(224, calldataload(_1)))
|
||||
if eq(0x26121ff0, shr(224, calldataload(0)))
|
||||
{
|
||||
if callvalue() { revert(_1, _1) }
|
||||
if slt(add(calldatasize(), not(3)), _1) { revert(_1, _1) }
|
||||
return(_1, _1)
|
||||
if callvalue() { revert(0, 0) }
|
||||
if slt(add(calldatasize(), not(3)), 0) { revert(0, 0) }
|
||||
return(0, 0)
|
||||
}
|
||||
}
|
||||
revert(0, 0)
|
||||
|
@ -17,14 +17,17 @@ object "D_8" {
|
||||
code {
|
||||
{
|
||||
/// @src 0:82:166 "contract D {..."
|
||||
mstore(64, 128)
|
||||
if iszero(lt(calldatasize(), 4))
|
||||
{
|
||||
let _1 := 0
|
||||
if eq(0x26121ff0, shr(224, calldataload(_1)))
|
||||
if eq(0x26121ff0, shr(224, calldataload(0)))
|
||||
{
|
||||
if callvalue() { revert(_1, _1) }
|
||||
if slt(add(calldatasize(), not(3)), _1) { revert(_1, _1) }
|
||||
return(_1, _1)
|
||||
if callvalue() { revert(0, 0) }
|
||||
if slt(add(calldatasize(), not(3)), 0) { revert(0, 0) }
|
||||
/// @src 0:134:158 "assembly { mstore(0,0) }"
|
||||
mstore(0, 0)
|
||||
/// @src 0:82:166 "contract D {..."
|
||||
return(0, 0)
|
||||
}
|
||||
}
|
||||
revert(0, 0)
|
||||
|
@ -4,6 +4,7 @@ object "C_12" {
|
||||
code {
|
||||
{
|
||||
/// @src 0:62:463 "contract C {..."
|
||||
mstore(64, 128)
|
||||
if callvalue() { revert(0, 0) }
|
||||
/// @src 0:103:275 "assembly {..."
|
||||
mstore(0, 100)
|
||||
@ -19,9 +20,11 @@ object "C_12" {
|
||||
code {
|
||||
{
|
||||
/// @src 0:62:463 "contract C {..."
|
||||
mstore(64, 128)
|
||||
if callvalue() { revert(0, 0) }
|
||||
/// @src 0:317:454 "assembly {..."
|
||||
sstore(0, 17385872270140913825666367956517731270094621555228275961425792378517567244498)
|
||||
mstore(0, 100)
|
||||
sstore(0, keccak256(0, 32))
|
||||
/// @src 0:62:463 "contract C {..."
|
||||
stop()
|
||||
}
|
||||
|
@ -17,6 +17,7 @@ object "C_7" {
|
||||
code {
|
||||
{
|
||||
/// @src 0:62:285 "contract C {..."
|
||||
mstore(64, 128)
|
||||
if callvalue() { revert(0, 0) }
|
||||
/// @src 0:109:277 "assembly {..."
|
||||
mstore(0, 100)
|
||||
|
@ -18,104 +18,104 @@ object "C_59" {
|
||||
{
|
||||
/// @src 0:346:625 "contract C {..."
|
||||
let _1 := memoryguard(0x80)
|
||||
let _2 := 4
|
||||
if iszero(lt(calldatasize(), _2))
|
||||
let _2 := 64
|
||||
mstore(_2, _1)
|
||||
let _3 := 4
|
||||
if iszero(lt(calldatasize(), _3))
|
||||
{
|
||||
let _3 := 0
|
||||
if eq(0xf8eddcc6, shr(224, calldataload(_3)))
|
||||
if eq(0xf8eddcc6, shr(224, calldataload(0)))
|
||||
{
|
||||
if callvalue() { revert(_3, _3) }
|
||||
if callvalue() { revert(0, 0) }
|
||||
let _4 := 32
|
||||
if slt(add(calldatasize(), not(3)), _4) { revert(_3, _3) }
|
||||
let offset := calldataload(_2)
|
||||
if slt(add(calldatasize(), not(3)), _4) { revert(0, 0) }
|
||||
let offset := calldataload(_3)
|
||||
let _5 := 0xffffffffffffffff
|
||||
if gt(offset, _5) { revert(_3, _3) }
|
||||
if iszero(slt(add(offset, 35), calldatasize())) { revert(_3, _3) }
|
||||
let _6 := calldataload(add(_2, offset))
|
||||
if gt(offset, _5) { revert(0, 0) }
|
||||
if iszero(slt(add(offset, 35), calldatasize())) { revert(0, 0) }
|
||||
let _6 := calldataload(add(_3, offset))
|
||||
let _7 := 36
|
||||
if gt(_6, _5)
|
||||
{
|
||||
mstore(_3, shl(224, 0x4e487b71))
|
||||
mstore(_2, 0x41)
|
||||
revert(_3, _7)
|
||||
mstore(0, shl(224, 0x4e487b71))
|
||||
mstore(_3, 0x41)
|
||||
revert(0, _7)
|
||||
}
|
||||
let _8 := shl(5, _6)
|
||||
let _9 := not(31)
|
||||
let newFreePtr := add(_1, and(add(_8, 63), _9))
|
||||
if or(gt(newFreePtr, _5), lt(newFreePtr, _1))
|
||||
{
|
||||
mstore(_3, shl(224, 0x4e487b71))
|
||||
mstore(_2, 0x41)
|
||||
revert(_3, _7)
|
||||
mstore(0, shl(224, 0x4e487b71))
|
||||
mstore(_3, 0x41)
|
||||
revert(0, _7)
|
||||
}
|
||||
let _10 := 64
|
||||
mstore(_10, newFreePtr)
|
||||
mstore(_2, newFreePtr)
|
||||
let dst := _1
|
||||
mstore(_1, _6)
|
||||
dst := add(_1, _4)
|
||||
let dst_1 := dst
|
||||
let srcEnd := add(add(offset, _8), _7)
|
||||
if gt(srcEnd, calldatasize()) { revert(_3, _3) }
|
||||
if gt(srcEnd, calldatasize()) { revert(0, 0) }
|
||||
let src := add(offset, _7)
|
||||
for { } lt(src, srcEnd) { src := add(src, _4) }
|
||||
{
|
||||
if slt(sub(calldatasize(), src), _4) { revert(_3, _3) }
|
||||
let memPtr := mload(_10)
|
||||
if slt(sub(calldatasize(), src), _4) { revert(0, 0) }
|
||||
let memPtr := mload(_2)
|
||||
let newFreePtr_1 := add(memPtr, _4)
|
||||
if or(gt(newFreePtr_1, _5), lt(newFreePtr_1, memPtr))
|
||||
{
|
||||
mstore(_3, shl(224, 0x4e487b71))
|
||||
mstore(_2, 0x41)
|
||||
revert(_3, _7)
|
||||
mstore(0, shl(224, 0x4e487b71))
|
||||
mstore(_3, 0x41)
|
||||
revert(0, _7)
|
||||
}
|
||||
mstore(_10, newFreePtr_1)
|
||||
mstore(_2, newFreePtr_1)
|
||||
mstore(memPtr, calldataload(src))
|
||||
mstore(dst, memPtr)
|
||||
dst := add(dst, _4)
|
||||
}
|
||||
if iszero(mload(_1))
|
||||
{
|
||||
mstore(_3, shl(224, 0x4e487b71))
|
||||
mstore(_2, 0x32)
|
||||
revert(_3, _7)
|
||||
mstore(0, shl(224, 0x4e487b71))
|
||||
mstore(_3, 0x32)
|
||||
revert(0, _7)
|
||||
}
|
||||
sstore(_3, mload(/** @src 0:469:474 "_s[0]" */ mload(dst_1)))
|
||||
sstore(0, mload(/** @src 0:469:474 "_s[0]" */ mload(dst_1)))
|
||||
/// @src 0:346:625 "contract C {..."
|
||||
if iszero(lt(/** @src 0:492:493 "1" */ 0x01, /** @src 0:346:625 "contract C {..." */ mload(_1)))
|
||||
{
|
||||
mstore(_3, shl(224, 0x4e487b71))
|
||||
mstore(_2, 0x32)
|
||||
revert(_3, _7)
|
||||
mstore(0, shl(224, 0x4e487b71))
|
||||
mstore(_3, 0x32)
|
||||
revert(0, _7)
|
||||
}
|
||||
let _11 := mload(/** @src 0:489:494 "_s[1]" */ mload(/** @src 0:346:625 "contract C {..." */ add(_1, _10)))
|
||||
sstore(0x02, _11)
|
||||
let memPtr_1 := mload(_10)
|
||||
let _10 := mload(/** @src 0:489:494 "_s[1]" */ mload(/** @src 0:346:625 "contract C {..." */ add(_1, _2)))
|
||||
sstore(0x02, _10)
|
||||
let memPtr_1 := mload(_2)
|
||||
let newFreePtr_2 := add(memPtr_1, 160)
|
||||
if or(gt(newFreePtr_2, _5), lt(newFreePtr_2, memPtr_1))
|
||||
{
|
||||
mstore(_3, shl(224, 0x4e487b71))
|
||||
mstore(_2, 0x41)
|
||||
revert(_3, _7)
|
||||
mstore(0, shl(224, 0x4e487b71))
|
||||
mstore(_3, 0x41)
|
||||
revert(0, _7)
|
||||
}
|
||||
mstore(_10, newFreePtr_2)
|
||||
mstore(_2, newFreePtr_2)
|
||||
mstore(memPtr_1, 100)
|
||||
mstore(add(memPtr_1, _4), "longstringlongstringlongstringlo")
|
||||
mstore(add(memPtr_1, _10), "ngstringlongstringlongstringlong")
|
||||
let _12 := 96
|
||||
mstore(add(memPtr_1, _12), "stringlongstringlongstringlongst")
|
||||
mstore(add(memPtr_1, _2), "ngstringlongstringlongstringlong")
|
||||
let _11 := 96
|
||||
mstore(add(memPtr_1, _11), "stringlongstringlongstringlongst")
|
||||
mstore(add(memPtr_1, 128), "ring")
|
||||
let memPos := mload(_10)
|
||||
mstore(memPos, _11)
|
||||
mstore(add(memPos, _4), _10)
|
||||
let memPos := mload(_2)
|
||||
mstore(memPos, _10)
|
||||
mstore(add(memPos, _4), _2)
|
||||
let length := mload(memPtr_1)
|
||||
mstore(add(memPos, _10), length)
|
||||
let i := _3
|
||||
mstore(add(memPos, _2), length)
|
||||
let i := 0
|
||||
for { } lt(i, length) { i := add(i, _4) }
|
||||
{
|
||||
mstore(add(add(memPos, i), _12), mload(add(add(memPtr_1, i), _4)))
|
||||
mstore(add(add(memPos, i), _11), mload(add(add(memPtr_1, i), _4)))
|
||||
}
|
||||
mstore(add(add(memPos, length), _12), _3)
|
||||
return(memPos, add(sub(add(memPos, and(add(length, 31), _9)), memPos), _12))
|
||||
mstore(add(add(memPos, length), _11), 0)
|
||||
return(memPos, add(sub(add(memPos, and(add(length, 31), _9)), memPos), _11))
|
||||
}
|
||||
}
|
||||
revert(0, 0)
|
||||
|
@ -1,4 +1,4 @@
|
||||
|
||||
======= no_cbor_metadata/input.sol:C =======
|
||||
Binary:
|
||||
608080604052346013576003908160188239f35b5f80fdfe5f80fd
|
||||
608080604052346013576008908160188239f35b5f80fdfe60806040525f80fd
|
||||
|
@ -37,11 +37,11 @@ Text representation:
|
||||
/* "object_compiler/input.yul":217:238 */
|
||||
dup1
|
||||
dataOffset(sub_0)
|
||||
/* "object_compiler/input.yul":125:126 */
|
||||
/* "object_compiler/input.yul":214:215 */
|
||||
0x00
|
||||
/* "object_compiler/input.yul":205:260 */
|
||||
codecopy
|
||||
/* "object_compiler/input.yul":125:126 */
|
||||
/* "object_compiler/input.yul":272:273 */
|
||||
0x00
|
||||
/* "object_compiler/input.yul":265:295 */
|
||||
return
|
||||
@ -52,13 +52,13 @@ sub_0: assembly {
|
||||
0x00
|
||||
/* "object_compiler/input.yul":391:399 */
|
||||
sload
|
||||
/* "object_compiler/input.yul":397:398 */
|
||||
/* "object_compiler/input.yul":388:389 */
|
||||
0x00
|
||||
/* "object_compiler/input.yul":381:400 */
|
||||
mstore
|
||||
/* "object_compiler/input.yul":417:421 */
|
||||
0x20
|
||||
/* "object_compiler/input.yul":397:398 */
|
||||
/* "object_compiler/input.yul":414:415 */
|
||||
0x00
|
||||
/* "object_compiler/input.yul":407:422 */
|
||||
return
|
||||
|
@ -21,26 +21,30 @@ object "Arraysum_34" {
|
||||
let _1 := 4
|
||||
if iszero(lt(calldatasize(), _1))
|
||||
{
|
||||
let _2 := 0
|
||||
if eq(0x81d73423, shr(224, calldataload(_2)))
|
||||
if eq(0x81d73423, shr(224, calldataload(0)))
|
||||
{
|
||||
if callvalue() { revert(_2, _2) }
|
||||
if slt(add(calldatasize(), not(3)), _2) { revert(_2, _2) }
|
||||
let var_sum := _2
|
||||
if callvalue() { revert(0, 0) }
|
||||
if slt(add(calldatasize(), not(3)), 0) { revert(0, 0) }
|
||||
let var_sum := /** @src -1:-1:-1 */ 0
|
||||
/// @src 0:175:182 "sum = 0"
|
||||
var_sum := /** @src 0:181:182 "0" */ 0x00
|
||||
/// @src 0:368:378 "uint i = 0"
|
||||
let var_i := /** @src 0:80:429 "contract Arraysum {..." */ _2
|
||||
let _3 := sload(_2)
|
||||
let var_i := /** @src 0:181:182 "0" */ 0x00
|
||||
/// @src 0:80:429 "contract Arraysum {..."
|
||||
let _2 := sload(/** @src 0:384:390 "values" */ 0x00)
|
||||
/// @src 0:80:429 "contract Arraysum {..."
|
||||
let _3 := sload(/** @src 0:414:420 "values" */ 0x00)
|
||||
/// @src 0:364:423 "for(uint i = 0; i < values.length; i++)..."
|
||||
for { }
|
||||
/** @src 0:380:397 "i < values.length" */ lt(var_i, _3)
|
||||
/** @src 0:380:397 "i < values.length" */ lt(var_i, _2)
|
||||
/// @src 0:368:378 "uint i = 0"
|
||||
{
|
||||
/// @src 0:80:429 "contract Arraysum {..."
|
||||
if eq(var_i, not(0))
|
||||
{
|
||||
mstore(_2, shl(224, 0x4e487b71))
|
||||
mstore(0, shl(224, 0x4e487b71))
|
||||
mstore(_1, 0x11)
|
||||
revert(_2, 0x24)
|
||||
revert(0, 0x24)
|
||||
}
|
||||
/// @src 0:399:402 "i++"
|
||||
var_i := /** @src 0:80:429 "contract Arraysum {..." */ add(var_i, 1)
|
||||
@ -48,13 +52,20 @@ object "Arraysum_34" {
|
||||
/// @src 0:399:402 "i++"
|
||||
{
|
||||
/// @src 0:80:429 "contract Arraysum {..."
|
||||
mstore(_2, _2)
|
||||
let sum := add(var_sum, sload(add(18569430475105882587588266137607568536673111973893317399460219858819262702947, var_i)))
|
||||
if iszero(lt(var_i, _3))
|
||||
{
|
||||
mstore(0, shl(224, 0x4e487b71))
|
||||
mstore(_1, 0x32)
|
||||
revert(0, 0x24)
|
||||
}
|
||||
mstore(0, /** @src 0:414:420 "values" */ 0x00)
|
||||
/// @src 0:80:429 "contract Arraysum {..."
|
||||
let sum := add(var_sum, sload(add(keccak256(0, 0x20), var_i)))
|
||||
if gt(var_sum, sum)
|
||||
{
|
||||
mstore(_2, shl(224, 0x4e487b71))
|
||||
mstore(0, shl(224, 0x4e487b71))
|
||||
mstore(_1, 0x11)
|
||||
revert(_2, 0x24)
|
||||
revert(0, 0x24)
|
||||
}
|
||||
/// @src 0:407:423 "sum += values[i]"
|
||||
var_sum := sum
|
||||
@ -62,7 +73,7 @@ object "Arraysum_34" {
|
||||
/// @src 0:80:429 "contract Arraysum {..."
|
||||
let memPos := mload(64)
|
||||
mstore(memPos, var_sum)
|
||||
return(memPos, 32)
|
||||
return(memPos, 0x20)
|
||||
}
|
||||
}
|
||||
revert(0, 0)
|
||||
|
@ -9,6 +9,9 @@
|
||||
{
|
||||
"assembly": " /* \"C\":79:428 contract C... */
|
||||
0xa0
|
||||
dup1
|
||||
0x40
|
||||
mstore
|
||||
jumpi(tag_5, callvalue)
|
||||
0x1f
|
||||
bytecodeSize
|
||||
@ -51,6 +54,7 @@
|
||||
mload
|
||||
/* \"C\":147:149 42 */
|
||||
mstore(0x80, 0x2a)
|
||||
/* \"C\":203:219 stateVar = _init */
|
||||
0x00
|
||||
/* \"C\":79:428 contract C... */
|
||||
sstore
|
||||
@ -82,20 +86,16 @@ sub_0: assembly {
|
||||
/* \"C\":79:428 contract C... */
|
||||
0x80
|
||||
0x40
|
||||
dup2
|
||||
dup2
|
||||
swap1
|
||||
dup1
|
||||
dup3
|
||||
mstore
|
||||
jumpi(tag_2, iszero(lt(calldatasize, 0x04)))
|
||||
0x00
|
||||
dup1
|
||||
revert
|
||||
tag_2:
|
||||
0x00
|
||||
swap2
|
||||
dup3
|
||||
calldataload
|
||||
0xe0
|
||||
shr
|
||||
shr(0xe0, calldataload(0x00))
|
||||
swap1
|
||||
dup2
|
||||
0x26121ff0
|
||||
@ -116,13 +116,11 @@ sub_0: assembly {
|
||||
dup1
|
||||
revert
|
||||
tag_8:
|
||||
jumpi(tag_12, callvalue)
|
||||
dup2
|
||||
add(calldatasize, not(0x03))
|
||||
slt
|
||||
tag_12
|
||||
jumpi
|
||||
dup2
|
||||
jumpi(tag_26, callvalue)
|
||||
jumpi(tag_26, slt(add(not(0x03), calldatasize), 0x00))
|
||||
/* \"C\":322:332 stateVar++ */
|
||||
0x00
|
||||
/* \"C\":79:428 contract C... */
|
||||
sload
|
||||
sub(shl(0xff, 0x01), 0x01)
|
||||
dup2
|
||||
@ -131,9 +129,11 @@ sub_0: assembly {
|
||||
jumpi
|
||||
0x01
|
||||
add
|
||||
swap2
|
||||
dup3
|
||||
/* \"C\":322:332 stateVar++ */
|
||||
0x00
|
||||
/* \"C\":79:428 contract C... */
|
||||
dup2
|
||||
swap1
|
||||
sstore
|
||||
dup2
|
||||
mload
|
||||
@ -141,48 +141,52 @@ sub_0: assembly {
|
||||
/* \"C\":403:411 this.f() */
|
||||
dup2
|
||||
mstore
|
||||
0x20
|
||||
/* \"C\":403:407 this */
|
||||
dup2
|
||||
/* \"C\":79:428 contract C... */
|
||||
swap2
|
||||
swap1
|
||||
/* \"C\":403:411 this.f() */
|
||||
0x20
|
||||
/* \"C\":79:428 contract C... */
|
||||
dup4
|
||||
0x04
|
||||
/* \"C\":403:407 this */
|
||||
dup2
|
||||
/* \"C\":403:407 this */
|
||||
address
|
||||
/* \"C\":403:411 this.f() */
|
||||
gas
|
||||
staticcall
|
||||
swap2
|
||||
dup3
|
||||
swap3
|
||||
dup4
|
||||
iszero
|
||||
tag_16
|
||||
jumpi
|
||||
dup1
|
||||
swap3
|
||||
0x00
|
||||
swap4
|
||||
tag_18
|
||||
jumpi
|
||||
/* \"C\":79:428 contract C... */
|
||||
tag_19:
|
||||
/* \"C\":392:411 stateVar + this.f() */
|
||||
pop
|
||||
tag_20
|
||||
/* \"C\":403:411 this.f() */
|
||||
0x20
|
||||
/* \"C\":392:411 stateVar + this.f() */
|
||||
dup5
|
||||
swap4
|
||||
/* \"C\":392:422 stateVar + this.f() + immutVar */
|
||||
tag_20
|
||||
/* \"C\":392:411 stateVar + this.f() */
|
||||
tag_21
|
||||
dup7
|
||||
dup10
|
||||
/* \"C\":392:411 stateVar + this.f() */
|
||||
swap3
|
||||
tag_1
|
||||
jump\t// in
|
||||
tag_21:
|
||||
tag_20:
|
||||
/* \"C\":414:422 immutVar */
|
||||
immutable(\"0xe4b1702d9298fee62dfeccc57d322a463ad55ca201256d01f62b45b2e1c21c10\")
|
||||
/* \"C\":392:422 stateVar + this.f() + immutVar */
|
||||
swap1
|
||||
tag_1
|
||||
jump\t// in
|
||||
tag_20:
|
||||
tag_21:
|
||||
/* \"C\":79:428 contract C... */
|
||||
swap1
|
||||
mload
|
||||
@ -192,8 +196,7 @@ sub_0: assembly {
|
||||
return
|
||||
/* \"C\":403:411 this.f() */
|
||||
tag_18:
|
||||
swap1
|
||||
swap2
|
||||
swap3
|
||||
pop
|
||||
0x20
|
||||
returndatasize
|
||||
@ -208,12 +211,12 @@ sub_0: assembly {
|
||||
add
|
||||
not(0x1f)
|
||||
and
|
||||
dup4
|
||||
dup5
|
||||
add
|
||||
0xffffffffffffffff
|
||||
dup2
|
||||
gt
|
||||
dup5
|
||||
dup6
|
||||
dup3
|
||||
lt
|
||||
or
|
||||
@ -223,9 +226,9 @@ sub_0: assembly {
|
||||
0x20
|
||||
/* \"C\":79:428 contract C... */
|
||||
swap2
|
||||
dup5
|
||||
dup6
|
||||
swap2
|
||||
dup7
|
||||
dup6
|
||||
mstore
|
||||
/* \"C\":403:411 this.f() */
|
||||
dup2
|
||||
@ -235,27 +238,26 @@ sub_0: assembly {
|
||||
slt
|
||||
tag_26
|
||||
jumpi
|
||||
pop
|
||||
swap2
|
||||
mload
|
||||
swap2
|
||||
/* \"C\":392:411 stateVar + this.f() */
|
||||
tag_21
|
||||
tag_20
|
||||
/* \"C\":403:411 this.f() */
|
||||
0x20
|
||||
jump(tag_19)
|
||||
/* \"C\":79:428 contract C... */
|
||||
tag_26:
|
||||
0x00
|
||||
dup1
|
||||
revert
|
||||
tag_24:
|
||||
/* \"C\":117:119 41 */
|
||||
shl(0xe0, 0x4e487b71)
|
||||
dup4
|
||||
/* \"C\":79:428 contract C... */
|
||||
0x00
|
||||
mstore
|
||||
mstore(0x04, 0x41)
|
||||
0x24
|
||||
/* \"C\":117:119 41 */
|
||||
dup4
|
||||
/* \"C\":79:428 contract C... */
|
||||
revert
|
||||
revert(0x00, 0x24)
|
||||
/* \"C\":403:411 this.f() */
|
||||
tag_22:
|
||||
pop
|
||||
@ -263,44 +265,34 @@ sub_0: assembly {
|
||||
jump(tag_23)
|
||||
tag_16:
|
||||
/* \"C\":79:428 contract C... */
|
||||
dup4
|
||||
dup3
|
||||
mload
|
||||
swap1
|
||||
returndatasize
|
||||
swap1
|
||||
0x00
|
||||
dup3
|
||||
returndatacopy
|
||||
returndatasize
|
||||
swap1
|
||||
revert
|
||||
tag_14:
|
||||
shl(0xe0, 0x4e487b71)
|
||||
/* \"C\":117:119 41 */
|
||||
dup4
|
||||
mstore
|
||||
mstore(0x00, shl(0xe0, 0x4e487b71))
|
||||
0x11
|
||||
/* \"C\":79:428 contract C... */
|
||||
0x04
|
||||
/* \"C\":117:119 41 */
|
||||
mstore
|
||||
0x24
|
||||
dup4
|
||||
revert
|
||||
revert(0x00, 0x24)
|
||||
/* \"C\":79:428 contract C... */
|
||||
tag_12:
|
||||
pop
|
||||
dup1
|
||||
revert
|
||||
tag_6:
|
||||
pop
|
||||
jumpi(tag_12, callvalue)
|
||||
dup2
|
||||
add(calldatasize, not(0x03))
|
||||
slt
|
||||
tag_12
|
||||
jumpi
|
||||
jumpi(tag_26, callvalue)
|
||||
jumpi(tag_26, slt(add(not(0x03), calldatasize), 0x00))
|
||||
0x20
|
||||
swap2
|
||||
swap1
|
||||
/* \"C\":152:171 int public stateVar */
|
||||
0x00
|
||||
/* \"C\":79:428 contract C... */
|
||||
sload
|
||||
swap1
|
||||
mload
|
||||
@ -309,22 +301,17 @@ sub_0: assembly {
|
||||
mstore
|
||||
return
|
||||
tag_4:
|
||||
dup4
|
||||
swap1
|
||||
jumpi(tag_12, callvalue)
|
||||
dup2
|
||||
add(calldatasize, not(0x03))
|
||||
slt
|
||||
tag_12
|
||||
jumpi
|
||||
jumpi(tag_26, callvalue)
|
||||
jumpi(tag_26, slt(add(not(0x03), calldatasize), 0x00))
|
||||
/* \"C\":290:298 immutVar */
|
||||
immutable(\"0xe4b1702d9298fee62dfeccc57d322a463ad55ca201256d01f62b45b2e1c21c10\")
|
||||
/* \"C\":117:119 41 */
|
||||
dup1
|
||||
0x29
|
||||
add
|
||||
swap1
|
||||
dup2
|
||||
0x29
|
||||
add
|
||||
swap2
|
||||
dup3
|
||||
slt
|
||||
0x01
|
||||
and
|
||||
@ -332,8 +319,7 @@ sub_0: assembly {
|
||||
jumpi
|
||||
/* \"C\":79:428 contract C... */
|
||||
0x20
|
||||
swap3
|
||||
pop
|
||||
swap2
|
||||
dup2
|
||||
mstore
|
||||
return
|
||||
@ -360,13 +346,9 @@ sub_0: assembly {
|
||||
iszero
|
||||
and
|
||||
or
|
||||
tag_38
|
||||
tag_14
|
||||
jumpi
|
||||
jump\t// out
|
||||
tag_38:
|
||||
mstore(0x00, shl(0xe0, 0x4e487b71))
|
||||
mstore(0x04, 0x11)
|
||||
revert(0x00, 0x24)
|
||||
|
||||
auxdata: <AUXDATA REMOVED>
|
||||
}
|
||||
@ -382,6 +364,9 @@ sub_0: assembly {
|
||||
{
|
||||
"assembly": " /* \"D\":91:166 contract D is C(3)... */
|
||||
0xa0
|
||||
dup1
|
||||
0x40
|
||||
mstore
|
||||
jumpi(tag_5, callvalue)
|
||||
0x1f
|
||||
bytecodeSize
|
||||
@ -424,11 +409,15 @@ sub_0: assembly {
|
||||
mload
|
||||
/* \"C\":147:149 42 */
|
||||
mstore(0x80, 0x2a)
|
||||
/* \"D\":91:166 contract D is C(3)... */
|
||||
dup1
|
||||
/* \"D\":107:108 3 */
|
||||
0x03
|
||||
/* \"C\":203:219 stateVar = _init */
|
||||
0x00
|
||||
/* \"D\":91:166 contract D is C(3)... */
|
||||
dup2
|
||||
swap1
|
||||
sstore
|
||||
dup2
|
||||
add
|
||||
swap1
|
||||
dup2
|
||||
@ -437,7 +426,9 @@ sub_0: assembly {
|
||||
and
|
||||
tag_7
|
||||
jumpi
|
||||
/* \"D\":142:160 stateVar += _init2 */
|
||||
0x00
|
||||
/* \"D\":91:166 contract D is C(3)... */
|
||||
sstore
|
||||
mload(0x40)
|
||||
dataSize(sub_0)
|
||||
@ -471,20 +462,16 @@ sub_0: assembly {
|
||||
/* \"D\":91:166 contract D is C(3)... */
|
||||
0x80
|
||||
0x40
|
||||
dup2
|
||||
dup2
|
||||
swap1
|
||||
dup1
|
||||
dup3
|
||||
mstore
|
||||
jumpi(tag_2, iszero(lt(calldatasize, 0x04)))
|
||||
0x00
|
||||
dup1
|
||||
revert
|
||||
tag_2:
|
||||
0x00
|
||||
swap2
|
||||
dup3
|
||||
calldataload
|
||||
0xe0
|
||||
shr
|
||||
shr(0xe0, calldataload(0x00))
|
||||
swap1
|
||||
dup2
|
||||
0x26121ff0
|
||||
@ -505,13 +492,11 @@ sub_0: assembly {
|
||||
dup1
|
||||
revert
|
||||
tag_8:
|
||||
jumpi(tag_12, callvalue)
|
||||
dup2
|
||||
add(calldatasize, not(0x03))
|
||||
slt
|
||||
tag_12
|
||||
jumpi
|
||||
dup2
|
||||
jumpi(tag_26, callvalue)
|
||||
jumpi(tag_26, slt(add(not(0x03), calldatasize), 0x00))
|
||||
/* \"C\":322:332 stateVar++ */
|
||||
0x00
|
||||
/* \"D\":91:166 contract D is C(3)... */
|
||||
sload
|
||||
sub(shl(0xff, 0x01), 0x01)
|
||||
dup2
|
||||
@ -520,9 +505,11 @@ sub_0: assembly {
|
||||
jumpi
|
||||
0x01
|
||||
add
|
||||
swap2
|
||||
dup3
|
||||
/* \"C\":322:332 stateVar++ */
|
||||
0x00
|
||||
/* \"D\":91:166 contract D is C(3)... */
|
||||
dup2
|
||||
swap1
|
||||
sstore
|
||||
dup2
|
||||
mload
|
||||
@ -530,48 +517,52 @@ sub_0: assembly {
|
||||
/* \"C\":403:411 this.f() */
|
||||
dup2
|
||||
mstore
|
||||
0x20
|
||||
/* \"C\":403:407 this */
|
||||
dup2
|
||||
/* \"D\":91:166 contract D is C(3)... */
|
||||
swap2
|
||||
swap1
|
||||
/* \"C\":403:411 this.f() */
|
||||
0x20
|
||||
/* \"D\":91:166 contract D is C(3)... */
|
||||
dup4
|
||||
0x04
|
||||
/* \"C\":403:407 this */
|
||||
dup2
|
||||
/* \"C\":403:407 this */
|
||||
address
|
||||
/* \"C\":403:411 this.f() */
|
||||
gas
|
||||
staticcall
|
||||
swap2
|
||||
dup3
|
||||
swap3
|
||||
dup4
|
||||
iszero
|
||||
tag_16
|
||||
jumpi
|
||||
dup1
|
||||
swap3
|
||||
0x00
|
||||
swap4
|
||||
tag_18
|
||||
jumpi
|
||||
/* \"D\":91:166 contract D is C(3)... */
|
||||
tag_19:
|
||||
/* \"C\":392:411 stateVar + this.f() */
|
||||
pop
|
||||
tag_20
|
||||
/* \"C\":403:411 this.f() */
|
||||
0x20
|
||||
/* \"C\":392:411 stateVar + this.f() */
|
||||
dup5
|
||||
swap4
|
||||
/* \"C\":392:422 stateVar + this.f() + immutVar */
|
||||
tag_20
|
||||
/* \"C\":392:411 stateVar + this.f() */
|
||||
tag_21
|
||||
dup7
|
||||
dup10
|
||||
/* \"C\":392:411 stateVar + this.f() */
|
||||
swap3
|
||||
tag_1
|
||||
jump\t// in
|
||||
tag_21:
|
||||
tag_20:
|
||||
/* \"C\":414:422 immutVar */
|
||||
immutable(\"0xe4b1702d9298fee62dfeccc57d322a463ad55ca201256d01f62b45b2e1c21c10\")
|
||||
/* \"C\":392:422 stateVar + this.f() + immutVar */
|
||||
swap1
|
||||
tag_1
|
||||
jump\t// in
|
||||
tag_20:
|
||||
tag_21:
|
||||
/* \"D\":91:166 contract D is C(3)... */
|
||||
swap1
|
||||
mload
|
||||
@ -581,8 +572,7 @@ sub_0: assembly {
|
||||
return
|
||||
/* \"C\":403:411 this.f() */
|
||||
tag_18:
|
||||
swap1
|
||||
swap2
|
||||
swap3
|
||||
pop
|
||||
0x20
|
||||
returndatasize
|
||||
@ -597,12 +587,12 @@ sub_0: assembly {
|
||||
add
|
||||
not(0x1f)
|
||||
and
|
||||
dup4
|
||||
dup5
|
||||
add
|
||||
0xffffffffffffffff
|
||||
dup2
|
||||
gt
|
||||
dup5
|
||||
dup6
|
||||
dup3
|
||||
lt
|
||||
or
|
||||
@ -612,9 +602,9 @@ sub_0: assembly {
|
||||
0x20
|
||||
/* \"D\":91:166 contract D is C(3)... */
|
||||
swap2
|
||||
dup5
|
||||
dup6
|
||||
swap2
|
||||
dup7
|
||||
dup6
|
||||
mstore
|
||||
/* \"C\":403:411 this.f() */
|
||||
dup2
|
||||
@ -624,27 +614,26 @@ sub_0: assembly {
|
||||
slt
|
||||
tag_26
|
||||
jumpi
|
||||
pop
|
||||
swap2
|
||||
mload
|
||||
swap2
|
||||
/* \"C\":392:411 stateVar + this.f() */
|
||||
tag_21
|
||||
tag_20
|
||||
/* \"C\":403:411 this.f() */
|
||||
0x20
|
||||
jump(tag_19)
|
||||
/* \"D\":91:166 contract D is C(3)... */
|
||||
tag_26:
|
||||
0x00
|
||||
dup1
|
||||
revert
|
||||
tag_24:
|
||||
/* \"C\":117:119 41 */
|
||||
shl(0xe0, 0x4e487b71)
|
||||
dup4
|
||||
/* \"D\":91:166 contract D is C(3)... */
|
||||
0x00
|
||||
mstore
|
||||
mstore(0x04, 0x41)
|
||||
0x24
|
||||
/* \"C\":117:119 41 */
|
||||
dup4
|
||||
/* \"D\":91:166 contract D is C(3)... */
|
||||
revert
|
||||
revert(0x00, 0x24)
|
||||
/* \"C\":403:411 this.f() */
|
||||
tag_22:
|
||||
pop
|
||||
@ -652,44 +641,34 @@ sub_0: assembly {
|
||||
jump(tag_23)
|
||||
tag_16:
|
||||
/* \"D\":91:166 contract D is C(3)... */
|
||||
dup4
|
||||
dup3
|
||||
mload
|
||||
swap1
|
||||
returndatasize
|
||||
swap1
|
||||
0x00
|
||||
dup3
|
||||
returndatacopy
|
||||
returndatasize
|
||||
swap1
|
||||
revert
|
||||
tag_14:
|
||||
shl(0xe0, 0x4e487b71)
|
||||
/* \"C\":117:119 41 */
|
||||
dup4
|
||||
mstore
|
||||
mstore(0x00, shl(0xe0, 0x4e487b71))
|
||||
0x11
|
||||
/* \"D\":91:166 contract D is C(3)... */
|
||||
0x04
|
||||
/* \"C\":117:119 41 */
|
||||
mstore
|
||||
0x24
|
||||
dup4
|
||||
revert
|
||||
revert(0x00, 0x24)
|
||||
/* \"D\":91:166 contract D is C(3)... */
|
||||
tag_12:
|
||||
pop
|
||||
dup1
|
||||
revert
|
||||
tag_6:
|
||||
pop
|
||||
jumpi(tag_12, callvalue)
|
||||
dup2
|
||||
add(calldatasize, not(0x03))
|
||||
slt
|
||||
tag_12
|
||||
jumpi
|
||||
jumpi(tag_26, callvalue)
|
||||
jumpi(tag_26, slt(add(not(0x03), calldatasize), 0x00))
|
||||
0x20
|
||||
swap2
|
||||
swap1
|
||||
/* \"C\":152:171 int public stateVar */
|
||||
0x00
|
||||
/* \"D\":91:166 contract D is C(3)... */
|
||||
sload
|
||||
swap1
|
||||
mload
|
||||
@ -698,22 +677,17 @@ sub_0: assembly {
|
||||
mstore
|
||||
return
|
||||
tag_4:
|
||||
dup4
|
||||
swap1
|
||||
jumpi(tag_12, callvalue)
|
||||
dup2
|
||||
add(calldatasize, not(0x03))
|
||||
slt
|
||||
tag_12
|
||||
jumpi
|
||||
jumpi(tag_26, callvalue)
|
||||
jumpi(tag_26, slt(add(not(0x03), calldatasize), 0x00))
|
||||
/* \"C\":290:298 immutVar */
|
||||
immutable(\"0xe4b1702d9298fee62dfeccc57d322a463ad55ca201256d01f62b45b2e1c21c10\")
|
||||
/* \"C\":117:119 41 */
|
||||
dup1
|
||||
0x29
|
||||
add
|
||||
swap1
|
||||
dup2
|
||||
0x29
|
||||
add
|
||||
swap2
|
||||
dup3
|
||||
slt
|
||||
0x01
|
||||
and
|
||||
@ -721,8 +695,7 @@ sub_0: assembly {
|
||||
jumpi
|
||||
/* \"D\":91:166 contract D is C(3)... */
|
||||
0x20
|
||||
swap3
|
||||
pop
|
||||
swap2
|
||||
dup2
|
||||
mstore
|
||||
return
|
||||
@ -749,13 +722,9 @@ sub_0: assembly {
|
||||
iszero
|
||||
and
|
||||
or
|
||||
tag_38
|
||||
tag_14
|
||||
jumpi
|
||||
jump\t// out
|
||||
tag_38:
|
||||
mstore(0x00, shl(0xe0, 0x4e487b71))
|
||||
mstore(0x04, 0x11)
|
||||
revert(0x00, 0x24)
|
||||
|
||||
auxdata: <AUXDATA REMOVED>
|
||||
}
|
||||
|
@ -192,14 +192,14 @@ object \"C_6\" {
|
||||
code {
|
||||
{
|
||||
/// @src 0:60:101 \"contract C {...\"
|
||||
mstore(64, memoryguard(0x80))
|
||||
if iszero(lt(calldatasize(), 4))
|
||||
{
|
||||
let _1 := 0
|
||||
if eq(0x26121ff0, shr(224, calldataload(_1)))
|
||||
if eq(0x26121ff0, shr(224, calldataload(0)))
|
||||
{
|
||||
if callvalue() { revert(_1, _1) }
|
||||
if slt(add(calldatasize(), not(3)), _1) { revert(_1, _1) }
|
||||
return(_1, _1)
|
||||
if callvalue() { revert(0, 0) }
|
||||
if slt(add(calldatasize(), not(3)), 0) { revert(0, 0) }
|
||||
return(0, 0)
|
||||
}
|
||||
}
|
||||
revert(0, 0)
|
||||
|
@ -191,14 +191,14 @@ object \"C_6\" {
|
||||
code {
|
||||
{
|
||||
/// @src 0:60:101
|
||||
mstore(64, memoryguard(0x80))
|
||||
if iszero(lt(calldatasize(), 4))
|
||||
{
|
||||
let _1 := 0
|
||||
if eq(0x26121ff0, shr(224, calldataload(_1)))
|
||||
if eq(0x26121ff0, shr(224, calldataload(0)))
|
||||
{
|
||||
if callvalue() { revert(_1, _1) }
|
||||
if slt(add(calldatasize(), not(3)), _1) { revert(_1, _1) }
|
||||
return(_1, _1)
|
||||
if callvalue() { revert(0, 0) }
|
||||
if slt(add(calldatasize(), not(3)), 0) { revert(0, 0) }
|
||||
return(0, 0)
|
||||
}
|
||||
}
|
||||
revert(0, 0)
|
||||
|
@ -180,14 +180,14 @@ object \"C_6\" {
|
||||
object \"C_6_deployed\" {
|
||||
code {
|
||||
{
|
||||
mstore(64, memoryguard(0x80))
|
||||
if iszero(lt(calldatasize(), 4))
|
||||
{
|
||||
let _1 := 0
|
||||
if eq(0x26121ff0, shr(224, calldataload(_1)))
|
||||
if eq(0x26121ff0, shr(224, calldataload(0)))
|
||||
{
|
||||
if callvalue() { revert(_1, _1) }
|
||||
if slt(add(calldatasize(), not(3)), _1) { revert(_1, _1) }
|
||||
return(_1, _1)
|
||||
if callvalue() { revert(0, 0) }
|
||||
if slt(add(calldatasize(), not(3)), 0) { revert(0, 0) }
|
||||
return(0, 0)
|
||||
}
|
||||
}
|
||||
revert(0, 0)
|
||||
|
@ -618,28 +618,25 @@ object \"C_54\" {
|
||||
{
|
||||
/// @src 0:79:435 \"contract C...\"
|
||||
let _1 := memoryguard(0xa0)
|
||||
mstore(64, _1)
|
||||
if callvalue() { revert(0, 0) }
|
||||
let programSize := datasize(\"C_54\")
|
||||
let argSize := sub(codesize(), programSize)
|
||||
let newFreePtr := add(_1, and(add(argSize, 31), not(31)))
|
||||
if or(gt(newFreePtr, sub(shl(64, 1), 1)), lt(newFreePtr, _1))
|
||||
{
|
||||
mstore(/** @src -1:-1:-1 */ 0, /** @src 0:79:435 \"contract C...\" */ shl(224, 0x4e487b71))
|
||||
mstore(0, shl(224, 0x4e487b71))
|
||||
mstore(4, 0x41)
|
||||
revert(/** @src -1:-1:-1 */ 0, /** @src 0:79:435 \"contract C...\" */ 0x24)
|
||||
revert(0, 0x24)
|
||||
}
|
||||
mstore(64, newFreePtr)
|
||||
codecopy(_1, programSize, argSize)
|
||||
if slt(sub(add(_1, argSize), _1), 32)
|
||||
{
|
||||
revert(/** @src -1:-1:-1 */ 0, 0)
|
||||
}
|
||||
/// @src 0:79:435 \"contract C...\"
|
||||
if slt(sub(add(_1, argSize), _1), 32) { revert(0, 0) }
|
||||
let value := mload(_1)
|
||||
/// @src 0:154:156 \"42\"
|
||||
mstore(128, 0x2a)
|
||||
/// @src 0:79:435 \"contract C...\"
|
||||
sstore(/** @src -1:-1:-1 */ 0, /** @src 0:79:435 \"contract C...\" */ value)
|
||||
sstore(/** @src 0:210:226 \"stateVar = _init\" */ 0x00, /** @src 0:79:435 \"contract C...\" */ value)
|
||||
let _2 := mload(64)
|
||||
let _3 := datasize(\"C_54_deployed\")
|
||||
codecopy(_2, dataoffset(\"C_54_deployed\"), _3)
|
||||
@ -658,44 +655,45 @@ object \"C_54\" {
|
||||
mstore(_2, _1)
|
||||
if iszero(lt(calldatasize(), 4))
|
||||
{
|
||||
let _3 := 0
|
||||
switch shr(224, calldataload(_3))
|
||||
switch shr(224, calldataload(0))
|
||||
case 0x26121ff0 {
|
||||
if callvalue() { revert(_3, _3) }
|
||||
if slt(add(calldatasize(), not(3)), _3) { revert(_3, _3) }
|
||||
if callvalue() { revert(0, 0) }
|
||||
if slt(add(calldatasize(), not(3)), 0) { revert(0, 0) }
|
||||
/// @src 0:297:305 \"immutVar\"
|
||||
let _4 := loadimmutable(\"8\")
|
||||
let _3 := loadimmutable(\"8\")
|
||||
/// @src 0:79:435 \"contract C...\"
|
||||
let sum := add(/** @src 0:124:126 \"41\" */ 0x29, /** @src 0:79:435 \"contract C...\" */ _4)
|
||||
if and(1, slt(sum, _4))
|
||||
let sum := add(/** @src 0:124:126 \"41\" */ 0x29, /** @src 0:79:435 \"contract C...\" */ _3)
|
||||
if and(1, slt(sum, _3))
|
||||
{
|
||||
mstore(_3, shl(224, 0x4e487b71))
|
||||
mstore(0, shl(224, 0x4e487b71))
|
||||
mstore(4, 0x11)
|
||||
revert(_3, 0x24)
|
||||
revert(0, 0x24)
|
||||
}
|
||||
mstore(_1, sum)
|
||||
return(_1, 32)
|
||||
}
|
||||
case 0x793816ec {
|
||||
if callvalue() { revert(_3, _3) }
|
||||
if slt(add(calldatasize(), not(3)), _3) { revert(_3, _3) }
|
||||
let _5 := sload(_3)
|
||||
if callvalue() { revert(0, 0) }
|
||||
if slt(add(calldatasize(), not(3)), 0) { revert(0, 0) }
|
||||
let _4 := sload(/** @src 0:159:178 \"int public stateVar\" */ 0)
|
||||
/// @src 0:79:435 \"contract C...\"
|
||||
let memPos := mload(_2)
|
||||
mstore(memPos, _5)
|
||||
mstore(memPos, _4)
|
||||
return(memPos, 32)
|
||||
}
|
||||
case 0x9942ec6f {
|
||||
if callvalue() { revert(_3, _3) }
|
||||
if slt(add(calldatasize(), not(3)), _3) { revert(_3, _3) }
|
||||
let _6 := sload(_3)
|
||||
if eq(_6, sub(shl(255, 1), 1))
|
||||
if callvalue() { revert(0, 0) }
|
||||
if slt(add(calldatasize(), not(3)), 0) { revert(0, 0) }
|
||||
let _5 := sload(/** @src 0:329:339 \"stateVar++\" */ 0x00)
|
||||
/// @src 0:79:435 \"contract C...\"
|
||||
if eq(_5, sub(shl(255, 1), 1))
|
||||
{
|
||||
mstore(_3, shl(224, 0x4e487b71))
|
||||
mstore(0, shl(224, 0x4e487b71))
|
||||
mstore(4, 0x11)
|
||||
revert(_3, 0x24)
|
||||
revert(0, 0x24)
|
||||
}
|
||||
let ret := add(_6, 1)
|
||||
sstore(_3, ret)
|
||||
sstore(/** @src 0:329:339 \"stateVar++\" */ 0x00, /** @src 0:79:435 \"contract C...\" */ add(_5, 1))
|
||||
let _6 := sload(/** @src 0:399:407 \"stateVar\" */ 0x00)
|
||||
/// @src 0:410:418 \"this.f()\"
|
||||
let _7 := /** @src 0:79:435 \"contract C...\" */ mload(_2)
|
||||
/// @src 0:410:418 \"this.f()\"
|
||||
@ -706,11 +704,11 @@ object \"C_54\" {
|
||||
{
|
||||
/// @src 0:79:435 \"contract C...\"
|
||||
let pos := mload(_2)
|
||||
returndatacopy(pos, _3, returndatasize())
|
||||
returndatacopy(pos, 0, returndatasize())
|
||||
revert(pos, returndatasize())
|
||||
}
|
||||
/// @src 0:410:418 \"this.f()\"
|
||||
let expr := /** @src 0:79:435 \"contract C...\" */ _3
|
||||
let expr := /** @src -1:-1:-1 */ 0
|
||||
/// @src 0:410:418 \"this.f()\"
|
||||
if _8
|
||||
{
|
||||
@ -720,19 +718,19 @@ object \"C_54\" {
|
||||
let newFreePtr := add(_7, and(add(_9, 31), not(31)))
|
||||
if or(gt(newFreePtr, 0xffffffffffffffff), lt(newFreePtr, _7))
|
||||
{
|
||||
mstore(_3, shl(224, 0x4e487b71))
|
||||
mstore(0, shl(224, 0x4e487b71))
|
||||
mstore(4, 0x41)
|
||||
revert(_3, 0x24)
|
||||
revert(0, 0x24)
|
||||
}
|
||||
mstore(_2, newFreePtr)
|
||||
if slt(sub(/** @src 0:410:418 \"this.f()\" */ add(_7, _9), /** @src 0:79:435 \"contract C...\" */ _7), /** @src 0:410:418 \"this.f()\" */ 32)
|
||||
/// @src 0:79:435 \"contract C...\"
|
||||
{ revert(_3, _3) }
|
||||
{ revert(0, 0) }
|
||||
/// @src 0:410:418 \"this.f()\"
|
||||
expr := /** @src 0:79:435 \"contract C...\" */ mload(_7)
|
||||
}
|
||||
/// @src 0:399:418 \"stateVar + this.f()\"
|
||||
let expr_1 := checked_add_int256(ret, expr)
|
||||
let expr_1 := checked_add_int256(_6, expr)
|
||||
/// @src 0:392:429 \"return stateVar + this.f() + immutVar\"
|
||||
let var := /** @src 0:399:429 \"stateVar + this.f() + immutVar\" */ checked_add_int256(expr_1, /** @src 0:421:429 \"immutVar\" */ loadimmutable(\"8\"))
|
||||
/// @src 0:79:435 \"contract C...\"
|
||||
@ -741,8 +739,8 @@ object \"C_54\" {
|
||||
return(memPos_1, /** @src 0:410:418 \"this.f()\" */ 32)
|
||||
}
|
||||
case /** @src 0:79:435 \"contract C...\" */ 0xa00b982b {
|
||||
if callvalue() { revert(_3, _3) }
|
||||
if slt(add(calldatasize(), not(3)), _3) { revert(_3, _3) }
|
||||
if callvalue() { revert(0, 0) }
|
||||
if slt(add(calldatasize(), not(3)), 0) { revert(0, 0) }
|
||||
let memPos_2 := mload(_2)
|
||||
mstore(memPos_2, /** @src 0:124:126 \"41\" */ 0x29)
|
||||
/// @src 0:79:435 \"contract C...\"
|
||||
@ -1457,41 +1455,44 @@ object \"D_72\" {
|
||||
{
|
||||
/// @src 1:91:166 \"contract D is C(3)...\"
|
||||
let _1 := memoryguard(0xa0)
|
||||
mstore(64, _1)
|
||||
if callvalue() { revert(0, 0) }
|
||||
let programSize := datasize(\"D_72\")
|
||||
let argSize := sub(codesize(), programSize)
|
||||
let newFreePtr := add(_1, and(add(argSize, 31), not(31)))
|
||||
if or(gt(newFreePtr, sub(shl(64, 1), 1)), lt(newFreePtr, _1))
|
||||
{
|
||||
mstore(/** @src -1:-1:-1 */ 0, /** @src 1:91:166 \"contract D is C(3)...\" */ shl(224, 0x4e487b71))
|
||||
mstore(0, shl(224, 0x4e487b71))
|
||||
mstore(4, 0x41)
|
||||
revert(/** @src -1:-1:-1 */ 0, /** @src 1:91:166 \"contract D is C(3)...\" */ 0x24)
|
||||
revert(0, 0x24)
|
||||
}
|
||||
mstore(64, newFreePtr)
|
||||
codecopy(_1, programSize, argSize)
|
||||
if slt(sub(add(_1, argSize), _1), 32)
|
||||
{
|
||||
revert(/** @src -1:-1:-1 */ 0, 0)
|
||||
}
|
||||
/// @src 1:91:166 \"contract D is C(3)...\"
|
||||
if slt(sub(add(_1, argSize), _1), 32) { revert(0, 0) }
|
||||
let value := mload(_1)
|
||||
/// @src 0:154:156 \"42\"
|
||||
mstore(128, 0x2a)
|
||||
/// @src 1:91:166 \"contract D is C(3)...\"
|
||||
let sum := add(/** @src 1:107:108 \"3\" */ 0x03, /** @src 1:91:166 \"contract D is C(3)...\" */ value)
|
||||
if and(1, slt(sum, value))
|
||||
{
|
||||
mstore(/** @src -1:-1:-1 */ 0, /** @src 1:91:166 \"contract D is C(3)...\" */ shl(224, 0x4e487b71))
|
||||
mstore(4, 0x11)
|
||||
revert(/** @src -1:-1:-1 */ 0, /** @src 1:91:166 \"contract D is C(3)...\" */ 0x24)
|
||||
}
|
||||
sstore(/** @src -1:-1:-1 */ 0, /** @src 1:91:166 \"contract D is C(3)...\" */ sum)
|
||||
let _2 := mload(64)
|
||||
let _3 := datasize(\"D_72_deployed\")
|
||||
codecopy(_2, dataoffset(\"D_72_deployed\"), _3)
|
||||
setimmutable(_2, \"8\", mload(/** @src 0:154:156 \"42\" */ 128))
|
||||
sstore(/** @src 0:210:226 \"stateVar = _init\" */ 0x00, /** @src 1:107:108 \"3\" */ 0x03)
|
||||
/// @src 1:91:166 \"contract D is C(3)...\"
|
||||
return(_2, _3)
|
||||
let _2 := sload(/** @src 1:142:160 \"stateVar += _init2\" */ 0x00)
|
||||
/// @src 1:91:166 \"contract D is C(3)...\"
|
||||
let sum := add(_2, value)
|
||||
let _3 := slt(sum, value)
|
||||
let _4 := slt(_2, 0)
|
||||
if or(and(iszero(_4), _3), and(_4, iszero(_3)))
|
||||
{
|
||||
mstore(0, shl(224, 0x4e487b71))
|
||||
mstore(4, 0x11)
|
||||
revert(0, 0x24)
|
||||
}
|
||||
sstore(/** @src 1:142:160 \"stateVar += _init2\" */ 0x00, /** @src 1:91:166 \"contract D is C(3)...\" */ sum)
|
||||
let _5 := mload(64)
|
||||
let _6 := datasize(\"D_72_deployed\")
|
||||
codecopy(_5, dataoffset(\"D_72_deployed\"), _6)
|
||||
setimmutable(_5, \"8\", mload(/** @src 0:154:156 \"42\" */ 128))
|
||||
/// @src 1:91:166 \"contract D is C(3)...\"
|
||||
return(_5, _6)
|
||||
}
|
||||
}
|
||||
/// @use-src 0:\"C\", 1:\"D\"
|
||||
@ -1504,44 +1505,45 @@ object \"D_72\" {
|
||||
mstore(_2, _1)
|
||||
if iszero(lt(calldatasize(), 4))
|
||||
{
|
||||
let _3 := 0
|
||||
switch shr(224, calldataload(_3))
|
||||
switch shr(224, calldataload(0))
|
||||
case 0x26121ff0 {
|
||||
if callvalue() { revert(_3, _3) }
|
||||
if slt(add(calldatasize(), not(3)), _3) { revert(_3, _3) }
|
||||
if callvalue() { revert(0, 0) }
|
||||
if slt(add(calldatasize(), not(3)), 0) { revert(0, 0) }
|
||||
/// @src 0:297:305 \"immutVar\"
|
||||
let _4 := loadimmutable(\"8\")
|
||||
let _3 := loadimmutable(\"8\")
|
||||
/// @src 1:91:166 \"contract D is C(3)...\"
|
||||
let sum := add(/** @src 0:124:126 \"41\" */ 0x29, /** @src 1:91:166 \"contract D is C(3)...\" */ _4)
|
||||
if and(1, slt(sum, _4))
|
||||
let sum := add(/** @src 0:124:126 \"41\" */ 0x29, /** @src 1:91:166 \"contract D is C(3)...\" */ _3)
|
||||
if and(1, slt(sum, _3))
|
||||
{
|
||||
mstore(_3, shl(224, 0x4e487b71))
|
||||
mstore(0, shl(224, 0x4e487b71))
|
||||
mstore(4, 0x11)
|
||||
revert(_3, 0x24)
|
||||
revert(0, 0x24)
|
||||
}
|
||||
mstore(_1, sum)
|
||||
return(_1, 32)
|
||||
}
|
||||
case 0x793816ec {
|
||||
if callvalue() { revert(_3, _3) }
|
||||
if slt(add(calldatasize(), not(3)), _3) { revert(_3, _3) }
|
||||
let _5 := sload(_3)
|
||||
if callvalue() { revert(0, 0) }
|
||||
if slt(add(calldatasize(), not(3)), 0) { revert(0, 0) }
|
||||
let _4 := sload(/** @src 0:159:178 \"int public stateVar\" */ 0)
|
||||
/// @src 1:91:166 \"contract D is C(3)...\"
|
||||
let memPos := mload(_2)
|
||||
mstore(memPos, _5)
|
||||
mstore(memPos, _4)
|
||||
return(memPos, 32)
|
||||
}
|
||||
case 0x9942ec6f {
|
||||
if callvalue() { revert(_3, _3) }
|
||||
if slt(add(calldatasize(), not(3)), _3) { revert(_3, _3) }
|
||||
let _6 := sload(_3)
|
||||
if eq(_6, sub(shl(255, 1), 1))
|
||||
if callvalue() { revert(0, 0) }
|
||||
if slt(add(calldatasize(), not(3)), 0) { revert(0, 0) }
|
||||
let _5 := sload(/** @src 0:329:339 \"stateVar++\" */ 0x00)
|
||||
/// @src 1:91:166 \"contract D is C(3)...\"
|
||||
if eq(_5, sub(shl(255, 1), 1))
|
||||
{
|
||||
mstore(_3, shl(224, 0x4e487b71))
|
||||
mstore(0, shl(224, 0x4e487b71))
|
||||
mstore(4, 0x11)
|
||||
revert(_3, 0x24)
|
||||
revert(0, 0x24)
|
||||
}
|
||||
let ret := add(_6, 1)
|
||||
sstore(_3, ret)
|
||||
sstore(/** @src 0:329:339 \"stateVar++\" */ 0x00, /** @src 1:91:166 \"contract D is C(3)...\" */ add(_5, 1))
|
||||
let _6 := sload(/** @src 0:399:407 \"stateVar\" */ 0x00)
|
||||
/// @src 0:410:418 \"this.f()\"
|
||||
let _7 := /** @src 1:91:166 \"contract D is C(3)...\" */ mload(_2)
|
||||
/// @src 0:410:418 \"this.f()\"
|
||||
@ -1552,11 +1554,11 @@ object \"D_72\" {
|
||||
{
|
||||
/// @src 1:91:166 \"contract D is C(3)...\"
|
||||
let pos := mload(_2)
|
||||
returndatacopy(pos, _3, returndatasize())
|
||||
returndatacopy(pos, 0, returndatasize())
|
||||
revert(pos, returndatasize())
|
||||
}
|
||||
/// @src 0:410:418 \"this.f()\"
|
||||
let expr := /** @src 1:91:166 \"contract D is C(3)...\" */ _3
|
||||
let expr := /** @src -1:-1:-1 */ 0
|
||||
/// @src 0:410:418 \"this.f()\"
|
||||
if _8
|
||||
{
|
||||
@ -1566,19 +1568,19 @@ object \"D_72\" {
|
||||
let newFreePtr := add(_7, and(add(_9, 31), not(31)))
|
||||
if or(gt(newFreePtr, 0xffffffffffffffff), lt(newFreePtr, _7))
|
||||
{
|
||||
mstore(_3, shl(224, 0x4e487b71))
|
||||
mstore(0, shl(224, 0x4e487b71))
|
||||
mstore(4, 0x41)
|
||||
revert(_3, 0x24)
|
||||
revert(0, 0x24)
|
||||
}
|
||||
mstore(_2, newFreePtr)
|
||||
if slt(sub(/** @src 0:410:418 \"this.f()\" */ add(_7, _9), /** @src 1:91:166 \"contract D is C(3)...\" */ _7), /** @src 0:410:418 \"this.f()\" */ 32)
|
||||
/// @src 1:91:166 \"contract D is C(3)...\"
|
||||
{ revert(_3, _3) }
|
||||
{ revert(0, 0) }
|
||||
/// @src 0:410:418 \"this.f()\"
|
||||
expr := /** @src 1:91:166 \"contract D is C(3)...\" */ mload(_7)
|
||||
}
|
||||
/// @src 0:399:418 \"stateVar + this.f()\"
|
||||
let expr_1 := checked_add_int256(ret, expr)
|
||||
let expr_1 := checked_add_int256(_6, expr)
|
||||
/// @src 0:392:429 \"return stateVar + this.f() + immutVar\"
|
||||
let var := /** @src 0:399:429 \"stateVar + this.f() + immutVar\" */ checked_add_int256(expr_1, /** @src 0:421:429 \"immutVar\" */ loadimmutable(\"8\"))
|
||||
/// @src 1:91:166 \"contract D is C(3)...\"
|
||||
@ -1587,8 +1589,8 @@ object \"D_72\" {
|
||||
return(memPos_1, /** @src 0:410:418 \"this.f()\" */ 32)
|
||||
}
|
||||
case /** @src 1:91:166 \"contract D is C(3)...\" */ 0xa00b982b {
|
||||
if callvalue() { revert(_3, _3) }
|
||||
if slt(add(calldatasize(), not(3)), _3) { revert(_3, _3) }
|
||||
if callvalue() { revert(0, 0) }
|
||||
if slt(add(calldatasize(), not(3)), 0) { revert(0, 0) }
|
||||
let memPos_2 := mload(_2)
|
||||
mstore(memPos_2, /** @src 0:124:126 \"41\" */ 0x29)
|
||||
/// @src 1:91:166 \"contract D is C(3)...\"
|
||||
|
@ -7,7 +7,7 @@
|
||||
{
|
||||
"evm":
|
||||
{
|
||||
"assembly": " /* \"A\":17:18 */
|
||||
"assembly": " /* \"A\":38:39 */
|
||||
0x00
|
||||
/* \"A\":11:19 */
|
||||
dup1
|
||||
|
@ -3,6 +3,9 @@
|
||||
EVM assembly:
|
||||
/* "viair_subobject_optimization/input.sol":61:668 contract C {... */
|
||||
0x80
|
||||
dup1
|
||||
0x40
|
||||
mstore
|
||||
jumpi(tag_7, callvalue)
|
||||
0x1f
|
||||
bytecodeSize
|
||||
@ -60,8 +63,8 @@ EVM assembly:
|
||||
return
|
||||
/* "viair_subobject_optimization/input.sol":616:661 if (x == 0xFFFFFFFFFFFFFFFF42)... */
|
||||
tag_7:
|
||||
0x00
|
||||
/* "viair_subobject_optimization/input.sol":653:661 revert() */
|
||||
0x00
|
||||
dup1
|
||||
revert
|
||||
/* "viair_subobject_optimization/input.sol":61:668 contract C {... */
|
||||
@ -73,6 +76,7 @@ stop
|
||||
|
||||
sub_0: assembly {
|
||||
/* "viair_subobject_optimization/input.sol":61:668 contract C {... */
|
||||
mstore(0x40, 0x80)
|
||||
0x00
|
||||
dup1
|
||||
revert
|
||||
@ -105,108 +109,98 @@ stop
|
||||
sub_0: assembly {
|
||||
/* "viair_subobject_optimization/input.sol":669:772 contract D {... */
|
||||
0x80
|
||||
0x40
|
||||
dup2
|
||||
dup2
|
||||
mstore
|
||||
jumpi(tag_1, iszero(lt(calldatasize, 0x04)))
|
||||
0x00
|
||||
dup1
|
||||
revert
|
||||
tag_1:
|
||||
0x00
|
||||
dup1
|
||||
calldataload
|
||||
0xe0
|
||||
shr
|
||||
0x26121ff0
|
||||
eq
|
||||
tag_3
|
||||
jumpi
|
||||
jumpi(tag_3, eq(0x26121ff0, shr(0xe0, calldataload(0x00))))
|
||||
0x00
|
||||
dup1
|
||||
revert
|
||||
tag_3:
|
||||
jumpi(tag_7, callvalue)
|
||||
dup1
|
||||
add(calldatasize, not(0x03))
|
||||
slt
|
||||
tag_7
|
||||
jumpi
|
||||
jumpi(tag_7, slt(add(not(0x03), calldatasize), 0x00))
|
||||
/* "viair_subobject_optimization/input.sol":745:765 type(C).creationCode */
|
||||
dataSize(sub_0)
|
||||
/* "viair_subobject_optimization/input.sol":669:772 contract D {... */
|
||||
swap2
|
||||
not(0x1f)
|
||||
/* "viair_subobject_optimization/input.sol":669:772 contract D {... */
|
||||
swap1
|
||||
dup2
|
||||
0x3f
|
||||
dup6
|
||||
dup5
|
||||
add
|
||||
dup3
|
||||
and
|
||||
dup2
|
||||
add
|
||||
swap3
|
||||
dup2
|
||||
dup5
|
||||
lt
|
||||
0xffffffffffffffff
|
||||
dup6
|
||||
dup2
|
||||
gt
|
||||
dup3
|
||||
dup3
|
||||
lt
|
||||
or
|
||||
tag_9
|
||||
jumpi
|
||||
swap1
|
||||
swap2
|
||||
0x40
|
||||
swap4
|
||||
dup5
|
||||
mstore
|
||||
/* "viair_subobject_optimization/input.sol":745:765 type(C).creationCode */
|
||||
dup5
|
||||
dup4
|
||||
mstore
|
||||
/* "viair_subobject_optimization/input.sol":745:765 type(C).creationCode */
|
||||
dup4
|
||||
dup2
|
||||
mstore
|
||||
/* "viair_subobject_optimization/input.sol":669:772 contract D {... */
|
||||
swap3
|
||||
/* "viair_subobject_optimization/input.sol":745:765 type(C).creationCode */
|
||||
0x20
|
||||
swap5
|
||||
swap2
|
||||
/* "viair_subobject_optimization/input.sol":669:772 contract D {... */
|
||||
swap1
|
||||
/* "viair_subobject_optimization/input.sol":745:765 type(C).creationCode */
|
||||
dataOffset(sub_0)
|
||||
dup4
|
||||
dup7
|
||||
dup6
|
||||
add
|
||||
codecopy
|
||||
/* "viair_subobject_optimization/input.sol":669:772 contract D {... */
|
||||
dup4
|
||||
dup3
|
||||
mload
|
||||
swap5
|
||||
swap4
|
||||
dup3
|
||||
dup6
|
||||
swap3
|
||||
dup2
|
||||
swap4
|
||||
dup5
|
||||
mstore
|
||||
dup5
|
||||
dup2
|
||||
mload
|
||||
swap2
|
||||
dup3
|
||||
dup2
|
||||
dup3
|
||||
dup7
|
||||
add
|
||||
mstore
|
||||
dup2
|
||||
swap6
|
||||
0x00
|
||||
tag_11:
|
||||
dup4
|
||||
dup8
|
||||
dup2
|
||||
lt
|
||||
tag_12
|
||||
jumpi
|
||||
pop
|
||||
pop
|
||||
0x00
|
||||
dup5
|
||||
dup4
|
||||
swap5
|
||||
pop
|
||||
dup6
|
||||
dup3
|
||||
0x1f
|
||||
swap5
|
||||
swap6
|
||||
add
|
||||
dup7
|
||||
add
|
||||
mstore
|
||||
pop
|
||||
0x1f
|
||||
add
|
||||
and
|
||||
dup2
|
||||
@ -216,35 +210,30 @@ sub_0: assembly {
|
||||
swap1
|
||||
return
|
||||
tag_12:
|
||||
dup7
|
||||
dup2
|
||||
dup2
|
||||
add
|
||||
dup3
|
||||
dup4
|
||||
add
|
||||
mload
|
||||
dup10
|
||||
dup9
|
||||
dup3
|
||||
add
|
||||
dup10
|
||||
dup9
|
||||
add
|
||||
mstore
|
||||
swap6
|
||||
dup2
|
||||
add
|
||||
swap6
|
||||
dup9
|
||||
dup8
|
||||
swap6
|
||||
pop
|
||||
dup3
|
||||
add
|
||||
jump(tag_11)
|
||||
tag_9:
|
||||
shl(0xe0, 0x4e487b71)
|
||||
dup2
|
||||
mstore
|
||||
mstore(0x00, shl(0xe0, 0x4e487b71))
|
||||
mstore(0x04, 0x41)
|
||||
0x24
|
||||
swap1
|
||||
revert
|
||||
revert(0x00, 0x24)
|
||||
tag_7:
|
||||
0x00
|
||||
dup1
|
||||
revert
|
||||
stop
|
||||
@ -252,6 +241,9 @@ sub_0: assembly {
|
||||
sub_0: assembly {
|
||||
/* "viair_subobject_optimization/input.sol":61:668 contract C {... */
|
||||
0x80
|
||||
dup1
|
||||
0x40
|
||||
mstore
|
||||
jumpi(tag_7, callvalue)
|
||||
0x1f
|
||||
bytecodeSize
|
||||
@ -309,8 +301,8 @@ sub_0: assembly {
|
||||
return
|
||||
/* "viair_subobject_optimization/input.sol":616:661 if (x == 0xFFFFFFFFFFFFFFFF42)... */
|
||||
tag_7:
|
||||
0x00
|
||||
/* "viair_subobject_optimization/input.sol":653:661 revert() */
|
||||
0x00
|
||||
dup1
|
||||
revert
|
||||
/* "viair_subobject_optimization/input.sol":61:668 contract C {... */
|
||||
@ -322,6 +314,7 @@ sub_0: assembly {
|
||||
|
||||
sub_0: assembly {
|
||||
/* "viair_subobject_optimization/input.sol":61:668 contract C {... */
|
||||
mstore(0x40, 0x80)
|
||||
0x00
|
||||
dup1
|
||||
revert
|
||||
|
@ -23,6 +23,7 @@ object "C_3" {
|
||||
code {
|
||||
{
|
||||
/// @src 0:82:95 "contract C {}"
|
||||
mstore(64, memoryguard(0x80))
|
||||
revert(0, 0)
|
||||
}
|
||||
}
|
||||
@ -59,31 +60,30 @@ object "D_16" {
|
||||
mstore(64, _1)
|
||||
if iszero(lt(calldatasize(), 4))
|
||||
{
|
||||
let _2 := 0
|
||||
if eq(0x26121ff0, shr(224, calldataload(_2)))
|
||||
if eq(0x26121ff0, shr(224, calldataload(0)))
|
||||
{
|
||||
if callvalue() { revert(_2, _2) }
|
||||
if slt(add(calldatasize(), not(3)), _2) { revert(_2, _2) }
|
||||
if callvalue() { revert(0, 0) }
|
||||
if slt(add(calldatasize(), not(3)), 0) { revert(0, 0) }
|
||||
/// @src 0:149:156 "new C()"
|
||||
let _3 := datasize("C_3")
|
||||
let _4 := add(_1, _3)
|
||||
if or(gt(_4, 0xffffffffffffffff), lt(_4, _1))
|
||||
let _2 := datasize("C_3")
|
||||
let _3 := add(_1, _2)
|
||||
if or(gt(_3, 0xffffffffffffffff), lt(_3, _1))
|
||||
{
|
||||
/// @src 0:96:165 "contract D {..."
|
||||
mstore(_2, shl(224, 0x4e487b71))
|
||||
mstore(0, shl(224, 0x4e487b71))
|
||||
mstore(4, 0x41)
|
||||
revert(_2, 0x24)
|
||||
revert(0, 0x24)
|
||||
}
|
||||
/// @src 0:149:156 "new C()"
|
||||
datacopy(_1, dataoffset("C_3"), _3)
|
||||
if iszero(create(/** @src 0:96:165 "contract D {..." */ _2, /** @src 0:149:156 "new C()" */ _1, sub(_4, _1)))
|
||||
datacopy(_1, dataoffset("C_3"), _2)
|
||||
if iszero(create(0, _1, sub(_3, _1)))
|
||||
{
|
||||
/// @src 0:96:165 "contract D {..."
|
||||
let pos := mload(64)
|
||||
returndatacopy(pos, _2, returndatasize())
|
||||
returndatacopy(pos, 0, returndatasize())
|
||||
revert(pos, returndatasize())
|
||||
}
|
||||
return(_2, _2)
|
||||
return(0, 0)
|
||||
}
|
||||
}
|
||||
revert(0, 0)
|
||||
@ -107,6 +107,7 @@ object "D_16" {
|
||||
code {
|
||||
{
|
||||
/// @src 0:82:95 "contract C {}"
|
||||
mstore(64, memoryguard(0x80))
|
||||
revert(0, 0)
|
||||
}
|
||||
}
|
||||
|
@ -33,7 +33,7 @@ Text representation:
|
||||
0x00
|
||||
/* "yul_optimize_runs/input.yul":71:144 */
|
||||
codecopy
|
||||
/* "yul_optimize_runs/input.yul":80:81 */
|
||||
/* "yul_optimize_runs/input.yul":160:161 */
|
||||
0x00
|
||||
/* "yul_optimize_runs/input.yul":153:192 */
|
||||
return
|
||||
|
@ -7,7 +7,7 @@ object "C_8" {
|
||||
mstore(64, memoryguard(0x80))
|
||||
/// @src 0:129:213 "assembly (\"memory-safe\") {..."
|
||||
let usr$a := 0
|
||||
revert(usr$a, usr$a)
|
||||
revert(0, 0)
|
||||
}
|
||||
}
|
||||
/// @use-src 0:"yul_optimizer_steps_short_sequence/input.sol"
|
||||
|
@ -17,9 +17,9 @@ contract C {
|
||||
// optimize-yul: true
|
||||
// ----
|
||||
// creation:
|
||||
// codeDepositCost: 640600
|
||||
// executionCost: 674
|
||||
// totalCost: 641274
|
||||
// codeDepositCost: 638600
|
||||
// executionCost: 668
|
||||
// totalCost: 639268
|
||||
// external:
|
||||
// a(): 2283
|
||||
// b(uint256): 4649
|
||||
|
@ -21,6 +21,6 @@ contract C {
|
||||
}
|
||||
// ----
|
||||
// f() -> 0x20, 0x8, 0x40, 0x3, 0x9, 0xa, 0xb
|
||||
// gas irOptimized: 203166
|
||||
// gas irOptimized: 203228
|
||||
// gas legacy: 206263
|
||||
// gas legacyOptimized: 203151
|
||||
// gas legacyOptimized: 203156
|
||||
|
@ -59,10 +59,10 @@ contract C {
|
||||
// EVMVersion: >homestead
|
||||
// ----
|
||||
// test_bytes() ->
|
||||
// gas irOptimized: 361321
|
||||
// gas irOptimized: 360863
|
||||
// gas legacy: 411269
|
||||
// gas legacyOptimized: 317754
|
||||
// test_uint256() ->
|
||||
// gas irOptimized: 509988
|
||||
// gas irOptimized: 509569
|
||||
// gas legacy: 577469
|
||||
// gas legacyOptimized: 440931
|
||||
|
@ -24,6 +24,6 @@ contract C {
|
||||
// ----
|
||||
// library: L
|
||||
// f() -> 8, 7, 1, 2, 7, 12
|
||||
// gas irOptimized: 166506
|
||||
// gas irOptimized: 166723
|
||||
// gas legacy: 169283
|
||||
// gas legacyOptimized: 167248
|
||||
|
@ -60,10 +60,10 @@ contract C {
|
||||
// EVMVersion: >homestead
|
||||
// ----
|
||||
// test_bytes() ->
|
||||
// gas irOptimized: 361321
|
||||
// gas irOptimized: 360863
|
||||
// gas legacy: 411269
|
||||
// gas legacyOptimized: 317754
|
||||
// test_uint256() ->
|
||||
// gas irOptimized: 509988
|
||||
// gas irOptimized: 509569
|
||||
// gas legacy: 577469
|
||||
// gas legacyOptimized: 440931
|
||||
|
@ -50,6 +50,6 @@ contract C {
|
||||
// f2() -> 0x20, 0xa0, 0x1, 0x60, 0x2, 0x3, "abc"
|
||||
// f3() -> 0x20, 0xa0, 0x1, 0x60, 0x2, 0x3, "abc"
|
||||
// f4() -> 0x20, 0x160, 0x1, 0x80, 0xc0, 0x2, 0x3, "abc", 0x7, 0x40, 0x2, 0x2, 0x3
|
||||
// gas irOptimized: 112641
|
||||
// gas irOptimized: 112740
|
||||
// gas legacy: 114794
|
||||
// gas legacyOptimized: 112572
|
||||
|
@ -30,6 +30,6 @@ contract C is B {
|
||||
}
|
||||
// ----
|
||||
// test() -> 77
|
||||
// gas irOptimized: 119177
|
||||
// gas irOptimized: 110737
|
||||
// gas legacy: 151866
|
||||
// gas legacyOptimized: 110359
|
||||
|
@ -20,6 +20,6 @@ contract C {
|
||||
// f(uint256[][1]): 32, 32, 0 -> true
|
||||
// f(uint256[][1]): 32, 32, 1, 42 -> true
|
||||
// f(uint256[][1]): 32, 32, 8, 421, 422, 423, 424, 425, 426, 427, 428 -> true
|
||||
// gas irOptimized: 127012
|
||||
// gas irOptimized: 126851
|
||||
// gas legacy: 139800
|
||||
// gas legacyOptimized: 119092
|
||||
|
@ -33,7 +33,7 @@ contract C {
|
||||
// f_which(uint256[],uint256[2],uint256): 0x40, 1, 2, 1, 5, 6 -> 0x20, 0x40, 5, 2
|
||||
// f_which(uint256[],uint256[2],uint256): 0x40, 1, 2, 1 -> FAILURE
|
||||
// f_storage(uint256[],uint256[2]): 0x20, 1, 2 -> 0x20, 0x60, 0x20, 1, 2
|
||||
// gas irOptimized: 111650
|
||||
// gas irOptimized: 111732
|
||||
// gas legacy: 112944
|
||||
// gas legacyOptimized: 112092
|
||||
// f_storage(uint256[],uint256[2]): 0x40, 1, 2, 5, 6 -> 0x20, 0x80, 0x20, 2, 5, 6
|
||||
|
@ -18,10 +18,10 @@ contract C {
|
||||
// EVMVersion: >homestead
|
||||
// ----
|
||||
// h(uint256[2][]): 0x20, 3, 123, 124, 223, 224, 323, 324 -> 32, 256, 0x20, 3, 123, 124, 223, 224, 323, 324
|
||||
// gas irOptimized: 180823
|
||||
// gas irOptimized: 180889
|
||||
// gas legacy: 184830
|
||||
// gas legacyOptimized: 181493
|
||||
// i(uint256[2][2]): 123, 124, 223, 224 -> 32, 128, 123, 124, 223, 224
|
||||
// gas irOptimized: 112459
|
||||
// gas irOptimized: 112425
|
||||
// gas legacy: 115398
|
||||
// gas legacyOptimized: 112982
|
||||
|
@ -8,6 +8,6 @@ contract C {
|
||||
}
|
||||
// ----
|
||||
// f(bytes): 0x20, 0x80, 0x21, 0x40, 0x7, "abcdefg" -> 0x21, 0x40, 0x7, "abcdefg"
|
||||
// gas irOptimized: 135693
|
||||
// gas irOptimized: 135738
|
||||
// gas legacy: 137278
|
||||
// gas legacyOptimized: 136043
|
||||
// gas legacyOptimized: 136048
|
||||
|
@ -26,7 +26,7 @@ contract C {
|
||||
// index(uint256): 10 -> true
|
||||
// index(uint256): 20 -> true
|
||||
// index(uint256): 0xFF -> true
|
||||
// gas irOptimized: 135073
|
||||
// gas irOptimized: 135060
|
||||
// gas legacy: 241703
|
||||
// gas legacyOptimized: 151613
|
||||
// accessIndex(uint256,int256): 10, 1 -> 2
|
||||
|
@ -16,38 +16,38 @@ contract C {
|
||||
// ----
|
||||
// test_indices(uint256): 1 ->
|
||||
// test_indices(uint256): 129 ->
|
||||
// gas irOptimized: 3019936
|
||||
// gas irOptimized: 3043899
|
||||
// gas legacy: 3069098
|
||||
// gas legacyOptimized: 3013250
|
||||
// test_indices(uint256): 5 ->
|
||||
// gas irOptimized: 577789
|
||||
// gas irOptimized: 590601
|
||||
// gas legacy: 574754
|
||||
// gas legacyOptimized: 572383
|
||||
// test_indices(uint256): 10 ->
|
||||
// gas irOptimized: 158291
|
||||
// gas irOptimized: 159493
|
||||
// gas legacy: 162468
|
||||
// gas legacyOptimized: 158336
|
||||
// test_indices(uint256): 15 ->
|
||||
// gas irOptimized: 173296
|
||||
// gas irOptimized: 174798
|
||||
// gas legacy: 179513
|
||||
// gas legacyOptimized: 173606
|
||||
// test_indices(uint256): 0xFF ->
|
||||
// gas irOptimized: 5678606
|
||||
// gas irOptimized: 5724353
|
||||
// gas legacy: 5775928
|
||||
// gas legacyOptimized: 5666726
|
||||
// test_indices(uint256): 1000 ->
|
||||
// gas irOptimized: 18197173
|
||||
// gas irOptimized: 18351755
|
||||
// gas legacy: 18583810
|
||||
// gas legacyOptimized: 18171248
|
||||
// test_indices(uint256): 129 ->
|
||||
// gas irOptimized: 4156312
|
||||
// gas irOptimized: 4250972
|
||||
// gas legacy: 4164468
|
||||
// gas legacyOptimized: 4122100
|
||||
// test_indices(uint256): 128 ->
|
||||
// gas irOptimized: 411289
|
||||
// gas irOptimized: 419063
|
||||
// gas legacy: 463706
|
||||
// gas legacyOptimized: 418061
|
||||
// test_indices(uint256): 1 ->
|
||||
// gas irOptimized: 581362
|
||||
// gas irOptimized: 594287
|
||||
// gas legacy: 576904
|
||||
// gas legacyOptimized: 575649
|
||||
|
@ -16,11 +16,11 @@ contract C {
|
||||
// test_boundary_check(uint256,uint256): 1, 1 -> FAILURE, hex"4e487b71", 0x32
|
||||
// test_boundary_check(uint256,uint256): 10, 10 -> FAILURE, hex"4e487b71", 0x32
|
||||
// test_boundary_check(uint256,uint256): 256, 256 -> FAILURE, hex"4e487b71", 0x32
|
||||
// gas irOptimized: 140383
|
||||
// gas irOptimized: 171594
|
||||
// gas legacy: 133633
|
||||
// gas legacyOptimized: 114354
|
||||
// test_boundary_check(uint256,uint256): 256, 255 -> 0
|
||||
// gas irOptimized: 142515
|
||||
// gas irOptimized: 173767
|
||||
// gas legacy: 135949
|
||||
// gas legacyOptimized: 116533
|
||||
// test_boundary_check(uint256,uint256): 256, 0xFFFF -> FAILURE, hex"4e487b71", 0x32
|
||||
|
@ -52,18 +52,18 @@ contract C {
|
||||
// ----
|
||||
// test_zeroed_indicies(uint256): 1 ->
|
||||
// test_zeroed_indicies(uint256): 5 ->
|
||||
// gas irOptimized: 131925
|
||||
// gas irOptimized: 134360
|
||||
// gas legacy: 132804
|
||||
// gas legacyOptimized: 130649
|
||||
// test_zeroed_indicies(uint256): 10 ->
|
||||
// gas irOptimized: 225874
|
||||
// gas irOptimized: 229960
|
||||
// gas legacy: 227786
|
||||
// gas legacyOptimized: 223830
|
||||
// test_zeroed_indicies(uint256): 15 ->
|
||||
// gas irOptimized: 323938
|
||||
// gas irOptimized: 329572
|
||||
// gas legacy: 326902
|
||||
// gas legacyOptimized: 321206
|
||||
// test_zeroed_indicies(uint256): 0xFF ->
|
||||
// gas irOptimized: 5116738
|
||||
// gas irOptimized: 5221116
|
||||
// gas legacy: 5165874
|
||||
// gas legacyOptimized: 5062182
|
||||
|
@ -12,11 +12,11 @@ contract C {
|
||||
// set_get_length(uint256): 10 -> 10
|
||||
// set_get_length(uint256): 20 -> 20
|
||||
// set_get_length(uint256): 0xFF -> 0xFF
|
||||
// gas irOptimized: 96690
|
||||
// gas irOptimized: 144589
|
||||
// gas legacy: 128571
|
||||
// gas legacyOptimized: 110143
|
||||
// set_get_length(uint256): 0xFFF -> 0xFFF
|
||||
// gas irOptimized: 1220647
|
||||
// gas irOptimized: 1957916
|
||||
// gas legacy: 1689548
|
||||
// gas legacyOptimized: 1393535
|
||||
// set_get_length(uint256): 0xFFFFF -> FAILURE # Out-of-gas #
|
||||
|
@ -12,11 +12,11 @@ contract C {
|
||||
// EVMVersion: >=petersburg
|
||||
// ----
|
||||
// pushEmpty(uint256): 128
|
||||
// gas irOptimized: 406413
|
||||
// gas irOptimized: 426490
|
||||
// gas legacy: 415744
|
||||
// gas legacyOptimized: 397380
|
||||
// pushEmpty(uint256): 256
|
||||
// gas irOptimized: 693185
|
||||
// gas irOptimized: 717102
|
||||
// gas legacy: 715316
|
||||
// gas legacyOptimized: 688632
|
||||
// pushEmpty(uint256): 38869 -> FAILURE # out-of-gas #
|
||||
|
@ -21,11 +21,11 @@ contract C {
|
||||
// gas legacy: 77730
|
||||
// gas legacyOptimized: 77162
|
||||
// set_get_length(uint256): 0xFF -> 0xFF
|
||||
// gas irOptimized: 161440
|
||||
// gas irOptimized: 193804
|
||||
// gas legacy: 696850
|
||||
// gas legacyOptimized: 134488
|
||||
// set_get_length(uint256): 0xFFF -> 0xFFF
|
||||
// gas irOptimized: 1800622
|
||||
// gas irOptimized: 2288281
|
||||
// gas legacy: 9857362
|
||||
// gas legacyOptimized: 1393660
|
||||
// set_get_length(uint256): 0xFFFFF -> FAILURE # Out-of-gas #
|
||||
|
@ -17,11 +17,11 @@ contract C {
|
||||
// gas legacy: 105722
|
||||
// gas legacyOptimized: 103508
|
||||
// set_get_length(uint256): 0xFF -> 0
|
||||
// gas irOptimized: 821106
|
||||
// gas irOptimized: 890706
|
||||
// gas legacy: 808020
|
||||
// gas legacyOptimized: 784467
|
||||
// set_get_length(uint256): 0xFFF -> 0
|
||||
// gas irOptimized: 12828798
|
||||
// gas irOptimized: 13946718
|
||||
// gas legacy: 12612192
|
||||
// gas legacyOptimized: 12239199
|
||||
// set_get_length(uint256): 0xFFFF -> FAILURE # Out-of-gas #
|
||||
|
@ -12,7 +12,7 @@ contract Test {
|
||||
}
|
||||
// ----
|
||||
// set(uint24[3][]): 0x20, 0x06, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f, 0x10, 0x11, 0x12 -> 0x06
|
||||
// gas irOptimized: 186537
|
||||
// gas irOptimized: 186560
|
||||
// gas legacy: 211054
|
||||
// gas legacyOptimized: 206042
|
||||
// data(uint256,uint256): 0x02, 0x02 -> 0x09
|
||||
|
@ -17,6 +17,6 @@ contract c {
|
||||
}
|
||||
// ----
|
||||
// test() -> 0
|
||||
// gas irOptimized: 125584
|
||||
// gas irOptimized: 125104
|
||||
// gas legacy: 150372
|
||||
// gas legacyOptimized: 146391
|
||||
|
@ -13,7 +13,7 @@ contract c {
|
||||
// ----
|
||||
// getLength() -> 0
|
||||
// set(): 1, 2 -> true
|
||||
// gas irOptimized: 110400
|
||||
// gas irOptimized: 110408
|
||||
// gas legacy: 110952
|
||||
// gas legacyOptimized: 110580
|
||||
// gas legacyOptimized: 110576
|
||||
// getLength() -> 68
|
||||
|
@ -8,7 +8,7 @@ contract C {
|
||||
}
|
||||
// ----
|
||||
// constructor(): 1, 2, 3 ->
|
||||
// gas irOptimized: 140952
|
||||
// gas irOptimized: 139729
|
||||
// gas legacy: 180517
|
||||
// gas legacyOptimized: 150462
|
||||
// a(uint256): 0 -> 1
|
||||
|
@ -20,7 +20,7 @@ contract c {
|
||||
}
|
||||
// ----
|
||||
// store(uint256[9],uint8[3][]): 21, 22, 23, 24, 25, 26, 27, 28, 29, 0x140, 4, 1, 2, 3, 11, 12, 13, 21, 22, 23, 31, 32, 33 -> 32
|
||||
// gas irOptimized: 648323
|
||||
// gas irOptimized: 648352
|
||||
// gas legacy: 694356
|
||||
// gas legacyOptimized: 693864
|
||||
// retrieve() -> 9, 28, 9, 28, 4, 3, 32
|
||||
|
@ -46,6 +46,6 @@ contract C {
|
||||
}
|
||||
// ----
|
||||
// f() -> true
|
||||
// gas irOptimized: 117369
|
||||
// gas irOptimized: 122796
|
||||
// gas legacy: 124660
|
||||
// gas legacyOptimized: 122801
|
||||
|
@ -13,6 +13,6 @@ contract C {
|
||||
}
|
||||
// ----
|
||||
// f() -> 0
|
||||
// gas irOptimized: 107488
|
||||
// gas irOptimized: 108354
|
||||
// gas legacy: 108218
|
||||
// gas legacyOptimized: 107625
|
||||
|
@ -18,6 +18,6 @@ contract c {
|
||||
}
|
||||
// ----
|
||||
// test() -> 0x01000000000000000000000000000000000000000000000000, 0x02000000000000000000000000000000000000000000000000, 0x03000000000000000000000000000000000000000000000000, 0x04000000000000000000000000000000000000000000000000, 0x05000000000000000000000000000000000000000000000000
|
||||
// gas irOptimized: 208122
|
||||
// gas irOptimized: 209745
|
||||
// gas legacy: 221769
|
||||
// gas legacyOptimized: 220611
|
||||
|
@ -35,12 +35,12 @@ contract c {
|
||||
}
|
||||
// ----
|
||||
// test() -> 0x02000202
|
||||
// gas irOptimized: 4548245
|
||||
// gas irOptimized: 4549147
|
||||
// gas legacy: 4476222
|
||||
// gas legacyOptimized: 4448113
|
||||
// storageEmpty -> 1
|
||||
// clear() -> 0, 0
|
||||
// gas irOptimized: 4475224
|
||||
// gas irOptimized: 4477925
|
||||
// gas legacy: 4408014
|
||||
// gas legacyOptimized: 4381784
|
||||
// storageEmpty -> 1
|
||||
|
@ -12,6 +12,6 @@ contract c {
|
||||
}
|
||||
// ----
|
||||
// test(uint256[2][]): 32, 3, 7, 8, 9, 10, 11, 12 -> 10
|
||||
// gas irOptimized: 689714
|
||||
// gas irOptimized: 689898
|
||||
// gas legacy: 686178
|
||||
// gas legacyOptimized: 685628
|
||||
|
@ -17,6 +17,6 @@ contract c {
|
||||
}
|
||||
// ----
|
||||
// test() -> 5, 4
|
||||
// gas irOptimized: 205062
|
||||
// gas irOptimized: 205329
|
||||
// gas legacy: 213863
|
||||
// gas legacyOptimized: 212902
|
||||
|
@ -21,6 +21,6 @@ contract c {
|
||||
}
|
||||
// ----
|
||||
// test() -> 3, 4
|
||||
// gas irOptimized: 169602
|
||||
// gas irOptimized: 169620
|
||||
// gas legacy: 175424
|
||||
// gas legacyOptimized: 172535
|
||||
|
@ -15,7 +15,7 @@ contract c {
|
||||
// ----
|
||||
// setData1(uint256,uint256,uint256): 10, 5, 4 ->
|
||||
// copyStorageStorage() ->
|
||||
// gas irOptimized: 111366
|
||||
// gas irOptimized: 111370
|
||||
// gas legacy: 109272
|
||||
// gas legacyOptimized: 109262
|
||||
// getData2(uint256): 5 -> 10, 4
|
||||
|
@ -17,6 +17,6 @@ contract c {
|
||||
}
|
||||
// ----
|
||||
// test() -> 5, 4
|
||||
// gas irOptimized: 252986
|
||||
// gas irOptimized: 253389
|
||||
// gas legacy: 250892
|
||||
// gas legacyOptimized: 250046
|
||||
|
@ -11,6 +11,6 @@ contract c {
|
||||
}
|
||||
// ----
|
||||
// test() -> 9, 4
|
||||
// gas irOptimized: 123142
|
||||
// gas irOptimized: 123230
|
||||
// gas legacy: 123567
|
||||
// gas legacyOptimized: 123202
|
||||
|
@ -14,6 +14,6 @@ contract c {
|
||||
}
|
||||
// ----
|
||||
// test() -> 8, 0
|
||||
// gas irOptimized: 196278
|
||||
// gas irOptimized: 196259
|
||||
// gas legacy: 194843
|
||||
// gas legacyOptimized: 194281
|
||||
|
@ -17,7 +17,7 @@ contract c {
|
||||
}
|
||||
// ----
|
||||
// test() -> 4, 5
|
||||
// gas irOptimized: 190870
|
||||
// gas irOptimized: 192450
|
||||
// gas legacy: 190852
|
||||
// gas legacyOptimized: 189658
|
||||
// storageEmpty -> 1
|
||||
|
@ -15,6 +15,6 @@ contract C {
|
||||
}
|
||||
// ----
|
||||
// f() -> 0x20, 2, 0x40, 0xa0, 2, 0, 1, 2, 2, 3
|
||||
// gas irOptimized: 161715
|
||||
// gas irOptimized: 161939
|
||||
// gas legacy: 162203
|
||||
// gas legacyOptimized: 159941
|
||||
// gas legacyOptimized: 159934
|
||||
|
@ -17,6 +17,6 @@ contract c {
|
||||
}
|
||||
// ----
|
||||
// test() -> 0xffffffff, 0x0000000000000000000000000a00090008000700060005000400030002000100, 0x0000000000000000000000000000000000000000000000000000000000000000
|
||||
// gas irOptimized: 104665
|
||||
// gas irOptimized: 104526
|
||||
// gas legacy: 166874
|
||||
// gas legacyOptimized: 145474
|
||||
|
@ -18,6 +18,6 @@ contract c {
|
||||
}
|
||||
// ----
|
||||
// test() -> 0x01000000000000000000000000000000000000000000000000, 0x02000000000000000000000000000000000000000000000000, 0x03000000000000000000000000000000000000000000000000, 0x04000000000000000000000000000000000000000000000000, 0x0
|
||||
// gas irOptimized: 273576
|
||||
// gas irOptimized: 273564
|
||||
// gas legacy: 283666
|
||||
// gas legacyOptimized: 282023
|
||||
|
@ -18,6 +18,6 @@ contract c {
|
||||
}
|
||||
// ----
|
||||
// test() -> 0x01000000000000000000000000000000000000000000000000, 0x02000000000000000000000000000000000000000000000000, 0x03000000000000000000000000000000000000000000000000, 0x04000000000000000000000000000000000000000000000000, 0x00
|
||||
// gas irOptimized: 233285
|
||||
// gas irOptimized: 233271
|
||||
// gas legacy: 236523
|
||||
// gas legacyOptimized: 235592
|
||||
|
@ -52,9 +52,9 @@ contract C {
|
||||
}
|
||||
// ----
|
||||
// from_storage() -> 0x20, 2, 0x40, 0xa0, 2, 10, 11, 3, 12, 13, 14
|
||||
// gas irOptimized: 150061
|
||||
// gas irOptimized: 150006
|
||||
// gas legacy: 150745
|
||||
// gas legacyOptimized: 148685
|
||||
// gas legacyOptimized: 148678
|
||||
// from_storage_ptr() -> 0x20, 2, 0x40, 0xa0, 2, 10, 11, 3, 12, 13, 14
|
||||
// from_memory() -> 0x20, 2, 0x40, 0xa0, 2, 10, 11, 3, 12, 13, 14
|
||||
// from_calldata(uint8[][]): 0x20, 2, 0x40, 0xa0, 2, 10, 11, 3, 12, 13, 14 -> 0x20, 2, 0x40, 0xa0, 2, 10, 11, 3, 12, 13, 14
|
||||
|
@ -38,10 +38,10 @@ contract c {
|
||||
// compileViaYul: true
|
||||
// ----
|
||||
// test1(uint256[][]): 0x20, 2, 0x40, 0x40, 2, 23, 42 -> 2, 65
|
||||
// gas irOptimized: 180759
|
||||
// gas irOptimized: 181047
|
||||
// test2(uint256[][2]): 0x20, 0x40, 0x40, 2, 23, 42 -> 2, 65
|
||||
// gas irOptimized: 157562
|
||||
// gas irOptimized: 157637
|
||||
// test3(uint256[2][]): 0x20, 2, 23, 42, 23, 42 -> 2, 65
|
||||
// gas irOptimized: 134637
|
||||
// gas irOptimized: 134723
|
||||
// test4(uint256[2][2]): 23, 42, 23, 42 -> 65
|
||||
// gas irOptimized: 111270
|
||||
// gas irOptimized: 111252
|
||||
|
@ -38,12 +38,12 @@ contract Test {
|
||||
}
|
||||
// ----
|
||||
// test() -> 24
|
||||
// gas irOptimized: 226687
|
||||
// gas irOptimized: 226652
|
||||
// gas legacy: 227084
|
||||
// gas legacyOptimized: 226529
|
||||
// test1() -> 3
|
||||
// test2() -> 6
|
||||
// test3() -> 24
|
||||
// gas irOptimized: 141244
|
||||
// gas irOptimized: 141338
|
||||
// gas legacy: 142238
|
||||
// gas legacyOptimized: 141365
|
||||
|
@ -45,7 +45,7 @@ contract C {
|
||||
}
|
||||
// ----
|
||||
// copyExternalStorageArrayOfFunctionType() -> true
|
||||
// gas irOptimized: 104606
|
||||
// gas irOptimized: 104770
|
||||
// gas legacy: 108554
|
||||
// gas legacyOptimized: 102413
|
||||
// copyInternalArrayOfFunctionType() -> true
|
||||
|
@ -48,7 +48,7 @@ contract C {
|
||||
}
|
||||
// ----
|
||||
// copyExternalStorageArraysOfFunctionType() -> true
|
||||
// gas irOptimized: 104279
|
||||
// gas irOptimized: 104427
|
||||
// gas legacy: 108295
|
||||
// gas legacyOptimized: 102146
|
||||
// copyInternalArrayOfFunctionType() -> true
|
||||
|
@ -17,4 +17,4 @@ contract C {
|
||||
// compileViaYul: true
|
||||
// ----
|
||||
// f((uint128,uint64,uint128)[]): 0x20, 3, 0, 0, 12, 0, 11, 0, 10, 0, 0 -> 10, 11, 12
|
||||
// gas irOptimized: 119736
|
||||
// gas irOptimized: 119937
|
||||
|
@ -19,4 +19,4 @@ contract C {
|
||||
// compileViaYul: true
|
||||
// ----
|
||||
// f() -> 10, 11, 12
|
||||
// gas irOptimized: 118393
|
||||
// gas irOptimized: 118565
|
||||
|
@ -23,4 +23,4 @@ contract C {
|
||||
// compileViaYul: true
|
||||
// ----
|
||||
// f((uint256[])[]): 0x20, 3, 0x60, 0x60, 0x60, 0x20, 3, 1, 2, 3 -> 3, 1
|
||||
// gas irOptimized: 327759
|
||||
// gas irOptimized: 328430
|
||||
|
@ -26,4 +26,4 @@ contract C {
|
||||
// compileViaYul: true
|
||||
// ----
|
||||
// f() -> 3, 3, 3, 1
|
||||
// gas irOptimized: 181950
|
||||
// gas irOptimized: 181908
|
||||
|
@ -12,6 +12,6 @@ contract C {
|
||||
}
|
||||
// ----
|
||||
// f() -> 1, 2, 3
|
||||
// gas irOptimized: 131932
|
||||
// gas irOptimized: 131921
|
||||
// gas legacy: 134606
|
||||
// gas legacyOptimized: 131938
|
||||
|
@ -37,8 +37,8 @@ contract C {
|
||||
}
|
||||
// ----
|
||||
// from_storage() -> 0x20, 2, 0x40, 0xa0, 2, 10, 11, 3, 12, 13, 14
|
||||
// gas irOptimized: 147892
|
||||
// gas irOptimized: 147915
|
||||
// gas legacy: 148896
|
||||
// gas legacyOptimized: 146908
|
||||
// gas legacyOptimized: 146901
|
||||
// from_storage_ptr() -> 0x20, 2, 0x40, 0xa0, 2, 10, 11, 3, 12, 13, 14
|
||||
// from_memory() -> 0x20, 2, 0x40, 0xa0, 2, 10, 11, 3, 12, 13, 14
|
||||
|
@ -5,13 +5,13 @@ contract c {
|
||||
}
|
||||
// ----
|
||||
// set(uint256): 1, 2 -> true
|
||||
// gas irOptimized: 110574
|
||||
// gas irOptimized: 110558
|
||||
// gas legacy: 111312
|
||||
// gas legacyOptimized: 110744
|
||||
// gas legacyOptimized: 110741
|
||||
// set(uint256): 2, 2, 3, 4, 5 -> true
|
||||
// gas irOptimized: 177525
|
||||
// gas irOptimized: 177509
|
||||
// gas legacy: 178314
|
||||
// gas legacyOptimized: 177719
|
||||
// gas legacyOptimized: 177716
|
||||
// storageEmpty -> 0
|
||||
// copy(uint256,uint256): 1, 2 -> true
|
||||
// storageEmpty -> 0
|
||||
|
@ -17,25 +17,25 @@ contract c {
|
||||
// ----
|
||||
// f(uint256): 0 -> 0x20, 0x00
|
||||
// f(uint256): 31 -> 0x20, 0x1f, 0x0102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e00
|
||||
// gas irOptimized: 109255
|
||||
// gas irOptimized: 109275
|
||||
// gas legacy: 123948
|
||||
// gas legacyOptimized: 118948
|
||||
// f(uint256): 32 -> 0x20, 0x20, 1780731860627700044960722568376592200742329637303199754547598369979440671
|
||||
// gas irOptimized: 123936
|
||||
// gas irOptimized: 124380
|
||||
// gas legacy: 140362
|
||||
// gas legacyOptimized: 135386
|
||||
// gas legacyOptimized: 135384
|
||||
// f(uint256): 33 -> 0x20, 33, 1780731860627700044960722568376592200742329637303199754547598369979440671, 0x2000000000000000000000000000000000000000000000000000000000000000
|
||||
// gas irOptimized: 130543
|
||||
// gas irOptimized: 130982
|
||||
// gas legacy: 147916
|
||||
// gas legacyOptimized: 142290
|
||||
// gas legacyOptimized: 142276
|
||||
// f(uint256): 63 -> 0x20, 0x3f, 1780731860627700044960722568376592200742329637303199754547598369979440671, 14532552714582660066924456880521368950258152170031413196862950297402215316992
|
||||
// gas irOptimized: 139333
|
||||
// gas irOptimized: 140042
|
||||
// gas legacy: 171136
|
||||
// gas legacyOptimized: 161550
|
||||
// gas legacyOptimized: 161536
|
||||
// f(uint256): 12 -> 0x20, 0x0c, 0x0102030405060708090a0b0000000000000000000000000000000000000000
|
||||
// gas legacy: 59345
|
||||
// gas legacyOptimized: 57279
|
||||
// f(uint256): 129 -> 0x20, 0x81, 1780731860627700044960722568376592200742329637303199754547598369979440671, 0x202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f, 29063324697304692433803953038474361308315562010425523193971352996434451193439, 0x606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f, -57896044618658097711785492504343953926634992332820282019728792003956564819968
|
||||
// gas irOptimized: 441985
|
||||
// gas irOptimized: 443206
|
||||
// gas legacy: 505021
|
||||
// gas legacyOptimized: 486997
|
||||
// gas legacyOptimized: 486995
|
||||
|
@ -9,6 +9,6 @@ contract C {
|
||||
}
|
||||
// ----
|
||||
// f(uint256[]): 0x20, 0x03, 0x1, 0x2, 0x3 -> 0x1
|
||||
// gas irOptimized: 110970
|
||||
// gas irOptimized: 111049
|
||||
// gas legacy: 111551
|
||||
// gas legacyOptimized: 111339
|
||||
|
@ -14,4 +14,4 @@ contract C {
|
||||
// compileViaYul: true
|
||||
// ----
|
||||
// from_calldata(uint8[][]): 0x20, 2, 0x40, 0xa0, 2, 10, 11, 3, 12, 13, 14 -> 0x20, 2, 0x40, 0xa0, 2, 10, 11, 3, 12, 13, 14
|
||||
// gas irOptimized: 139905
|
||||
// gas irOptimized: 139683
|
||||
|
@ -16,7 +16,7 @@ contract C {
|
||||
}
|
||||
// ----
|
||||
// constructor()
|
||||
// gas irOptimized: 234419
|
||||
// gas irOptimized: 210785
|
||||
// gas legacy: 215757
|
||||
// gas legacyOptimized: 181760
|
||||
// f() -> 0
|
||||
|
@ -35,12 +35,12 @@ contract C {
|
||||
}
|
||||
// ----
|
||||
// f() -> 0x40, 0x80, 6, 0x6162636465660000000000000000000000000000000000000000000000000000, 0x49, 0x3132333435363738393031323334353637383930313233343536373839303120, 0x3132333435363738393031323334353637383930313233343536373839303120, 0x3132333435363738390000000000000000000000000000000000000000000000
|
||||
// gas irOptimized: 179752
|
||||
// gas irOptimized: 179696
|
||||
// gas legacy: 181001
|
||||
// gas legacyOptimized: 180014
|
||||
// gas legacyOptimized: 180018
|
||||
// g() -> 0x40, 0xc0, 0x49, 0x3132333435363738393031323334353637383930313233343536373839303120, 0x3132333435363738393031323334353637383930313233343536373839303120, 0x3132333435363738390000000000000000000000000000000000000000000000, 0x11, 0x3132333435363738393233343536373839000000000000000000000000000000
|
||||
// gas irOptimized: 106682
|
||||
// gas irOptimized: 106631
|
||||
// gas legacy: 109720
|
||||
// gas legacyOptimized: 106937
|
||||
// gas legacyOptimized: 106932
|
||||
// h() -> 0x40, 0x60, 0x00, 0x00
|
||||
// storageEmpty -> 1
|
||||
|
@ -46,6 +46,6 @@ contract C {
|
||||
}
|
||||
// ----
|
||||
// f() -> 0xff
|
||||
// gas irOptimized: 143426
|
||||
// gas irOptimized: 144270
|
||||
// gas legacy: 153395
|
||||
// gas legacyOptimized: 146722
|
||||
// gas legacyOptimized: 146720
|
||||
|
@ -15,6 +15,6 @@ contract C {
|
||||
}
|
||||
// ----
|
||||
// test() -> 7
|
||||
// gas irOptimized: 122477
|
||||
// gas irOptimized: 122662
|
||||
// gas legacy: 205176
|
||||
// gas legacyOptimized: 204971
|
||||
|
@ -7,9 +7,9 @@ contract c {
|
||||
}
|
||||
// ----
|
||||
// set(): 1, 2, 3, 4, 5 -> true
|
||||
// gas irOptimized: 177383
|
||||
// gas irOptimized: 177368
|
||||
// gas legacy: 177954
|
||||
// gas legacyOptimized: 177554
|
||||
// gas legacyOptimized: 177550
|
||||
// storageEmpty -> 0
|
||||
// reset() -> true
|
||||
// storageEmpty -> 1
|
||||
|
@ -18,9 +18,9 @@ contract sender {
|
||||
}
|
||||
// ----
|
||||
// (): 7 ->
|
||||
// gas irOptimized: 110820
|
||||
// gas irOptimized: 110901
|
||||
// gas legacy: 111388
|
||||
// gas legacyOptimized: 111071
|
||||
// gas legacyOptimized: 111065
|
||||
// val() -> 0
|
||||
// forward(bool): true -> true
|
||||
// val() -> 0x80
|
||||
|
@ -31,8 +31,8 @@ contract C {
|
||||
// compileViaYul: true
|
||||
// ----
|
||||
// test1((uint8[],uint8[2])[][][]): 0x20, 1, 0x20, 2, 0x40, 0x0140, 1, 0x20, 0x60, 3, 7, 2, 1, 2, 2, 0x40, 0x0100, 0x60, 17, 19, 2, 11, 13, 0x60, 31, 37, 2, 23, 29 -> 0x20, 2, 0x40, 0x0140, 1, 0x20, 0x60, 3, 7, 2, 1, 2, 2, 0x40, 0x0100, 0x60, 17, 19, 2, 11, 13, 0x60, 31, 37, 2, 23, 29
|
||||
// gas irOptimized: 327821
|
||||
// gas irOptimized: 327934
|
||||
// test2((uint8[],uint8[2])[][1][]): 0x20, 2, 0x40, 0x0160, 0x20, 1, 0x20, 0x60, 17, 19, 2, 11, 13, 0x20, 1, 0x20, 0x60, 31, 37, 2, 23, 29 -> 0x20, 0x20, 1, 0x20, 0x60, 17, 19, 2, 11, 13
|
||||
// gas irOptimized: 140867
|
||||
// gas irOptimized: 140870
|
||||
// test3((uint8[],uint8[2])[1][][2]): 0x20, 0x40, 0x60, 0, 2, 0x40, 288, 0x20, 0x60, 3, 7, 2, 1, 2, 0x20, 0x60, 17, 19, 2, 11, 13 -> 0x20, 2, 0x40, 288, 0x20, 0x60, 3, 7, 2, 1, 2, 0x20, 0x60, 17, 19, 2, 11, 13
|
||||
// gas irOptimized: 188473
|
||||
// gas irOptimized: 188553
|
||||
|
@ -31,8 +31,8 @@ contract C {
|
||||
// compileViaYul: true
|
||||
// ----
|
||||
// test1((uint8[],uint8[2])[][][]): 0x20, 1, 0x20, 2, 0x40, 0x0140, 1, 0x20, 0x60, 3, 7, 2, 1, 2, 2, 0x40, 0x0100, 0x60, 17, 19, 2, 11, 13, 0x60, 31, 37, 2, 23, 29 -> 0x20, 2, 0x40, 0x0140, 1, 0x20, 0x60, 3, 7, 2, 1, 2, 2, 0x40, 0x0100, 0x60, 17, 19, 2, 11, 13, 0x60, 31, 37, 2, 23, 29
|
||||
// gas irOptimized: 332527
|
||||
// gas irOptimized: 332777
|
||||
// test2((uint8[],uint8[2])[][1][]): 0x20, 2, 0x40, 0x0160, 0x20, 1, 0x20, 0x60, 17, 19, 2, 11, 13, 0x20, 1, 0x20, 0x60, 31, 37, 2, 23, 29 -> 0x20, 0x20, 1, 0x20, 0x60, 17, 19, 2, 11, 13
|
||||
// gas irOptimized: 145155
|
||||
// gas irOptimized: 145161
|
||||
// test3((uint8[],uint8[2])[1][][2]): 0x20, 0x40, 0x60, 0, 2, 0x40, 288, 0x20, 0x60, 3, 7, 2, 1, 2, 0x20, 0x60, 17, 19, 2, 11, 13 -> 0x20, 2, 0x40, 288, 0x20, 0x60, 3, 7, 2, 1, 2, 0x20, 0x60, 17, 19, 2, 11, 13
|
||||
// gas irOptimized: 192476
|
||||
// gas irOptimized: 192680
|
||||
|
@ -46,11 +46,11 @@ contract C {
|
||||
}
|
||||
// ----
|
||||
// test() -> 0x20, 0x14, "[a called][b called]"
|
||||
// gas irOptimized: 116638
|
||||
// gas irOptimized: 116438
|
||||
// gas legacy: 118936
|
||||
// gas legacyOptimized: 116975
|
||||
// test2() -> 0x20, 0x14, "[b called][a called]"
|
||||
// test3() -> 0x20, 0x14, "[b called][a called]"
|
||||
// gas irOptimized: 103241
|
||||
// gas irOptimized: 103292
|
||||
// gas legacy: 102745
|
||||
// gas legacyOptimized: 101669
|
||||
|
@ -18,6 +18,6 @@ contract C {
|
||||
}
|
||||
// ----
|
||||
// f() -> 3
|
||||
// gas irOptimized: 128116
|
||||
// gas irOptimized: 129339
|
||||
// gas legacy: 130584
|
||||
// gas legacyOptimized: 129031
|
||||
// gas legacyOptimized: 129028
|
||||
|
@ -70,15 +70,15 @@ contract C {
|
||||
}
|
||||
// ----
|
||||
// test1() ->
|
||||
// gas irOptimized: 150508
|
||||
// gas irOptimized: 150502
|
||||
// gas legacy: 150949
|
||||
// gas legacyOptimized: 150906
|
||||
// test2() -> FAILURE
|
||||
// gas irOptimized: 150385
|
||||
// gas irOptimized: 150429
|
||||
// gas legacy: 150673
|
||||
// gas legacyOptimized: 150576
|
||||
// test3() ->
|
||||
// gas irOptimized: 123776
|
||||
// gas irOptimized: 124005
|
||||
// gas legacy: 125333
|
||||
// gas legacyOptimized: 125127
|
||||
// test4() -> FAILURE
|
||||
|
@ -29,8 +29,8 @@ contract C {
|
||||
// compileViaYul: true
|
||||
// ----
|
||||
// test1((uint8[],uint8[2])[][]): 0x20, 2, 0x40, 0x0140, 1, 0x20, 0x60, 3, 7, 2, 1, 2, 2, 0x40, 0x0100, 0x60, 17, 19, 2, 11, 13, 0x60, 31, 37, 2, 23, 29 -> 0x20, 2, 0x40, 0x0140, 1, 0x20, 0x60, 3, 7, 2, 1, 2, 2, 0x40, 0x0100, 0x60, 17, 19, 2, 11, 13, 0x60, 31, 37, 2, 23, 29
|
||||
// gas irOptimized: 304714
|
||||
// gas irOptimized: 304746
|
||||
// test2((uint8[],uint8[2])[][1]): 0x20, 0x20, 1, 0x20, 0x60, 17, 19, 2, 11, 13 -> 0x20, 0x20, 1, 0x20, 0x60, 17, 19, 2, 11, 13
|
||||
// gas irOptimized: 116454
|
||||
// gas irOptimized: 116447
|
||||
// test3((uint8[],uint8[2])[1][]): 0x20, 2, 0x40, 0x0120, 0x20, 0x60, 3, 7, 2, 1, 2, 0x20, 0x60, 17, 19, 2, 11, 13 -> 0x20, 2, 0x40, 0x0120, 0x20, 0x60, 3, 7, 2, 1, 2, 0x20, 0x60, 17, 19, 2, 11, 13
|
||||
// gas irOptimized: 187962
|
||||
// gas irOptimized: 188042
|
||||
|
@ -29,8 +29,8 @@ contract C {
|
||||
// compileViaYul: true
|
||||
// ----
|
||||
// test1((uint8[],uint8[2])[][]): 0x20, 2, 0x40, 0x0140, 1, 0x20, 0x60, 3, 7, 2, 1, 2, 2, 0x40, 0x0100, 0x60, 17, 19, 2, 11, 13, 0x60, 31, 37, 2, 23, 29 -> 0x20, 2, 0x40, 0x0140, 1, 0x20, 0x60, 3, 7, 2, 1, 2, 2, 0x40, 0x0100, 0x60, 17, 19, 2, 11, 13, 0x60, 31, 37, 2, 23, 29
|
||||
// gas irOptimized: 309068
|
||||
// gas irOptimized: 309070
|
||||
// test2((uint8[],uint8[2])[][1]): 0x20, 0x20, 1, 0x20, 0x60, 17, 19, 2, 11, 13 -> 0x20, 0x20, 1, 0x20, 0x60, 17, 19, 2, 11, 13
|
||||
// gas irOptimized: 118167
|
||||
// gas irOptimized: 118262
|
||||
// test3((uint8[],uint8[2])[1][]): 0x20, 2, 0x40, 0x0120, 0x20, 0x60, 3, 7, 2, 1, 2, 0x20, 0x60, 17, 19, 2, 11, 13 -> 0x20, 2, 0x40, 0x0120, 0x20, 0x60, 3, 7, 2, 1, 2, 0x20, 0x60, 17, 19, 2, 11, 13
|
||||
// gas irOptimized: 190961
|
||||
// gas irOptimized: 191041
|
||||
|
@ -63,7 +63,7 @@ contract C {
|
||||
// compileViaYul: true
|
||||
// ----
|
||||
// test1()
|
||||
// gas irOptimized: 123237
|
||||
// gas irOptimized: 123207
|
||||
// test2()
|
||||
// gas irOptimized: 123043
|
||||
// gas irOptimized: 123042
|
||||
// test3()
|
||||
|
@ -30,7 +30,7 @@ contract C {
|
||||
// compileViaYul: true
|
||||
// ----
|
||||
// test(uint8[][][]): 0x20, 2, 0x40, 0x60, 0, 2, 0x40, 0x80, 1, 7, 2, 8, 9
|
||||
// gas irOptimized: 138054
|
||||
// gas irOptimized: 138063
|
||||
// test2(uint8[][]): 0x20, 2, 0x40, 0x80, 1, 7, 2, 8, 9
|
||||
// gas irOptimized: 164232
|
||||
// gas irOptimized: 164291
|
||||
// gas legacyOptimized: 120228
|
||||
|
@ -17,6 +17,6 @@ contract C {
|
||||
}
|
||||
// ----
|
||||
// f() -> 1, 2, 3, 4, 5, 6, 7
|
||||
// gas irOptimized: 205974
|
||||
// gas irOptimized: 206351
|
||||
// gas legacy: 212237
|
||||
// gas legacyOptimized: 211425
|
||||
|
@ -11,6 +11,6 @@ contract C {
|
||||
}
|
||||
// ----
|
||||
// f() -> 0x20, 0x02, 0x40, 0x80, 3, 0x6162630000000000000000000000000000000000000000000000000000000000, 0x99, 44048183304486788312148433451363384677562265908331949128489393215789685032262, 32241931068525137014058842823026578386641954854143559838526554899205067598957, 49951309422467613961193228765530489307475214998374779756599339590522149884499, 0x54555658595a6162636465666768696a6b6c6d6e6f707172737475767778797a, 0x4142434445464748494a4b4c4d4e4f5051525354555658595a00000000000000
|
||||
// gas irOptimized: 202805
|
||||
// gas irOptimized: 202852
|
||||
// gas legacy: 204798
|
||||
// gas legacyOptimized: 203368
|
||||
// gas legacyOptimized: 203357
|
||||
|
@ -18,6 +18,6 @@ contract C {
|
||||
}
|
||||
// ----
|
||||
// f() -> 1, 2, 3, 4, 5, 6, 7
|
||||
// gas irOptimized: 205974
|
||||
// gas irOptimized: 206351
|
||||
// gas legacy: 212242
|
||||
// gas legacyOptimized: 211430
|
||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user