summaryrefslogtreecommitdiffstats
path: root/core/modules/qemu
diff options
context:
space:
mode:
authorManuel Bentele2021-11-16 08:54:18 +0100
committerManuel Bentele2021-11-16 08:54:18 +0100
commitae622c9b32f5c42926e7d3febd0165ea0db71c4d (patch)
tree923cd4fc1f72b0ca5d03966e9919733c8649e275 /core/modules/qemu
parent[xorg] iris driver workaround: Only required for Mesa 20.x (diff)
downloadmltk-ae622c9b32f5c42926e7d3febd0165ea0db71c4d.tar.gz
mltk-ae622c9b32f5c42926e7d3febd0165ea0db71c4d.tar.xz
mltk-ae622c9b32f5c42926e7d3febd0165ea0db71c4d.zip
[qemu] Set number of CPU cores instead of CPU sockets for a VM
Diffstat (limited to 'core/modules/qemu')
-rw-r--r--core/modules/qemu/runvirt-plugin-qemu/src/main/java/org/openslx/runvirt/plugin/qemu/configuration/TransformationGenericCpu.java30
-rw-r--r--core/modules/qemu/runvirt-plugin-qemu/src/test/java/org/openslx/runvirt/plugin/qemu/configuration/TransformationGenericCpuTest.java14
2 files changed, 41 insertions, 3 deletions
diff --git a/core/modules/qemu/runvirt-plugin-qemu/src/main/java/org/openslx/runvirt/plugin/qemu/configuration/TransformationGenericCpu.java b/core/modules/qemu/runvirt-plugin-qemu/src/main/java/org/openslx/runvirt/plugin/qemu/configuration/TransformationGenericCpu.java
index 9d9237c7..73cd4c1f 100644
--- a/core/modules/qemu/runvirt-plugin-qemu/src/main/java/org/openslx/runvirt/plugin/qemu/configuration/TransformationGenericCpu.java
+++ b/core/modules/qemu/runvirt-plugin-qemu/src/main/java/org/openslx/runvirt/plugin/qemu/configuration/TransformationGenericCpu.java
@@ -21,6 +21,21 @@ public class TransformationGenericCpu extends TransformationGeneric<Domain, Comm
private static final String NAME = "CPU [number of cores, mode, ...]";
/**
+ * Number of CPU dies per virtual machine.
+ */
+ public static final int CPU_NUM_DIES = 1;
+
+ /**
+ * Number of CPU sockets per virtual machine.
+ */
+ public static final int CPU_NUM_SOCKETS = 1;
+
+ /**
+ * Number of threads per virtual machine's CPU.
+ */
+ public static final int CPU_NUM_THREADS = 1;
+
+ /**
* Creates a new generic CPU transformation for Libvirt/QEMU virtualization configurations.
*/
public TransformationGenericCpu()
@@ -40,7 +55,7 @@ public class TransformationGenericCpu extends TransformationGeneric<Domain, Comm
if ( config == null || args == null ) {
throw new TransformationException( "Virtualization configuration or input arguments are missing!" );
} else if ( args.getVmNumCpus() < 1 ) {
- throw new TransformationException( "Invalid number of CPUs specified! Expected a number n > 0!" );
+ throw new TransformationException( "Invalid number of virtual CPUs specified! Expected a number n > 0!" );
}
}
@@ -50,8 +65,19 @@ public class TransformationGenericCpu extends TransformationGeneric<Domain, Comm
// validate configuration and input arguments
this.validateInputs( config, args );
- config.setVCpu( args.getVmNumCpus() );
+ // set general CPU modes
config.setCpuMode( CpuMode.HOST_PASSTHROUGH );
config.setCpuCheck( CpuCheck.PARTIAL );
+
+ // set detailed CPU topology
+ config.setCpuDies( TransformationGenericCpu.CPU_NUM_DIES );
+ config.setCpuSockets( TransformationGenericCpu.CPU_NUM_SOCKETS );
+ config.setCpuCores( args.getVmNumCpus() );
+ config.setCpuThreads( TransformationGenericCpu.CPU_NUM_THREADS );
+
+ // set maximum allocated CPUs for the VM
+ final int maxCpus = TransformationGenericCpu.CPU_NUM_DIES * TransformationGenericCpu.CPU_NUM_SOCKETS
+ * args.getVmNumCpus() * TransformationGenericCpu.CPU_NUM_THREADS;
+ config.setVCpu( maxCpus );
}
}
diff --git a/core/modules/qemu/runvirt-plugin-qemu/src/test/java/org/openslx/runvirt/plugin/qemu/configuration/TransformationGenericCpuTest.java b/core/modules/qemu/runvirt-plugin-qemu/src/test/java/org/openslx/runvirt/plugin/qemu/configuration/TransformationGenericCpuTest.java
index d88857a6..f90c5625 100644
--- a/core/modules/qemu/runvirt-plugin-qemu/src/test/java/org/openslx/runvirt/plugin/qemu/configuration/TransformationGenericCpuTest.java
+++ b/core/modules/qemu/runvirt-plugin-qemu/src/test/java/org/openslx/runvirt/plugin/qemu/configuration/TransformationGenericCpuTest.java
@@ -29,10 +29,22 @@ public class TransformationGenericCpuTest
transformation.transform( config, args );
- assertEquals( Integer.parseInt( TransformationTestUtils.DEFAULT_VM_NCPUS ), config.getVCpu() );
assertEquals( CpuMode.HOST_PASSTHROUGH, config.getCpuMode() );
assertEquals( CpuCheck.PARTIAL, config.getCpuCheck() );
+ final int numDies = TransformationGenericCpu.CPU_NUM_DIES;
+ final int numSockets = TransformationGenericCpu.CPU_NUM_SOCKETS;
+ final int numCores = Integer.valueOf( TransformationTestUtils.DEFAULT_VM_NCPUS );
+ final int numThreads = TransformationGenericCpu.CPU_NUM_THREADS;
+
+ final int numVCpus = numDies * numSockets * numCores * numThreads;
+
+ assertEquals( numDies, config.getCpuDies() );
+ assertEquals( numSockets, config.getCpuSockets() );
+ assertEquals( numCores, config.getCpuCores() );
+ assertEquals( numThreads, config.getCpuThreads() );
+ assertEquals( numVCpus, config.getVCpu() );
+
assertDoesNotThrow( () -> config.validateXml() );
}