Also bump `EXECUTION_PAYLOAD_GINDEX`
This commit is contained in:
parent
0b5bb1ae3f
commit
82143e1977
|
@ -16,5 +16,5 @@ from eth2spec.bellatrix import {preset_name} as bellatrix
|
||||||
@classmethod
|
@classmethod
|
||||||
def hardcoded_ssz_dep_constants(cls) -> Dict[str, str]:
|
def hardcoded_ssz_dep_constants(cls) -> Dict[str, str]:
|
||||||
return {
|
return {
|
||||||
'EXECUTION_PAYLOAD_INDEX': 'GeneralizedIndex(25)',
|
'EXECUTION_PAYLOAD_GINDEX': 'GeneralizedIndex(25)',
|
||||||
}
|
}
|
||||||
|
|
|
@ -27,6 +27,6 @@ import json
|
||||||
@classmethod
|
@classmethod
|
||||||
def hardcoded_ssz_dep_constants(cls) -> Dict[str, str]:
|
def hardcoded_ssz_dep_constants(cls) -> Dict[str, str]:
|
||||||
constants = {
|
constants = {
|
||||||
'EXECUTION_PAYLOAD_INDEX': 'GeneralizedIndex(41)',
|
'EXECUTION_PAYLOAD_GINDEX': 'GeneralizedIndex(41)',
|
||||||
}
|
}
|
||||||
return {**super().hardcoded_ssz_dep_constants(), **constants}
|
return {**super().hardcoded_ssz_dep_constants(), **constants}
|
||||||
|
|
|
@ -47,7 +47,7 @@ def block_to_light_client_header(block: SignedBeaconBlock) -> LightClientHeader:
|
||||||
withdrawals_root=hash_tree_root(payload.withdrawals),
|
withdrawals_root=hash_tree_root(payload.withdrawals),
|
||||||
)
|
)
|
||||||
execution_branch = ExecutionBranch(
|
execution_branch = ExecutionBranch(
|
||||||
compute_merkle_proof(block.message.body, EXECUTION_PAYLOAD_INDEX))
|
compute_merkle_proof(block.message.body, EXECUTION_PAYLOAD_GINDEX))
|
||||||
else:
|
else:
|
||||||
# Note that during fork transitions, `finalized_header` may still point to earlier forks.
|
# Note that during fork transitions, `finalized_header` may still point to earlier forks.
|
||||||
# While Bellatrix blocks also contain an `ExecutionPayload` (minus `withdrawals_root`),
|
# While Bellatrix blocks also contain an `ExecutionPayload` (minus `withdrawals_root`),
|
||||||
|
|
|
@ -32,13 +32,13 @@ Additional documents describes the impact of the upgrade on certain roles:
|
||||||
|
|
||||||
| Name | SSZ equivalent | Description |
|
| Name | SSZ equivalent | Description |
|
||||||
| - | - | - |
|
| - | - | - |
|
||||||
| `ExecutionBranch` | `Vector[Bytes32, floorlog2(EXECUTION_PAYLOAD_INDEX)]` | Merkle branch of `execution_payload` within `BeaconBlockBody` |
|
| `ExecutionBranch` | `Vector[Bytes32, floorlog2(EXECUTION_PAYLOAD_GINDEX)]` | Merkle branch of `execution_payload` within `BeaconBlockBody` |
|
||||||
|
|
||||||
## Constants
|
## Constants
|
||||||
|
|
||||||
| Name | Value |
|
| Name | Value |
|
||||||
| - | - |
|
| - | - |
|
||||||
| `EXECUTION_PAYLOAD_INDEX` | `get_generalized_index(BeaconBlockBody, 'execution_payload')` (= 25) |
|
| `EXECUTION_PAYLOAD_GINDEX` | `get_generalized_index(BeaconBlockBody, 'execution_payload')` (= 25) |
|
||||||
|
|
||||||
## Containers
|
## Containers
|
||||||
|
|
||||||
|
@ -82,8 +82,8 @@ def is_valid_light_client_header(header: LightClientHeader) -> bool:
|
||||||
return is_valid_merkle_branch(
|
return is_valid_merkle_branch(
|
||||||
leaf=get_lc_execution_root(header),
|
leaf=get_lc_execution_root(header),
|
||||||
branch=header.execution_branch,
|
branch=header.execution_branch,
|
||||||
depth=floorlog2(EXECUTION_PAYLOAD_INDEX),
|
depth=floorlog2(EXECUTION_PAYLOAD_GINDEX),
|
||||||
index=get_subtree_index(EXECUTION_PAYLOAD_INDEX),
|
index=get_subtree_index(EXECUTION_PAYLOAD_GINDEX),
|
||||||
root=header.beacon.body_root,
|
root=header.beacon.body_root,
|
||||||
)
|
)
|
||||||
```
|
```
|
||||||
|
|
|
@ -53,7 +53,7 @@ def block_to_light_client_header(block: SignedBeaconBlock) -> LightClientHeader:
|
||||||
execution_header.excess_blob_gas = payload.excess_blob_gas
|
execution_header.excess_blob_gas = payload.excess_blob_gas
|
||||||
|
|
||||||
execution_branch = ExecutionBranch(
|
execution_branch = ExecutionBranch(
|
||||||
compute_merkle_proof(block.message.body, EXECUTION_PAYLOAD_INDEX))
|
compute_merkle_proof(block.message.body, EXECUTION_PAYLOAD_GINDEX))
|
||||||
else:
|
else:
|
||||||
# Note that during fork transitions, `finalized_header` may still point to earlier forks.
|
# Note that during fork transitions, `finalized_header` may still point to earlier forks.
|
||||||
# While Bellatrix blocks also contain an `ExecutionPayload` (minus `withdrawals_root`),
|
# While Bellatrix blocks also contain an `ExecutionPayload` (minus `withdrawals_root`),
|
||||||
|
|
|
@ -80,8 +80,8 @@ def is_valid_light_client_header(header: LightClientHeader) -> bool:
|
||||||
return is_valid_merkle_branch(
|
return is_valid_merkle_branch(
|
||||||
leaf=get_lc_execution_root(header),
|
leaf=get_lc_execution_root(header),
|
||||||
branch=header.execution_branch,
|
branch=header.execution_branch,
|
||||||
depth=floorlog2(EXECUTION_PAYLOAD_INDEX),
|
depth=floorlog2(EXECUTION_PAYLOAD_GINDEX),
|
||||||
index=get_subtree_index(EXECUTION_PAYLOAD_INDEX),
|
index=get_subtree_index(EXECUTION_PAYLOAD_GINDEX),
|
||||||
root=header.beacon.body_root,
|
root=header.beacon.body_root,
|
||||||
)
|
)
|
||||||
```
|
```
|
||||||
|
|
|
@ -15,16 +15,16 @@ def test_execution_merkle_proof(spec, state):
|
||||||
block = state_transition_with_full_block(spec, state, True, False)
|
block = state_transition_with_full_block(spec, state, True, False)
|
||||||
|
|
||||||
yield "object", block.message.body
|
yield "object", block.message.body
|
||||||
execution_branch = spec.compute_merkle_proof(block.message.body, spec.EXECUTION_PAYLOAD_INDEX)
|
execution_branch = spec.compute_merkle_proof(block.message.body, spec.EXECUTION_PAYLOAD_GINDEX)
|
||||||
yield "proof", {
|
yield "proof", {
|
||||||
"leaf": "0x" + block.message.body.execution_payload.hash_tree_root().hex(),
|
"leaf": "0x" + block.message.body.execution_payload.hash_tree_root().hex(),
|
||||||
"leaf_index": spec.EXECUTION_PAYLOAD_INDEX,
|
"leaf_index": spec.EXECUTION_PAYLOAD_GINDEX,
|
||||||
"branch": ['0x' + root.hex() for root in execution_branch]
|
"branch": ['0x' + root.hex() for root in execution_branch]
|
||||||
}
|
}
|
||||||
assert spec.is_valid_merkle_branch(
|
assert spec.is_valid_merkle_branch(
|
||||||
leaf=block.message.body.execution_payload.hash_tree_root(),
|
leaf=block.message.body.execution_payload.hash_tree_root(),
|
||||||
branch=execution_branch,
|
branch=execution_branch,
|
||||||
depth=spec.floorlog2(spec.EXECUTION_PAYLOAD_INDEX),
|
depth=spec.floorlog2(spec.EXECUTION_PAYLOAD_GINDEX),
|
||||||
index=spec.get_subtree_index(spec.EXECUTION_PAYLOAD_INDEX),
|
index=spec.get_subtree_index(spec.EXECUTION_PAYLOAD_GINDEX),
|
||||||
root=block.message.body.hash_tree_root(),
|
root=block.message.body.hash_tree_root(),
|
||||||
)
|
)
|
||||||
|
|
Loading…
Reference in New Issue