Pinning the Threads

Yeah, it’s actually Thread Pinning, who would’ve thought?

To begin, open your DarwinKVM window from Virt-Manager and head to the XML tab.

If you’ve already done Virtio IO Thread then you’ll put this under

<iothreads>1</iothreads>

If you’ve already done Fake Core Count then you’ll put this under

<vcpus>
  ...
</vcpus>

To begin, this section is called CPU Tune. We can add this below whichever works for you above.

<cputune>
  <vcpupin vcpu='0' cpuset='1'/>
  <vcpupin vcpu='1' cpuset='9'/>
  <vcpupin vcpu='2' cpuset='2'/>
  <vcpupin vcpu='3' cpuset='10'/>
  <vcpupin vcpu='4' cpuset='3'/>
  <vcpupin vcpu='5' cpuset='11'/>
  <vcpupin vcpu='6' cpuset='4'/>
  <vcpupin vcpu='7' cpuset='12'/>
  <vcpupin vcpu='8' cpuset='5'/>
  <vcpupin vcpu='9' cpuset='13'/>
  <vcpupin vcpu='10' cpuset='6'/>
  <vcpupin vcpu='11' cpuset='14'/>
  <vcpupin vcpu='12' cpuset='7'/>
  <vcpupin vcpu='13' cpuset='15'/>
  ...
  ...
</cputune>

You must customize this example above for your Virtual Machines Virtual Core Count. Below we will go over two different scenarios and how to determine how many vCPU’s you need to keep.

Example 1 - Stock, No Fake Core Count

<vcpu placement="static">8</vcpu> // 1 Socket, 4 Cores, 2 Threads, 8 vCPU's total

Example 2 - if you’ve done Fake Core Count

<vcpu placement="static" current="14">16</vcpu> // VM is 1 Socket 8 Cores, 2 Threads, but only using 14 host threads

In the first example, we’re only using 8 threads or (vCPU’s) so we would do

<cputune>
  <vcpupin vcpu='0' cpuset='1'/>
  <vcpupin vcpu='1' cpuset='9'/>
  <vcpupin vcpu='2' cpuset='2'/>
  <vcpupin vcpu='3' cpuset='10'/>
  <vcpupin vcpu='4' cpuset='3'/>
  <vcpupin vcpu='5' cpuset='11'/>
  <vcpupin vcpu='6' cpuset='4'/>
  <vcpupin vcpu='7' cpuset='12'/>
  ...
  ...
</cputune>

Don’t forget! vCPU 7 is actually Thread 8! We start counting from 0 not 1.

In the second example, it was a 14 Thread Virtual Machine, so the following is used

<cputune>
  <vcpupin vcpu='0' cpuset='1'/>
  <vcpupin vcpu='1' cpuset='9'/>
  <vcpupin vcpu='2' cpuset='2'/>
  <vcpupin vcpu='3' cpuset='10'/>
  <vcpupin vcpu='4' cpuset='3'/>
  <vcpupin vcpu='5' cpuset='11'/>
  <vcpupin vcpu='6' cpuset='4'/>
  <vcpupin vcpu='7' cpuset='12'/>
  <vcpupin vcpu='8' cpuset='5'/>
  <vcpupin vcpu='9' cpuset='13'/>
  <vcpupin vcpu='10' cpuset='6'/>
  <vcpupin vcpu='11' cpuset='14'/>
  <vcpupin vcpu='12' cpuset='7'/>
  <vcpupin vcpu='13' cpuset='15'/>
  ...
  ...
</cputune>

Don’t forget! vCPU 13 is actually Thread 14! We start counting from 0 not 1.

That is all. This should automatically allocate starting from Core 2 (Thread 2. LP #2), all the way up to the very last core on your system. Such as the image below shows.

Thanks for reading!


DarwinKVM Docs Version 2.0.0~prerelease
Copyright © 2024 RoyalGraphX. Distributed by a BSD 3-Clause License.
Last Modified: Wed, 11 Dec 2024 7:37:47 CDT