Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
G
Geth-Modification
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
张蕾
Geth-Modification
Commits
dfd07624
Commit
dfd07624
authored
Jun 28, 2017
by
Péter Szilágyi
Committed by
GitHub
Jun 28, 2017
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #14718 from holiman/gascalc_fix
core/vm: fix overflow in gas calculation formula
parents
6dc32e89
e4301564
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
17 additions
and
17 deletions
+17
-17
gas_table.go
core/vm/gas_table.go
+10
-6
gas_table_test.go
core/vm/gas_table_test.go
+7
-11
No files found.
core/vm/gas_table.go
View file @
dfd07624
...
...
@@ -17,7 +17,6 @@
package
vm
import
(
gmath
"math"
"math/big"
"github.com/ethereum/go-ethereum/common"
...
...
@@ -28,15 +27,20 @@ import (
// memoryGasCosts calculates the quadratic gas for memory expansion. It does so
// only for the memory region that is expanded, not the total memory.
func
memoryGasCost
(
mem
*
Memory
,
newMemSize
uint64
)
(
uint64
,
error
)
{
// The maximum that will fit in a uint64 is max_word_count - 1
// anything above that will result in an overflow.
if
newMemSize
>
gmath
.
MaxUint64
-
32
{
return
0
,
errGasUintOverflow
}
if
newMemSize
==
0
{
return
0
,
nil
}
// The maximum that will fit in a uint64 is max_word_count - 1
// anything above that will result in an overflow.
// Additionally, a newMemSize which results in a
// newMemSizeWords larger than 0x7ffffffff will cause the square operation
// to overflow.
// The constant 0xffffffffe0 is the highest number that can be used without
// overflowing the gas calculation
if
newMemSize
>
0xffffffffe0
{
return
0
,
errGasUintOverflow
}
newMemSizeWords
:=
toWordSize
(
newMemSize
)
newMemSize
=
newMemSizeWords
*
32
...
...
core/vm/gas_table_test.go
View file @
dfd07624
...
...
@@ -16,24 +16,20 @@
package
vm
import
(
"math"
"testing"
)
import
"testing"
func
TestMemoryGasCost
(
t
*
testing
.
T
)
{
size
:=
uint64
(
math
.
MaxUint64
-
64
)
_
,
err
:=
memoryGasCost
(
&
Memory
{},
size
)
//size := uint64(math.MaxUint64 - 64)
size
:=
uint64
(
0xffffffffe0
)
v
,
err
:=
memoryGasCost
(
&
Memory
{},
size
)
if
err
!=
nil
{
t
.
Error
(
"didn't expect error:"
,
err
)
}
_
,
err
=
memoryGasCost
(
&
Memory
{},
size
+
32
)
if
err
!=
nil
{
t
.
Error
(
"didn't expect error:"
,
err
)
if
v
!=
36028899963961341
{
t
.
Errorf
(
"Expected: 36028899963961341, got %d"
,
v
)
}
_
,
err
=
memoryGasCost
(
&
Memory
{},
size
+
33
)
_
,
err
=
memoryGasCost
(
&
Memory
{},
size
+
1
)
if
err
==
nil
{
t
.
Error
(
"expected error"
)
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment