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

blockstore: make merkle root Optional in MerkleRootMeta column #34091

Merged
merged 1 commit into from
Nov 15, 2023

Conversation

AshwinSekar
Copy link
Contributor

Problem

After discussion, it seems like legacy shreds should be supported for a while longer. To avoid having to use unwrap_or_default() and mess around with Hash::default(), we change the type of the yet to be used column to optional.

Summary of Changes

Change type. This will be backported to the same branches as #33979
Contributes to #33644

Copy link
Contributor

@behzadnouri behzadnouri left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

please make sure this is backported along with the original commit.

@AshwinSekar AshwinSekar merged commit 693d576 into solana-labs:master Nov 15, 2023
17 checks passed
@AshwinSekar AshwinSekar deleted the merkle-root-meta-option branch November 15, 2023 18:09
@steviez
Copy link
Contributor

steviez commented Nov 15, 2023

We good with leaving the Option<_> in there forever, or think you'll want to rip it out after legacy shreds are fully gone ?

@AshwinSekar
Copy link
Contributor Author

We good with leaving the Option<_> in there forever, or think you'll want to rip it out after legacy shreds are fully gone ?

We can probably rip it out after legacy shreds are fully gone, depending on how much of a PITA it is to migrate the column.

@steviez
Copy link
Contributor

steviez commented Nov 20, 2023

We good with leaving the Option<_> in there forever, or think you'll want to rip it out after legacy shreds are fully gone ?

We can probably rip it out after legacy shreds are fully gone, depending on how much of a PITA it is to migrate the column.

Gotcha - my question was aimed at whether we should try to be proactive and put something like an enum in place to allow dual-support. But, the enum would be as much (if not more) hassle in matching enum type than always dealing with the Option<_>, so I think we just leave this for now and disregard my question 😅

@AshwinSekar AshwinSekar self-assigned this Nov 29, 2023
@AshwinSekar AshwinSekar requested a review from t-nelson November 30, 2023 23:29
mergify bot added a commit that referenced this pull request Dec 1, 2023
…#34028)

* add merkle root meta column to blockstore (#33979)

* add merkle root meta column to blockstore

* pr feedback: remove write/reads to column

* pr feedback: u64 -> u32 + revert

* pr feedback: fec_set_index u32, use Self::Index

* pr feedback: key size 16 -> 12

(cherry picked from commit e457c02)

* blockstore: make merkle root Optional in MerkleRootMeta column (#34091)

---------

Co-authored-by: Ashwin Sekar <ashwin@solana.com>
steviez pushed a commit that referenced this pull request Jan 5, 2024
…#34665)

* add merkle root meta column to blockstore (#33979)

* add merkle root meta column to blockstore

* pr feedback: remove write/reads to column

* pr feedback: u64 -> u32 + revert

* pr feedback: fec_set_index u32, use Self::Index

* pr feedback: key size 16 -> 12

(cherry picked from commit e457c02)

# Conflicts:
#	ledger/src/blockstore.rs

* fix conflicts

* blockstore: make merkle root Optional in MerkleRootMeta column (#34091)

---------

Co-authored-by: Ashwin Sekar <ashwin@solana.com>
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
Development

Successfully merging this pull request may close these issues.

3 participants