use crate::sharded_cache::{ShardedCache, UnitWeighter};
use alloc::sync::Arc;
use crate::{GlobalTableId, fs::FsFile};
const TAG_BLOCK: u8 = 0;
const TAG_BLOB: u8 = 1;
type Item = Arc<dyn FsFile>;
#[derive(Clone, Copy, Eq, core::hash::Hash, PartialEq)]
struct CacheKey(u8, u64, u64);
const FD_CACHE_SHARDS: usize = 16;
pub struct DescriptorTable {
inner: ShardedCache<CacheKey, Item, UnitWeighter, rustc_hash::FxBuildHasher>,
}
impl DescriptorTable {
#[must_use]
pub fn new(capacity: usize) -> Self {
let inner = ShardedCache::with_weighter(
capacity as u64,
FD_CACHE_SHARDS,
capacity,
UnitWeighter,
rustc_hash::FxBuildHasher,
);
Self { inner }
}
pub(crate) fn len(&self) -> usize {
self.inner.len()
}
#[must_use]
pub fn access_for_table(&self, id: &GlobalTableId) -> Option<Arc<dyn FsFile>> {
let key = CacheKey(TAG_BLOCK, id.tree_id(), id.table_id());
self.inner.get(&key)
}
pub fn insert_for_table(&self, id: GlobalTableId, item: Item) {
let key = CacheKey(TAG_BLOCK, id.tree_id(), id.table_id());
self.inner.insert(key, item);
}
#[must_use]
pub fn access_for_blob_file(&self, id: &GlobalTableId) -> Option<Arc<dyn FsFile>> {
let key = CacheKey(TAG_BLOB, id.tree_id(), id.table_id());
self.inner.get(&key)
}
pub fn insert_for_blob_file(&self, id: GlobalTableId, item: Item) {
let key = CacheKey(TAG_BLOB, id.tree_id(), id.table_id());
self.inner.insert(key, item);
}
pub fn remove_for_table(&self, id: &GlobalTableId) {
let key = CacheKey(TAG_BLOCK, id.tree_id(), id.table_id());
self.inner.remove(&key);
}
pub fn remove_for_blob_file(&self, id: &GlobalTableId) {
let key = CacheKey(TAG_BLOB, id.tree_id(), id.table_id());
self.inner.remove(&key);
}
}