2017-01-13 01:56:25 +01:00
/* ------------------------------------------------------------------------ */
2023-01-09 12:23:19 +01:00
/* Copyright 2002-2023, OpenNebula Project, OpenNebula Systems */
2017-01-13 01:56:25 +01: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. */
/* -------------------------------------------------------------------------*/
# ifndef VMGROUP_RULE_H_
# define VMGROUP_RULE_H_
# include <bitset>
# include "VMGroupRole.h"
struct VMGroupRule_compare ;
2017-01-20 20:46:50 +01:00
/**
* Placement policy rules for roles
* AFFINED : VMs of all roles are placed in the same hypervisor
* ANTI_AFFINED : VMs are placed in different hypervisors ( role - wise )
* NONE : No additional placement constraints
*/
enum class VMGroupPolicy
{
NONE = 0x00 ,
AFFINED = 0x01 ,
ANTI_AFFINED = 0x02
} ;
std : : ostream & operator < < ( std : : ostream & os , VMGroupPolicy policy ) ;
2017-01-13 01:56:25 +01:00
/**
* A rule represents a role placement policy
*/
class VMGroupRule
{
public :
2017-01-13 18:32:37 +01:00
/**
* A specialized set for rules
*/
typedef std : : set < VMGroupRule , VMGroupRule_compare > rule_set ;
2017-01-20 20:46:50 +01:00
typedef std : : bitset < VMGroupRoles : : MAX_ROLES > role_bitset ;
2017-01-13 01:56:25 +01:00
/* ---------------------------------------------------------------------- */
2017-01-13 18:32:37 +01:00
/* Rule Constructors */
2017-01-13 01:56:25 +01:00
/* ---------------------------------------------------------------------- */
2017-01-20 20:46:50 +01:00
VMGroupRule ( ) : policy ( VMGroupPolicy : : NONE ) , roles ( ) { } ;
2017-01-13 01:56:25 +01:00
2017-01-20 20:46:50 +01:00
VMGroupRule ( VMGroupPolicy p , std : : set < int > roles_id ) : policy ( p )
2017-01-13 01:56:25 +01:00
{
2020-09-17 11:10:55 +02:00
for ( auto rid : roles_id )
2017-01-13 01:56:25 +01:00
{
2020-09-17 11:10:55 +02:00
if ( rid < VMGroupRoles : : MAX_ROLES )
2017-01-13 01:56:25 +01:00
{
2020-09-17 11:10:55 +02:00
roles [ rid ] = 1 ;
2017-01-13 01:56:25 +01:00
}
}
} ;
2023-01-31 13:46:09 +01:00
VMGroupRule ( VMGroupPolicy p , const role_bitset & _roles )
: policy ( p )
, roles ( _roles )
{ }
2017-01-13 01:56:25 +01:00
2023-01-31 13:46:09 +01:00
VMGroupRule ( const VMGroupRule & other ) = default ;
2017-01-13 01:56:25 +01:00
/* ---------------------------------------------------------------------- */
2017-01-13 18:32:37 +01:00
/* Rule operators */
2017-01-13 01:56:25 +01:00
/* ---------------------------------------------------------------------- */
VMGroupRule & operator = ( const VMGroupRule & other )
{
if ( this ! = & other )
{
policy = other . policy ;
roles = other . roles ;
}
return * this ;
}
VMGroupRule & operator & = ( const VMGroupRule & other )
{
roles & = other . roles ;
return * this ;
}
2017-01-25 20:08:12 +01:00
VMGroupRule operator & ( const VMGroupRule & other ) const
2017-01-13 01:56:25 +01:00
{
return VMGroupRule ( policy , other . roles & roles ) ;
}
VMGroupRule & operator | = ( const VMGroupRule & other )
{
roles | = other . roles ;
return * this ;
}
2017-01-25 20:08:12 +01:00
VMGroupRule operator | ( const VMGroupRule & other ) const
2017-01-13 01:56:25 +01:00
{
return VMGroupRule ( policy , other . roles | roles ) ;
}
bool none ( )
{
return roles . none ( ) ;
}
2017-01-13 18:32:37 +01:00
/* ---------------------------------------------------------------------- */
/* Rule interface */
/* ---------------------------------------------------------------------- */
/**
* Check if an affined and anti - affined rule set are compatible . Sets are
* compatible if there isn ' t a role in the affined and anti - affined sets
* at the same time
* @ param affined rule set
* @ param anti affined rule set
* @ param err a rule with the roles in both sets
*
* @ return true if sets are compatible
*/
2017-01-13 01:56:25 +01:00
static bool compatible ( rule_set & affined , rule_set & anti , VMGroupRule & err ) ;
2017-01-25 20:08:12 +01:00
/**
* Reduce a set of affinity rules merging rules affecting the same roles
* Example :
* AFFINED = a , b
* AFFINED = b , c - - - - - - - > AFFINED = a , b , c
* AFFINED = e , d AFFINED = e , d
*
* @ param affined set of rules to be reduced
* @ param reduced set
*/
static void reduce ( rule_set affined , rule_set & reduced ) ;
2017-01-13 18:32:37 +01:00
/**
* @ return the roles in the rule as a bitset ( 1 roles is in )
*/
2017-01-20 20:46:50 +01:00
const role_bitset & get_roles ( ) const
2017-01-13 18:32:37 +01:00
{
return roles ;
}
2017-01-20 20:46:50 +01:00
VMGroupPolicy get_policy ( ) const
2017-01-18 00:31:50 +01:00
{
2017-01-20 20:46:50 +01:00
return policy ;
2017-01-18 00:31:50 +01:00
}
2017-01-13 01:56:25 +01:00
private :
friend class VMGroupRule_compare ;
/**
* Type of the rule
*/
2017-01-20 20:46:50 +01:00
VMGroupPolicy policy ;
2017-01-13 01:56:25 +01:00
/**
* Roles participating in the rule
*/
std : : bitset < VMGroupRoles : : MAX_ROLES > roles ;
} ;
2017-01-13 18:32:37 +01:00
/**
* Functor to compre two rules . Two rules are considered equivalent if the
* include the same roles .
*/
2017-01-13 01:56:25 +01:00
struct VMGroupRule_compare
{
bool operator ( ) ( const VMGroupRule & lhs , const VMGroupRule & rhs ) const
{
return lhs . roles . to_ullong ( ) < rhs . roles . to_ullong ( ) ;
}
} ;
# endif /*VMGROUP_RULE_H_*/