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
060e33fb
Unverified
Commit
060e33fb
authored
Aug 22, 2019
by
Péter Szilágyi
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
core/vm: enable istanbul EIPs in the jump table
parent
46ec63b8
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
19 additions
and
6 deletions
+19
-6
interpreter.go
core/vm/interpreter.go
+2
-0
jump_table.go
core/vm/jump_table.go
+17
-6
No files found.
core/vm/interpreter.go
View file @
060e33fb
...
@@ -93,6 +93,8 @@ func NewEVMInterpreter(evm *EVM, cfg Config) *EVMInterpreter {
...
@@ -93,6 +93,8 @@ func NewEVMInterpreter(evm *EVM, cfg Config) *EVMInterpreter {
if
!
cfg
.
JumpTable
[
STOP
]
.
valid
{
if
!
cfg
.
JumpTable
[
STOP
]
.
valid
{
var
jt
JumpTable
var
jt
JumpTable
switch
{
switch
{
case
evm
.
chainRules
.
IsIstanbul
:
jt
=
istanbulInstructionSet
case
evm
.
chainRules
.
IsConstantinople
:
case
evm
.
chainRules
.
IsConstantinople
:
jt
=
constantinopleInstructionSet
jt
=
constantinopleInstructionSet
case
evm
.
chainRules
.
IsByzantium
:
case
evm
.
chainRules
.
IsByzantium
:
...
...
core/vm/jump_table.go
View file @
060e33fb
...
@@ -60,15 +60,27 @@ var (
...
@@ -60,15 +60,27 @@ var (
spuriousDragonInstructionSet
=
newSpuriousDragonInstructionSet
()
spuriousDragonInstructionSet
=
newSpuriousDragonInstructionSet
()
byzantiumInstructionSet
=
newByzantiumInstructionSet
()
byzantiumInstructionSet
=
newByzantiumInstructionSet
()
constantinopleInstructionSet
=
newConstantinopleInstructionSet
()
constantinopleInstructionSet
=
newConstantinopleInstructionSet
()
istanbulInstructionSet
=
newIstanbulInstructionSet
()
)
)
// JumpTable contains the EVM opcodes supported at a given fork.
// JumpTable contains the EVM opcodes supported at a given fork.
type
JumpTable
[
256
]
operation
type
JumpTable
[
256
]
operation
// NewConstantinopleInstructionSet returns the frontier, homestead
// newIstanbulInstructionSet returns the frontier, homestead
// byzantium, contantinople and petersburg instructions.
func
newIstanbulInstructionSet
()
JumpTable
{
instructionSet
:=
newConstantinopleInstructionSet
()
enable1344
(
&
instructionSet
)
// ChainID opcode - https://eips.ethereum.org/EIPS/eip-1344
enable1884
(
&
instructionSet
)
// Reprice reader opcodes - https://eips.ethereum.org/EIPS/eip-1884
enable2200
(
&
instructionSet
)
// Net metered SSTORE - https://eips.ethereum.org/EIPS/eip-2200
return
instructionSet
}
// newConstantinopleInstructionSet returns the frontier, homestead
// byzantium and contantinople instructions.
// byzantium and contantinople instructions.
func
newConstantinopleInstructionSet
()
JumpTable
{
func
newConstantinopleInstructionSet
()
JumpTable
{
// instructions that can be executed during the byzantium phase.
instructionSet
:=
newByzantiumInstructionSet
()
instructionSet
:=
newByzantiumInstructionSet
()
instructionSet
[
SHL
]
=
operation
{
instructionSet
[
SHL
]
=
operation
{
execute
:
opSHL
,
execute
:
opSHL
,
...
@@ -112,10 +124,9 @@ func newConstantinopleInstructionSet() JumpTable {
...
@@ -112,10 +124,9 @@ func newConstantinopleInstructionSet() JumpTable {
return
instructionSet
return
instructionSet
}
}
//
N
ewByzantiumInstructionSet returns the frontier, homestead and
//
n
ewByzantiumInstructionSet returns the frontier, homestead and
// byzantium instructions.
// byzantium instructions.
func
newByzantiumInstructionSet
()
JumpTable
{
func
newByzantiumInstructionSet
()
JumpTable
{
// instructions that can be executed during the homestead phase.
instructionSet
:=
newSpuriousDragonInstructionSet
()
instructionSet
:=
newSpuriousDragonInstructionSet
()
instructionSet
[
STATICCALL
]
=
operation
{
instructionSet
[
STATICCALL
]
=
operation
{
execute
:
opStaticCall
,
execute
:
opStaticCall
,
...
@@ -177,7 +188,7 @@ func newTangerineWhistleInstructionSet() JumpTable {
...
@@ -177,7 +188,7 @@ func newTangerineWhistleInstructionSet() JumpTable {
return
instructionSet
return
instructionSet
}
}
//
N
ewHomesteadInstructionSet returns the frontier and homestead
//
n
ewHomesteadInstructionSet returns the frontier and homestead
// instructions that can be executed during the homestead phase.
// instructions that can be executed during the homestead phase.
func
newHomesteadInstructionSet
()
JumpTable
{
func
newHomesteadInstructionSet
()
JumpTable
{
instructionSet
:=
newFrontierInstructionSet
()
instructionSet
:=
newFrontierInstructionSet
()
...
@@ -194,7 +205,7 @@ func newHomesteadInstructionSet() JumpTable {
...
@@ -194,7 +205,7 @@ func newHomesteadInstructionSet() JumpTable {
return
instructionSet
return
instructionSet
}
}
//
N
ewFrontierInstructionSet returns the frontier instructions
//
n
ewFrontierInstructionSet returns the frontier instructions
// that can be executed during the frontier phase.
// that can be executed during the frontier phase.
func
newFrontierInstructionSet
()
JumpTable
{
func
newFrontierInstructionSet
()
JumpTable
{
return
JumpTable
{
return
JumpTable
{
...
...
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