2012-01-10 17:31:21 +00:00
/*
* virt - host - validate - lxc . c : Sanity check a LXC hypervisor host
*
* Copyright ( C ) 2012 Red Hat , Inc .
*
* This library is free software ; you can redistribute it and / or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation ; either
* version 2.1 of the License , or ( at your option ) any later version .
*
* This library is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the GNU
* Lesser General Public License for more details .
*
* You should have received a copy of the GNU Lesser General Public
2012-09-20 16:30:55 -06:00
* License along with this library . If not , see
2012-07-21 18:06:23 +08:00
* < http : //www.gnu.org/licenses/>.
2012-01-10 17:31:21 +00:00
*
*/
# include <config.h>
# include "virt-host-validate-lxc.h"
# include "virt-host-validate-common.h"
2018-09-29 21:37:22 +02:00
# include "vircgroup.h"
2012-01-10 17:31:21 +00:00
int virHostValidateLXC ( void )
{
int ret = 0 ;
if ( virHostValidateLinuxKernel ( " LXC " , ( 2 < < 16 ) | ( 6 < < 8 ) | 26 ,
2024-06-06 17:07:24 +01:00
VIR_VALIDATE_FAIL ,
2012-01-10 17:31:21 +00:00
_ ( " Upgrade to a kernel supporting namespaces " ) ) < 0 )
ret = - 1 ;
2015-10-07 16:58:39 +01:00
if ( virHostValidateNamespace ( " LXC " , " ipc " ,
2024-06-06 17:07:24 +01:00
VIR_VALIDATE_FAIL ,
2015-10-07 16:58:39 +01:00
_ ( " IPC namespace support is required " ) ) < 0 )
ret = - 1 ;
if ( virHostValidateNamespace ( " LXC " , " mnt " ,
2024-06-06 17:07:24 +01:00
VIR_VALIDATE_FAIL ,
2015-10-07 16:58:39 +01:00
_ ( " Mount namespace support is required " ) ) < 0 )
ret = - 1 ;
if ( virHostValidateNamespace ( " LXC " , " pid " ,
2024-06-06 17:07:24 +01:00
VIR_VALIDATE_FAIL ,
2015-10-07 16:58:39 +01:00
_ ( " PID namespace support is required " ) ) < 0 )
ret = - 1 ;
if ( virHostValidateNamespace ( " LXC " , " uts " ,
2024-06-06 17:07:24 +01:00
VIR_VALIDATE_FAIL ,
2015-10-07 16:58:39 +01:00
_ ( " UTS namespace support is required " ) ) < 0 )
ret = - 1 ;
if ( virHostValidateNamespace ( " LXC " , " net " ,
2024-06-06 17:07:24 +01:00
VIR_VALIDATE_WARN ,
2015-10-07 16:58:39 +01:00
_ ( " Network namespace support is recommended " ) ) < 0 )
ret = - 1 ;
if ( virHostValidateNamespace ( " LXC " , " user " ,
2024-06-06 17:07:24 +01:00
VIR_VALIDATE_WARN ,
2015-10-07 16:58:39 +01:00
_ ( " User namespace support is recommended " ) ) < 0 )
ret = - 1 ;
2018-09-29 21:37:22 +02:00
if ( virHostValidateCGroupControllers ( " LXC " ,
( 1 < < VIR_CGROUP_CONTROLLER_MEMORY ) |
( 1 < < VIR_CGROUP_CONTROLLER_CPU ) |
( 1 < < VIR_CGROUP_CONTROLLER_CPUACCT ) |
( 1 < < VIR_CGROUP_CONTROLLER_CPUSET ) |
( 1 < < VIR_CGROUP_CONTROLLER_DEVICES ) |
2018-09-29 21:47:50 +02:00
( 1 < < VIR_CGROUP_CONTROLLER_FREEZER ) |
2018-09-29 21:37:22 +02:00
( 1 < < VIR_CGROUP_CONTROLLER_BLKIO ) ,
2024-06-06 17:07:24 +01:00
VIR_VALIDATE_FAIL ) < 0 ) {
2015-10-07 17:36:37 +01:00
ret = - 1 ;
2018-09-29 21:37:22 +02:00
}
2015-10-07 17:36:37 +01:00
2017-10-12 16:51:13 +02:00
# if WITH_FUSE
if ( virHostValidateDeviceExists ( " LXC " , " /sys/fs/fuse/connections " ,
2024-06-06 17:07:24 +01:00
VIR_VALIDATE_FAIL ,
2017-10-12 16:51:13 +02:00
_ ( " Load the 'fuse' module to enable /proc/ overrides " ) ) < 0 )
ret = - 1 ;
# endif
2012-01-10 17:31:21 +00:00
return ret ;
}