From 011f8d3ff7319121ac99e92ba92b58f2dc2aa483 Mon Sep 17 00:00:00 2001 From: hrkrshnn Date: Mon, 19 Apr 2021 13:08:19 +0200 Subject: [PATCH] Changed the type of gas calculation to bigint instead of size_t Since the gas calculation can involve multiplication by ``--optimize-runs``, it is possible that `size_t` is not enough to represent the total gas. --- libyul/backends/evm/ConstantOptimiser.h | 2 +- libyul/backends/evm/EVMMetrics.cpp | 16 ++++++++-------- libyul/backends/evm/EVMMetrics.h | 20 ++++++++++---------- 3 files changed, 19 insertions(+), 19 deletions(-) diff --git a/libyul/backends/evm/ConstantOptimiser.h b/libyul/backends/evm/ConstantOptimiser.h index 52d78be86..e95a152c8 100644 --- a/libyul/backends/evm/ConstantOptimiser.h +++ b/libyul/backends/evm/ConstantOptimiser.h @@ -58,7 +58,7 @@ public: struct Representation { std::unique_ptr expression; - size_t cost = size_t(-1); + bigint cost; }; private: diff --git a/libyul/backends/evm/EVMMetrics.cpp b/libyul/backends/evm/EVMMetrics.cpp index de28792d3..dfb716c19 100644 --- a/libyul/backends/evm/EVMMetrics.cpp +++ b/libyul/backends/evm/EVMMetrics.cpp @@ -37,23 +37,23 @@ using namespace solidity; using namespace solidity::yul; using namespace solidity::util; -size_t GasMeter::costs(Expression const& _expression) const +bigint GasMeter::costs(Expression const& _expression) const { return combineCosts(GasMeterVisitor::costs(_expression, m_dialect, m_isCreation)); } -size_t GasMeter::instructionCosts(evmasm::Instruction _instruction) const +bigint GasMeter::instructionCosts(evmasm::Instruction _instruction) const { return combineCosts(GasMeterVisitor::instructionCosts(_instruction, m_dialect, m_isCreation)); } -size_t GasMeter::combineCosts(std::pair _costs) const +bigint GasMeter::combineCosts(std::pair _costs) const { return _costs.first * m_runs + _costs.second; } -pair GasMeterVisitor::costs( +pair GasMeterVisitor::costs( Expression const& _expression, EVMDialect const& _dialect, bool _isCreation @@ -64,7 +64,7 @@ pair GasMeterVisitor::costs( return {gmv.m_runGas, gmv.m_dataGas}; } -pair GasMeterVisitor::instructionCosts( +pair GasMeterVisitor::instructionCosts( evmasm::Instruction _instruction, EVMDialect const& _dialect, bool _isCreation @@ -92,11 +92,11 @@ void GasMeterVisitor::operator()(Literal const& _lit) m_runGas += evmasm::GasMeter::runGas(evmasm::Instruction::PUSH1); m_dataGas += singleByteDataGas() + - static_cast(evmasm::GasMeter::dataGas( + evmasm::GasMeter::dataGas( toCompactBigEndian(valueOfLiteral(_lit), 1), m_isCreation, m_dialect.evmVersion() - )); + ); } void GasMeterVisitor::operator()(Identifier const&) @@ -105,7 +105,7 @@ void GasMeterVisitor::operator()(Identifier const&) m_dataGas += singleByteDataGas(); } -size_t GasMeterVisitor::singleByteDataGas() const +bigint GasMeterVisitor::singleByteDataGas() const { if (m_isCreation) return evmasm::GasCosts::txDataNonZeroGas(m_dialect.evmVersion()); diff --git a/libyul/backends/evm/EVMMetrics.h b/libyul/backends/evm/EVMMetrics.h index ec59976f7..19702b8f3 100644 --- a/libyul/backends/evm/EVMMetrics.h +++ b/libyul/backends/evm/EVMMetrics.h @@ -42,36 +42,36 @@ struct EVMDialect; class GasMeter { public: - GasMeter(EVMDialect const& _dialect, bool _isCreation, size_t _runs): + GasMeter(EVMDialect const& _dialect, bool _isCreation, bigint _runs): m_dialect(_dialect), m_isCreation{_isCreation}, m_runs(_isCreation? 1 : _runs) {} /// @returns the full combined costs of deploying and evaluating the expression. - size_t costs(Expression const& _expression) const; + bigint costs(Expression const& _expression) const; /// @returns the combined costs of deploying and running the instruction, not including /// the costs for its arguments. - size_t instructionCosts(evmasm::Instruction _instruction) const; + bigint instructionCosts(evmasm::Instruction _instruction) const; private: - size_t combineCosts(std::pair _costs) const; + bigint combineCosts(std::pair _costs) const; EVMDialect const& m_dialect; bool m_isCreation = false; - size_t m_runs; + bigint m_runs; }; class GasMeterVisitor: public ASTWalker { public: - static std::pair costs( + static std::pair costs( Expression const& _expression, EVMDialect const& _dialect, bool _isCreation ); - static std::pair instructionCosts( + static std::pair instructionCosts( evmasm::Instruction _instruction, EVMDialect const& _dialect, bool _isCreation = false @@ -88,7 +88,7 @@ public: void operator()(Identifier const& _identifier) override; private: - size_t singleByteDataGas() const; + bigint singleByteDataGas() const; /// Computes the cost of storing and executing the single instruction (excluding its arguments). /// For EXP, it assumes that the exponent is at most 255. /// Does not work particularly exact for anything apart from arithmetic. @@ -96,8 +96,8 @@ private: EVMDialect const& m_dialect; bool m_isCreation = false; - size_t m_runGas = 0; - size_t m_dataGas = 0; + bigint m_runGas = 0; + bigint m_dataGas = 0; }; }