qemu-arm
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Qemu-arm] [Qemu-devel] [PATCH v2 01/14] target/arm/cpu64: Ensure kv


From: Andrew Jones
Subject: Re: [Qemu-arm] [Qemu-devel] [PATCH v2 01/14] target/arm/cpu64: Ensure kvm really supports aarch64=off
Date: Wed, 24 Jul 2019 15:52:37 +0200
User-agent: NeoMutt/20180716

On Wed, Jul 24, 2019 at 02:51:15PM +0200, Auger Eric wrote:
> Hi Drew,
> 
> On 6/25/19 3:34 PM, Andrew Jones wrote:
> > On Tue, Jun 25, 2019 at 11:35:12AM +0200, Auger Eric wrote:
> >> Hi Drew,
> >>
> >> On 6/21/19 6:34 PM, Andrew Jones wrote:
> >>> If -cpu <cpu>,aarch64=off is used then KVM must also be used, and it
> >>> and the host must support running the vcpu in 32-bit mode. Also, if
> s/and it//

"and it and the host" means "and KVM and the host", as 'it' refers to the
last subject, which is KVM. I wanted to point out both the host (machine)
and KVM (version of kernel with KVM) need to support the feature.

> >>> -cpu <cpu>,aarch64=on is used, then it doesn't matter if kvm is
> >>> enabled or not.
> >>>
> >>> Signed-off-by: Andrew Jones <address@hidden>
> >>
> >>
> >>> ---
> >>>  target/arm/cpu64.c   | 12 ++++++------
> >>>  target/arm/kvm64.c   | 11 +++++++++++
> >>>  target/arm/kvm_arm.h | 14 ++++++++++++++
> >>>  3 files changed, 31 insertions(+), 6 deletions(-)
> >>>
> >>> diff --git a/target/arm/cpu64.c b/target/arm/cpu64.c
> >>> index 1901997a0645..946994838d8a 100644
> >>> --- a/target/arm/cpu64.c
> >>> +++ b/target/arm/cpu64.c
> >>> @@ -407,13 +407,13 @@ static void aarch64_cpu_set_aarch64(Object *obj, 
> >>> bool value, Error **errp)
> >>>       * restriction allows us to avoid fixing up functionality that 
> >>> assumes a
> >>>       * uniform execution state like do_interrupt.
> >>>       */> -    if (!kvm_enabled()) {
> >>> -        error_setg(errp, "'aarch64' feature cannot be disabled "
> >>> -                         "unless KVM is enabled");
> >>> -        return;
> >>> -    }
> >>> -
> >>>      if (value == false) {
> >>> +        if (!kvm_enabled() || !kvm_arm_aarch32_supported(CPU(cpu))) {
> >>> +            error_setg(errp, "'aarch64' feature cannot be disabled "
> >>> +                             "unless KVM is enabled and 32-bit EL1 "
> >>> +                             "is supported");
> >>> +            return;
> >>> +        }
> >>>          unset_feature(&cpu->env, ARM_FEATURE_AARCH64);
> >>>      } else {
> >>>          set_feature(&cpu->env, ARM_FEATURE_AARCH64);
> >>> diff --git a/target/arm/kvm64.c b/target/arm/kvm64.c
> >>> index 22d19c9aec6f..45ccda589903 100644
> >>> --- a/target/arm/kvm64.c
> >>> +++ b/target/arm/kvm64.c
> >>> @@ -24,7 +24,9 @@
> >>>  #include "exec/gdbstub.h"
> >>>  #include "sysemu/sysemu.h"
> >>>  #include "sysemu/kvm.h"
> >>> +#include "sysemu/kvm_int.h"
> >>>  #include "kvm_arm.h"
> >>> +#include "hw/boards.h"
> By the way those two new headers are not needed by this patch

Really?

current_machine is defined in hw/boards.h and KVM_STATE is defined
in sysemu/kvm_int.h.

> >>>  #include "internals.h"
> >>>  
> >>>  static bool have_guest_debug;
> >>> @@ -593,6 +595,15 @@ bool 
> >>> kvm_arm_get_host_cpu_features(ARMHostCPUFeatures *ahcf)
> >>>      return true;
> >>>  }
> >>>  
> >>> +bool kvm_arm_aarch32_supported(CPUState *cpu)
> >>> +{
> >>> +    KVMState *s = KVM_STATE(current_machine->accelerator);
> >>> +    int ret;
> >>> +
> >>> +    ret = kvm_check_extension(s, KVM_CAP_ARM_EL1_32BIT);
> >>> +    return ret > 0;
> >> nit: return kvm_check_extension() should be sufficient
> > 
> > Ah yes, I forgot kvm_check_extension() already converts negative
> > error codes to zero. I'll fix that for v3.
> > 
> >>> +}
> >>> +
> >>>  #define ARM_CPU_ID_MPIDR       3, 0, 0, 0, 5
> >>>  
> >>>  int kvm_arch_init_vcpu(CPUState *cs)
> >>> diff --git a/target/arm/kvm_arm.h b/target/arm/kvm_arm.h
> >>> index 2a07333c615f..812125f805a1 100644
> >>> --- a/target/arm/kvm_arm.h
> >>> +++ b/target/arm/kvm_arm.h
> >>> @@ -207,6 +207,15 @@ bool 
> >>> kvm_arm_get_host_cpu_features(ARMHostCPUFeatures *ahcf);
> >>>   */
> >>>  void kvm_arm_set_cpu_features_from_host(ARMCPU *cpu);
> >>>  
> >>> +/**
> >>> + * kvm_arm_aarch32_supported:
> >>> + * @cs: CPUState
> >> use kernel-doc comment style?
> > 
> > This file (kvm_arm.h) doesn't appear to have a super consistent comment
> > style. I see some use @var: for the parameters and some have 'Returns:
> > ...' lines as well. I'm happy to do whatever the maintainers prefer. For
> > now I was just trying to mimic whatever caught my eye.>
> >>> + *
> >>> + * Returns true if the KVM VCPU can enable AArch32 mode and false
> >>> + * otherwise.
> >>> + */
> >>> +bool kvm_arm_aarch32_supported(CPUState *cs);
> >>> +
> >>>  /**
> >>>   * kvm_arm_get_max_vm_ipa_size - Returns the number of bits in the
> >>>   * IPA address space supported by KVM
> >>> @@ -247,6 +256,11 @@ static inline void 
> >>> kvm_arm_set_cpu_features_from_host(ARMCPU *cpu)
> >>>      cpu->host_cpu_probe_failed = true;
> >>>  }
> >>>  
> >>> +static inline bool kvm_arm_aarch32_supported(CPUState *cs)
> >>> +{
> >>> +    return false;
> >>> +}
> >>> +
> >>>  static inline int kvm_arm_get_max_vm_ipa_size(MachineState *ms)
> >>>  {
> >>>      return -ENOENT;
> >>>
> >> Reviewed-by: Eric Auger <address@hidden>

Thanks,
drew



reply via email to

[Prev in Thread] Current Thread [Next in Thread]