aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorchriseth <c@ethdev.com>2016-08-02 05:13:56 +0800
committerchriseth <c@ethdev.com>2016-08-02 05:41:11 +0800
commitc0afb4549ebecfc5e4ad05e8e24d26d92f4ec64d (patch)
treeb3a7ac61c925ad445489507d3086d982aed29c79
parentfb90e8876f6d1172405890bee694ccc6000b9387 (diff)
downloaddexon-solidity-c0afb4549ebecfc5e4ad05e8e24d26d92f4ec64d.tar
dexon-solidity-c0afb4549ebecfc5e4ad05e8e24d26d92f4ec64d.tar.gz
dexon-solidity-c0afb4549ebecfc5e4ad05e8e24d26d92f4ec64d.tar.bz2
dexon-solidity-c0afb4549ebecfc5e4ad05e8e24d26d92f4ec64d.tar.lz
dexon-solidity-c0afb4549ebecfc5e4ad05e8e24d26d92f4ec64d.tar.xz
dexon-solidity-c0afb4549ebecfc5e4ad05e8e24d26d92f4ec64d.tar.zst
dexon-solidity-c0afb4549ebecfc5e4ad05e8e24d26d92f4ec64d.zip
Further fixes to the optimizer.
-rw-r--r--libevmasm/ControlFlowGraph.cpp7
-rw-r--r--libevmasm/ControlFlowGraph.h2
-rw-r--r--test/libsolidity/SolidityOptimizer.cpp5
3 files changed, 9 insertions, 5 deletions
diff --git a/libevmasm/ControlFlowGraph.cpp b/libevmasm/ControlFlowGraph.cpp
index 61b24e4b..d4801562 100644
--- a/libevmasm/ControlFlowGraph.cpp
+++ b/libevmasm/ControlFlowGraph.cpp
@@ -250,10 +250,11 @@ void ControlFlowGraph::gatherKnowledge()
KnownStatePointer state = item.state;
if (block.startState)
{
- if (m_joinKnowledge)
- state->reduceToCommonKnowledge(*block.startState, !item.blocksSeen.count(item.blockId));
- else
+ // We call reduceToCommonKnowledge even in the non-join setting to get the correct
+ // sequence number
+ if (!m_joinKnowledge)
state->reset();
+ state->reduceToCommonKnowledge(*block.startState, !item.blocksSeen.count(item.blockId));
if (*state == *block.startState)
continue;
}
diff --git a/libevmasm/ControlFlowGraph.h b/libevmasm/ControlFlowGraph.h
index a6a9df8e..03a1f717 100644
--- a/libevmasm/ControlFlowGraph.h
+++ b/libevmasm/ControlFlowGraph.h
@@ -116,7 +116,7 @@ private:
unsigned m_lastUsedId = 0;
AssemblyItems const& m_items;
- bool m_joinKnowledge;
+ bool m_joinKnowledge = true;
std::map<BlockId, BasicBlock> m_blocks;
};
diff --git a/test/libsolidity/SolidityOptimizer.cpp b/test/libsolidity/SolidityOptimizer.cpp
index 2e4ed4b3..206f23fb 100644
--- a/test/libsolidity/SolidityOptimizer.cpp
+++ b/test/libsolidity/SolidityOptimizer.cpp
@@ -282,6 +282,8 @@ BOOST_AUTO_TEST_CASE(storage_write_in_loops)
compareVersions("f(uint256)", 36);
}
+// Test disabled with https://github.com/ethereum/solidity/pull/762
+// Information in joining branches is not retained anymore.
BOOST_AUTO_TEST_CASE(retain_information_in_branches)
{
// This tests that the optimizer knows that we already have "z == sha3(y)" inside both branches.
@@ -315,7 +317,8 @@ BOOST_AUTO_TEST_CASE(retain_information_in_branches)
if (_instr == Instruction::SHA3)
numSHA3s++;
});
- BOOST_CHECK_EQUAL(1, numSHA3s);
+// TEST DISABLED - OPTIMIZER IS NOT EFFECTIVE ON THIS ONE ANYMORE
+// BOOST_CHECK_EQUAL(1, numSHA3s);
}
BOOST_AUTO_TEST_CASE(store_tags_as_unions)