Skip to content

Commit

Permalink
make london hard fork default, add EIP1559 basefee opcode
Browse files Browse the repository at this point in the history
  • Loading branch information
0xalpharush committed Jan 19, 2022
1 parent 2184d6b commit fa76024
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 1 deletion.
13 changes: 12 additions & 1 deletion pyevmasm/evmasm.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
from future.builtins import next, bytes # type: ignore
import copy

DEFAULT_FORK = "istanbul"
DEFAULT_FORK = "london"

"""
Example use::
Expand Down Expand Up @@ -976,6 +976,14 @@ def __repr__(self):
istanbul_instruction_table, previous_fork=serenity_instruction_table
)

london_instruction_table = {
0x48: ("BASEFEE", 0, 0, 1, 2, "Base fee in wei")
}

london_instruction_table = InstructionTable( # type: ignore
london_instruction_table, previous_fork=istanbul_instruction_table
)

accepted_forks = (
"frontier",
"homestead",
Expand All @@ -986,6 +994,7 @@ def __repr__(self):
"petersburg",
"serenity",
"istanbul",
"london"
)


Expand All @@ -999,6 +1008,7 @@ def __repr__(self):
"petersburg": constantinople_instruction_table, # constantinople table is intentional here: those two are aliases
"serenity": serenity_instruction_table,
"istanbul": istanbul_instruction_table,
"london": london_instruction_table
}


Expand Down Expand Up @@ -1032,6 +1042,7 @@ def block_to_fork(block_number):
# 7280000: "constantinople", # Same Block as petersburg, commented to avoid conflicts
7280000: "petersburg",
9999999: "serenity", # to be replaced after Serenity launch
12965000: "london"
}
fork_names = list(forks_by_block.values())
fork_blocks = list(forks_by_block.keys())
Expand Down
7 changes: 7 additions & 0 deletions tests/test_EVMAssembler.py
Original file line number Diff line number Diff line change
Expand Up @@ -120,6 +120,13 @@ def test_istanbul_fork(self):
self.assertTrue(insn.fee == 800)
self.assertTrue(insn.pops == 1)
self.assertTrue(insn.pushes == 1)

def test_london_fork(self):
insn = EVMAsm.disassemble_one(b"\x48", fork="london")
self.assertTrue(insn.mnemonic == "BASEFEE")
self.assertTrue(insn.fee == 2)
self.assertTrue(insn.pops == 0)
self.assertTrue(insn.pushes == 1)

def test_assemble_DUP1_regression(self):
insn = EVMAsm.assemble_one("DUP1")
Expand Down

0 comments on commit fa76024

Please sign in to comment.