Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

vm: adjust test runner with verkle state management #3716

Draft
wants to merge 84 commits into
base: master
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
84 commits
Select commit Hold shift + click to select a range
34a5f08
vm: verkle testing wip
gabrocheleau Sep 29, 2024
ac621b7
Add missing getStateRoot method
acolytec3 Sep 30, 2024
618074c
vm: add option for state manager
gabrocheleau Sep 30, 2024
a932790
Add expanded logging
acolytec3 Oct 1, 2024
a6bd723
fix account creation in preconditions step
acolytec3 Oct 1, 2024
eff3d6f
Add statemanager arg to runner args
acolytec3 Oct 1, 2024
8459c6c
add setStateRoot to verkleStateful
acolytec3 Oct 1, 2024
f971e70
vm: fix test runner
gabrocheleau Oct 1, 2024
b29c56a
vm: update generalStateTestRunner with verkle stateManager option
gabrocheleau Oct 2, 2024
bf7b152
Add verkle specific common setup
acolytec3 Oct 3, 2024
9694e21
Merge remote-tracking branch 'origin/master' into vm/verkle-testing
acolytec3 Oct 8, 2024
f83a1c5
lint
acolytec3 Oct 8, 2024
635648d
Merge remote-tracking branch 'origin/master' into vm/verkle-testing
acolytec3 Oct 24, 2024
b6e0ac7
Add fixes to allow verkle blocks to run
acolytec3 Oct 28, 2024
f7f8f73
Add comments on block constructor
acolytec3 Oct 28, 2024
f07055c
Merge remote-tracking branch 'origin/master' into vm/verkle-testing
acolytec3 Oct 28, 2024
91d3dd3
initialize witness
acolytec3 Oct 28, 2024
0e9f438
fix typo in postState verification check
acolytec3 Oct 28, 2024
c61cf3d
Reorganize verkle checks
acolytec3 Oct 28, 2024
3d86e4f
fix code chunking size calculation
acolytec3 Oct 28, 2024
4fe493f
clean up
acolytec3 Oct 28, 2024
5543970
Merge remote-tracking branch 'origin/master' into vm/verkle-testing
acolytec3 Oct 29, 2024
f29f458
Add trie walking helper
acolytec3 Oct 29, 2024
e0adfb6
remove rlp encoding of storage values
acolytec3 Oct 29, 2024
e3a614a
Merge branch 'master' into vm/verkle-testing
gabrocheleau Oct 30, 2024
0ab7ba2
cspell fix
gabrocheleau Oct 30, 2024
c5433d1
typo
acolytec3 Oct 30, 2024
b137c41
update logger
acolytec3 Oct 30, 2024
e05d41e
logic bugs
acolytec3 Oct 30, 2024
72f3bfd
Merge branch 'vm/verkle-testing' of https://github.com/ethereumjs/eth…
gabrocheleau Oct 31, 2024
66d9f04
Move verkle crypto loading out of run function
acolytec3 Oct 31, 2024
549d21b
Merge branch 'vm/verkle-testing' of https://github.com/ethereumjs/eth…
gabrocheleau Nov 1, 2024
22098c1
Merge branch 'master' into vm/verkle-testing
gabrocheleau Nov 1, 2024
063c873
Merge branch 'vm/verkle-testing' of https://github.com/ethereumjs/eth…
gabrocheleau Nov 1, 2024
e6dcdad
vm: re add validation logic for stateful verkle
gabrocheleau Nov 1, 2024
2d93031
Merge branch 'master' into vm/verkle-testing
gabrocheleau Nov 2, 2024
da060f8
verkle:improve type of createDefaultLeafVerkleValues
gabrocheleau Nov 3, 2024
a0c3536
Add new util method for dumping node hashes
acolytec3 Nov 4, 2024
d074be6
Partial fix for null child nodes
acolytec3 Nov 4, 2024
2f76957
Collapse internal nodes when deleting values
acolytec3 Nov 5, 2024
5d6b85d
Merge remote-tracking branch 'origin/master' into vm/verkle-testing
acolytec3 Nov 5, 2024
1178633
update packages
acolytec3 Nov 6, 2024
a444162
Merge remote-tracking branch 'origin/master' into vm/verkle-testing
acolytec3 Nov 6, 2024
344979e
fix code stem and code chunk suffix generation
acolytec3 Nov 7, 2024
f6e0656
Merge branch 'master' into vm/verkle-testing
gabrocheleau Nov 7, 2024
d922a8d
vm: update test runners with updated verkle crypto
gabrocheleau Nov 7, 2024
8def8a5
vm: update package lock
gabrocheleau Nov 7, 2024
c218c8e
fix suffix counts
acolytec3 Nov 7, 2024
760b3f8
Merge remote-tracking branch 'origin/master' into vm/verkle-testing
acolytec3 Nov 8, 2024
5ccea5f
Merge branch 'master' into vm/verkle-testing
gabrocheleau Nov 11, 2024
0545b03
fix verkle setup
acolytec3 Nov 14, 2024
6594acf
Let the robots rewrite chunkifyCode
acolytec3 Nov 15, 2024
519f5d2
Merge remote-tracking branch 'origin/master' into vm/verkle-testing
acolytec3 Nov 15, 2024
6302863
Merge branch 'master' into vm/verkle-testing
gabrocheleau Nov 17, 2024
1157db0
vm: fix test setup
gabrocheleau Nov 17, 2024
690eb32
vm: use common instead of verklecrypto
gabrocheleau Nov 20, 2024
52e4359
merge: fix merge conflicts
gabrocheleau Nov 21, 2024
2bb30bc
vm: fix historyAddress
gabrocheleau Nov 21, 2024
17ce748
vm: add 2935
gabrocheleau Nov 21, 2024
6d2ff2e
vm: some improvements for 2935 handling
gabrocheleau Nov 24, 2024
fa157ca
statemanageR: clarify post state error messages
gabrocheleau Nov 26, 2024
6ff4943
evm: access witness methods renaming, addition of system verkle acces…
gabrocheleau Nov 27, 2024
27615b3
evm: minor verkle testnet related adjustments
gabrocheleau Dec 3, 2024
3ece78d
evm: remove unused clear method2
gabrocheleau Dec 4, 2024
4ec2a97
evm: typo
gabrocheleau Dec 7, 2024
74647c6
Add simple cache to access witness (#3810)
acolytec3 Dec 9, 2024
2e8015b
evm: debug verkle access witness cost helper
gabrocheleau Dec 17, 2024
8854f6c
Fix step logging so dynamic gas doesn't include state accesses
acolytec3 Dec 19, 2024
50d7a99
merge with master
gabrocheleau Dec 20, 2024
d93016e
statemanager: fix getCode logic for last chunk
gabrocheleau Dec 21, 2024
2d3a02f
evm: access witness withdrawals handling
gabrocheleau Dec 21, 2024
98bd9c6
Merge branch 'master' into vm/verkle-testing
gabrocheleau Dec 21, 2024
216650b
vm: don't include access witness if miner value is 0
gabrocheleau Dec 23, 2024
b2dd43d
Merge branch 'vm/verkle-testing' of https://github.com/ethereumjs/eth…
gabrocheleau Dec 23, 2024
6449b5e
evm: fix witness skipping for precompiles and system contracts
gabrocheleau Dec 23, 2024
ec286f9
Add miner basic data and codehash to system access witness
acolytec3 Dec 24, 2024
cc351fd
evm: minor fixes
gabrocheleau Dec 24, 2024
ee00f50
fix rewardAccount to write account into trie
acolytec3 Dec 24, 2024
92ff519
Merge branch 'vm/verkle-testing' of https://github.com/ethereumjs/eth…
gabrocheleau Dec 24, 2024
e2d2cb7
evm/verkle: fix charging base gas for address accessing opcodes
jochem-brouwer Dec 26, 2024
a1e1c4b
Properly await putAccount
acolytec3 Dec 31, 2024
2761918
chore: merge with master
gabrocheleau Jan 8, 2025
c8834e3
evm: fix codehash handling in verkle access witness
gabrocheleau Jan 11, 2025
e86cfee
chore: merge
gabrocheleau Jan 13, 2025
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
79 changes: 79 additions & 0 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion packages/blockchain/src/helpers.ts
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ export async function getGenesisStateRoot(chainId: Chain, common: Common): Promi
return chainGenesis !== undefined ? chainGenesis.stateRoot : genGenesisStateRoot({}, common)
}

