2017-01-13 01:56:25 +01:00
/* ------------------------------------------------------------------------ */
2019-01-16 11:27:59 +01:00
/* Copyright 2002-2019, 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
{
std : : set < int > : : iterator it ;
for ( it = roles_id . begin ( ) ; it ! = roles_id . end ( ) ; + + it )
{
if ( * it < VMGroupRoles : : MAX_ROLES )
{
roles [ * it ] = 1 ;
}
}
} ;
2017-01-20 20:46:50 +01:00
VMGroupRule ( VMGroupPolicy p , role_bitset _roles ) : policy ( p ) , roles ( _roles ) { } ;
2017-01-13 01:56:25 +01:00
VMGroupRule ( const VMGroupRule & other )
{
policy = other . policy ;
roles = other . roles ;
}
/* ---------------------------------------------------------------------- */
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_*/