diff options
author | Alex Beregszaszi <alex@rtfs.hu> | 2016-10-21 04:55:45 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2016-10-21 04:55:45 +0800 |
commit | 5875890576eb95dd73bc04b5e864975cd7a55f43 (patch) | |
tree | 88845f6ad9ce185992a35841b70272161616c8be /libsolidity/inlineasm/AsmCodeGen.cpp | |
parent | 008c4111d730becb1eeb53946b982e575e982c9b (diff) | |
parent | 6cb2770344ccc781911d48a645335733e850e0af (diff) | |
download | dexon-solidity-5875890576eb95dd73bc04b5e864975cd7a55f43.tar dexon-solidity-5875890576eb95dd73bc04b5e864975cd7a55f43.tar.gz dexon-solidity-5875890576eb95dd73bc04b5e864975cd7a55f43.tar.bz2 dexon-solidity-5875890576eb95dd73bc04b5e864975cd7a55f43.tar.lz dexon-solidity-5875890576eb95dd73bc04b5e864975cd7a55f43.tar.xz dexon-solidity-5875890576eb95dd73bc04b5e864975cd7a55f43.tar.zst dexon-solidity-5875890576eb95dd73bc04b5e864975cd7a55f43.zip |
Merge pull request #1224 from ethereum/inline-assembly-stack-warning
Issue inline assembly stack warning if not balanced
Diffstat (limited to 'libsolidity/inlineasm/AsmCodeGen.cpp')
-rw-r--r-- | libsolidity/inlineasm/AsmCodeGen.cpp | 26 |
1 files changed, 24 insertions, 2 deletions
diff --git a/libsolidity/inlineasm/AsmCodeGen.cpp b/libsolidity/inlineasm/AsmCodeGen.cpp index 53d19b0a..5d920cb7 100644 --- a/libsolidity/inlineasm/AsmCodeGen.cpp +++ b/libsolidity/inlineasm/AsmCodeGen.cpp @@ -23,6 +23,7 @@ #include <libsolidity/inlineasm/AsmCodeGen.h> #include <memory> #include <functional> +#include <libdevcore/CommonIO.h> #include <libevmasm/Assembly.h> #include <libevmasm/SourceLocation.h> #include <libevmasm/Instruction.h> @@ -213,10 +214,31 @@ public: void operator()(assembly::Block const& _block) { size_t numVariables = m_state.variables.size(); + int deposit = m_state.assembly.deposit(); std::for_each(_block.statements.begin(), _block.statements.end(), boost::apply_visitor(*this)); - // pop variables - // we deliberately do not check stack height + deposit = m_state.assembly.deposit() - deposit; + m_state.assembly.setSourceLocation(_block.location); + + // issue warnings for stack height discrepancies + if (deposit < 0) + { + m_state.addError( + Error::Type::Warning, + "Inline assembly block is not balanced. It takes " + toString(-deposit) + " item(s) from the stack.", + _block.location + ); + } + else if (deposit > 0) + { + m_state.addError( + Error::Type::Warning, + "Inline assembly block is not balanced. It leaves " + toString(deposit) + " item(s) on the stack.", + _block.location + ); + } + + // pop variables while (m_state.variables.size() > numVariables) { m_state.assembly.append(solidity::Instruction::POP); |