On Tue, Jan 14, 2014 at 02:50:01PM +0100, Cédric Bosdonnat wrote:
---
src/lxc/lxc_native.c | 27 ++++++++++++++++
.../lxcconf2xmldata/lxcconf2xml-cpusettune.config | 8 +++++
tests/lxcconf2xmldata/lxcconf2xml-cpusettune.xml | 36 ++++++++++++++++++++++
tests/lxcconf2xmltest.c | 1 +
4 files changed, 72 insertions(+)
create mode 100644 tests/lxcconf2xmldata/lxcconf2xml-cpusettune.config
create mode 100644 tests/lxcconf2xmldata/lxcconf2xml-cpusettune.xml
diff --git a/src/lxc/lxc_native.c b/src/lxc/lxc_native.c
index 80b7e74..635eb89 100644
--- a/src/lxc/lxc_native.c
+++ b/src/lxc/lxc_native.c
@@ -812,6 +812,29 @@ lxcSetCpuTune(virDomainDefPtr def, virPropertiesPtr properties)
return 0;
}
+static int
+lxcSetCpusetTune(virDomainDefPtr def, virPropertiesPtr properties)
+{
+ char *value;
BTW this should be 'const' throughout this series
+
+ if ((value = virPropertiesLookup(properties, "lxc.cgroup.cpuset.cpus")))
{
+ if (virBitmapParse(value, 0, &def->cpumask, VIR_DOMAIN_CPUMASK_LEN) <
0)
+ return -1;
+
+ def->placement_mode = VIR_DOMAIN_CPU_PLACEMENT_MODE_STATIC;
+ }
+
+ if ((value = virPropertiesLookup(properties, "lxc.cgroup.cpuset.mems")))
{
+ def->numatune.memory.placement_mode =
VIR_NUMA_TUNE_MEM_PLACEMENT_MODE_STATIC;
+ def->numatune.memory.mode = VIR_DOMAIN_NUMATUNE_MEM_STRICT;
+ if (virBitmapParse(value, 0, &def->numatune.memory.nodemask,
+ VIR_DOMAIN_CPUMASK_LEN) < 0)
+ return -1;
+ }
+
+ return 0;
+}
Daniel
--
|:
http://berrange.com -o-
http://www.flickr.com/photos/dberrange/ :|
|:
http://libvirt.org -o-
http://virt-manager.org :|
|:
http://autobuild.org -o-
http://search.cpan.org/~danberr/ :|
|:
http://entangle-photo.org -o-
http://live.gnome.org/gtk-vnc :|