mirror of
https://github.com/cloud-hypervisor/cloud-hypervisor.git
synced 2025-01-05 12:25:19 +00:00
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:
parent
7c3582b4a8
commit
55c5961f43
@ -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
|
||||||
|
@ -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(())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user