On Sat, Nov 21, 2015 at 02:09:25AM +0100, Borislav Petkov wrote: > On Sat, Nov 21, 2015 at 12:11:35AM +0100, Andreas Färber wrote: > > Hi, > > > > CC'ing qemu-devel. > > Ah, thanks. > > > Am 21.11.2015 um 00:01 schrieb Borislav Petkov: > > > From: Borislav Petkov <bp@xxxxxxx> > > > > > > Software Error Recovery, i.e. SER, is purely an Intel feature and it > > > shouldn't be set by default. Enable it only on Intel. What happens when SER is enabled on an AMD CPU? If it really should't be enabled, why is KVM returning it on KVM_X86_GET_MCE_CAP_SUPPORTED? > > > > Is this new in 2.5? Otherwise we would probably need compatibility code > > in pc*.[ch] for incoming live migration from older versions. > > It looks it is really old, AFAIK from 2010: > > c0532a76b407 ("MCE: Relay UCR MCE to guest") > > You'd need to be more verbose about pc*.[ch]. An example perhaps...? If you change something that's guest-visible and not part of the migration stream, you need to keep the old behavior on older machine-types (e.g. pc-i440fx-2.4), or the CPU will change under the guest's feet when migrating to another host. For examples, see the recent commits to include/hw/i386/pc.h. They are all about keeping compatibility when CPUID bits are changed: 33b5e8c0 target-i386: Disable rdtscp on Opteron_G* CPU models 6aa91e4a target-i386: Remove POPCNT from qemu64 and qemu32 CPU models 71195672 target-i386: Remove ABM from qemu64 CPU model 0909ad24 target-i386: Remove SSE4a from qemu64 CPU model In the case of this code, it looks like it's already broken because the resulting mcg_cap depends on host kernel capabilities (the ones reported by kvm_get_mce_cap_supported()), and the data initialized by target-i386/cpu.c:mce_init() is silently overwritten by kvm_arch_init_vcpu(). So we would need to fix that before implementing a proper compatibility mechanism for mcg_cap. -- Eduardo -- To unsubscribe from this list: send the line "unsubscribe kvm" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html