Skip to content
This repository has been archived by the owner on Jan 13, 2025. It is now read-only.

Commit

Permalink
Add merkle proof fetching
Browse files Browse the repository at this point in the history
  • Loading branch information
carllin committed Dec 24, 2019
1 parent 506b6f8 commit f01cd0e
Showing 1 changed file with 27 additions and 0 deletions.
27 changes: 27 additions & 0 deletions book/src/proposals/leader-duplicate-block-slashing.md
Original file line number Diff line number Diff line change
Expand Up @@ -178,3 +178,30 @@ shreds for slot `B`.
4) If no version of slot `A` chains, then deserializie `S_B` to find the first
tick `T_B`, then make a `Orphan(slot, T_B.hash, T_B.num_hashes)` request
to get the last shred in the version of slot `A` that chains to slot `B`.

### Replay Failures
As summarized under the `Dead Slots` column family in the
`Indexing the Column Families by Blockhash` section above, validators must now
account for the possibility that some versions of a slot have correctness
issues while other versions don't.

Protocol:

Let `V_A` be a version of slot `A` with blockhash `B_A`.

Assume that on replay of `V_A` the validator runs into some correctness issue
(entry verification failure, bad tick count, etc.) while replaying the entries.

On entry verification failures of `E1` and `E2`:

Let `S` be the set of all shreds that contain any part of `E1` and `E2`.

1) The validator queries for a merkle proof of entry `E1` and `E2` to prove that
both entries were indeed part of the version `A` with blockhash `B_A`.

2) If the merkle proof checks out, we add `(A, B_A)` to the `Dead Slots` column
family. No further forks chaining to this slot will be played.

3) If the merkle proof instead shows that there is a different version of some
shred in `S`, that means we got maliciously sent the wrong shred for version
`B_A`. We must then drop those wrong shreds and repair them again.

0 comments on commit f01cd0e

Please sign in to comment.