Allow optimizer steps to run on FunctionDefinition and group suite.

This commit is contained in:
chriseth 2019-02-04 14:01:05 +01:00
parent b34e104173
commit 5a34743d88
11 changed files with 203 additions and 118 deletions

View File

@ -60,6 +60,13 @@ map<YulString, size_t> ReferencesCounter::countReferences(Block const& _block)
return counter.references(); return counter.references();
} }
map<YulString, size_t> ReferencesCounter::countReferences(FunctionDefinition const& _function)
{
ReferencesCounter counter;
counter(_function);
return counter.references();
}
map<YulString, size_t> ReferencesCounter::countReferences(Expression const& _expression) map<YulString, size_t> ReferencesCounter::countReferences(Expression const& _expression)
{ {
ReferencesCounter counter; ReferencesCounter counter;

View File

@ -59,6 +59,7 @@ public:
virtual void operator()(FunctionCall const& _funCall); virtual void operator()(FunctionCall const& _funCall);
static std::map<YulString, size_t> countReferences(Block const& _block); static std::map<YulString, size_t> countReferences(Block const& _block);
static std::map<YulString, size_t> countReferences(FunctionDefinition const& _function);
static std::map<YulString, size_t> countReferences(Expression const& _expression); static std::map<YulString, size_t> countReferences(Expression const& _expression);
std::map<YulString, size_t> const& references() const { return m_references; } std::map<YulString, size_t> const& references() const { return m_references; }

View File

@ -35,12 +35,23 @@ void Rematerialiser::run(Dialect const& _dialect, Block& _ast)
Rematerialiser{_dialect, _ast}(_ast); Rematerialiser{_dialect, _ast}(_ast);
} }
void Rematerialiser::run(Dialect const& _dialect, FunctionDefinition& _function)
{
Rematerialiser{_dialect, _function}(_function);
}
Rematerialiser::Rematerialiser(Dialect const& _dialect, Block& _ast): Rematerialiser::Rematerialiser(Dialect const& _dialect, Block& _ast):
DataFlowAnalyzer(_dialect), DataFlowAnalyzer(_dialect),
m_referenceCounts(ReferencesCounter::countReferences(_ast)) m_referenceCounts(ReferencesCounter::countReferences(_ast))
{ {
} }
Rematerialiser::Rematerialiser(Dialect const& _dialect, FunctionDefinition& _function):
DataFlowAnalyzer(_dialect),
m_referenceCounts(ReferencesCounter::countReferences(_function))
{
}
void Rematerialiser::visit(Expression& _e) void Rematerialiser::visit(Expression& _e)
{ {
if (_e.type() == typeid(Identifier)) if (_e.type() == typeid(Identifier))

View File

@ -39,9 +39,11 @@ class Rematerialiser: public DataFlowAnalyzer
{ {
public: public:
static void run(Dialect const& _dialect, Block& _ast); static void run(Dialect const& _dialect, Block& _ast);
static void run(Dialect const& _dialect, FunctionDefinition& _function);
protected: protected:
Rematerialiser(Dialect const& _dialect, Block& _ast); Rematerialiser(Dialect const& _dialect, Block& _ast);
Rematerialiser(Dialect const& _dialect, FunctionDefinition& _function);
using ASTModifier::visit; using ASTModifier::visit;
void visit(Expression& _e) override; void visit(Expression& _e) override;

View File

@ -69,11 +69,16 @@ void OptimiserSuite::run(
(ForLoopInitRewriter{})(ast); (ForLoopInitRewriter{})(ast);
(BlockFlattener{})(ast); (BlockFlattener{})(ast);
StructuralSimplifier{*_dialect}(ast); StructuralSimplifier{*_dialect}(ast);
(BlockFlattener{})(ast);
// None of the above can make stack problems worse.
NameDispenser dispenser{*_dialect, ast}; NameDispenser dispenser{*_dialect, ast};
for (size_t i = 0; i < 4; i++) for (size_t i = 0; i < 4; i++)
{ {
{
// Turn into SSA and simplify
ExpressionSplitter{*_dialect, dispenser}(ast); ExpressionSplitter{*_dialect, dispenser}(ast);
SSATransform::run(ast, dispenser); SSATransform::run(ast, dispenser);
RedundantAssignEliminator::run(*_dialect, ast); RedundantAssignEliminator::run(*_dialect, ast);
@ -81,35 +86,57 @@ void OptimiserSuite::run(
ExpressionSimplifier::run(*_dialect, ast); ExpressionSimplifier::run(*_dialect, ast);
CommonSubexpressionEliminator{*_dialect}(ast); CommonSubexpressionEliminator{*_dialect}(ast);
}
{
// still in SSA, perform structural simplification
StructuralSimplifier{*_dialect}(ast); StructuralSimplifier{*_dialect}(ast);
(BlockFlattener{})(ast); (BlockFlattener{})(ast);
SSATransform::run(ast, dispenser);
RedundantAssignEliminator::run(*_dialect, ast);
RedundantAssignEliminator::run(*_dialect, ast);
UnusedPruner::runUntilStabilised(*_dialect, ast, reservedIdentifiers); UnusedPruner::runUntilStabilised(*_dialect, ast, reservedIdentifiers);
}
{
// simplify again
CommonSubexpressionEliminator{*_dialect}(ast); CommonSubexpressionEliminator{*_dialect}(ast);
UnusedPruner::runUntilStabilised(*_dialect, ast, reservedIdentifiers); UnusedPruner::runUntilStabilised(*_dialect, ast, reservedIdentifiers);
}
{
// reverse SSA
SSAReverser::run(ast); SSAReverser::run(ast);
CommonSubexpressionEliminator{*_dialect}(ast); CommonSubexpressionEliminator{*_dialect}(ast);
UnusedPruner::runUntilStabilised(*_dialect, ast, reservedIdentifiers); UnusedPruner::runUntilStabilised(*_dialect, ast, reservedIdentifiers);
ExpressionJoiner::run(ast); ExpressionJoiner::run(ast);
ExpressionJoiner::run(ast); ExpressionJoiner::run(ast);
}
// should have good "compilability" property here.
{
// run functional expression inliner
ExpressionInliner(*_dialect, ast).run(); ExpressionInliner(*_dialect, ast).run();
UnusedPruner::runUntilStabilised(*_dialect, ast, reservedIdentifiers); UnusedPruner::runUntilStabilised(*_dialect, ast, reservedIdentifiers);
}
{
// Turn into SSA again and simplify
ExpressionSplitter{*_dialect, dispenser}(ast); ExpressionSplitter{*_dialect, dispenser}(ast);
SSATransform::run(ast, dispenser); SSATransform::run(ast, dispenser);
RedundantAssignEliminator::run(*_dialect, ast); RedundantAssignEliminator::run(*_dialect, ast);
RedundantAssignEliminator::run(*_dialect, ast); RedundantAssignEliminator::run(*_dialect, ast);
CommonSubexpressionEliminator{*_dialect}(ast); CommonSubexpressionEliminator{*_dialect}(ast);
}
{
// run full inliner
(FunctionGrouper{})(ast); (FunctionGrouper{})(ast);
EquivalentFunctionCombiner::run(ast); EquivalentFunctionCombiner::run(ast);
FullInliner{ast, dispenser}.run(); FullInliner{ast, dispenser}.run();
(BlockFlattener{})(ast); (BlockFlattener{})(ast);
}
{
// SSA plus simplify
SSATransform::run(ast, dispenser); SSATransform::run(ast, dispenser);
RedundantAssignEliminator::run(*_dialect, ast); RedundantAssignEliminator::run(*_dialect, ast);
RedundantAssignEliminator::run(*_dialect, ast); RedundantAssignEliminator::run(*_dialect, ast);
@ -123,6 +150,10 @@ void OptimiserSuite::run(
UnusedPruner::runUntilStabilised(*_dialect, ast, reservedIdentifiers); UnusedPruner::runUntilStabilised(*_dialect, ast, reservedIdentifiers);
CommonSubexpressionEliminator{*_dialect}(ast); CommonSubexpressionEliminator{*_dialect}(ast);
} }
}
// Make source short and pretty.
ExpressionJoiner::run(ast); ExpressionJoiner::run(ast);
Rematerialiser::run(*_dialect, ast); Rematerialiser::run(*_dialect, ast);
UnusedPruner::runUntilStabilised(*_dialect, ast, reservedIdentifiers); UnusedPruner::runUntilStabilised(*_dialect, ast, reservedIdentifiers);

View File

@ -35,10 +35,15 @@ using namespace yul;
UnusedPruner::UnusedPruner(Dialect const& _dialect, Block& _ast, set<YulString> const& _externallyUsedFunctions): UnusedPruner::UnusedPruner(Dialect const& _dialect, Block& _ast, set<YulString> const& _externallyUsedFunctions):
m_dialect(_dialect) m_dialect(_dialect)
{ {
ReferencesCounter counter; m_references = ReferencesCounter::countReferences(_ast);
counter(_ast); for (auto const& f: _externallyUsedFunctions)
++m_references[f];
}
m_references = counter.references(); UnusedPruner::UnusedPruner(Dialect const& _dialect, FunctionDefinition& _function, set<YulString> const& _externallyUsedFunctions):
m_dialect(_dialect)
{
m_references = ReferencesCounter::countReferences(_function);
for (auto const& f: _externallyUsedFunctions) for (auto const& f: _externallyUsedFunctions)
++m_references[f]; ++m_references[f];
} }
@ -116,6 +121,21 @@ void UnusedPruner::runUntilStabilised(
} }
} }
void UnusedPruner::runUntilStabilised(
Dialect const& _dialect,
FunctionDefinition& _function,
set<YulString> const& _externallyUsedFunctions
)
{
while (true)
{
UnusedPruner pruner(_dialect, _function, _externallyUsedFunctions);
pruner(_function);
if (!pruner.shouldRunAgain())
return;
}
}
bool UnusedPruner::used(YulString _name) const bool UnusedPruner::used(YulString _name) const
{ {
return m_references.count(_name) && m_references.at(_name) > 0; return m_references.count(_name) && m_references.at(_name) > 0;

View File

@ -46,6 +46,11 @@ public:
Block& _ast, Block& _ast,
std::set<YulString> const& _externallyUsedFunctions = {} std::set<YulString> const& _externallyUsedFunctions = {}
); );
UnusedPruner(
Dialect const& _dialect,
FunctionDefinition& _function,
std::set<YulString> const& _externallyUsedFunctions = {}
);
using ASTModifier::operator(); using ASTModifier::operator();
void operator()(Block& _block) override; void operator()(Block& _block) override;
@ -60,6 +65,14 @@ public:
std::set<YulString> const& _externallyUsedFunctions = {} std::set<YulString> const& _externallyUsedFunctions = {}
); );
// Run the pruner until the code does not change anymore.
// Only run on the given function.
static void runUntilStabilised(
Dialect const& _dialect,
FunctionDefinition& _functionDefinition,
std::set<YulString> const& _externallyUsedFunctions = {}
);
private: private:
bool used(YulString _name) const; bool used(YulString _name) const;
void subtractReferences(std::map<YulString, size_t> const& _subtrahend); void subtractReferences(std::map<YulString, size_t> const& _subtrahend);

View File

@ -1073,12 +1073,12 @@
// fullSuite // fullSuite
// { // {
// let _2 := mload(1) // let _2 := mload(1)
// let _153 := mload(0) // let _134 := mload(0)
// if slt(sub(_2, _153), 64) // if slt(sub(_2, _134), 64)
// { // {
// revert(0, 0) // revert(0, 0)
// } // }
// sstore(0, and(calldataload(_153), 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF)) // sstore(0, and(calldataload(_134), 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF))
// let x0, x1, x2, x3, x4 := abi_decode_tuple_t_addresst_uint256t_bytes_calldata_ptrt_enum$_Operation_$1949(mload(7), mload(8)) // let x0, x1, x2, x3, x4 := abi_decode_tuple_t_addresst_uint256t_bytes_calldata_ptrt_enum$_Operation_$1949(mload(7), mload(8))
// sstore(x1, x0) // sstore(x1, x0)
// sstore(x3, x2) // sstore(x3, x2)
@ -1093,40 +1093,40 @@
// value0_57 := and(calldataload(headStart_55), 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF) // value0_57 := and(calldataload(headStart_55), 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF)
// value1_58 := calldataload(add(headStart_55, 32)) // value1_58 := calldataload(add(headStart_55, 32))
// let offset_62 := calldataload(add(headStart_55, 64)) // let offset_62 := calldataload(add(headStart_55, 64))
// let _200 := 0xffffffffffffffff // let _181 := 0xffffffffffffffff
// if gt(offset_62, _200) // if gt(offset_62, _181)
// { // {
// revert(value4, value4) // revert(value4, value4)
// } // }
// let _202 := add(headStart_55, offset_62) // let _183 := add(headStart_55, offset_62)
// if iszero(slt(add(_202, 0x1f), dataEnd_56)) // if iszero(slt(add(_183, 0x1f), dataEnd_56))
// { // {
// revert(value4, value4) // revert(value4, value4)
// } // }
// let abi_decode_length_15_244 := calldataload(_202) // let abi_decode_length_15_225 := calldataload(_183)
// if gt(abi_decode_length_15_244, _200) // if gt(abi_decode_length_15_225, _181)
// { // {
// revert(value4, value4) // revert(value4, value4)
// } // }
// if gt(add(add(_202, abi_decode_length_15_244), 32), dataEnd_56) // if gt(add(add(_183, abi_decode_length_15_225), 32), dataEnd_56)
// { // {
// revert(value4, value4) // revert(value4, value4)
// } // }
// value2_59 := add(_202, 32) // value2_59 := add(_183, 32)
// value3 := abi_decode_length_15_244 // value3 := abi_decode_length_15_225
// let _205 := calldataload(add(headStart_55, 96)) // let _186 := calldataload(add(headStart_55, 96))
// if iszero(lt(_205, 3)) // if iszero(lt(_186, 3))
// { // {
// revert(value4, value4) // revert(value4, value4)
// } // }
// value4 := _205 // value4 := _186
// } // }
// function abi_encode_tuple_t_bytes32_t_address_t_uint256_t_bytes32_t_enum$_Operation_$1949_t_uint256_t_uint256_t_uint256_t_address_t_address_t_uint256__to_t_bytes32_t_address_t_uint256_t_bytes32_t_uint8_t_uint256_t_uint256_t_uint256_t_address_t_address_t_uint256_(headStart_252, value10_253, value9_254, value8_255, value7_256, value6_257, value5_258, value4_259, value3_260, value2_261, value1_262, value0_263) -> tail_264 // function abi_encode_tuple_t_bytes32_t_address_t_uint256_t_bytes32_t_enum$_Operation_$1949_t_uint256_t_uint256_t_uint256_t_address_t_address_t_uint256__to_t_bytes32_t_address_t_uint256_t_bytes32_t_uint8_t_uint256_t_uint256_t_uint256_t_address_t_address_t_uint256_(headStart_252, value10_253, value9_254, value8_255, value7_256, value6_257, value5_258, value4_259, value3_260, value2_261, value1_262, value0_263) -> tail_264
// { // {
// tail_264 := add(headStart_252, 352) // tail_264 := add(headStart_252, 352)
// mstore(headStart_252, value0_263) // mstore(headStart_252, value0_263)
// let _409 := 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF // let _382 := 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
// mstore(add(headStart_252, 32), and(value1_262, _409)) // mstore(add(headStart_252, 32), and(value1_262, _382))
// mstore(add(headStart_252, 64), value2_261) // mstore(add(headStart_252, 64), value2_261)
// mstore(add(headStart_252, 96), value3_260) // mstore(add(headStart_252, 96), value3_260)
// if iszero(lt(value4_259, 3)) // if iszero(lt(value4_259, 3))
@ -1137,8 +1137,8 @@
// mstore(add(headStart_252, 160), value5_258) // mstore(add(headStart_252, 160), value5_258)
// mstore(add(headStart_252, 192), value6_257) // mstore(add(headStart_252, 192), value6_257)
// mstore(add(headStart_252, 224), value7_256) // mstore(add(headStart_252, 224), value7_256)
// mstore(add(headStart_252, 256), and(value8_255, _409)) // mstore(add(headStart_252, 256), and(value8_255, _382))
// mstore(add(headStart_252, 288), and(value9_254, _409)) // mstore(add(headStart_252, 288), and(value9_254, _382))
// mstore(add(headStart_252, 320), value10_253) // mstore(add(headStart_252, 320), value10_253)
// } // }
// } // }

View File

@ -460,12 +460,12 @@
// { // {
// let _1 := 0x20 // let _1 := 0x20
// let _2 := 0 // let _2 := 0
// let _218 := mload(_2) // let _168 := mload(_2)
// let abi_encode_pos := _1 // let abi_encode_pos := _1
// let abi_encode_length_68 := mload(_218) // let abi_encode_length_68 := mload(_168)
// mstore(_1, abi_encode_length_68) // mstore(_1, abi_encode_length_68)
// abi_encode_pos := 64 // abi_encode_pos := 64
// let abi_encode_srcPtr := add(_218, _1) // let abi_encode_srcPtr := add(_168, _1)
// let abi_encode_i_69 := _2 // let abi_encode_i_69 := _2
// for { // for {
// } // }
@ -474,45 +474,45 @@
// abi_encode_i_69 := add(abi_encode_i_69, 1) // abi_encode_i_69 := add(abi_encode_i_69, 1)
// } // }
// { // {
// let _579 := mload(abi_encode_srcPtr) // let _491 := mload(abi_encode_srcPtr)
// let abi_encode_pos_71_671 := abi_encode_pos // let abi_encode_pos_71_583 := abi_encode_pos
// let abi_encode_srcPtr_73_673 := _579 // let abi_encode_srcPtr_73_585 := _491
// let abi_encode_i_74_674 := _2 // let abi_encode_i_74_586 := _2
// for { // for {
// } // }
// lt(abi_encode_i_74_674, 0x3) // lt(abi_encode_i_74_586, 0x3)
// { // {
// abi_encode_i_74_674 := add(abi_encode_i_74_674, 1) // abi_encode_i_74_586 := add(abi_encode_i_74_586, 1)
// } // }
// { // {
// mstore(abi_encode_pos_71_671, and(mload(abi_encode_srcPtr_73_673), 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF)) // mstore(abi_encode_pos_71_583, and(mload(abi_encode_srcPtr_73_585), 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF))
// abi_encode_srcPtr_73_673 := add(abi_encode_srcPtr_73_673, _1) // abi_encode_srcPtr_73_585 := add(abi_encode_srcPtr_73_585, _1)
// abi_encode_pos_71_671 := add(abi_encode_pos_71_671, _1) // abi_encode_pos_71_583 := add(abi_encode_pos_71_583, _1)
// } // }
// abi_encode_srcPtr := add(abi_encode_srcPtr, _1) // abi_encode_srcPtr := add(abi_encode_srcPtr, _1)
// abi_encode_pos := add(abi_encode_pos, 0x60) // abi_encode_pos := add(abi_encode_pos, 0x60)
// } // }
// let _220 := mload(64) // let _170 := mload(64)
// let _221 := mload(_1) // let _171 := mload(_1)
// if slt(sub(_220, _221), 128) // if slt(sub(_170, _171), 128)
// { // {
// revert(_2, _2) // revert(_2, _2)
// } // }
// let abi_decode_offset_64 := calldataload(add(_221, 64)) // let abi_decode_offset_64 := calldataload(add(_171, 64))
// let abi_decode__74 := 0xffffffffffffffff // let abi_decode__74 := 0xffffffffffffffff
// if gt(abi_decode_offset_64, abi_decode__74) // if gt(abi_decode_offset_64, abi_decode__74)
// { // {
// revert(_2, _2) // revert(_2, _2)
// } // }
// let abi_decode_value2_314 := abi_decode_t_array$_t_uint256_$dyn_memory_ptr(add(_221, abi_decode_offset_64), _220) // let abi_decode_value2_264 := abi_decode_t_array$_t_uint256_$dyn_memory_ptr(add(_171, abi_decode_offset_64), _170)
// let abi_decode_offset_65 := calldataload(add(_221, 96)) // let abi_decode_offset_65 := calldataload(add(_171, 96))
// if gt(abi_decode_offset_65, abi_decode__74) // if gt(abi_decode_offset_65, abi_decode__74)
// { // {
// revert(_2, _2) // revert(_2, _2)
// } // }
// let abi_decode_value3_315 := abi_decode_t_array$_t_array$_t_uint256_$2_memory_$dyn_memory_ptr(add(_221, abi_decode_offset_65), _220) // let abi_decode_value3_265 := abi_decode_t_array$_t_array$_t_uint256_$2_memory_$dyn_memory_ptr(add(_171, abi_decode_offset_65), _170)
// sstore(calldataload(_221), calldataload(add(_221, _1))) // sstore(calldataload(_171), calldataload(add(_171, _1)))
// sstore(abi_decode_value2_314, abi_decode_value3_315) // sstore(abi_decode_value2_264, abi_decode_value3_265)
// sstore(_2, abi_encode_pos) // sstore(_2, abi_encode_pos)
// function abi_decode_t_array$_t_array$_t_uint256_$2_memory_$dyn_memory_ptr(offset_3, end_4) -> array_5 // function abi_decode_t_array$_t_array$_t_uint256_$2_memory_$dyn_memory_ptr(offset_3, end_4) -> array_5
// { // {
@ -544,10 +544,10 @@
// revert(0, 0) // revert(0, 0)
// } // }
// let abi_decode_dst_15 := allocateMemory(array_allocation_size_t_array$_t_uint256_$2_memory(0x2)) // let abi_decode_dst_15 := allocateMemory(array_allocation_size_t_array$_t_uint256_$2_memory(0x2))
// let abi_decode_dst_15_1154 := abi_decode_dst_15 // let abi_decode_dst_15_990 := abi_decode_dst_15
// let abi_decode_src_16 := src_8 // let abi_decode_src_16 := src_8
// let abi_decode__238 := add(src_8, 0x40) // let abi_decode__188 := add(src_8, 0x40)
// if gt(abi_decode__238, end_4) // if gt(abi_decode__188, end_4)
// { // {
// revert(0, 0) // revert(0, 0)
// } // }
@ -563,9 +563,9 @@
// abi_decode_dst_15 := add(abi_decode_dst_15, _16) // abi_decode_dst_15 := add(abi_decode_dst_15, _16)
// abi_decode_src_16 := add(abi_decode_src_16, _16) // abi_decode_src_16 := add(abi_decode_src_16, _16)
// } // }
// mstore(dst_7, abi_decode_dst_15_1154) // mstore(dst_7, abi_decode_dst_15_990)
// dst_7 := add(dst_7, _16) // dst_7 := add(dst_7, _16)
// src_8 := abi_decode__238 // src_8 := abi_decode__188
// } // }
// } // }
// function abi_decode_t_array$_t_uint256_$dyn_memory_ptr(offset_27, end_28) -> array_29 // function abi_decode_t_array$_t_uint256_$dyn_memory_ptr(offset_27, end_28) -> array_29

View File

@ -254,7 +254,7 @@
// hashCommitments(validateJo_notes, validateJo_n) // hashCommitments(validateJo_notes, validateJo_n)
// let validateJo_b := add(0x300, mul(validateJo_n, validateJo__6)) // let validateJo_b := add(0x300, mul(validateJo_n, validateJo__6))
// let validateJo_i := 0 // let validateJo_i := 0
// let validateJo_i_1306 := validateJo_i // let validateJo_i_1218 := validateJo_i
// for { // for {
// } // }
// lt(validateJo_i, validateJo_n) // lt(validateJo_i, validateJo_n)
@ -263,10 +263,10 @@
// } // }
// { // {
// let validateJo__34 := 0x20 // let validateJo__34 := 0x20
// let validateJo__351 := add(validateJo__10, mul(validateJo_i, 0xc0)) // let validateJo__329 := add(validateJo__10, mul(validateJo_i, 0xc0))
// let validateJo_noteIndex := add(validateJo__351, 0x24) // let validateJo_noteIndex := add(validateJo__329, 0x24)
// let validateJo_k := validateJo_i_1306 // let validateJo_k := validateJo_i_1218
// let validateJo_a := calldataload(add(validateJo__351, 0x44)) // let validateJo_a := calldataload(add(validateJo__329, 0x44))
// let validateJo_c := validateJo_challenge // let validateJo_c := validateJo_challenge
// let validateJo__39 := add(validateJo_i, 0x01) // let validateJo__39 := add(validateJo_i, 0x01)
// switch eq(validateJo__39, validateJo_n) // switch eq(validateJo__39, validateJo_n)
@ -284,30 +284,30 @@
// switch gt(validateJo__39, validateJo_m) // switch gt(validateJo__39, validateJo_m)
// case 1 { // case 1 {
// validateJo_kn := addmod(validateJo_kn, sub(validateJo_gen_order, validateJo_k), validateJo_gen_order) // validateJo_kn := addmod(validateJo_kn, sub(validateJo_gen_order, validateJo_k), validateJo_gen_order)
// let validateJo_x := mod(mload(validateJo_i_1306), validateJo_gen_order) // let validateJo_x := mod(mload(validateJo_i_1218), validateJo_gen_order)
// validateJo_k := mulmod(validateJo_k, validateJo_x, validateJo_gen_order) // validateJo_k := mulmod(validateJo_k, validateJo_x, validateJo_gen_order)
// validateJo_a := mulmod(validateJo_a, validateJo_x, validateJo_gen_order) // validateJo_a := mulmod(validateJo_a, validateJo_x, validateJo_gen_order)
// validateJo_c := mulmod(validateJo_challenge, validateJo_x, validateJo_gen_order) // validateJo_c := mulmod(validateJo_challenge, validateJo_x, validateJo_gen_order)
// mstore(validateJo_i_1306, keccak256(validateJo_i_1306, validateJo__34)) // mstore(validateJo_i_1218, keccak256(validateJo_i_1218, validateJo__34))
// } // }
// case 0 { // case 0 {
// validateJo_kn := addmod(validateJo_kn, validateJo_k, validateJo_gen_order) // validateJo_kn := addmod(validateJo_kn, validateJo_k, validateJo_gen_order)
// } // }
// let validateJo__52 := 0x40 // let validateJo__52 := 0x40
// calldatacopy(0xe0, add(validateJo__351, 164), validateJo__52) // calldatacopy(0xe0, add(validateJo__329, 164), validateJo__52)
// calldatacopy(validateJo__34, add(validateJo__351, 100), validateJo__52) // calldatacopy(validateJo__34, add(validateJo__329, 100), validateJo__52)
// let validateJo__61 := 0x120 // let validateJo__61 := 0x120
// mstore(validateJo__61, sub(validateJo_gen_order, validateJo_c)) // mstore(validateJo__61, sub(validateJo_gen_order, validateJo_c))
// let validateJo__62 := 0x60 // let validateJo__62 := 0x60
// mstore(validateJo__62, validateJo_k) // mstore(validateJo__62, validateJo_k)
// mstore(0xc0, validateJo_a) // mstore(0xc0, validateJo_a)
// let validateJo__65 := 0x1a0 // let validateJo__65 := 0x1a0
// let validateJo_result := call(gas(), 7, validateJo_i_1306, 0xe0, validateJo__62, validateJo__65, validateJo__52) // let validateJo_result := call(gas(), 7, validateJo_i_1218, 0xe0, validateJo__62, validateJo__65, validateJo__52)
// let validateJo_result_303 := and(validateJo_result, call(gas(), 7, validateJo_i_1306, validateJo__34, validateJo__62, validateJo__61, validateJo__52)) // let validateJo_result_303 := and(validateJo_result, call(gas(), 7, validateJo_i_1218, validateJo__34, validateJo__62, validateJo__61, validateJo__52))
// let validateJo__80 := 0x160 // let validateJo__80 := 0x160
// let validateJo_result_304 := and(validateJo_result_303, call(gas(), 7, validateJo_i_1306, validateJo__6, validateJo__62, validateJo__80, validateJo__52)) // let validateJo_result_304 := and(validateJo_result_303, call(gas(), 7, validateJo_i_1218, validateJo__6, validateJo__62, validateJo__80, validateJo__52))
// let validateJo_result_305 := and(validateJo_result_304, call(gas(), 6, validateJo_i_1306, validateJo__61, validateJo__6, validateJo__80, validateJo__52)) // let validateJo_result_305 := and(validateJo_result_304, call(gas(), 6, validateJo_i_1218, validateJo__61, validateJo__6, validateJo__80, validateJo__52))
// validateJo_result := and(validateJo_result_305, call(gas(), 6, validateJo_i_1306, validateJo__80, validateJo__6, validateJo_b, validateJo__52)) // validateJo_result := and(validateJo_result_305, call(gas(), 6, validateJo_i_1218, validateJo__80, validateJo__6, validateJo_b, validateJo__52))
// if eq(validateJo_i, validateJo_m) // if eq(validateJo_i, validateJo_m)
// { // {
// mstore(0x260, mload(validateJo__34)) // mstore(0x260, mload(validateJo__34))
@ -319,14 +319,14 @@
// { // {
// mstore(validateJo__62, validateJo_c) // mstore(validateJo__62, validateJo_c)
// let validateJo__120 := 0x220 // let validateJo__120 := 0x220
// let validateJo_result_307 := and(validateJo_result, call(gas(), 7, validateJo_i_1306, validateJo__34, validateJo__62, validateJo__120, validateJo__52)) // let validateJo_result_307 := and(validateJo_result, call(gas(), 7, validateJo_i_1218, validateJo__34, validateJo__62, validateJo__120, validateJo__52))
// let validateJo_result_308 := and(validateJo_result_307, call(gas(), 6, validateJo_i_1306, validateJo__120, validateJo__6, 0x260, validateJo__52)) // let validateJo_result_308 := and(validateJo_result_307, call(gas(), 6, validateJo_i_1218, validateJo__120, validateJo__6, 0x260, validateJo__52))
// validateJo_result := and(validateJo_result_308, call(gas(), 6, validateJo_i_1306, validateJo__65, validateJo__6, 0x1e0, validateJo__52)) // validateJo_result := and(validateJo_result_308, call(gas(), 6, validateJo_i_1218, validateJo__65, validateJo__6, 0x1e0, validateJo__52))
// } // }
// if iszero(validateJo_result) // if iszero(validateJo_result)
// { // {
// mstore(validateJo_i_1306, 400) // mstore(validateJo_i_1218, 400)
// revert(validateJo_i_1306, validateJo__34) // revert(validateJo_i_1218, validateJo__34)
// } // }
// validateJo_b := add(validateJo_b, validateJo__52) // validateJo_b := add(validateJo_b, validateJo__52)
// } // }
@ -336,13 +336,13 @@
// } // }
// if iszero(eq(mod(keccak256(validateJo__24, add(validateJo_b, 0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffd60)), validateJo_gen_order), validateJo_challenge)) // if iszero(eq(mod(keccak256(validateJo__24, add(validateJo_b, 0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffd60)), validateJo_gen_order), validateJo_challenge))
// { // {
// mstore(validateJo_i_1306, 404) // mstore(validateJo_i_1218, 404)
// revert(validateJo_i_1306, 0x20) // revert(validateJo_i_1218, 0x20)
// } // }
// mstore(validateJo_i_1306, 0x01) // mstore(validateJo_i_1218, 0x01)
// return(validateJo_i_1306, 0x20) // return(validateJo_i_1218, 0x20)
// mstore(validateJo_i_1306, 404) // mstore(validateJo_i_1218, 404)
// revert(validateJo_i_1306, 0x20) // revert(validateJo_i_1218, 0x20)
// function validatePairing(t2) // function validatePairing(t2)
// { // {
// let t2_x_1 := calldataload(t2) // let t2_x_1 := calldataload(t2)

View File

@ -21,8 +21,8 @@
// { // {
// let allocate__19 := 0x40 // let allocate__19 := 0x40
// mstore(allocate__19, add(mload(allocate__19), 0x20)) // mstore(allocate__19, add(mload(allocate__19), 0x20))
// let allocate_p_35_39 := mload(allocate__19) // let allocate_p_33_37 := mload(allocate__19)
// mstore(allocate__19, add(allocate_p_35_39, allocate__19)) // mstore(allocate__19, add(allocate_p_33_37, allocate__19))
// mstore(add(allocate_p_35_39, 96), 2) // mstore(add(allocate_p_33_37, 96), 2)
// mstore(allocate__19, 0x20) // mstore(allocate__19, 0x20)
// } // }