kvm: ppc: disable sPAPR code if CONFIG_PSERIES is disabled
target/ppc/kvm.c calls out to code in hw/ppc/spapr*.c; that code is not present and fails to link if CONFIG_PSERIES is not enabled. Adjust kvm.c to depend on CONFIG_PSERIES instead of TARGET_PPC64, and compile out anything that requires cap_papr, because only the pseries machine will call kvmppc_set_papr(). Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
957f583b7c
commit
566abdb4d9
@ -49,6 +49,8 @@
|
||||
#include "elf.h"
|
||||
#include "sysemu/kvm_int.h"
|
||||
|
||||
#include CONFIG_DEVICES
|
||||
|
||||
#define PROC_DEVTREE_CPU "/proc/device-tree/cpus/"
|
||||
|
||||
#define DEBUG_RETURN_GUEST 0
|
||||
@ -71,7 +73,6 @@ static int cap_hior;
|
||||
static int cap_one_reg;
|
||||
static int cap_epr;
|
||||
static int cap_ppc_watchdog;
|
||||
static int cap_papr;
|
||||
static int cap_htab_fd;
|
||||
static int cap_fixup_hcalls;
|
||||
static int cap_htm; /* Hardware transactional memory support */
|
||||
@ -90,6 +91,12 @@ static int cap_fwnmi;
|
||||
static int cap_rpt_invalidate;
|
||||
static int cap_ail_mode_3;
|
||||
|
||||
#ifdef CONFIG_PSERIES
|
||||
static int cap_papr;
|
||||
#else
|
||||
#define cap_papr (0)
|
||||
#endif
|
||||
|
||||
static uint32_t debug_inst_opcode;
|
||||
|
||||
/*
|
||||
@ -1668,7 +1675,7 @@ int kvm_arch_handle_exit(CPUState *cs, struct kvm_run *run)
|
||||
trace_kvm_handle_halt();
|
||||
ret = kvmppc_handle_halt(cpu);
|
||||
break;
|
||||
#if defined(TARGET_PPC64)
|
||||
#if defined(CONFIG_PSERIES)
|
||||
case KVM_EXIT_PAPR_HCALL:
|
||||
trace_kvm_handle_papr_hcall(run->papr_hcall.nr);
|
||||
run->papr_hcall.ret = spapr_hypercall(cpu,
|
||||
@ -1698,7 +1705,7 @@ int kvm_arch_handle_exit(CPUState *cs, struct kvm_run *run)
|
||||
ret = 0;
|
||||
break;
|
||||
|
||||
#if defined(TARGET_PPC64)
|
||||
#if defined(CONFIG_PSERIES)
|
||||
case KVM_EXIT_NMI:
|
||||
trace_kvm_handle_nmi_exception();
|
||||
ret = kvm_handle_nmi(cpu, run);
|
||||
@ -2054,6 +2061,7 @@ void kvmppc_enable_h_rpt_invalidate(void)
|
||||
kvmppc_enable_hcall(kvm_state, H_RPT_INVALIDATE);
|
||||
}
|
||||
|
||||
#ifdef CONFIG_PSERIES
|
||||
void kvmppc_set_papr(PowerPCCPU *cpu)
|
||||
{
|
||||
CPUState *cs = CPU(cpu);
|
||||
@ -2075,6 +2083,7 @@ void kvmppc_set_papr(PowerPCCPU *cpu)
|
||||
*/
|
||||
cap_papr = 1;
|
||||
}
|
||||
#endif
|
||||
|
||||
int kvmppc_set_compat(PowerPCCPU *cpu, uint32_t compat_pvr)
|
||||
{
|
||||
@ -2837,7 +2846,7 @@ int kvm_arch_msi_data_to_gsi(uint32_t data)
|
||||
return data & 0xffff;
|
||||
}
|
||||
|
||||
#if defined(TARGET_PPC64)
|
||||
#if defined(CONFIG_PSERIES)
|
||||
int kvm_handle_nmi(PowerPCCPU *cpu, struct kvm_run *run)
|
||||
{
|
||||
uint16_t flags = run->flags & KVM_RUN_PPC_NMI_DISP_MASK;
|
||||
|
Loading…
x
Reference in New Issue
Block a user