aboutsummaryrefslogtreecommitdiffstats
path: root/core/vm/gas_table.go
diff options
context:
space:
mode:
authorPéter Szilágyi <peterke@gmail.com>2017-08-16 20:19:33 +0800
committerGitHub <noreply@github.com>2017-08-16 20:19:33 +0800
commit0b978f91b6adcc4b595391096a72db73bc625bcf (patch)
tree39fec54fa2601c10b57ccd00eebf494003c57b5f /core/vm/gas_table.go
parent76069eef38082089d2eaf99661a80e1a953bf271 (diff)
parent64d199edf2c152072df92f31313e2c157d38c520 (diff)
downloadgo-tangerine-0b978f91b6adcc4b595391096a72db73bc625bcf.tar.gz
go-tangerine-0b978f91b6adcc4b595391096a72db73bc625bcf.tar.zst
go-tangerine-0b978f91b6adcc4b595391096a72db73bc625bcf.zip
Merge pull request #14981 from karalabe/metropolis-returndata
core/vm: implement RETURNDATA metropolis opcodes
Diffstat (limited to 'core/vm/gas_table.go')
-rw-r--r--core/vm/gas_table.go28
1 files changed, 27 insertions, 1 deletions
diff --git a/core/vm/gas_table.go b/core/vm/gas_table.go
index 8a6c2741d..a6346bd80 100644
--- a/core/vm/gas_table.go
+++ b/core/vm/gas_table.go
@@ -65,7 +65,33 @@ func constGasFunc(gas uint64) gasFunc {
}
}
-func gasCalldataCopy(gt params.GasTable, evm *EVM, contract *Contract, stack *Stack, mem *Memory, memorySize uint64) (uint64, error) {
+func gasCallDataCopy(gt params.GasTable, evm *EVM, contract *Contract, stack *Stack, mem *Memory, memorySize uint64) (uint64, error) {
+ gas, err := memoryGasCost(mem, memorySize)
+ if err != nil {
+ return 0, err
+ }
+
+ var overflow bool
+ if gas, overflow = math.SafeAdd(gas, GasFastestStep); overflow {
+ return 0, errGasUintOverflow
+ }
+
+ words, overflow := bigUint64(stack.Back(2))
+ if overflow {
+ return 0, errGasUintOverflow
+ }
+
+ if words, overflow = math.SafeMul(toWordSize(words), params.CopyGas); overflow {
+ return 0, errGasUintOverflow
+ }
+
+ if gas, overflow = math.SafeAdd(gas, words); overflow {
+ return 0, errGasUintOverflow
+ }
+ return gas, nil
+}
+
+func gasReturnDataCopy(gt params.GasTable, evm *EVM, contract *Contract, stack *Stack, mem *Memory, memorySize uint64) (uint64, error) {
gas, err := memoryGasCost(mem, memorySize)
if err != nil {
return 0, err