提交 1e911742 编写于 作者: P Prerna Saxena 提交者: Michal Privoznik

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: NPrerna Saxena <prerna@linux.vnet.ibm.com>
Signed-off-by: NPradipta Kr. Banerjee <bpradip@in.ibm.com>
Signed-off-by: NAnton Blanchard <anton@samba.org>
Reviewed-by: NMichal Privoznik <mprivozn@redhat.com>
上级 addce06c
......@@ -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>
......@@ -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;
}
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册