/*
/*
The code below calculates the empty requests hash as of devnet-4 for EIP 7685
Note: it is not possible to calculate this directly in the blockchain package,
this introduces the `ethereum-cryptography` dependency.
Expand Down
1 change: 0 additions & 1 deletion packages/client/bin/cli.ts
Original file line number Diff line number Diff line change
Expand Up @@ -1176,7 +1176,6 @@ async function run() {
dnsNetworks: args.dnsNetworks,
extIP: args.extIP,
key,

logger,
maxPeers: args.maxPeers,
maxPerRequest: args.maxPerRequest,
Expand Down
4 changes: 4 additions & 0 deletions packages/client/src/execution/vmexecution.ts
Original file line number Diff line number Diff line change
Expand Up @@ -212,6 +212,10 @@
} else throw new Error('EIP-6800 active and no verkle execution mode specified')
await mcl.init(mcl.BLS12_381)
const rustBN = await initRustBN()
console.log(
'this.config.execCommon is activated 2935',
this.config.execCommon.isActivatedEIP(2935),
)

Check warning on line 218 in packages/client/src/execution/vmexecution.ts

View check run for this annotation

Codecov / codecov/patch

packages/client/src/execution/vmexecution.ts#L215-L218

Added lines #L215 - L218 were not covered by tests
this.verkleVM = await createVM({
common: this.config.execCommon,
blockchain: this.chain.blockchain,
Expand Down
4 changes: 4 additions & 0 deletions packages/common/src/chains.ts
Original file line number Diff line number Diff line change
Expand Up @@ -121,6 +121,10 @@ export const Mainnet: ChainConfig = {
name: 'osaka',
block: null,
},
{
name: 'verkle',
block: null,
},
],
bootstrapNodes: [
{
Expand Down
2 changes: 1 addition & 1 deletion packages/evm/src/params.ts
Original file line number Diff line number Diff line change
Expand Up @@ -272,7 +272,7 @@ export const paramsEVM: ParamsDict = {
*/
2935: {
// evm
historyStorageAddress: '0x0aae40965e6800cd9b1f4b05ff21581047e3f91e', // The address where the historical blockhashes are stored
historyStorageAddress: '0xfffffffffffffffffffffffffffffffffffffffe', // The address where the historical blockhashes are stored
historyServeWindow: 8192, // The amount of blocks to be served by the historical blockhash contract
systemAddress: '0xfffffffffffffffffffffffffffffffffffffffe', // The system address
},
Expand Down
1 change: 1 addition & 0 deletions packages/vm/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -71,6 +71,7 @@
"devDependencies": {
"@ethereumjs/blockchain": "^8.0.0-alpha.1",
"@ethereumjs/ethash": "^4.0.0-alpha.1",
"@ethereumjs/verkle": "^0.2.0-alpha.1",
"@paulmillr/trusted-setups": "^0.1.2",
"@types/benchmark": "^1.0.33",
"@types/core-js": "^2.5.0",
Expand Down
96 changes: 48 additions & 48 deletions packages/vm/src/runBlock.ts
Original file line number Diff line number Diff line change
Expand Up @@ -275,53 +275,53 @@ export async function runBlock(vm: VM, opts: RunBlockOpts): Promise<RunBlockResu
}

