vmm: config: Remove dax & cache_size options from FsConfig

Fixes: #3889

Signed-off-by: Rob Bradford <robert.bradford@intel.com>
This commit is contained in:
Rob Bradford 2022-05-26 12:19:36 +01:00 committed by Sebastien Boeuf
parent 7c3582b4a8
commit 55c5961f43
2 changed files with 2 additions and 82 deletions

View File

@ -870,8 +870,6 @@ components:
FsConfig: FsConfig:
required: required:
- cache_size
- dax
- num_queues - num_queues
- queue_size - queue_size
- socket - socket
@ -888,13 +886,6 @@ components:
queue_size: queue_size:
type: integer type: integer
default: 1024 default: 1024
dax:
type: boolean
default: true
cache_size:
type: integer
format: int64
default: 8589934592
pci_segment: pci_segment:
type: integer type: integer
format: int16 format: int16

View File

@ -43,8 +43,6 @@ pub enum Error {
ParseFsTagMissing, ParseFsTagMissing,
/// Filesystem socket is missing /// Filesystem socket is missing
ParseFsSockMissing, ParseFsSockMissing,
/// Cannot have dax=off along with cache_size parameter.
InvalidCacheSizeWithDaxOff,
/// Missing persistent memory file parameter. /// Missing persistent memory file parameter.
ParsePmemFileMissing, ParsePmemFileMissing,
/// Missing vsock socket path parameter. /// Missing vsock socket path parameter.
@ -291,9 +289,6 @@ impl fmt::Display for Error {
ParseFileSystem(o) => write!(f, "Error parsing --fs: {}", o), ParseFileSystem(o) => write!(f, "Error parsing --fs: {}", o),
ParseFsSockMissing => write!(f, "Error parsing --fs: socket missing"), ParseFsSockMissing => write!(f, "Error parsing --fs: socket missing"),
ParseFsTagMissing => write!(f, "Error parsing --fs: tag missing"), ParseFsTagMissing => write!(f, "Error parsing --fs: tag missing"),
InvalidCacheSizeWithDaxOff => {
write!(f, "Error parsing --fs: cache_size used with dax=off")
}
ParsePersistentMemory(o) => write!(f, "Error parsing --pmem: {}", o), ParsePersistentMemory(o) => write!(f, "Error parsing --pmem: {}", o),
ParsePmemFileMissing => write!(f, "Error parsing --pmem: file missing"), ParsePmemFileMissing => write!(f, "Error parsing --pmem: file missing"),
ParseVsock(o) => write!(f, "Error parsing --vsock: {}", o), ParseVsock(o) => write!(f, "Error parsing --vsock: {}", o),
@ -1577,10 +1572,6 @@ pub struct FsConfig {
pub num_queues: usize, pub num_queues: usize,
#[serde(default = "default_fsconfig_queue_size")] #[serde(default = "default_fsconfig_queue_size")]
pub queue_size: u16, pub queue_size: u16,
#[serde(default = "default_fsconfig_dax")]
pub dax: bool,
#[serde(default = "default_fsconfig_cache_size")]
pub cache_size: u64,
#[serde(default)] #[serde(default)]
pub id: Option<String>, pub id: Option<String>,
#[serde(default)] #[serde(default)]
@ -1595,14 +1586,6 @@ fn default_fsconfig_queue_size() -> u16 {
1024 1024
} }
fn default_fsconfig_dax() -> bool {
false
}
fn default_fsconfig_cache_size() -> u64 {
0x0002_0000_0000
}
impl Default for FsConfig { impl Default for FsConfig {
fn default() -> Self { fn default() -> Self {
Self { Self {
@ -1610,8 +1593,6 @@ impl Default for FsConfig {
socket: PathBuf::new(), socket: PathBuf::new(),
num_queues: default_fsconfig_num_queues(), num_queues: default_fsconfig_num_queues(),
queue_size: default_fsconfig_queue_size(), queue_size: default_fsconfig_queue_size(),
dax: default_fsconfig_dax(),
cache_size: default_fsconfig_cache_size(),
id: None, id: None,
pci_segment: 0, pci_segment: 0,
} }
@ -1621,15 +1602,12 @@ impl Default for FsConfig {
impl FsConfig { impl FsConfig {
pub const SYNTAX: &'static str = "virtio-fs parameters \ pub const SYNTAX: &'static str = "virtio-fs parameters \
\"tag=<tag_name>,socket=<socket_path>,num_queues=<number_of_queues>,\ \"tag=<tag_name>,socket=<socket_path>,num_queues=<number_of_queues>,\
queue_size=<size_of_each_queue>,dax=on|off,cache_size=<DAX cache size: \ queue_size=<size_of_each_queue>,id=<device_id>,pci_segment=<segment_id>\"";
default 8Gib>,id=<device_id>,pci_segment=<segment_id>\"";
pub fn parse(fs: &str) -> Result<Self> { pub fn parse(fs: &str) -> Result<Self> {
let mut parser = OptionParser::new(); let mut parser = OptionParser::new();
parser parser
.add("tag") .add("tag")
.add("dax")
.add("cache_size")
.add("queue_size") .add("queue_size")
.add("num_queues") .add("num_queues")
.add("socket") .add("socket")
@ -1649,22 +1627,6 @@ impl FsConfig {
.map_err(Error::ParseFileSystem)? .map_err(Error::ParseFileSystem)?
.unwrap_or_else(default_fsconfig_num_queues); .unwrap_or_else(default_fsconfig_num_queues);
let dax = parser
.convert::<Toggle>("dax")
.map_err(Error::ParseFileSystem)?
.unwrap_or_else(|| Toggle(default_fsconfig_dax()))
.0;
if parser.is_set("cache_size") && !dax {
return Err(Error::InvalidCacheSizeWithDaxOff);
}
let cache_size = parser
.convert::<ByteSized>("cache_size")
.map_err(Error::ParseFileSystem)?
.unwrap_or_else(|| ByteSized(default_fsconfig_cache_size()))
.0;
let id = parser.get("id"); let id = parser.get("id");
let pci_segment = parser let pci_segment = parser
@ -1677,8 +1639,6 @@ impl FsConfig {
socket, socket,
num_queues, num_queues,
queue_size, queue_size,
dax,
cache_size,
id, id,
pci_segment, pci_segment,
}) })
@ -1703,15 +1663,6 @@ impl FsConfig {
} }
} }
if self.dax {
// TODO: Remove the dax parameter.
// Tracked by https://github.com/cloud-hypervisor/cloud-hypervisor/issues/3889
warn!(
"The experimental DAX feature is deprecated and will be \
removed in a future release. A request to enable it is ignored."
);
}
Ok(()) Ok(())
} }
} }
@ -3116,29 +3067,7 @@ mod tests {
..Default::default() ..Default::default()
} }
); );
// DAX on -> default cache size
assert_eq!(
FsConfig::parse("tag=mytag,socket=/tmp/sock,dax=on")?,
FsConfig {
socket: PathBuf::from("/tmp/sock"),
tag: "mytag".to_owned(),
dax: true,
cache_size: default_fsconfig_cache_size(),
..Default::default()
}
);
assert_eq!(
FsConfig::parse("tag=mytag,socket=/tmp/sock,dax=on,cache_size=4G")?,
FsConfig {
socket: PathBuf::from("/tmp/sock"),
tag: "mytag".to_owned(),
dax: true,
cache_size: 4 << 30,
..Default::default()
}
);
// Cache size without DAX is an error
assert!(FsConfig::parse("tag=mytag,socket=/tmp/sock,dax=off,cache_size=4G").is_err());
Ok(()) Ok(())
} }