Currently KVM only supports vPMU for Intel platforms. This patch set enable vPMU support for AMD platform by creating a common PMU interface for x86. The PMU calls from guest VMs are dispatched to corresponding functions defined in arch specific files. V2: * Create a generic pmu.c file which is shared by Intel and AMD CPUs; * pmu.c code becomes part of kvm.ko module. Similarly pmu_intel.c and pmu_amd.c are linked to kvm-intel.ko and kvm-amd.ko respectively; * Re-define kvm_pmu_ops function pointers. Per Radim Krcmar's comments, a large portion of Intel vPMU code are now consolidated and moved to pmu.c; * Polish pmu_amd.c code to comply with new definition of kvm_pmu_ops; V1: * Adopt the file layout suggested by Radim Krcmar * Link arch module with its specific PMU file RFC: * Initial version for RFC Wei Huang (5): KVM: x86/vPMU: Define kvm_pmu_ops to support vPMU function dispatch KVM: x86/vPMU: Rename pmu.c file to pmu_intel.c KVM: x86/vPMU: Create vPMU interface for VMX and SVM KVM: x86/vPMU: Implement vPMU code AMD CPUs KVM: x86/vPMU: Enable PMU handling for AMD PERFCTRn and EVNTSELn MSRs arch/x86/include/asm/kvm_host.h | 38 ++- arch/x86/kvm/Makefile | 4 +- arch/x86/kvm/cpuid.c | 3 +- arch/x86/kvm/pmu.c | 563 +++++++++++----------------------------- arch/x86/kvm/pmu.h | 98 +++++++ arch/x86/kvm/pmu_amd.c | 198 ++++++++++++++ arch/x86/kvm/pmu_intel.c | 360 +++++++++++++++++++++++++ arch/x86/kvm/svm.c | 8 + arch/x86/kvm/vmx.c | 8 + arch/x86/kvm/x86.c | 57 ++-- 10 files changed, 896 insertions(+), 441 deletions(-) create mode 100644 arch/x86/kvm/pmu.h create mode 100644 arch/x86/kvm/pmu_amd.c create mode 100644 arch/x86/kvm/pmu_intel.c -- 1.8.3.1 -- 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