mirror of
https://github.com/OpenNebula/one.git
synced 2025-01-21 18:03:38 +03:00
907f26050f
- SHORT_ADDRESS can be used to select specific devices (useful on homogenous clusters or nic attach operations). This name has been selected because of: 1. It is the attrbute shown host info 2. It does not collide with the reserved ADDRESS attribute - New test and add functions that considers both allocation methods: by name (VENDOR/CLASS/DEVICE) or address (SHORT_ADDRESS) - Parameter check on VM creation - revert and add method use the same pci_attribute function to add info to the VM PCI attribute - Remove well-known attributes when parsing PCI devices (ADDRESS, PREV_ADDRES, BUS, FUNCTION, SLOT, NUMA_NODE, UUID) - Support for attach and detach NIC with PCI attributes * onevm_exec.rb looks for PCI devices for ATTACH=YES when attaching/detaching an interface * script action are now written in Ruby * KVM module with common actions (hostdev/interface device str) * Minor changes in xmlparser and OpenNebulaVM classes - PCI selection options to onevm nic-attach: * pci short_address * pci_device device ID * pci_vendor vendor ID * pci_class class ID - VF can be configured by setting some parameters through IP link (e.g. MAC or VLAN_ID). This commit includes a mixin to activate_vf. * one_vmm_exec.rb looks for PCI VN_MAD drivers * VM class (VNM) adds a @pcis array * activate_vf should be called in the pre stage. The following drivers acticate VFs (VLAN_ID is implemented as 802.1Q tag) - 802.1Q - bridge - fw - ovswitch - Improve integration with Libvirt/QEMU: * When attach, only activate the VF being attached * Attach: Use <interface> and not <hostdev> for VF. There seems to be a race condition between accessing the vfio device and permission setup. * Attach: Remove address on attach as it may fail beacuse PCI controller is not present, e.g.: ATTACHNIC: Could not attach NIC to 28534240: error: Failed to attach device from /dev/fd/63 error: XML error: Invalid PCI address 0000:01:01.0. Only PCI buses up to 0 are available ExitCode: 1 * Detach: Detach always use <hostdev> as libvirt fails to identified the device just by address when using <interface>
216 lines
6.8 KiB
C++
216 lines
6.8 KiB
C++
/* ------------------------------------------------------------------------ */
|
|
/* Copyright 2002-2022, OpenNebula Project, OpenNebula Systems */
|
|
/* */
|
|
/* Licensed under the Apache License, Version 2.0 (the "License"); you may */
|
|
/* not use this file except in compliance with the License. You may obtain */
|
|
/* a copy of the License at */
|
|
/* */
|
|
/* http://www.apache.org/licenses/LICENSE-2.0 */
|
|
/* */
|
|
/* Unless required by applicable law or agreed to in writing, software */
|
|
/* distributed under the License is distributed on an "AS IS" BASIS, */
|
|
/* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. */
|
|
/* See the License for the specific language governing permissions and */
|
|
/* limitations under the License. */
|
|
/* ------------------------------------------------------------------------ */
|
|
|
|
#ifndef HOST_SHARE_H_
|
|
#define HOST_SHARE_H_
|
|
|
|
#include "ObjectXML.h"
|
|
#include "Template.h"
|
|
|
|
#include "HostSharePCI.h"
|
|
#include "HostShareNUMA.h"
|
|
#include "HostShareDatastore.h"
|
|
#include "HostShareCapacity.h"
|
|
|
|
/* -------------------------------------------------------------------------- */
|
|
/* -------------------------------------------------------------------------- */
|
|
|
|
/**
|
|
* The HostShare class. It represents a logical partition of a host...
|
|
*/
|
|
class HostShare : public ObjectXML
|
|
{
|
|
public:
|
|
HostShare();
|
|
|
|
~HostShare(){};
|
|
|
|
/**
|
|
* Pin policy for the host
|
|
*/
|
|
enum PinPolicy
|
|
{
|
|
PP_NONE = 0, /**< No pin. Default. */
|
|
PP_CORE = 1, /**< vCPUs are assigned to host cores exclusively */
|
|
PP_THREAD = 2, /**< vCPUS are assigned to host threads */
|
|
PP_SHARED = 3 /**< vCPUs are assigned to a set of host threads */
|
|
};
|
|
|
|
static PinPolicy str_to_pin_policy(std::string& pp_s);
|
|
|
|
/**
|
|
* Rebuilds the object from an xml node
|
|
* @param node The xml node pointer
|
|
*
|
|
* @return 0 on success, -1 otherwise
|
|
*/
|
|
int from_xml_node(const xmlNodePtr node);
|
|
|
|
/**
|
|
* Add a VM capacity to this share
|
|
* @param sr requested capacity by the VM
|
|
*/
|
|
void add(HostShareCapacity &sr);
|
|
|
|
bool add_pci(HostShareCapacity &sr)
|
|
{
|
|
// NOTE THIS FUNCTION DOES NOT PERFORM ANY ROLLBACK
|
|
return pci.add(sr.pci, sr.vmid);
|
|
}
|
|
|
|
/**
|
|
* Delete VM capacity from this share
|
|
* @param sr requested capacity by the VM
|
|
*/
|
|
void del(HostShareCapacity &sr);
|
|
|
|
void del_pci(HostShareCapacity &sr)
|
|
{
|
|
pci.del(sr.pci, sr.vmid);
|
|
}
|
|
|
|
/**
|
|
* Revert changes in PCI Devices
|
|
* @param sr capacity info by the VM
|
|
*/
|
|
void revert_pci(HostShareCapacity &sr);
|
|
|
|
/**
|
|
* Check if this share can host a VM.
|
|
* @param cpu requested by the VM
|
|
* @param mem requested by the VM
|
|
* @param disk requested by the VM
|
|
* @param pci_devs requested by the VM
|
|
* @param error Returns the error reason, if any
|
|
*
|
|
* @return true if the share can host the VM or it is the only one
|
|
* configured
|
|
*/
|
|
bool test(HostShareCapacity& sr, std::string& error) const;
|
|
|
|
/**
|
|
* Function to write a HostShare to an output stream
|
|
*/
|
|
friend std::ostream& operator<<(std::ostream& os, const HostShare& hs);
|
|
|
|
/**
|
|
* Function to print the HostShare object into a string in
|
|
* XML format
|
|
* @param xml the resulting XML string
|
|
* @return a reference to the generated string
|
|
*/
|
|
std::string& to_xml(std::string& xml) const;
|
|
|
|
/**
|
|
* Set the capacity attributes of the share. CPU and Memory may reserve some
|
|
* capacity according to RESERVED_CPU and RESERVED_MEM. These values can be
|
|
* either absolute or a percentage.
|
|
*
|
|
* The function also set the PCI, NUMA and datastore information.
|
|
*
|
|
* Share values are read from the Host template returned by the monitoring
|
|
* probes. The values are removed from the template.
|
|
*
|
|
* @param ht template for the host
|
|
* @param rcpu, reserved cpu for the host
|
|
* @param rmem, reserved mem for the host
|
|
*
|
|
* NOTE: reserved strings will be modified
|
|
*/
|
|
void set_monitorization(Template& ht, std::string& rcpu, std::string& rmem);
|
|
|
|
|
|
/**
|
|
* Set the capacity attributes of the share.
|
|
* Same as the 3 parameter method, except it does not update reserved CPU and Memory
|
|
*/
|
|
void set_monitorization(Template& ht);
|
|
|
|
/**
|
|
* Resets capaity values of the share
|
|
*/
|
|
void reset_capacity()
|
|
{
|
|
total_cpu = 0;
|
|
total_mem = 0;
|
|
|
|
max_cpu = 0;
|
|
max_mem = 0;
|
|
};
|
|
|
|
/**
|
|
* Update the capacity attributes when the RESERVED_CPU and RESERVED_MEM
|
|
* are updated. This function also updates VMS_THREAD and ISOLCPUS
|
|
* @param ht, host template
|
|
* @para rcpu, reserved cpu for the host
|
|
* @para rmem, reserved mem for the host
|
|
*
|
|
* NOTE: reserved strings will be modified
|
|
*/
|
|
void update_capacity(Template& ht, std::string& rcpu, std::string& rmem);
|
|
|
|
/**
|
|
* Return the number of running VMs in this host
|
|
*/
|
|
long long get_running_vms() const
|
|
{
|
|
return running_vms;
|
|
};
|
|
|
|
long long get_total_mem() const { return total_mem; }
|
|
long long get_total_cpu() const { return total_cpu; }
|
|
|
|
long long get_max_mem() const { return max_mem; }
|
|
long long get_max_cpu() const { return max_cpu; }
|
|
|
|
private:
|
|
|
|
long long mem_usage; /**< Memory allocated to VMs (in KB) */
|
|
long long cpu_usage; /**< CPU allocated to VMs (in percentage) */
|
|
|
|
long long total_mem; /**< Total memory capacity (in KB) */
|
|
long long total_cpu; /**< Total cpu capacity (in percentage) */
|
|
|
|
long long max_mem; /**< Total memory capacity (in KB) +/- reserved */
|
|
long long max_cpu; /**< Total cpu capacity (in percentage) +/- reserved*/
|
|
|
|
long long running_vms;/**< Number of running VMs in this Host */
|
|
|
|
unsigned int vms_thread; /**< VMs that can be allocated to a thread */
|
|
|
|
HostShareDatastore ds;
|
|
|
|
HostSharePCI pci;
|
|
|
|
HostShareNUMA numa;
|
|
|
|
/**
|
|
* Check if this share can host a VM, testing only the PCI devices.
|
|
* @param pci_devs requested by the VM
|
|
* @param error Returns the error reason, if any
|
|
*
|
|
* @return true if the share can host the VM or it is the only one
|
|
* configured
|
|
*/
|
|
bool test_compute(int cpu, long long mem, std::string &error) const;
|
|
|
|
bool test_pci(std::vector<VectorAttribute *>& pci_devs, std::string& error) const;
|
|
|
|
bool test_numa(HostShareCapacity &sr, std::string& error) const;
|
|
};
|
|
|
|
#endif /*HOST_SHARE_H_*/
|