diff options
Diffstat (limited to 'arch/arm64/kernel/asm-offsets.c')
| -rw-r--r-- | arch/arm64/kernel/asm-offsets.c | 34 | 
1 files changed, 34 insertions, 0 deletions
| diff --git a/arch/arm64/kernel/asm-offsets.c b/arch/arm64/kernel/asm-offsets.c index a2a4d810bea..666e231d410 100644 --- a/arch/arm64/kernel/asm-offsets.c +++ b/arch/arm64/kernel/asm-offsets.c @@ -21,6 +21,7 @@  #include <linux/sched.h>  #include <linux/mm.h>  #include <linux/dma-mapping.h> +#include <linux/kvm_host.h>  #include <asm/thread_info.h>  #include <asm/memory.h>  #include <asm/cputable.h> @@ -104,5 +105,38 @@ int main(void)    BLANK();    DEFINE(TZ_MINWEST,		offsetof(struct timezone, tz_minuteswest));    DEFINE(TZ_DSTTIME,		offsetof(struct timezone, tz_dsttime)); +  BLANK(); +#ifdef CONFIG_KVM_ARM_HOST +  DEFINE(VCPU_CONTEXT,		offsetof(struct kvm_vcpu, arch.ctxt)); +  DEFINE(CPU_GP_REGS,		offsetof(struct kvm_cpu_context, gp_regs)); +  DEFINE(CPU_USER_PT_REGS,	offsetof(struct kvm_regs, regs)); +  DEFINE(CPU_FP_REGS,		offsetof(struct kvm_regs, fp_regs)); +  DEFINE(CPU_SP_EL1,		offsetof(struct kvm_regs, sp_el1)); +  DEFINE(CPU_ELR_EL1,		offsetof(struct kvm_regs, elr_el1)); +  DEFINE(CPU_SPSR,		offsetof(struct kvm_regs, spsr)); +  DEFINE(CPU_SYSREGS,		offsetof(struct kvm_cpu_context, sys_regs)); +  DEFINE(VCPU_ESR_EL2,		offsetof(struct kvm_vcpu, arch.fault.esr_el2)); +  DEFINE(VCPU_FAR_EL2,		offsetof(struct kvm_vcpu, arch.fault.far_el2)); +  DEFINE(VCPU_HPFAR_EL2,	offsetof(struct kvm_vcpu, arch.fault.hpfar_el2)); +  DEFINE(VCPU_HCR_EL2,		offsetof(struct kvm_vcpu, arch.hcr_el2)); +  DEFINE(VCPU_IRQ_LINES,	offsetof(struct kvm_vcpu, arch.irq_lines)); +  DEFINE(VCPU_HOST_CONTEXT,	offsetof(struct kvm_vcpu, arch.host_cpu_context)); +  DEFINE(VCPU_TIMER_CNTV_CTL,	offsetof(struct kvm_vcpu, arch.timer_cpu.cntv_ctl)); +  DEFINE(VCPU_TIMER_CNTV_CVAL,	offsetof(struct kvm_vcpu, arch.timer_cpu.cntv_cval)); +  DEFINE(KVM_TIMER_CNTVOFF,	offsetof(struct kvm, arch.timer.cntvoff)); +  DEFINE(KVM_TIMER_ENABLED,	offsetof(struct kvm, arch.timer.enabled)); +  DEFINE(VCPU_KVM,		offsetof(struct kvm_vcpu, kvm)); +  DEFINE(VCPU_VGIC_CPU,		offsetof(struct kvm_vcpu, arch.vgic_cpu)); +  DEFINE(VGIC_CPU_HCR,		offsetof(struct vgic_cpu, vgic_hcr)); +  DEFINE(VGIC_CPU_VMCR,		offsetof(struct vgic_cpu, vgic_vmcr)); +  DEFINE(VGIC_CPU_MISR,		offsetof(struct vgic_cpu, vgic_misr)); +  DEFINE(VGIC_CPU_EISR,		offsetof(struct vgic_cpu, vgic_eisr)); +  DEFINE(VGIC_CPU_ELRSR,	offsetof(struct vgic_cpu, vgic_elrsr)); +  DEFINE(VGIC_CPU_APR,		offsetof(struct vgic_cpu, vgic_apr)); +  DEFINE(VGIC_CPU_LR,		offsetof(struct vgic_cpu, vgic_lr)); +  DEFINE(VGIC_CPU_NR_LR,	offsetof(struct vgic_cpu, nr_lr)); +  DEFINE(KVM_VTTBR,		offsetof(struct kvm, arch.vttbr)); +  DEFINE(KVM_VGIC_VCTRL,	offsetof(struct kvm, arch.vgic.vctrl_base)); +#endif    return 0;  } | 
