2018-04-06 16:52:10 +02:00
|
|
|
# Nimbus
|
|
|
|
# Copyright (c) 2018 Status Research & Development GmbH
|
|
|
|
# Licensed under either of
|
|
|
|
# * Apache License, version 2.0, ([LICENSE-APACHE](LICENSE-APACHE) or http://www.apache.org/licenses/LICENSE-2.0)
|
|
|
|
# * MIT license ([LICENSE-MIT](LICENSE-MIT) or http://opensource.org/licenses/MIT)
|
|
|
|
# at your option. This file may not be copied, modified, or distributed except according to those terms.
|
|
|
|
|
2018-01-15 20:42:40 +02:00
|
|
|
import
|
2018-08-22 21:38:00 -06:00
|
|
|
chronicles, strformat, eth_common, # GasInt
|
|
|
|
../../errors, ../../vm_types
|
|
|
|
|
|
|
|
logScope:
|
|
|
|
topics = "vm gas"
|
2018-01-15 20:42:40 +02:00
|
|
|
|
2018-07-18 15:18:17 +03:00
|
|
|
proc init*(m: var GasMeter, startGas: GasInt) =
|
|
|
|
m.startGas = startGas
|
|
|
|
m.gasRemaining = m.startGas
|
|
|
|
m.gasRefunded = 0
|
2018-01-15 20:42:40 +02:00
|
|
|
|
2018-05-25 12:25:19 +02:00
|
|
|
proc consumeGas*(gasMeter: var GasMeter; amount: GasInt; reason: string) =
|
2018-02-20 19:27:43 +02:00
|
|
|
#if amount < 0.u256:
|
|
|
|
# raise newException(ValidationError, "Gas consumption amount must be positive")
|
2018-05-25 12:25:19 +02:00
|
|
|
# Alternatively: use a range type `range[0'i64 .. high(int64)]`
|
|
|
|
# https://github.com/status-im/nimbus/issues/35#issuecomment-391726518
|
2018-01-15 20:42:40 +02:00
|
|
|
if amount > gasMeter.gasRemaining:
|
|
|
|
raise newException(OutOfGas,
|
2018-01-23 00:23:07 +02:00
|
|
|
&"Out of gas: Needed {amount} - Remaining {gasMeter.gasRemaining} - Reason: {reason}")
|
2018-01-15 20:42:40 +02:00
|
|
|
gasMeter.gasRemaining -= amount
|
2018-08-22 21:38:00 -06:00
|
|
|
|
|
|
|
when defined(nimbusTrace): # XXX: https://github.com/status-im/nim-chronicles/issues/26
|
|
|
|
debug(
|
|
|
|
"GAS CONSUMPTION", total = gasMeter.gasRemaining + amount, amount, remaining = gasMeter.gasRemaining, reason)
|
2018-01-15 20:42:40 +02:00
|
|
|
|
2018-05-25 12:25:19 +02:00
|
|
|
proc returnGas*(gasMeter: var GasMeter; amount: GasInt) =
|
2018-02-20 19:27:43 +02:00
|
|
|
#if amount < 0.int256:
|
|
|
|
# raise newException(ValidationError, "Gas return amount must be positive")
|
2018-05-25 12:25:19 +02:00
|
|
|
# Alternatively: use a range type `range[0'i64 .. high(int64)]`
|
|
|
|
# https://github.com/status-im/nimbus/issues/35#issuecomment-391726518
|
2018-01-15 20:42:40 +02:00
|
|
|
gasMeter.gasRemaining += amount
|
2018-08-22 21:38:00 -06:00
|
|
|
when defined(nimbusTrace): # XXX: https://github.com/status-im/nim-chronicles/issues/26
|
|
|
|
debug(
|
|
|
|
"GAS RETURNED", consumed = gasMeter.gasRemaining - amount, amount, remaining = gasMeter.gasRemaining)
|
2018-01-15 20:42:40 +02:00
|
|
|
|
2018-05-25 12:25:19 +02:00
|
|
|
proc refundGas*(gasMeter: var GasMeter; amount: GasInt) =
|
2018-02-20 19:27:43 +02:00
|
|
|
#if amount < 0.int256:
|
|
|
|
# raise newException(ValidationError, "Gas refund amount must be positive")
|
2018-05-25 12:25:19 +02:00
|
|
|
# Alternatively: use a range type `range[0'i64 .. high(int64)]`
|
|
|
|
# https://github.com/status-im/nimbus/issues/35#issuecomment-391726518
|
2018-01-15 20:42:40 +02:00
|
|
|
gasMeter.gasRefunded += amount
|
2018-08-22 21:38:00 -06:00
|
|
|
when defined(nimbusTrace): # XXX: https://github.com/status-im/nim-chronicles/issues/26
|
|
|
|
debug(
|
|
|
|
"GAS REFUND", consumed = gasMeter.gasRemaining - amount, amount, refunded = gasMeter.gasRefunded)
|