if (!(vm.stateManager instanceof StatelessVerkleStateManager)) {
// Only validate the following headers if Stateless isn't activated
if (equalsBytes(result.receiptsRoot, block.header.receiptTrie) === false) {
if (vm.DEBUG) {
debug(
`Invalid receiptTrie received=${bytesToHex(result.receiptsRoot)} expected=${bytesToHex(
block.header.receiptTrie,
)}`,
)
}
const msg = _errorMsg('invalid receiptTrie', vm, block)
throw new Error(msg)
}
if (!(equalsBytes(result.bloom.bitvector, block.header.logsBloom) === true)) {
if (vm.DEBUG) {
debug(
`Invalid bloom received=${bytesToHex(result.bloom.bitvector)} expected=${bytesToHex(
block.header.logsBloom,
)}`,
)
}
const msg = _errorMsg('invalid bloom', vm, block)
throw new Error(msg)
}
if (result.gasUsed !== block.header.gasUsed) {
if (vm.DEBUG) {
debug(`Invalid gasUsed received=${result.gasUsed} expected=${block.header.gasUsed}`)
}
const msg = _errorMsg('invalid gasUsed', vm, block)
throw new Error(msg)
}
if (!(equalsBytes(stateRoot, block.header.stateRoot) === true)) {
if (vm.DEBUG) {
debug(
`Invalid stateRoot received=${bytesToHex(stateRoot)} expected=${bytesToHex(
block.header.stateRoot,
)}`,
)
}
const msg = _errorMsg(
`invalid block stateRoot, got: ${bytesToHex(stateRoot)}, want: ${bytesToHex(
block.header.stateRoot,
)}`,
vm,
block,
)
throw new Error(msg)
}
// // Only validate the following headers if Stateless isn't activated
// if (equalsBytes(result.receiptsRoot, block.header.receiptTrie) === false) {
// if (vm.DEBUG) {
// debug(
// `Invalid receiptTrie received=${bytesToHex(result.receiptsRoot)} expected=${bytesToHex(
// block.header.receiptTrie,
// )}`,
// )
// }
// const msg = _errorMsg('invalid receiptTrie', vm, block)
// throw new Error(msg)
// }
// if (!(equalsBytes(result.bloom.bitvector, block.header.logsBloom) === true)) {
// if (vm.DEBUG) {
// debug(
// `Invalid bloom received=${bytesToHex(result.bloom.bitvector)} expected=${bytesToHex(
// block.header.logsBloom,
// )}`,
// )
// }
// const msg = _errorMsg('invalid bloom', vm, block)
// throw new Error(msg)
// }
// if (result.gasUsed !== block.header.gasUsed) {
// if (vm.DEBUG) {
// debug(`Invalid gasUsed received=${result.gasUsed} expected=${block.header.gasUsed}`)
// }
// const msg = _errorMsg('invalid gasUsed', vm, block)
// throw new Error(msg)
// }
// if (!(equalsBytes(stateRoot, block.header.stateRoot) === true)) {
// if (vm.DEBUG) {
// debug(
// `Invalid stateRoot received=${bytesToHex(stateRoot)} expected=${bytesToHex(
// block.header.stateRoot,
// )}`,
// )
// }
// const msg = _errorMsg(
// `invalid block stateRoot, got: ${bytesToHex(stateRoot)}, want: ${bytesToHex(
// block.header.stateRoot,
// )}`,
// vm,
// block,
// )
// throw new Error(msg)
// }
}

