linux/arch/x86/kvm
Andre Przywara bd22f5cfcf KVM: move and fix substitue search for missing CPUID entries
If KVM cannot find an exact match for a requested CPUID leaf, the
code will try to find the closest match instead of simply confessing
it's failure.
The implementation was meant to satisfy the CPUID specification, but
did not properly check for extended and standard leaves and also
didn't account for the index subleaf.
Beside that this rule only applies to CPUID intercepts, which is not
the only user of the kvm_find_cpuid_entry() function.

So fix this algorithm and call it from kvm_emulate_cpuid().
This fixes a crash of newer Linux kernels as KVM guests on
AMD Bulldozer CPUs, where bogus values were returned in response to
a CPUID intercept.

Signed-off-by: Andre Przywara <andre.przywara@amd.com>
Signed-off-by: Avi Kivity <avi@redhat.com>
2011-04-06 13:15:56 +03:00
..
emulate.c KVM: emulator: Fix permission checking in io permission bitmap 2011-03-17 13:08:33 -03:00
i8254.c
i8254.h
i8259.c KVM: remove isr_ack logic from PIC 2011-03-17 13:08:30 -03:00
irq.c
irq.h
Kconfig
kvm_cache_regs.h
kvm_timer.h
lapic.c KVM: x86: Remove useless regs_page pointer from kvm_lapic 2011-03-17 13:08:33 -03:00
lapic.h KVM: x86: Remove useless regs_page pointer from kvm_lapic 2011-03-17 13:08:33 -03:00
Makefile
mmu_audit.c
mmu.c KVM: MMU: cleanup pte write path 2011-03-17 13:08:35 -03:00
mmu.h
mmutrace.h
paging_tmpl.h Merge branch 'x86-fixes-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/linux-2.6-tip 2011-03-18 10:45:21 -07:00
svm.c KVM: SVM: Load %gs earlier if CONFIG_X86_32_LAZY_GS=n 2011-03-17 13:08:33 -03:00
timer.c x86: Fix common misspellings 2011-03-18 10:39:30 +01:00
trace.h
tss.h
vmx.c KVM: unbreak userspace that does not sets tss address 2011-03-17 13:08:35 -03:00
x86.c KVM: move and fix substitue search for missing CPUID entries 2011-04-06 13:15:56 +03:00
x86.h