2010-04-27 19:42:37 +04:00
/* ------------------------------------------------------------------------ */
2015-02-24 14:27:59 +03:00
/* Copyright 2002-2015, OpenNebula Project (OpenNebula.org), C12G Labs */
2010-04-27 19:42:37 +04:00
/* */
/* 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. */
/* ------------------------------------------------------------------------ */
2008-06-17 20:27:32 +04:00
# ifndef HOST_SHARE_H_
# define HOST_SHARE_H_
2011-02-24 20:12:26 +03:00
# include "ObjectXML.h"
2013-10-22 17:42:51 +04:00
# include "Template.h"
2008-06-17 20:27:32 +04:00
# include <time.h>
2015-08-20 18:39:56 +03:00
# include <set>
2008-06-17 20:27:32 +04:00
2010-04-27 19:42:37 +04:00
/* ------------------------------------------------------------------------ */
/* ------------------------------------------------------------------------ */
2008-06-17 20:27:32 +04:00
2015-08-20 18:39:56 +03:00
class HostShareDatastore : public Template
2013-10-22 17:42:51 +04:00
{
public :
2015-08-21 00:22:02 +03:00
HostShareDatastore ( ) : Template ( false , ' = ' , " DATASTORES " ) { } ;
2013-10-22 17:42:51 +04:00
2015-08-20 18:39:56 +03:00
virtual ~ HostShareDatastore ( ) { } ;
2013-10-22 17:42:51 +04:00
} ;
2015-08-20 18:39:56 +03:00
/**
* This class represents a PCI DEVICE list for the host . The list is in the
* form :
* < PCI >
2015-08-22 18:00:55 +03:00
* < DOMAIN > PCI address domain
* < BUS > PCI address bus
* < SLOT > PCI address slot
* < FUNCTION > PCI address function
* < ADDRESS > PCI address , bus , slot and function
* < VENDOR > ID of PCI device vendor
* < DEVICE > ID of PCI device
* < CLASS > ID of PCI device class
* < VMID > ID using this device , - 1 if free
*
* The monitor probe may report additional information such as VENDOR_NAME ,
* DEVICE_NAME , CLASS_NAME . . .
2015-08-20 18:39:56 +03:00
*/
class HostSharePCI : public Template
{
public :
HostSharePCI ( ) : Template ( false , ' = ' , " PCI_DEVICES " ) { } ;
virtual ~ HostSharePCI ( )
{
map < string , PCIDevice * > : : iterator it ;
for ( it = pci_devices . begin ( ) ; it ! = pci_devices . end ( ) ; it + + )
{
delete it - > second ;
} ;
} ;
/**
* Builds the devices list from its XML representation . This function
* is used when importing it from the DB .
* @ param node xmlNode for the template
* @ return 0 on success
*/
int from_xml_node ( const xmlNodePtr node ) ;
/**
2015-08-26 13:34:27 +03:00
* Test whether this PCI device set has the requested devices available .
2015-08-20 18:39:56 +03:00
* @ param devs list of requested devices by the VM .
* @ return true if all the devices are available .
*/
2015-08-27 17:19:58 +03:00
bool test ( const vector < Attribute * > & devs ) const ;
2015-08-20 18:39:56 +03:00
/**
2015-08-26 13:34:27 +03:00
* Assign the requested devices to the given VM . The assigned devices will
2015-08-20 18:39:56 +03:00
* be labeled with the VM and the PCI attribute of the VM extended with
* the address of the assigned devices .
* @ param devs list of requested PCI devices , will include address of
2015-08-26 13:34:27 +03:00
* assigned devices .
2015-08-20 18:39:56 +03:00
* @ param vmid of the VM
*/
2015-08-27 17:19:58 +03:00
void add ( vector < Attribute * > & devs , int vmid ) ;
2015-08-20 18:39:56 +03:00
/**
2015-08-26 13:34:27 +03:00
* Remove the VM assignment from the PCI device list
2015-08-20 18:39:56 +03:00
*/
void del ( const vector < Attribute * > & devs ) ;
/**
* Updates the PCI list with monitor data , it will create or
* remove PCIDevices as needed .
*/
void set_monitorization ( vector < Attribute * > & pci_att ) ;
2015-08-21 14:46:10 +03:00
/**
* Prints the PCI device list to an output stream . This function is used
* for logging purposes and * not * for generating DB content .
*/
friend ostream & operator < < ( ostream & o , const HostSharePCI & p ) ;
2015-08-20 18:39:56 +03:00
private :
/**
* Sets the internal class structures from the template
*/
int init ( ) ;
/**
* Gets a 4 hex digits value from attribute
* @ param name of the attribute
* @ pci_device VectorAttribute representing the device
* @ return the value as unsigned int or 0 if was not found
*/
static unsigned int get_pci_value ( const char * name ,
const VectorAttribute * pci_device ) ;
/**
* Internal structure to represent PCI devices for fast look up and
* update
*/
struct PCIDevice
{
PCIDevice ( VectorAttribute * _attrs ) ;
~ PCIDevice ( ) { } ;
unsigned int vendor_id ;
unsigned int device_id ;
unsigned int class_id ;
int vmid ;
string address ;
VectorAttribute * attrs ;
} ;
map < string , PCIDevice * > pci_devices ;
} ;
2013-10-22 17:42:51 +04:00
2008-06-17 20:27:32 +04:00
/**
* The HostShare class . It represents a logical partition of a host . . .
*/
2011-02-24 20:12:26 +03:00
class HostShare : public ObjectXML
2008-06-17 20:27:32 +04:00
{
public :
HostShare (
2013-10-02 00:34:22 +04:00
long long _max_disk = 0 ,
long long _max_mem = 0 ,
long long _max_cpu = 0 ) ;
2008-06-17 20:27:32 +04:00
~ HostShare ( ) { } ;
/**
* Add a new VM to this share
2015-08-21 02:08:28 +03:00
* @ param vmid of the VM
2012-07-12 14:48:27 +04:00
* @ param cpu requested by the VM , in percentage
* @ param mem requested by the VM , in KB
2008-06-17 20:27:32 +04:00
* @ param disk requested by the VM
2015-08-21 02:08:28 +03:00
* @ param pci_devs requested by the VM
2008-06-17 20:27:32 +04:00
*/
2015-08-21 02:08:28 +03:00
void add ( int vmid , long long cpu , long long mem , long long disk ,
vector < Attribute * > pci_devs )
2008-06-17 20:27:32 +04:00
{
cpu_usage + = cpu ;
mem_usage + = mem ;
disk_usage + = disk ;
2010-04-04 03:12:52 +04:00
2015-08-21 02:08:28 +03:00
pci . add ( pci_devs , vmid ) ;
2009-07-14 20:40:33 +04:00
running_vms + + ;
2008-06-17 20:27:32 +04:00
}
2013-02-23 22:49:06 +04:00
/**
* Updates the capacity of VM in this share
* @ param cpu increment
* @ param mem increment
* @ param disk increment
*/
void update ( int cpu , int mem , int disk )
{
cpu_usage + = cpu ;
mem_usage + = mem ;
disk_usage + = disk ;
}
2008-06-17 20:27:32 +04:00
/**
* Delete a VM from this share
* @ param cpu requested by the VM
* @ param mem requested by the VM
* @ param disk requested by the VM
2015-08-21 13:00:19 +03:00
* @ param pci_devs requested by the VM
2008-06-17 20:27:32 +04:00
*/
2015-08-21 13:00:19 +03:00
void del ( long long cpu , long long mem , long long disk , vector < Attribute * > pci_devs )
2008-06-17 20:27:32 +04:00
{
cpu_usage - = cpu ;
mem_usage - = mem ;
disk_usage - = disk ;
2010-04-04 03:12:52 +04:00
2015-08-21 13:00:19 +03:00
pci . del ( pci_devs ) ;
2010-04-04 03:12:52 +04:00
running_vms - - ;
2008-06-17 20:27:32 +04:00
}
2010-04-04 03:12:52 +04:00
2008-06-17 20:27:32 +04:00
/**
2010-04-04 03:12:52 +04:00
* Check if this share can host a VM .
2008-06-17 20:27:32 +04:00
* @ param cpu requested by the VM
* @ param mem requested by the VM
* @ param disk requested by the VM
2015-08-26 13:34:27 +03:00
* @ param pci_devs requested by the VM
* @ param error Returns the error reason , if any
2010-04-04 03:12:52 +04:00
*
* @ return true if the share can host the VM or it is the only one
2008-06-17 20:27:32 +04:00
* configured
*/
2015-08-26 13:34:27 +03:00
bool test ( long long cpu , long long mem , long long disk ,
vector < Attribute * > & pci_devs , string & error ) const
2008-06-17 20:27:32 +04:00
{
2015-08-26 13:34:27 +03:00
bool pci_fits = pci . test ( pci_devs ) ;
bool fits = ( ( ( max_cpu - cpu_usage ) > = cpu ) & &
( ( max_mem - mem_usage ) > = mem ) & &
( ( max_disk - disk_usage ) > = disk ) & &
pci_fits ) ;
if ( ! fits )
{
if ( pci_fits )
{
error = " Not enough capacity. " ;
}
else
{
error = " Unavailable PCI device. " ;
}
}
return fits ;
2010-04-04 03:12:52 +04:00
}
2008-06-17 20:27:32 +04:00
/**
* Function to write a HostShare to an output stream
*/
friend ostream & operator < < ( ostream & os , HostShare & hs ) ;
/**
2009-07-09 18:34:34 +04:00
* 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
2008-06-17 20:27:32 +04:00
*/
2009-07-09 18:34:34 +04:00
string & to_xml ( string & xml ) const ;
2010-04-04 03:12:52 +04:00
2013-10-22 17:42:51 +04:00
void set_ds_monitorization ( const vector < Attribute * > & ds_att ) ;
2015-08-20 18:39:56 +03:00
void set_pci_monitorization ( vector < Attribute * > & pci_att )
{
pci . set_monitorization ( pci_att ) ;
}
2015-08-18 00:14:15 +03:00
2009-07-09 18:34:34 +04:00
private :
2008-06-17 20:27:32 +04:00
2013-10-22 17:42:51 +04:00
long long disk_usage ; /**< Disk allocated to VMs (in MB). */
2013-10-02 00:34:22 +04:00
long long mem_usage ; /**< Memory allocated to VMs (in KB) */
long long cpu_usage ; /**< CPU allocated to VMs (in percentage) */
2010-04-04 03:12:52 +04:00
2013-10-22 17:42:51 +04:00
long long max_disk ; /**< Total disk capacity (in MB) */
2013-10-02 00:34:22 +04:00
long long max_mem ; /**< Total memory capacity (in KB) */
long long max_cpu ; /**< Total cpu capacity (in percentage) */
2008-06-17 20:27:32 +04:00
2013-10-02 00:34:22 +04:00
long long free_disk ; /**< Free disk from the IM monitor */
long long free_mem ; /**< Free memory from the IM monitor */
long long free_cpu ; /**< Free cpu from the IM monitor */
2008-06-17 20:27:32 +04:00
2013-10-02 00:34:22 +04:00
long long used_disk ; /**< Used disk from the IM monitor */
long long used_mem ; /**< Used memory from the IM monitor */
long long used_cpu ; /**< Used cpu from the IM monitor */
2008-06-17 20:27:32 +04:00
2013-10-02 00:34:22 +04:00
long long running_vms ; /**< Number of running VMs in this Host */
2010-04-04 03:12:52 +04:00
2015-08-20 18:39:56 +03:00
HostShareDatastore ds ;
HostSharePCI pci ;
2013-10-22 17:42:51 +04:00
2008-06-17 20:27:32 +04:00
// ----------------------------------------
// Friends
// ----------------------------------------
friend class Host ;
2010-04-04 03:12:52 +04:00
friend class HostPool ;
2008-06-17 20:27:32 +04:00
/**
2011-02-25 01:30:39 +03:00
* Rebuilds the object from an xml node
* @ param node The xml node pointer
*
* @ return 0 on success , - 1 otherwise
2009-07-09 18:34:34 +04:00
*/
2011-02-25 01:30:39 +03:00
int from_xml_node ( const xmlNodePtr node ) ;
2008-06-17 20:27:32 +04:00
} ;
# endif /*HOST_SHARE_H_*/