Skip to main content

cloud_hypervisor_client/models/
cpus_config.rs

1/*
2 * Cloud Hypervisor API
3 *
4 * Local HTTP based API for managing and inspecting a cloud-hypervisor virtual machine.
5 *
6 * The version of the OpenAPI document: 0.3.0
7 *
8 * Generated by: https://openapi-generator.tech
9 */
10
11use crate::models;
12use serde::{Deserialize, Serialize};
13
14#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
15pub struct CpusConfig {
16    #[serde(rename = "boot_vcpus")]
17    pub boot_vcpus: i32,
18    #[serde(rename = "max_vcpus")]
19    pub max_vcpus: i32,
20    #[serde(rename = "topology", skip_serializing_if = "Option::is_none")]
21    pub topology: Option<models::CpuTopology>,
22    #[serde(rename = "kvm_hyperv", skip_serializing_if = "Option::is_none")]
23    pub kvm_hyperv: Option<bool>,
24    #[serde(rename = "max_phys_bits", skip_serializing_if = "Option::is_none")]
25    pub max_phys_bits: Option<i32>,
26    #[serde(rename = "nested", skip_serializing_if = "Option::is_none")]
27    pub nested: Option<bool>,
28    #[serde(rename = "affinity", skip_serializing_if = "Option::is_none")]
29    pub affinity: Option<Vec<models::CpuAffinity>>,
30    #[serde(rename = "features", skip_serializing_if = "Option::is_none")]
31    pub features: Option<models::CpuFeatures>,
32    #[serde(rename = "core_scheduling", skip_serializing_if = "Option::is_none")]
33    pub core_scheduling: Option<models::CoreSchedulingMode>,
34}
35
36impl CpusConfig {
37    pub fn new(boot_vcpus: i32, max_vcpus: i32) -> CpusConfig {
38        CpusConfig {
39            boot_vcpus,
40            max_vcpus,
41            topology: None,
42            kvm_hyperv: None,
43            max_phys_bits: None,
44            nested: None,
45            affinity: None,
46            features: None,
47            core_scheduling: None,
48        }
49    }
50}