From: Bandan Das <bsd@redhat.com> To: Jintack Lim <jintack.lim@linaro.org> Cc: KVM General <kvm@vger.kernel.org>, Catalin Marinas <catalin.marinas@arm.com>, Will Deacon <will.deacon@arm.com>, kvmarm@lists.cs.columbia.edu, Shih-Wei Li <shihwei@cs.columbia.edu>, lorenzo.pieralisi@arm.com, linux@armlinux.org.uk, arm-mail-list <linux-arm-kernel@lists.infradead.org>, Marc Zyngier <marc.zyngier@arm.com>, Andre Przywara <andre.przywara@arm.com>, kevin.brodsky@arm.com, wcohen@redhat.com, anna-maria@linutronix.de, geoff@infradead.org, lkml - Kernel Mailing List <linux-kernel@vger.kernel.org>, Paolo Bonzini <pbonzini@redhat.com>, Jintack Lim <jintack@cs.columbia.edu> Subject: Re: [RFC 11/55] KVM: arm64: Emulate taking an exception to the guest hypervisor Date: Tue, 06 Jun 2017 18:07:07 -0400 [thread overview] Message-ID: <jpglgp4g48k.fsf@linux.bootlegged.copy> (raw) In-Reply-To: <CAHyh4xjvqiXDEa9+vDDc4iOVsEHVZyHUEQ5AqQT65E4BV+b0zA@mail.gmail.com> (Jintack Lim's message of "Tue, 6 Jun 2017 16:38:56 -0400") Hi Jintack, Jintack Lim <jintack.lim@linaro.org> writes: > Hi Bandan, > > On Tue, Jun 6, 2017 at 4:21 PM, Bandan Das <bsd@redhat.com> wrote: >> Jintack Lim <jintack@cs.columbia.edu> writes: >> >>> Emulate taking an exception to the guest hypervisor running in the >>> virtual EL2 as described in ARM ARM AArch64.TakeException(). >> >> ARM newbie here, I keep thinking of ARM ARM as a typo ;) > > ARM ARM means ARM Architecture Reference Manual :) > >> ... >>> +static inline int kvm_inject_nested_sync(struct kvm_vcpu *vcpu, u64 esr_el2) >>> +{ >>> + kvm_err("Unexpected call to %s for the non-nesting configuration\n", >>> + __func__); >>> + return -EINVAL; >>> +} >>> + >>> +static inline int kvm_inject_nested_irq(struct kvm_vcpu *vcpu) >>> +{ >>> + kvm_err("Unexpected call to %s for the non-nesting configuration\n", >>> + __func__); >>> + return -EINVAL; >>> +} >>> + >> >> I see these function stubs for aarch32 in the patches. I don't see how they >> can actually be called though. Is this because eventually, there will be >> a virtual el2 mode for aarch32 ? > > Current RFC doesn't support nested virtualization on 32bit arm > architecture and those functions will be never called. Those functions > are there for the compilation. Do you mean that compilation will fail ? It seems these functions are defined separately in 32/64 bit specific header files. Or is it that 64 bit compilation also depends on the 32 bit header file ? Bandan > Thanks, > Jintack > >> >> Bandan >> >>> static inline void kvm_arm_setup_shadow_state(struct kvm_vcpu *vcpu) { }; >>> static inline void kvm_arm_restore_shadow_state(struct kvm_vcpu *vcpu) { }; >>> static inline void kvm_arm_init_cpu_context(kvm_cpu_context_t *cpu_ctxt) { }; >>> diff --git a/arch/arm64/include/asm/kvm_emulate.h b/arch/arm64/include/asm/kvm_emulate.h >>> index 8892c82..0987ee4 100644 >>> --- a/arch/arm64/include/asm/kvm_emulate.h >>> +++ b/arch/arm64/include/asm/kvm_emulate.h >>> @@ -42,6 +42,25 @@ >>> void kvm_inject_dabt(struct kvm_vcpu *vcpu, unsigned long addr); >>> void kvm_inject_pabt(struct kvm_vcpu *vcpu, unsigned long addr); >>> >>> +#ifdef CONFIG_KVM_ARM_NESTED_HYP >>> +int kvm_inject_nested_sync(struct kvm_vcpu *vcpu, u64 esr_el2); >>> +int kvm_inject_nested_irq(struct kvm_vcpu *vcpu); >>> +#else >>> +static inline int kvm_inject_nested_sync(struct kvm_vcpu *vcpu, u64 esr_el2) >>> +{ >>> + kvm_err("Unexpected call to %s for the non-nesting configuration\n", >>> + __func__); >>> + return -EINVAL; >>> +} >>> + >>> +static inline int kvm_inject_nested_irq(struct kvm_vcpu *vcpu) >>> +{ >>> + kvm_err("Unexpected call to %s for the non-nesting configuration\n", >>> + __func__); >>> + return -EINVAL; >>> +} >>> +#endif >>> + >>> void kvm_arm_setup_shadow_state(struct kvm_vcpu *vcpu); >>> void kvm_arm_restore_shadow_state(struct kvm_vcpu *vcpu); >>> void kvm_arm_init_cpu_context(kvm_cpu_context_t *cpu_ctxt); >>> diff --git a/arch/arm64/kvm/Makefile b/arch/arm64/kvm/Makefile >>> index 7811d27..b342bdd 100644 >>> --- a/arch/arm64/kvm/Makefile >>> +++ b/arch/arm64/kvm/Makefile >>> @@ -34,3 +34,5 @@ kvm-$(CONFIG_KVM_ARM_HOST) += $(KVM)/arm/vgic/vgic-its.o >>> kvm-$(CONFIG_KVM_ARM_HOST) += $(KVM)/irqchip.o >>> kvm-$(CONFIG_KVM_ARM_HOST) += $(KVM)/arm/arch_timer.o >>> kvm-$(CONFIG_KVM_ARM_PMU) += $(KVM)/arm/pmu.o >>> + >>> +kvm-$(CONFIG_KVM_ARM_NESTED_HYP) += emulate-nested.o >>> diff --git a/arch/arm64/kvm/emulate-nested.c b/arch/arm64/kvm/emulate-nested.c >>> new file mode 100644 >>> index 0000000..59d147f >>> --- /dev/null >>> +++ b/arch/arm64/kvm/emulate-nested.c >>> @@ -0,0 +1,66 @@ >>> +/* >>> + * Copyright (C) 2016 - Columbia University >>> + * Author: Jintack Lim <jintack@cs.columbia.edu> >>> + * >>> + * This program is free software; you can redistribute it and/or modify >>> + * it under the terms of the GNU General Public License version 2 as >>> + * published by the Free Software Foundation. >>> + * >>> + * This program is distributed in the hope that it will be useful, >>> + * but WITHOUT ANY WARRANTY; without even the implied warranty of >>> + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the >>> + * GNU General Public License for more details. >>> + * >>> + * You should have received a copy of the GNU General Public License >>> + * along with this program. If not, see <http://www.gnu.org/licenses/>. >>> + */ >>> + >>> +#include <linux/kvm.h> >>> +#include <linux/kvm_host.h> >>> + >>> +#include <asm/kvm_emulate.h> >>> + >>> +#include "trace.h" >>> + >>> +#define EL2_EXCEPT_SYNC_OFFSET 0x400 >>> +#define EL2_EXCEPT_ASYNC_OFFSET 0x480 >>> + >>> + >>> +/* >>> + * Emulate taking an exception. See ARM ARM J8.1.2 AArch64.TakeException() >>> + */ >>> +static int kvm_inject_nested(struct kvm_vcpu *vcpu, u64 esr_el2, >>> + int exception_offset) >>> +{ >>> + int ret = 1; >>> + kvm_cpu_context_t *ctxt = &vcpu->arch.ctxt; >>> + >>> + /* We don't inject an exception recursively to virtual EL2 */ >>> + if (vcpu_mode_el2(vcpu)) >>> + BUG(); >>> + >>> + ctxt->el2_regs[SPSR_EL2] = *vcpu_cpsr(vcpu); >>> + ctxt->el2_regs[ELR_EL2] = *vcpu_pc(vcpu); >>> + ctxt->el2_regs[ESR_EL2] = esr_el2; >>> + >>> + /* On an exception, PSTATE.SP = 1 */ >>> + *vcpu_cpsr(vcpu) = PSR_MODE_EL2h; >>> + *vcpu_cpsr(vcpu) |= (PSR_A_BIT | PSR_F_BIT | PSR_I_BIT | PSR_D_BIT); >>> + *vcpu_pc(vcpu) = ctxt->el2_regs[VBAR_EL2] + exception_offset; >>> + >>> + trace_kvm_inject_nested_exception(vcpu, esr_el2, *vcpu_pc(vcpu)); >>> + >>> + return ret; >>> +} >>> + >>> +int kvm_inject_nested_sync(struct kvm_vcpu *vcpu, u64 esr_el2) >>> +{ >>> + return kvm_inject_nested(vcpu, esr_el2, EL2_EXCEPT_SYNC_OFFSET); >>> +} >>> + >>> +int kvm_inject_nested_irq(struct kvm_vcpu *vcpu) >>> +{ >>> + u64 esr_el2 = kvm_vcpu_get_hsr(vcpu); >>> + /* We supports only IRQ and FIQ, so the esr_el2 is not updated. */ >>> + return kvm_inject_nested(vcpu, esr_el2, EL2_EXCEPT_ASYNC_OFFSET); >>> +} >>> diff --git a/arch/arm64/kvm/trace.h b/arch/arm64/kvm/trace.h >>> index 7fb0008..7c86cfb 100644 >>> --- a/arch/arm64/kvm/trace.h >>> +++ b/arch/arm64/kvm/trace.h >>> @@ -167,6 +167,26 @@ >>> ); >>> >>> >>> +TRACE_EVENT(kvm_inject_nested_exception, >>> + TP_PROTO(struct kvm_vcpu *vcpu, unsigned long esr_el2, >>> + unsigned long pc), >>> + TP_ARGS(vcpu, esr_el2, pc), >>> + >>> + TP_STRUCT__entry( >>> + __field(struct kvm_vcpu *, vcpu) >>> + __field(unsigned long, esr_el2) >>> + __field(unsigned long, pc) >>> + ), >>> + >>> + TP_fast_assign( >>> + __entry->vcpu = vcpu; >>> + __entry->esr_el2 = esr_el2; >>> + __entry->pc = pc; >>> + ), >>> + >>> + TP_printk("vcpu: %p, inject exception to vEL2: ESR_EL2 0x%lx, vector: 0x%016lx", >>> + __entry->vcpu, __entry->esr_el2, __entry->pc) >>> +); >>> #endif /* _TRACE_ARM64_KVM_H */ >>> >>> #undef TRACE_INCLUDE_PATH >> _______________________________________________ >> kvmarm mailing list >> kvmarm@lists.cs.columbia.edu >> https://lists.cs.columbia.edu/mailman/listinfo/kvmarm
WARNING: multiple messages have this Message-ID (diff)
From: bsd@redhat.com (Bandan Das) To: linux-arm-kernel@lists.infradead.org Subject: [RFC 11/55] KVM: arm64: Emulate taking an exception to the guest hypervisor Date: Tue, 06 Jun 2017 18:07:07 -0400 [thread overview] Message-ID: <jpglgp4g48k.fsf@linux.bootlegged.copy> (raw) In-Reply-To: <CAHyh4xjvqiXDEa9+vDDc4iOVsEHVZyHUEQ5AqQT65E4BV+b0zA@mail.gmail.com> (Jintack Lim's message of "Tue, 6 Jun 2017 16:38:56 -0400") Hi Jintack, Jintack Lim <jintack.lim@linaro.org> writes: > Hi Bandan, > > On Tue, Jun 6, 2017 at 4:21 PM, Bandan Das <bsd@redhat.com> wrote: >> Jintack Lim <jintack@cs.columbia.edu> writes: >> >>> Emulate taking an exception to the guest hypervisor running in the >>> virtual EL2 as described in ARM ARM AArch64.TakeException(). >> >> ARM newbie here, I keep thinking of ARM ARM as a typo ;) > > ARM ARM means ARM Architecture Reference Manual :) > >> ... >>> +static inline int kvm_inject_nested_sync(struct kvm_vcpu *vcpu, u64 esr_el2) >>> +{ >>> + kvm_err("Unexpected call to %s for the non-nesting configuration\n", >>> + __func__); >>> + return -EINVAL; >>> +} >>> + >>> +static inline int kvm_inject_nested_irq(struct kvm_vcpu *vcpu) >>> +{ >>> + kvm_err("Unexpected call to %s for the non-nesting configuration\n", >>> + __func__); >>> + return -EINVAL; >>> +} >>> + >> >> I see these function stubs for aarch32 in the patches. I don't see how they >> can actually be called though. Is this because eventually, there will be >> a virtual el2 mode for aarch32 ? > > Current RFC doesn't support nested virtualization on 32bit arm > architecture and those functions will be never called. Those functions > are there for the compilation. Do you mean that compilation will fail ? It seems these functions are defined separately in 32/64 bit specific header files. Or is it that 64 bit compilation also depends on the 32 bit header file ? Bandan > Thanks, > Jintack > >> >> Bandan >> >>> static inline void kvm_arm_setup_shadow_state(struct kvm_vcpu *vcpu) { }; >>> static inline void kvm_arm_restore_shadow_state(struct kvm_vcpu *vcpu) { }; >>> static inline void kvm_arm_init_cpu_context(kvm_cpu_context_t *cpu_ctxt) { }; >>> diff --git a/arch/arm64/include/asm/kvm_emulate.h b/arch/arm64/include/asm/kvm_emulate.h >>> index 8892c82..0987ee4 100644 >>> --- a/arch/arm64/include/asm/kvm_emulate.h >>> +++ b/arch/arm64/include/asm/kvm_emulate.h >>> @@ -42,6 +42,25 @@ >>> void kvm_inject_dabt(struct kvm_vcpu *vcpu, unsigned long addr); >>> void kvm_inject_pabt(struct kvm_vcpu *vcpu, unsigned long addr); >>> >>> +#ifdef CONFIG_KVM_ARM_NESTED_HYP >>> +int kvm_inject_nested_sync(struct kvm_vcpu *vcpu, u64 esr_el2); >>> +int kvm_inject_nested_irq(struct kvm_vcpu *vcpu); >>> +#else >>> +static inline int kvm_inject_nested_sync(struct kvm_vcpu *vcpu, u64 esr_el2) >>> +{ >>> + kvm_err("Unexpected call to %s for the non-nesting configuration\n", >>> + __func__); >>> + return -EINVAL; >>> +} >>> + >>> +static inline int kvm_inject_nested_irq(struct kvm_vcpu *vcpu) >>> +{ >>> + kvm_err("Unexpected call to %s for the non-nesting configuration\n", >>> + __func__); >>> + return -EINVAL; >>> +} >>> +#endif >>> + >>> void kvm_arm_setup_shadow_state(struct kvm_vcpu *vcpu); >>> void kvm_arm_restore_shadow_state(struct kvm_vcpu *vcpu); >>> void kvm_arm_init_cpu_context(kvm_cpu_context_t *cpu_ctxt); >>> diff --git a/arch/arm64/kvm/Makefile b/arch/arm64/kvm/Makefile >>> index 7811d27..b342bdd 100644 >>> --- a/arch/arm64/kvm/Makefile >>> +++ b/arch/arm64/kvm/Makefile >>> @@ -34,3 +34,5 @@ kvm-$(CONFIG_KVM_ARM_HOST) += $(KVM)/arm/vgic/vgic-its.o >>> kvm-$(CONFIG_KVM_ARM_HOST) += $(KVM)/irqchip.o >>> kvm-$(CONFIG_KVM_ARM_HOST) += $(KVM)/arm/arch_timer.o >>> kvm-$(CONFIG_KVM_ARM_PMU) += $(KVM)/arm/pmu.o >>> + >>> +kvm-$(CONFIG_KVM_ARM_NESTED_HYP) += emulate-nested.o >>> diff --git a/arch/arm64/kvm/emulate-nested.c b/arch/arm64/kvm/emulate-nested.c >>> new file mode 100644 >>> index 0000000..59d147f >>> --- /dev/null >>> +++ b/arch/arm64/kvm/emulate-nested.c >>> @@ -0,0 +1,66 @@ >>> +/* >>> + * Copyright (C) 2016 - Columbia University >>> + * Author: Jintack Lim <jintack@cs.columbia.edu> >>> + * >>> + * This program is free software; you can redistribute it and/or modify >>> + * it under the terms of the GNU General Public License version 2 as >>> + * published by the Free Software Foundation. >>> + * >>> + * This program is distributed in the hope that it will be useful, >>> + * but WITHOUT ANY WARRANTY; without even the implied warranty of >>> + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the >>> + * GNU General Public License for more details. >>> + * >>> + * You should have received a copy of the GNU General Public License >>> + * along with this program. If not, see <http://www.gnu.org/licenses/>. >>> + */ >>> + >>> +#include <linux/kvm.h> >>> +#include <linux/kvm_host.h> >>> + >>> +#include <asm/kvm_emulate.h> >>> + >>> +#include "trace.h" >>> + >>> +#define EL2_EXCEPT_SYNC_OFFSET 0x400 >>> +#define EL2_EXCEPT_ASYNC_OFFSET 0x480 >>> + >>> + >>> +/* >>> + * Emulate taking an exception. See ARM ARM J8.1.2 AArch64.TakeException() >>> + */ >>> +static int kvm_inject_nested(struct kvm_vcpu *vcpu, u64 esr_el2, >>> + int exception_offset) >>> +{ >>> + int ret = 1; >>> + kvm_cpu_context_t *ctxt = &vcpu->arch.ctxt; >>> + >>> + /* We don't inject an exception recursively to virtual EL2 */ >>> + if (vcpu_mode_el2(vcpu)) >>> + BUG(); >>> + >>> + ctxt->el2_regs[SPSR_EL2] = *vcpu_cpsr(vcpu); >>> + ctxt->el2_regs[ELR_EL2] = *vcpu_pc(vcpu); >>> + ctxt->el2_regs[ESR_EL2] = esr_el2; >>> + >>> + /* On an exception, PSTATE.SP = 1 */ >>> + *vcpu_cpsr(vcpu) = PSR_MODE_EL2h; >>> + *vcpu_cpsr(vcpu) |= (PSR_A_BIT | PSR_F_BIT | PSR_I_BIT | PSR_D_BIT); >>> + *vcpu_pc(vcpu) = ctxt->el2_regs[VBAR_EL2] + exception_offset; >>> + >>> + trace_kvm_inject_nested_exception(vcpu, esr_el2, *vcpu_pc(vcpu)); >>> + >>> + return ret; >>> +} >>> + >>> +int kvm_inject_nested_sync(struct kvm_vcpu *vcpu, u64 esr_el2) >>> +{ >>> + return kvm_inject_nested(vcpu, esr_el2, EL2_EXCEPT_SYNC_OFFSET); >>> +} >>> + >>> +int kvm_inject_nested_irq(struct kvm_vcpu *vcpu) >>> +{ >>> + u64 esr_el2 = kvm_vcpu_get_hsr(vcpu); >>> + /* We supports only IRQ and FIQ, so the esr_el2 is not updated. */ >>> + return kvm_inject_nested(vcpu, esr_el2, EL2_EXCEPT_ASYNC_OFFSET); >>> +} >>> diff --git a/arch/arm64/kvm/trace.h b/arch/arm64/kvm/trace.h >>> index 7fb0008..7c86cfb 100644 >>> --- a/arch/arm64/kvm/trace.h >>> +++ b/arch/arm64/kvm/trace.h >>> @@ -167,6 +167,26 @@ >>> ); >>> >>> >>> +TRACE_EVENT(kvm_inject_nested_exception, >>> + TP_PROTO(struct kvm_vcpu *vcpu, unsigned long esr_el2, >>> + unsigned long pc), >>> + TP_ARGS(vcpu, esr_el2, pc), >>> + >>> + TP_STRUCT__entry( >>> + __field(struct kvm_vcpu *, vcpu) >>> + __field(unsigned long, esr_el2) >>> + __field(unsigned long, pc) >>> + ), >>> + >>> + TP_fast_assign( >>> + __entry->vcpu = vcpu; >>> + __entry->esr_el2 = esr_el2; >>> + __entry->pc = pc; >>> + ), >>> + >>> + TP_printk("vcpu: %p, inject exception to vEL2: ESR_EL2 0x%lx, vector: 0x%016lx", >>> + __entry->vcpu, __entry->esr_el2, __entry->pc) >>> +); >>> #endif /* _TRACE_ARM64_KVM_H */ >>> >>> #undef TRACE_INCLUDE_PATH >> _______________________________________________ >> kvmarm mailing list >> kvmarm at lists.cs.columbia.edu >> https://lists.cs.columbia.edu/mailman/listinfo/kvmarm
next prev parent reply other threads:[~2017-06-06 22:07 UTC|newest] Thread overview: 322+ messages / expand[flat|nested] mbox.gz Atom feed top 2017-01-09 6:23 [RFC 00/55] Nested Virtualization on KVM/ARM Jintack Lim 2017-01-09 6:23 ` Jintack Lim 2017-01-09 6:23 ` Jintack Lim 2017-01-09 6:23 ` [RFC 01/55] arm64: Add missing TCR hw defines Jintack Lim 2017-01-09 6:23 ` Jintack Lim 2017-01-09 6:23 ` Jintack Lim 2017-01-09 6:23 ` [RFC 02/55] KVM: arm64: Add nesting config option Jintack Lim 2017-01-09 6:23 ` Jintack Lim 2017-01-09 6:23 ` Jintack Lim 2017-01-09 6:23 ` [RFC 03/55] KVM: arm64: Add KVM nesting feature Jintack Lim 2017-01-09 6:23 ` Jintack Lim 2017-01-09 6:23 ` Jintack Lim 2017-01-09 6:24 ` [RFC 04/55] KVM: arm64: Allow userspace to set PSR_MODE_EL2x Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` [RFC 05/55] KVM: arm64: Add vcpu_mode_el2 primitive to support nesting Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` [RFC 06/55] KVM: arm64: Add EL2 execution context for nesting Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-02-22 11:10 ` Christoffer Dall 2017-02-22 11:10 ` Christoffer Dall 2017-02-22 11:10 ` Christoffer Dall 2017-06-26 14:33 ` Jintack Lim 2017-06-26 14:33 ` Jintack Lim 2017-06-26 14:33 ` Jintack Lim 2017-07-03 9:03 ` Christoffer Dall 2017-07-03 9:03 ` Christoffer Dall 2017-07-03 9:03 ` Christoffer Dall 2017-07-03 9:32 ` Marc Zyngier 2017-07-03 9:32 ` Marc Zyngier 2017-07-03 9:32 ` Marc Zyngier 2017-07-03 9:54 ` Christoffer Dall 2017-07-03 9:54 ` Christoffer Dall 2017-07-03 9:54 ` Christoffer Dall 2017-07-03 14:44 ` Jintack Lim 2017-07-03 14:44 ` Jintack Lim 2017-07-03 14:44 ` Jintack Lim 2017-07-03 15:30 ` Christoffer Dall 2017-07-03 15:30 ` Christoffer Dall 2017-07-03 15:30 ` Christoffer Dall 2017-01-09 6:24 ` [RFC 07/55] KVM: arm/arm64: Add virtual EL2 state emulation framework Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-02-22 11:12 ` Christoffer Dall 2017-02-22 11:12 ` Christoffer Dall 2017-02-22 11:12 ` Christoffer Dall 2017-06-01 20:05 ` Bandan Das 2017-06-01 20:05 ` Bandan Das 2017-06-02 11:51 ` Christoffer Dall 2017-06-02 11:51 ` Christoffer Dall 2017-06-02 11:51 ` Christoffer Dall 2017-06-02 17:36 ` Bandan Das 2017-06-02 17:36 ` Bandan Das 2017-06-02 17:36 ` Bandan Das 2017-06-02 19:06 ` Christoffer Dall 2017-06-02 19:06 ` Christoffer Dall 2017-06-02 19:06 ` Christoffer Dall 2017-06-02 19:25 ` Bandan Das 2017-06-02 19:25 ` Bandan Das 2017-06-02 19:25 ` Bandan Das [not found] ` <20170602194353.GG397@cbox> 2017-06-02 20:18 ` Bandan Das 2017-06-02 21:15 ` Christoffer Dall 2017-06-02 23:49 ` Bandan Das 2017-01-09 6:24 ` [RFC 08/55] KVM: arm64: Set virtual EL2 context depending on the guest exception level Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-02-22 11:14 ` Christoffer Dall 2017-02-22 11:14 ` Christoffer Dall 2017-02-22 11:14 ` Christoffer Dall 2017-06-01 20:22 ` Bandan Das 2017-06-01 20:22 ` Bandan Das 2017-06-02 8:48 ` Marc Zyngier 2017-06-02 8:48 ` Marc Zyngier 2017-06-02 8:48 ` Marc Zyngier 2017-01-09 6:24 ` [RFC 09/55] KVM: arm64: Set shadow EL1 registers for virtual EL2 execution Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-02-22 11:19 ` Christoffer Dall 2017-02-22 11:19 ` Christoffer Dall 2017-01-09 6:24 ` [RFC 10/55] KVM: arm64: Synchronize EL1 system registers on virtual EL2 entry and exit Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-06-06 20:16 ` Bandan Das 2017-06-06 20:16 ` Bandan Das 2017-06-06 20:16 ` Bandan Das 2017-06-07 4:26 ` Jintack Lim 2017-06-07 4:26 ` Jintack Lim 2017-01-09 6:24 ` [RFC 11/55] KVM: arm64: Emulate taking an exception to the guest hypervisor Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-02-22 11:28 ` Christoffer Dall 2017-02-22 11:28 ` Christoffer Dall 2017-02-22 11:28 ` Christoffer Dall 2017-06-06 20:21 ` Bandan Das 2017-06-06 20:21 ` Bandan Das 2017-06-06 20:21 ` Bandan Das 2017-06-06 20:38 ` Jintack Lim 2017-06-06 20:38 ` Jintack Lim 2017-06-06 22:07 ` Bandan Das [this message] 2017-06-06 22:07 ` Bandan Das 2017-06-06 23:16 ` Jintack Lim 2017-06-06 23:16 ` Jintack Lim 2017-06-06 23:16 ` Jintack Lim 2017-06-07 17:21 ` Bandan Das 2017-06-07 17:21 ` Bandan Das 2017-01-09 6:24 ` [RFC 12/55] KVM: arm64: Handle EL2 register access traps Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-02-22 11:30 ` Christoffer Dall 2017-02-22 11:30 ` Christoffer Dall 2017-02-22 11:31 ` Christoffer Dall 2017-02-22 11:31 ` Christoffer Dall 2017-02-22 11:31 ` Christoffer Dall 2017-01-09 6:24 ` [RFC 13/55] KVM: arm64: Handle eret instruction traps Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` [RFC 14/55] KVM: arm64: Take account of system " Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-02-22 11:34 ` Christoffer Dall 2017-02-22 11:34 ` Christoffer Dall 2017-01-09 6:24 ` [RFC 15/55] KVM: arm64: Trap EL1 VM register accesses in virtual EL2 Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` [RFC 16/55] KVM: arm64: Forward VM reg traps to the guest hypervisor Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-02-22 11:39 ` Christoffer Dall 2017-02-22 11:39 ` Christoffer Dall 2017-02-22 11:39 ` Christoffer Dall 2017-01-09 6:24 ` [RFC 17/55] KVM: arm64: Trap SPSR_EL1, ELR_EL1 and VBAR_EL1 in virtual EL2 Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-02-22 11:40 ` Christoffer Dall 2017-02-22 11:40 ` Christoffer Dall 2017-01-09 6:24 ` [RFC 18/55] KVM: arm64: Forward traps due to HCR_EL2.NV1 bit to the guest hypervisor Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-02-22 11:41 ` Christoffer Dall 2017-02-22 11:41 ` Christoffer Dall 2017-01-09 6:24 ` [RFC 19/55] KVM: arm64: Trap CPACR_EL1 access in virtual EL2 Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` [RFC 20/55] KVM: arm64: Forward CPACR_EL1 traps to the guest hypervisor Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` [RFC 21/55] KVM: arm64: Forward HVC instruction " Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-02-22 11:47 ` Christoffer Dall 2017-02-22 11:47 ` Christoffer Dall 2017-02-22 11:47 ` Christoffer Dall 2017-06-26 15:21 ` Jintack Lim 2017-06-26 15:21 ` Jintack Lim 2017-06-26 15:21 ` Jintack Lim 2017-07-03 9:08 ` Christoffer Dall 2017-07-03 9:08 ` Christoffer Dall 2017-07-03 9:08 ` Christoffer Dall 2017-07-03 9:31 ` Andrew Jones 2017-07-03 9:31 ` Andrew Jones 2017-07-03 9:31 ` Andrew Jones 2017-07-03 9:51 ` Christoffer Dall 2017-07-03 9:51 ` Christoffer Dall 2017-07-03 9:51 ` Christoffer Dall 2017-07-03 12:03 ` Will Deacon 2017-07-03 12:03 ` Will Deacon 2017-07-03 12:03 ` Will Deacon 2017-07-03 12:35 ` Marc Zyngier 2017-07-03 12:35 ` Marc Zyngier 2017-07-03 12:35 ` Marc Zyngier 2017-07-03 13:29 ` Jintack Lim 2017-07-03 13:29 ` Jintack Lim 2017-07-03 13:29 ` Jintack Lim 2017-01-09 6:24 ` [RFC 22/55] KVM: arm64: Handle PSCI call from the guest Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` [RFC 23/55] KVM: arm64: Forward WFX to the guest hypervisor Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` [RFC 24/55] KVM: arm64: Forward FP exceptions " Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` [RFC 25/55] KVM: arm/arm64: Let vcpu thread modify its own active state Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-02-22 12:27 ` Christoffer Dall 2017-02-22 12:27 ` Christoffer Dall 2017-01-09 6:24 ` [RFC 26/55] KVM: arm/arm64: Add VGIC data structures for the nesting Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` [RFC 27/55] KVM: arm/arm64: Emulate GICH interface on GICv2 Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-02-22 13:06 ` Christoffer Dall 2017-02-22 13:06 ` Christoffer Dall 2017-01-09 6:24 ` [RFC 28/55] KVM: arm/arm64: Prepare vgic state for the nested VM Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-02-22 13:12 ` Christoffer Dall 2017-02-22 13:12 ` Christoffer Dall 2017-02-22 13:12 ` Christoffer Dall 2017-01-09 6:24 ` [RFC 29/55] KVM: arm/arm64: Set up the prepared vgic state Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` [RFC 30/55] KVM: arm/arm64: Inject irqs to the guest hypervisor Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-02-22 13:16 ` Christoffer Dall 2017-02-22 13:16 ` Christoffer Dall 2017-01-09 6:24 ` [RFC 31/55] KVM: arm/arm64: Inject maintenance interrupts " Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-02-22 13:19 ` Christoffer Dall 2017-02-22 13:19 ` Christoffer Dall 2017-02-22 13:19 ` Christoffer Dall 2017-01-09 6:24 ` [RFC 32/55] KVM: arm/arm64: register GICH iodev for " Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-02-22 13:21 ` Christoffer Dall 2017-02-22 13:21 ` Christoffer Dall 2017-02-22 13:21 ` Christoffer Dall 2017-01-09 6:24 ` [RFC 33/55] KVM: arm/arm64: Remove unused params in mmu functions Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` [RFC 34/55] KVM: arm/arm64: Abstract stage-2 MMU state into a separate structure Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` [RFC 35/55] KVM: arm/arm64: Support mmu for the virtual EL2 execution Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-02-22 13:38 ` Christoffer Dall 2017-02-22 13:38 ` Christoffer Dall 2017-02-22 13:38 ` Christoffer Dall 2017-01-09 6:24 ` [RFC 36/55] KVM: arm64: Invalidate virtual EL2 TLB entries when needed Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` [RFC 37/55] KVM: arm64: Setup vttbr_el2 on each VM entry Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` [RFC 38/55] KVM: arm/arm64: Make mmu functions non-static Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` [RFC 39/55] KVM: arm/arm64: Add mmu context for the nesting Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-02-22 13:34 ` Christoffer Dall 2017-02-22 13:34 ` Christoffer Dall 2017-02-22 13:34 ` Christoffer Dall 2017-01-09 6:24 ` [RFC 40/55] KVM: arm/arm64: Handle vttbr_el2 write operation from the guest hypervisor Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-02-22 17:59 ` Christoffer Dall 2017-02-22 17:59 ` Christoffer Dall 2017-02-22 17:59 ` Christoffer Dall 2017-01-09 6:24 ` [RFC 41/55] KVM: arm/arm64: Unmap/flush shadow stage 2 page tables Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-02-22 18:09 ` Christoffer Dall 2017-02-22 18:09 ` Christoffer Dall 2017-02-22 18:09 ` Christoffer Dall 2017-01-09 6:24 ` [RFC 42/55] KVM: arm64: Implement nested Stage-2 page table walk logic Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` [RFC 43/55] KVM: arm/arm64: Handle shadow stage 2 page faults Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` [RFC 44/55] KVM: arm/arm64: Move kvm_is_write_fault to header file Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` [RFC 45/55] KVM: arm64: KVM: Inject stage-2 page faults Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` [RFC 46/55] KVM: arm64: Add more info to the S2 translation result Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` [RFC 47/55] KVM: arm/arm64: Forward the guest hypervisor's stage 2 permission faults Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-02-22 18:15 ` Christoffer Dall 2017-02-22 18:15 ` Christoffer Dall 2017-02-22 18:15 ` Christoffer Dall 2017-01-09 6:24 ` [RFC 48/55] KVM: arm64: Emulate TLBI instruction Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` [RFC 49/55] KVM: arm64: Fixes to toggle_cache for nesting Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` [RFC 50/55] KVM: arm/arm64: Abstract kvm_phys_addr_ioremap() function Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` [RFC 51/55] KVM: arm64: Expose physical address of vcpu interface Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` [RFC 52/55] KVM: arm/arm64: Create a vcpu mapping for the nested VM Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` [RFC 53/55] KVM: arm64: Reflect shadow VMPIDR_EL2 value to MPIDR_EL1 Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` [RFC 54/55] KVM: arm/arm64: Adjust virtual offset considering nesting Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-02-22 19:28 ` Christoffer Dall 2017-02-22 19:28 ` Christoffer Dall 2017-02-22 19:28 ` Christoffer Dall 2017-01-09 6:24 ` [RFC 55/55] KVM: arm64: Enable nested virtualization Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 6:24 ` Jintack Lim 2017-01-09 15:05 ` [RFC 00/55] Nested Virtualization on KVM/ARM David Hildenbrand 2017-01-09 15:05 ` David Hildenbrand 2017-01-10 16:18 ` Jintack Lim 2017-01-10 16:18 ` Jintack Lim 2017-01-10 16:18 ` Jintack Lim 2017-02-22 18:23 ` Christoffer Dall 2017-02-22 18:23 ` Christoffer Dall 2017-02-22 18:23 ` Christoffer Dall 2017-02-24 10:08 ` Jintack Lim 2017-02-24 10:28 ` Jintack Lim 2017-02-24 10:28 ` Jintack Lim 2017-02-24 10:28 ` Jintack Lim
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=jpglgp4g48k.fsf@linux.bootlegged.copy \ --to=bsd@redhat.com \ --cc=andre.przywara@arm.com \ --cc=anna-maria@linutronix.de \ --cc=catalin.marinas@arm.com \ --cc=geoff@infradead.org \ --cc=jintack.lim@linaro.org \ --cc=jintack@cs.columbia.edu \ --cc=kevin.brodsky@arm.com \ --cc=kvm@vger.kernel.org \ --cc=kvmarm@lists.cs.columbia.edu \ --cc=linux-arm-kernel@lists.infradead.org \ --cc=linux-kernel@vger.kernel.org \ --cc=linux@armlinux.org.uk \ --cc=lorenzo.pieralisi@arm.com \ --cc=marc.zyngier@arm.com \ --cc=pbonzini@redhat.com \ --cc=shihwei@cs.columbia.edu \ --cc=wcohen@redhat.com \ --cc=will.deacon@arm.com \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: linkBe sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes, see mirroring instructions on how to clone and mirror all data and code used by this external index.