(CCing libvir-list) On Thu, Nov 12, 2015 at 05:35:59PM +0100, Paolo Bonzini wrote: > On 12/11/2015 17:27, Eduardo Habkost wrote: > >> > > To simply remove rdtscp from all Opteron_G* models? > > > > > > Not sure this is the right thing to do... Real hardware has it, and > > > going forward KVM will provide it. > > > > Do you see any alternative? > > Live with the warning, and document it in the release notes. That's an option too. But it will cause breakage when upgrading the host kernel, and force users to live with a broken setup because we don't provide CPU models that work. In addition to providing CPU models that work, I believe it's better to make QEMU CPU models match what is already happening in practice with the existing VMs. > > > We need AMD CPU models that can run > > out of the box using today's kernels. As no existing VMs running > > Opteron_G* on AMD CPUs have rdtscp, I believe it makes sense to > > just define Opteron_G* without rdtscp. > > > > When we add SVM rdtscp support to KVM, we can add new > > "Opteron_G[2-5]-rdtscp" CPU models. > > Makes sense too. > > However, I'm a bit afraid of the interaction with libvirt. Right now, > libvirt has rdtscp in the description. If we remove it from libvirt, > libvirt will start adding +rdtscp to the QEMU CPU command line option, > so our change will be moot. And if we do not remove it from libvirt, > libvirt will not be able to start a VM with rdtscp on a fixed kernel. The former is not true (the change won't be moot). The latter seems true. AFAIK, the presence of rdtscp in cpu_map.xml only does two things: * Makes libvirt never use "-cpu Opteron_G2,+rdtscp" even if the user explicitly asked for rdtscp (which is a libvirt bug that should be fixed); * Makes libvirt refuse to run Opteron_G2 in hosts that lack rdtscp (which is also a libvirt bug, because it's checking host CPUID directly instead of GET_SUPPORTED_CPUID; libvirt must let QEMU check if the feature is really available). -- Eduardo -- libvir-list mailing list libvir-list@xxxxxxxxxx https://www.redhat.com/mailman/listinfo/libvir-list