Update max blobs per block (#4391)
* Change max blobs to 6 in code * Rename * fmt
This commit is contained in:
parent
ec1b36474b
commit
0a2a00a527
@ -5,7 +5,7 @@ use regex::bytes::Regex;
|
|||||||
use serde::Serialize;
|
use serde::Serialize;
|
||||||
use ssz_derive::{Decode, Encode};
|
use ssz_derive::{Decode, Encode};
|
||||||
use ssz_types::{
|
use ssz_types::{
|
||||||
typenum::{U1024, U256, U512},
|
typenum::{U1024, U256, U768},
|
||||||
VariableList,
|
VariableList,
|
||||||
};
|
};
|
||||||
use std::ops::Deref;
|
use std::ops::Deref;
|
||||||
@ -31,9 +31,9 @@ pub const MAX_REQUEST_BLOCKS_DENEB: u64 = 128;
|
|||||||
// TODO: this is calculated as MAX_REQUEST_BLOCKS_DENEB * MAX_BLOBS_PER_BLOCK and
|
// TODO: this is calculated as MAX_REQUEST_BLOCKS_DENEB * MAX_BLOBS_PER_BLOCK and
|
||||||
// MAX_BLOBS_PER_BLOCK comes from the spec.
|
// MAX_BLOBS_PER_BLOCK comes from the spec.
|
||||||
// MAX_REQUEST_BLOCKS_DENEB = 128
|
// MAX_REQUEST_BLOCKS_DENEB = 128
|
||||||
// MAX_BLOBS_PER_BLOCK = 4
|
// MAX_BLOBS_PER_BLOCK = 6
|
||||||
pub type MaxRequestBlobSidecars = U512;
|
pub type MaxRequestBlobSidecars = U768;
|
||||||
pub const MAX_REQUEST_BLOB_SIDECARS: u64 = 512;
|
pub const MAX_REQUEST_BLOB_SIDECARS: u64 = 768;
|
||||||
|
|
||||||
/// Wrapper over SSZ List to represent error message in rpc responses.
|
/// Wrapper over SSZ List to represent error message in rpc responses.
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone)]
|
||||||
|
@ -43,7 +43,8 @@ use std::{
|
|||||||
};
|
};
|
||||||
use types::ForkName;
|
use types::ForkName;
|
||||||
use types::{
|
use types::{
|
||||||
consts::altair::SYNC_COMMITTEE_SUBNET_COUNT, EnrForkId, EthSpec, ForkContext, Slot, SubnetId,
|
consts::altair::SYNC_COMMITTEE_SUBNET_COUNT, consts::deneb::BLOB_SIDECAR_SUBNET_COUNT,
|
||||||
|
EnrForkId, EthSpec, ForkContext, Slot, SubnetId,
|
||||||
};
|
};
|
||||||
use utils::{build_transport, strip_peer_id, Context as ServiceContext, MAX_CONNECTIONS_PER_PEER};
|
use utils::{build_transport, strip_peer_id, Context as ServiceContext, MAX_CONNECTIONS_PER_PEER};
|
||||||
|
|
||||||
@ -236,10 +237,11 @@ impl<AppReqId: ReqId, TSpec: EthSpec> Network<AppReqId, TSpec> {
|
|||||||
possible_fork_digests,
|
possible_fork_digests,
|
||||||
ctx.chain_spec.attestation_subnet_count,
|
ctx.chain_spec.attestation_subnet_count,
|
||||||
SYNC_COMMITTEE_SUBNET_COUNT,
|
SYNC_COMMITTEE_SUBNET_COUNT,
|
||||||
4, // TODO(pawan): get this from chainspec
|
BLOB_SIDECAR_SUBNET_COUNT,
|
||||||
),
|
),
|
||||||
max_subscribed_topics: 200,
|
max_subscribed_topics: 200,
|
||||||
max_subscriptions_per_request: 150, // 148 in theory = (64 attestation + 4 sync committee + 6 core topics) * 2
|
// 162 in theory = (64 attestation + 4 sync committee + 7 core topics + 6 blob topics) * 2
|
||||||
|
max_subscriptions_per_request: 160,
|
||||||
};
|
};
|
||||||
|
|
||||||
config.gs_config = gossipsub_config(config.network_load, ctx.fork_context.clone());
|
config.gs_config = gossipsub_config(config.network_load, ctx.fork_context.clone());
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
use libp2p::gossipsub::{IdentTopic as Topic, TopicHash};
|
use libp2p::gossipsub::{IdentTopic as Topic, TopicHash};
|
||||||
use serde_derive::{Deserialize, Serialize};
|
use serde_derive::{Deserialize, Serialize};
|
||||||
use strum::AsRefStr;
|
use strum::AsRefStr;
|
||||||
|
use types::consts::deneb::BLOB_SIDECAR_SUBNET_COUNT;
|
||||||
use types::{EthSpec, ForkName, SubnetId, SyncSubnetId};
|
use types::{EthSpec, ForkName, SubnetId, SyncSubnetId};
|
||||||
|
|
||||||
use crate::Subnet;
|
use crate::Subnet;
|
||||||
@ -52,8 +53,8 @@ pub fn fork_core_topics<T: EthSpec>(fork_name: &ForkName) -> Vec<GossipKind> {
|
|||||||
ForkName::Deneb => {
|
ForkName::Deneb => {
|
||||||
// All of deneb blob topics are core topics
|
// All of deneb blob topics are core topics
|
||||||
let mut deneb_blob_topics = Vec::new();
|
let mut deneb_blob_topics = Vec::new();
|
||||||
for i in 0..T::max_blobs_per_block() {
|
for i in 0..BLOB_SIDECAR_SUBNET_COUNT {
|
||||||
deneb_blob_topics.push(GossipKind::BlobSidecar(i as u64));
|
deneb_blob_topics.push(GossipKind::BlobSidecar(i));
|
||||||
}
|
}
|
||||||
let mut deneb_topics = DENEB_CORE_TOPICS.to_vec();
|
let mut deneb_topics = DENEB_CORE_TOPICS.to_vec();
|
||||||
deneb_topics.append(&mut deneb_blob_topics);
|
deneb_topics.append(&mut deneb_blob_topics);
|
||||||
|
@ -36,4 +36,5 @@ pub mod deneb {
|
|||||||
}
|
}
|
||||||
pub const BLOB_TX_TYPE: u8 = 3;
|
pub const BLOB_TX_TYPE: u8 = 3;
|
||||||
pub const VERSIONED_HASH_VERSION_KZG: u8 = 1;
|
pub const VERSIONED_HASH_VERSION_KZG: u8 = 1;
|
||||||
|
pub const BLOB_SIDECAR_SUBNET_COUNT: u64 = 6;
|
||||||
}
|
}
|
||||||
|
@ -4,7 +4,7 @@ use safe_arith::SafeArith;
|
|||||||
use serde_derive::{Deserialize, Serialize};
|
use serde_derive::{Deserialize, Serialize};
|
||||||
use ssz_types::typenum::{
|
use ssz_types::typenum::{
|
||||||
bit::B0, UInt, Unsigned, U0, U1024, U1048576, U1073741824, U1099511627776, U128, U131072, U16,
|
bit::B0, UInt, Unsigned, U0, U1024, U1048576, U1073741824, U1099511627776, U128, U131072, U16,
|
||||||
U16777216, U2, U2048, U256, U32, U4, U4096, U512, U625, U64, U65536, U8, U8192,
|
U16777216, U2, U2048, U256, U32, U4, U4096, U512, U6, U625, U64, U65536, U8, U8192,
|
||||||
};
|
};
|
||||||
use std::fmt::{self, Debug};
|
use std::fmt::{self, Debug};
|
||||||
use std::str::FromStr;
|
use std::str::FromStr;
|
||||||
@ -294,7 +294,7 @@ impl EthSpec for MainnetEthSpec {
|
|||||||
type GasLimitDenominator = U1024;
|
type GasLimitDenominator = U1024;
|
||||||
type MinGasLimit = U5000;
|
type MinGasLimit = U5000;
|
||||||
type MaxExtraDataBytes = U32;
|
type MaxExtraDataBytes = U32;
|
||||||
type MaxBlobsPerBlock = U4;
|
type MaxBlobsPerBlock = U6;
|
||||||
type BytesPerFieldElement = U32;
|
type BytesPerFieldElement = U32;
|
||||||
type FieldElementsPerBlob = U4096;
|
type FieldElementsPerBlob = U4096;
|
||||||
type BytesPerBlob = U131072;
|
type BytesPerBlob = U131072;
|
||||||
@ -398,7 +398,7 @@ impl EthSpec for GnosisEthSpec {
|
|||||||
type SlotsPerEth1VotingPeriod = U1024; // 64 epochs * 16 slots per epoch
|
type SlotsPerEth1VotingPeriod = U1024; // 64 epochs * 16 slots per epoch
|
||||||
type MaxBlsToExecutionChanges = U16;
|
type MaxBlsToExecutionChanges = U16;
|
||||||
type MaxWithdrawalsPerPayload = U8;
|
type MaxWithdrawalsPerPayload = U8;
|
||||||
type MaxBlobsPerBlock = U4;
|
type MaxBlobsPerBlock = U6;
|
||||||
type FieldElementsPerBlob = U4096;
|
type FieldElementsPerBlob = U4096;
|
||||||
type BytesPerFieldElement = U32;
|
type BytesPerFieldElement = U32;
|
||||||
type BytesPerBlob = U131072;
|
type BytesPerBlob = U131072;
|
||||||
|
Loading…
Reference in New Issue
Block a user