mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Tests for memoryloadresolver
This commit is contained in:
parent
1794000d2d
commit
4035f82881
@ -47,6 +47,7 @@
|
||||
#include <libyul/optimiser/LoopInvariantCodeMotion.h>
|
||||
#include <libyul/optimiser/MainFunction.h>
|
||||
#include <libyul/optimiser/StackLimitEvader.h>
|
||||
#include <libyul/optimiser/MemoryLoadResolver.h>
|
||||
#include <libyul/optimiser/NameDisplacer.h>
|
||||
#include <libyul/optimiser/Rematerialiser.h>
|
||||
#include <libyul/optimiser/ExpressionSimplifier.h>
|
||||
@ -433,6 +434,20 @@ TestCase::TestResult YulOptimizerTest::run(ostream& _stream, string const& _line
|
||||
fakeUnreachableGenerator(*obj.code);
|
||||
StackLimitEvader::run(*m_context, obj, fakeUnreachableGenerator.fakeUnreachables);
|
||||
}
|
||||
else if (m_optimizerStep == "memoryLoadResolver")
|
||||
{
|
||||
disambiguate();
|
||||
ForLoopInitRewriter::run(*m_context, *m_object->code);
|
||||
ExpressionSplitter::run(*m_context, *m_object->code);
|
||||
SSATransform::run(*m_context, *m_object->code);
|
||||
|
||||
MemoryLoadResolver::run(*m_context, *m_object->code);
|
||||
|
||||
// Cleanup
|
||||
UnusedPruner::run(*m_context, *m_object->code);
|
||||
ExpressionJoiner::run(*m_context, *m_object->code);
|
||||
ExpressionJoiner::run(*m_context, *m_object->code);
|
||||
}
|
||||
else
|
||||
{
|
||||
AnsiColorized(_stream, _formatted, {formatting::BOLD, formatting::RED}) << _linePrefix << "Invalid optimizer step: " << m_optimizerStep << endl;
|
||||
|
@ -0,0 +1,29 @@
|
||||
{
|
||||
let key := 64
|
||||
let value := 128
|
||||
mstore(key, value)
|
||||
|
||||
if callvalue() { revert(0, 0) }
|
||||
|
||||
let _1 := 0
|
||||
let c := calldatasize()
|
||||
|
||||
// Does not invalidate location 64
|
||||
calldatacopy(value, _1, c)
|
||||
|
||||
// Should be replaced by out := value
|
||||
let out := mload(key)
|
||||
sstore(0, out)
|
||||
}
|
||||
// ----
|
||||
// step: memoryLoadResolver
|
||||
//
|
||||
// {
|
||||
// let key := 64
|
||||
// let value := 128
|
||||
// mstore(key, value)
|
||||
// if callvalue() { revert(0, 0) }
|
||||
// let _1 := 0
|
||||
// calldatacopy(value, _1, calldatasize())
|
||||
// sstore(0, value)
|
||||
// }
|
17
test/libyul/yulOptimizerTests/memoryLoadResolver/simple.yul
Normal file
17
test/libyul/yulOptimizerTests/memoryLoadResolver/simple.yul
Normal file
@ -0,0 +1,17 @@
|
||||
{
|
||||
let key := 64
|
||||
let value := 128
|
||||
mstore(key, value)
|
||||
|
||||
// should be replaced by sstore(0, value)
|
||||
sstore(0, mload(key))
|
||||
}
|
||||
// ----
|
||||
// step: memoryLoadResolver
|
||||
//
|
||||
// {
|
||||
// let key := 64
|
||||
// let value := 128
|
||||
// mstore(key, value)
|
||||
// sstore(0, value)
|
||||
// }
|
@ -0,0 +1,5 @@
|
||||
{ }
|
||||
// ----
|
||||
// step: memoryLoadResolver
|
||||
//
|
||||
// { }
|
Loading…
Reference in New Issue
Block a user