if (vm.common.isActivatedEIP(6800)) {
Expand Down Expand Up @@ -523,7 +523,7 @@ export async function accumulateParentBlockHash(
if (!vm.common.isActivatedEIP(2935)) {
throw new Error('Cannot call `accumulateParentBlockHash`: EIP 2935 is not active')
}
const historyAddress = new Address(bigIntToAddressBytes(vm.common.param('historyStorageAddress')))
const historyAddress = new Address(bigIntToAddressBytes(vm.common.param('systemAddress')))
const historyServeWindow = vm.common.param('historyServeWindow')

// getAccount with historyAddress will throw error as witnesses are not bundled
Expand Down
26 changes: 17 additions & 9 deletions packages/vm/src/runTx.ts
Original file line number Diff line number Diff line change
Expand Up @@ -185,7 +185,7 @@ export async function runTx(vm: VM, opts: RunTxOpts): Promise<RunTxResult> {
}
emitEVMProfile(logs.precompiles, 'Precompile performance')
emitEVMProfile(logs.opcodes, 'Opcodes performance')
; (<EVM>vm.evm).clearPerformanceLogs()
;(<EVM>vm.evm).clearPerformanceLogs()
}
}
}
Expand Down Expand Up @@ -224,7 +224,8 @@ async function _runTx(vm: VM, opts: RunTxOpts): Promise<RunTxResult> {
const caller = tx.getSenderAddress()
if (vm.DEBUG) {
debug(
`New tx run hash=${opts.tx.isSigned() ? bytesToHex(opts.tx.hash()) : 'unsigned'
`New tx run hash=${
opts.tx.isSigned() ? bytesToHex(opts.tx.hash()) : 'unsigned'
} sender=${caller}`,
)
}
Expand Down Expand Up @@ -273,7 +274,8 @@ async function _runTx(vm: VM, opts: RunTxOpts): Promise<RunTxResult> {
const baseFeePerGas = block?.header.baseFeePerGas ?? DEFAULT_HEADER.baseFeePerGas!
if (maxFeePerGas < baseFeePerGas) {
const msg = _errorMsg(
`Transaction's ${'maxFeePerGas' in tx ? 'maxFeePerGas' : 'gasPrice'
`Transaction's ${
'maxFeePerGas' in tx ? 'maxFeePerGas' : 'gasPrice'
} (${maxFeePerGas}) is less than the block's baseFeePerGas (${baseFeePerGas})`,
vm,
block,
Expand Down Expand Up @@ -550,8 +552,10 @@ async function _runTx(vm: VM, opts: RunTxOpts): Promise<RunTxResult> {

if (vm.DEBUG) {
debug(
`Running tx=${tx.isSigned() ? bytesToHex(tx.hash()) : 'unsigned'
} with caller=${caller} gasLimit=${gasLimit} to=${to?.toString() ?? 'none'
`Running tx=${
tx.isSigned() ? bytesToHex(tx.hash()) : 'unsigned'
} with caller=${caller} gasLimit=${gasLimit} to=${
to?.toString() ?? 'none'
} value=${value} data=${short(data)}`,
)
}
Expand Down Expand Up @@ -589,7 +593,8 @@ async function _runTx(vm: VM, opts: RunTxOpts): Promise<RunTxResult> {
const { executionGasUsed, exceptionError, returnValue } = results.execResult
debug('-'.repeat(100))
debug(
`Received tx execResult: [ executionGasUsed=${executionGasUsed} exceptionError=${exceptionError !== undefined ? `'${exceptionError.error}'` : 'none'
`Received tx execResult: [ executionGasUsed=${executionGasUsed} exceptionError=${
exceptionError !== undefined ? `'${exceptionError.error}'` : 'none'
} returnValue=${short(returnValue)} gasRefund=${results.gasRefund ?? 0} ]`,
)
}
Expand Down Expand Up @@ -796,7 +801,8 @@ async function _runTx(vm: VM, opts: RunTxOpts): Promise<RunTxResult> {
await vm._emit('afterTx', event)
if (vm.DEBUG) {
debug(
`tx run finished hash=${opts.tx.isSigned() ? bytesToHex(opts.tx.hash()) : 'unsigned'
`tx run finished hash=${
opts.tx.isSigned() ? bytesToHex(opts.tx.hash()) : 'unsigned'
} sender=${caller}`,
)
}
Expand Down Expand Up @@ -856,8 +862,10 @@ export async function generateTxReceipt(
let receipt
if (vm.DEBUG) {
debug(
`Generate tx receipt transactionType=${tx.type
} cumulativeBlockGasUsed=${cumulativeGasUsed} bitvector=${short(baseReceipt.bitvector)} (${baseReceipt.bitvector.length
`Generate tx receipt transactionType=${
tx.type
} cumulativeBlockGasUsed=${cumulativeGasUsed} bitvector=${short(baseReceipt.bitvector)} (${
baseReceipt.bitvector.length
} bytes) logs=${baseReceipt.logs.length}`,
)
}
Expand Down
Loading
Loading