aboutsummaryrefslogtreecommitdiffstats
path: root/libsolidity/codegen/ContractCompiler.cpp
diff options
context:
space:
mode:
authorchriseth <chris@ethereum.org>2018-11-26 23:08:04 +0800
committerGitHub <noreply@github.com>2018-11-26 23:08:04 +0800
commit764d618c442c969e72ab73ffda8475060fca1299 (patch)
tree3c719ccd0a4be7487c8d3f629f6c17b403b84be2 /libsolidity/codegen/ContractCompiler.cpp
parentbd40c0ac028878a6b9a915bd2498fa5370edc347 (diff)
parent2d0326aad2a2233f58dd4c2c1cb4ef7bbbb22d87 (diff)
downloaddexon-solidity-764d618c442c969e72ab73ffda8475060fca1299.tar
dexon-solidity-764d618c442c969e72ab73ffda8475060fca1299.tar.gz
dexon-solidity-764d618c442c969e72ab73ffda8475060fca1299.tar.bz2
dexon-solidity-764d618c442c969e72ab73ffda8475060fca1299.tar.lz
dexon-solidity-764d618c442c969e72ab73ffda8475060fca1299.tar.xz
dexon-solidity-764d618c442c969e72ab73ffda8475060fca1299.tar.zst
dexon-solidity-764d618c442c969e72ab73ffda8475060fca1299.zip
Merge pull request #5404 from ethereum/jumpFixes
Annotate jump from calldata decode to function as "jump in".
Diffstat (limited to 'libsolidity/codegen/ContractCompiler.cpp')
-rw-r--r--libsolidity/codegen/ContractCompiler.cpp5
1 files changed, 4 insertions, 1 deletions
diff --git a/libsolidity/codegen/ContractCompiler.cpp b/libsolidity/codegen/ContractCompiler.cpp
index 157d5fa7..aabdbb79 100644
--- a/libsolidity/codegen/ContractCompiler.cpp
+++ b/libsolidity/codegen/ContractCompiler.cpp
@@ -344,7 +344,10 @@ void ContractCompiler::appendFunctionSelector(ContractDefinition const& _contrac
m_context << Instruction::DUP1 << Instruction::CALLDATASIZE << Instruction::SUB;
CompilerUtils(m_context).abiDecode(functionType->parameterTypes());
}
- m_context.appendJumpTo(m_context.functionEntryLabel(functionType->declaration()));
+ m_context.appendJumpTo(
+ m_context.functionEntryLabel(functionType->declaration()),
+ eth::AssemblyItem::JumpType::IntoFunction
+ );
m_context << returnTag;
// Return tag and input parameters get consumed.
m_context.adjustStackOffset(