Reflect use of prune margin epochs at import

This commit is contained in:
Emilia Hane 2023-01-24 10:10:11 +01:00
parent d4795601f2
commit 9c2e623555
No known key found for this signature in database
GPG Key ID: E73394F9C09206FA
2 changed files with 17 additions and 15 deletions

View File

@ -3015,12 +3015,17 @@ impl<T: BeaconChainTypes> BeaconChain<T> {
ops.push(StoreOp::PutBlock(block_root, signed_block.clone())); ops.push(StoreOp::PutBlock(block_root, signed_block.clone()));
ops.push(StoreOp::PutState(block.state_root(), &state)); ops.push(StoreOp::PutState(block.state_root(), &state));
// Only store blobs at the data availability boundary or younger. // Only consider blobs if the eip4844 fork is enabled.
// if let Some(data_availability_boundary) = self.data_availability_boundary() {
// todo(emhane): Should we add a marginal of one epoch here to ensure data availability
// consistency across network at epoch boundaries?
let block_epoch = block.slot().epoch(T::EthSpec::slots_per_epoch()); let block_epoch = block.slot().epoch(T::EthSpec::slots_per_epoch());
if Some(block_epoch) >= self.data_availability_boundary() { let import_boundary = match self.store.get_config().blob_prune_margin_epochs {
Some(margin_epochs) => data_availability_boundary - margin_epochs,
None => data_availability_boundary,
};
// Only store blobs at the data availability boundary, minus any configured epochs
// margin, or younger (of higher epoch number).
if block_epoch >= import_boundary {
if let Some(blobs) = blobs? { if let Some(blobs) = blobs? {
if blobs.blobs.len() > 0 { if blobs.blobs.len() > 0 {
//FIXME(sean) using this for debugging for now //FIXME(sean) using this for debugging for now
@ -3029,6 +3034,7 @@ impl<T: BeaconChainTypes> BeaconChain<T> {
} }
} }
} }
}
let txn_lock = self.store.hot_db.begin_rw_transaction(); let txn_lock = self.store.hot_db.begin_rw_transaction();

View File

@ -201,10 +201,6 @@ impl Config {
pub fn create_data_dir(&self) -> Result<PathBuf, String> { pub fn create_data_dir(&self) -> Result<PathBuf, String> {
ensure_dir_exists(self.get_data_dir()) ensure_dir_exists(self.get_data_dir())
} }
pub fn get_blob_prune_margin_epochs(&self) -> Option<u64> {
self.store.blob_prune_margin_epochs
}
} }
/// Ensure that the directory at `path` exists, by creating it and all parents if necessary. /// Ensure that the directory at `path` exists, by creating it and all parents if necessary.