1
0
mirror of https://gitlab.com/libvirt/libvirt.git synced 2025-03-20 06:50:22 +03:00

PowerPC:Improve PVR handling to fall back to cpu generation.

IBM Power processors differ uniquely across generations (such as power6,
power7, power8). Each generation signifies a new PowerISA version
that exhibits features unique to that generation.
The higher 16 bits of PVR for IBM Power processors encode the CPU
generation, while the CPU chip (sub)version is encoded in lower 16 bits.

For all practical purposes of launching a VM, we care about the
generation which the vCPU will belong to, and not specifically the chip
version. This patch updates the libvirt PVR check to reflect this
relationship. It allows libvirt to select the right CPU generation
in case the exact match for a a specific CPU is not found.
Hence, there will no longer be a need to add each PowerPC CPU model to
cpu_map.xml; just adding entry for the matching ISA generation will
suffice.

It also contains changes to cpu_map.xml since processor generations
as understood by QEMU compat mode go as "power6", "power7" or "power8"
[Reference : QEMU commit 8dfa3a5e85 ]

Signed-off-by: Prerna Saxena <prerna@linux.vnet.ibm.com>
Signed-off-by: Pradipta Kr. Banerjee <bpradip@in.ibm.com>
Signed-off-by: Anton Blanchard <anton@samba.org>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
This commit is contained in:
Prerna Saxena 2014-11-04 22:58:33 +05:30 committed by Michal Privoznik
parent addce06c92
commit 1e91174228
2 changed files with 38 additions and 0 deletions

View File

@ -627,5 +627,35 @@
<pvr value='0x004b0100'/>
</model>
<model name='power6'>
<vendor name='IBM'/>
<compat isa='2.05'/>
<pvr value='0x003e0000'/>
</model>
<model name='power7'>
<vendor name='IBM'/>
<compat isa='2.06'/>
<pvr value='0x003f0000'/>
</model>
<model name='power7+'>
<vendor name='IBM'/>
<compat isa='2.06B'/>
<pvr value='0x004a0000'/>
</model>
<model name='power8e'>
<vendor name='IBM'/>
<compat isa='2.07'/>
<pvr value='0x004b0000'/>
</model>
<model name='power8'>
<vendor name='IBM'/>
<compat isa='2.07'/>
<pvr value='0x004d0000'/>
</model>
</arch>
</cpus>

View File

@ -99,6 +99,14 @@ ppcModelFindPVR(const struct ppc_map *map,
model = model->next;
}
/* PowerPC Processor Version Register is interpreted as follows :
* Higher order 16 bits : Power ISA generation.
* Lower order 16 bits : CPU chip version number.
* If the exact CPU isnt found, return the nearest matching CPU generation
*/
if (pvr & 0x0000FFFFul)
return ppcModelFindPVR(map, (pvr & 0xFFFF0000ul));
return NULL;
}