storage_benchmarks/block_device.rs
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50
// Copyright 2022 The Fuchsia Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
use async_trait::async_trait;
use fidl_fuchsia_io as fio;
#[cfg(target_os = "fuchsia")]
use fs_management::filesystem::BlockConnector;
/// Block device configuration options.
pub struct BlockDeviceConfig {
/// If true, zxcrypt is initialized on top of the block device.
pub use_zxcrypt: bool,
/// For filesystem that are not FVM-aware, this option can be used to pre-allocate space inside
/// of the FVM volume.
pub fvm_volume_size: Option<u64>,
}
/// A trait representing a block device.
pub trait BlockDevice: Send + Sync {
fn dir(&self) -> &fio::DirectoryProxy;
#[cfg(target_os = "fuchsia")]
fn connector(&self) -> Box<dyn BlockConnector>;
}
/// A trait for constructing block devices.
#[async_trait]
pub trait BlockDeviceFactory: Send + Sync {
/// Constructs a new block device.
async fn create_block_device(&self, config: &BlockDeviceConfig) -> Box<dyn BlockDevice>;
}
/// A BlockDeviceFactory that panics when trying to create a block device. This is useful for
/// benchmarking filesystems that don't need to create a block device.
pub struct PanickingBlockDeviceFactory {}
impl PanickingBlockDeviceFactory {
pub fn new() -> Self {
Self {}
}
}
#[async_trait]
impl BlockDeviceFactory for PanickingBlockDeviceFactory {
async fn create_block_device(&self, _config: &BlockDeviceConfig) -> Box<dyn BlockDevice> {
panic!("PanickingBlockDeviceFactory can't create block devices");
}
}