mirror of
https://github.com/Cuprate/cuprate.git
synced 2025-01-10 21:05:01 +00:00
improve interface globals
This commit is contained in:
parent
403964bc22
commit
783f4260b4
2 changed files with 20 additions and 22 deletions
|
@ -2,13 +2,13 @@
|
||||||
//!
|
//!
|
||||||
//! This module contains all the functions to mutate the blockchain's state in any way, through the
|
//! This module contains all the functions to mutate the blockchain's state in any way, through the
|
||||||
//! blockchain manger.
|
//! blockchain manger.
|
||||||
|
use monero_serai::{block::Block, transaction::Transaction};
|
||||||
|
use rayon::prelude::*;
|
||||||
|
use std::sync::LazyLock;
|
||||||
use std::{
|
use std::{
|
||||||
collections::{HashMap, HashSet},
|
collections::{HashMap, HashSet},
|
||||||
sync::{Mutex, OnceLock},
|
sync::{Mutex, OnceLock},
|
||||||
};
|
};
|
||||||
|
|
||||||
use monero_serai::{block::Block, transaction::Transaction};
|
|
||||||
use rayon::prelude::*;
|
|
||||||
use tokio::sync::{mpsc, oneshot};
|
use tokio::sync::{mpsc, oneshot};
|
||||||
use tower::{Service, ServiceExt};
|
use tower::{Service, ServiceExt};
|
||||||
|
|
||||||
|
@ -25,14 +25,9 @@ use crate::{
|
||||||
};
|
};
|
||||||
|
|
||||||
/// The channel used to send [`BlockchainManagerCommand`]s to the blockchain manger.
|
/// The channel used to send [`BlockchainManagerCommand`]s to the blockchain manger.
|
||||||
pub static COMMAND_TX: OnceLock<mpsc::Sender<BlockchainManagerCommand>> = OnceLock::new();
|
|
||||||
|
|
||||||
/// A [`HashSet`] of block hashes that the blockchain manager is currently handling.
|
|
||||||
///
|
///
|
||||||
/// This is used over something like a dashmap as we expect a lot of collisions in a short amount of
|
/// This channel is initialized in [`init_blockchain_manger`](super::manager::init_blockchain_manger).
|
||||||
/// time for new blocks so we would lose the benefit of sharded locks. A dashmap is made up of `RwLocks`
|
pub(super) static COMMAND_TX: OnceLock<mpsc::Sender<BlockchainManagerCommand>> = OnceLock::new();
|
||||||
/// which are also more expensive than `Mutex`s.
|
|
||||||
pub static BLOCKS_BEING_HANDLED: OnceLock<Mutex<HashSet<[u8; 32]>>> = OnceLock::new();
|
|
||||||
|
|
||||||
/// An error that can be returned from [`handle_incoming_block`].
|
/// An error that can be returned from [`handle_incoming_block`].
|
||||||
#[derive(Debug, thiserror::Error)]
|
#[derive(Debug, thiserror::Error)]
|
||||||
|
@ -68,6 +63,16 @@ pub async fn handle_incoming_block(
|
||||||
given_txs: Vec<Transaction>,
|
given_txs: Vec<Transaction>,
|
||||||
blockchain_read_handle: &mut BlockchainReadHandle,
|
blockchain_read_handle: &mut BlockchainReadHandle,
|
||||||
) -> Result<bool, IncomingBlockError> {
|
) -> Result<bool, IncomingBlockError> {
|
||||||
|
/// A [`HashSet`] of block hashes that the blockchain manager is currently handling.
|
||||||
|
///
|
||||||
|
/// This lock prevents sending the same block to the blockchain manager from multiple connections
|
||||||
|
/// before one of them actually gets added to the chain, allowing peers to do other things.
|
||||||
|
///
|
||||||
|
/// This is used over something like a dashmap as we expect a lot of collisions in a short amount of
|
||||||
|
/// time for new blocks, so we would lose the benefit of sharded locks. A dashmap is made up of `RwLocks`
|
||||||
|
/// which are also more expensive than `Mutex`s.
|
||||||
|
static BLOCKS_BEING_HANDLED: LazyLock<Mutex<HashSet<[u8; 32]>>> =
|
||||||
|
LazyLock::new(|| Mutex::new(HashSet::new()));
|
||||||
// FIXME: we should look in the tx-pool for txs when that is ready.
|
// FIXME: we should look in the tx-pool for txs when that is ready.
|
||||||
|
|
||||||
if !block_exists(block.header.previous, blockchain_read_handle)
|
if !block_exists(block.header.previous, blockchain_read_handle)
|
||||||
|
@ -111,12 +116,7 @@ pub async fn handle_incoming_block(
|
||||||
};
|
};
|
||||||
|
|
||||||
// Add the blocks hash to the blocks being handled.
|
// Add the blocks hash to the blocks being handled.
|
||||||
if !BLOCKS_BEING_HANDLED
|
if !BLOCKS_BEING_HANDLED.lock().unwrap().insert(block_hash) {
|
||||||
.get_or_init(|| Mutex::new(HashSet::new()))
|
|
||||||
.lock()
|
|
||||||
.unwrap()
|
|
||||||
.insert(block_hash)
|
|
||||||
{
|
|
||||||
// If another place is already adding this block then we can stop.
|
// If another place is already adding this block then we can stop.
|
||||||
return Ok(false);
|
return Ok(false);
|
||||||
}
|
}
|
||||||
|
@ -140,12 +140,7 @@ pub async fn handle_incoming_block(
|
||||||
.map_err(IncomingBlockError::InvalidBlock);
|
.map_err(IncomingBlockError::InvalidBlock);
|
||||||
|
|
||||||
// Remove the block hash from the blocks being handled.
|
// Remove the block hash from the blocks being handled.
|
||||||
BLOCKS_BEING_HANDLED
|
BLOCKS_BEING_HANDLED.lock().unwrap().remove(&block_hash);
|
||||||
.get()
|
|
||||||
.unwrap()
|
|
||||||
.lock()
|
|
||||||
.unwrap()
|
|
||||||
.remove(&block_hash);
|
|
||||||
|
|
||||||
res
|
res
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,4 +6,7 @@ use tokio::sync::RwLock;
|
||||||
///
|
///
|
||||||
/// A [`RwLock`] where a write lock is taken during a reorg and a read lock can be taken
|
/// A [`RwLock`] where a write lock is taken during a reorg and a read lock can be taken
|
||||||
/// for any operation which must complete without a reorg happening.
|
/// for any operation which must complete without a reorg happening.
|
||||||
|
///
|
||||||
|
/// Currently, the only operation that needs to take a read lock is adding txs to the tx-pool,
|
||||||
|
/// this can potentially be removed in the future, see: TODO
|
||||||
pub static REORG_LOCK: RwLock<()> = RwLock::const_new(());
|
pub static REORG_LOCK: RwLock<()> = RwLock::const_new(());
|
||||||
|
|
Loading…
Reference in a new issue