qemu-s390x
[Top][All Lists]
Advanced

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

Re: [qemu-s390x] [PATCH 2/2] s390x/kvm: add etoken facility


From: David Hildenbrand
Subject: Re: [qemu-s390x] [PATCH 2/2] s390x/kvm: add etoken facility
Date: Tue, 31 Jul 2018 12:59:21 +0200
User-agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.8.0

On 31.07.2018 11:04, Christian Borntraeger wrote:
> Provide the etoken facility. We need to handle cpu model, migration and
> clear reset.
> 
> Signed-off-by: Christian Borntraeger <address@hidden>
> Acked-by: Janosch Frank <address@hidden>
> ---
>  target/s390x/cpu.h              |  3 +++
>  target/s390x/cpu_features.c     |  3 ++-
>  target/s390x/cpu_features_def.h |  3 ++-
>  target/s390x/gen-features.c     |  3 ++-
>  target/s390x/kvm.c              | 11 +++++++++++
>  target/s390x/machine.c          | 20 +++++++++++++++++++-
>  6 files changed, 39 insertions(+), 4 deletions(-)
> 
> diff --git a/target/s390x/cpu.h b/target/s390x/cpu.h
> index 2c3dd2d189..21b2f211fe 100644
> --- a/target/s390x/cpu.h
> +++ b/target/s390x/cpu.h
> @@ -2,6 +2,7 @@
>   * S/390 virtual CPU header
>   *
>   *  Copyright (c) 2009 Ulrich Hecht
> + *  Copyright IBM Corp. 2012, 2018
>   *
>   * This library is free software; you can redistribute it and/or
>   * modify it under the terms of the GNU Lesser General Public
> @@ -68,6 +69,8 @@ struct CPUS390XState {
>      uint32_t aregs[16];    /* access registers */
>      uint8_t riccb[64];     /* runtime instrumentation control */
>      uint64_t gscb[4];      /* guarded storage control */
> +    uint64_t etoken;       /* etoken */
> +    uint64_t etoken_extension; /* etoken extension */
>  
>      /* Fields up to this point are not cleared by initial CPU reset */
>      struct {} start_initial_reset_fields;
> diff --git a/target/s390x/cpu_features.c b/target/s390x/cpu_features.c
> index 3b9e2745e9..397960f278 100644
> --- a/target/s390x/cpu_features.c
> +++ b/target/s390x/cpu_features.c
> @@ -1,7 +1,7 @@
>  /*
>   * CPU features/facilities for s390x
>   *
> - * Copyright 2016 IBM Corp.
> + * Copyright IBM Corp. 2016, 2018
>   *
>   * Author(s): David Hildenbrand <address@hidden>
>   *
> @@ -106,6 +106,7 @@ static const S390FeatDef s390_features[] = {
>      FEAT_INIT("irbm", S390_FEAT_TYPE_STFL, 145, 
> "Insert-reference-bits-multiple facility"),
>      FEAT_INIT("msa8-base", S390_FEAT_TYPE_STFL, 146, 
> "Message-security-assist-extension-8 facility (excluding subfunctions)"),
>      FEAT_INIT("cmmnt", S390_FEAT_TYPE_STFL, 147, "CMM: ESSA-enhancement (no 
> translate) facility"),
> +    FEAT_INIT("etoken", S390_FEAT_TYPE_STFL, 156, "etoken facility"),
>  
>      /* SCLP SCCB Byte 80 - 98  (bit numbers relative to byte-80) */
>      FEAT_INIT("gsls", S390_FEAT_TYPE_SCLP_CONF_CHAR, 40, "SIE: 
> Guest-storage-limit-suppression facility"),
> diff --git a/target/s390x/cpu_features_def.h b/target/s390x/cpu_features_def.h
> index 7c5915c7b2..ac2c947f30 100644
> --- a/target/s390x/cpu_features_def.h
> +++ b/target/s390x/cpu_features_def.h
> @@ -1,7 +1,7 @@
>  /*
>   * CPU features/facilities for s390
>   *
> - * Copyright 2016 IBM Corp.
> + * Copyright IBM Corp. 2016, 2018
>   *
>   * Author(s): Michael Mueller <address@hidden>
>   *            David Hildenbrand <address@hidden>
> @@ -93,6 +93,7 @@ typedef enum {
>      S390_FEAT_INSERT_REFERENCE_BITS_MULT,
>      S390_FEAT_MSA_EXT_8,
>      S390_FEAT_CMM_NT,
> +    S390_FEAT_ETOKEN,
>  
>      /* Sclp Conf Char */
>      S390_FEAT_SIE_GSLS,
> diff --git a/target/s390x/gen-features.c b/target/s390x/gen-features.c
> index 6626b6f565..5af042c003 100644
> --- a/target/s390x/gen-features.c
> +++ b/target/s390x/gen-features.c
> @@ -1,7 +1,7 @@
>  /*
>   * S390 feature list generator
>   *
> - * Copyright 2016 IBM Corp.
> + * Copyright IBM Corp. 2016, 2018
>   *
>   * Author(s): Michael Mueller <address@hidden>
>   *            David Hildenbrand <address@hidden>
> @@ -471,6 +471,7 @@ static uint16_t full_GEN14_GA1[] = {
>      S390_FEAT_GROUP_MSA_EXT_7,
>      S390_FEAT_GROUP_MSA_EXT_8,
>      S390_FEAT_CMM_NT,
> +    S390_FEAT_ETOKEN,
>      S390_FEAT_HPMA2,
>      S390_FEAT_SIE_KSS,
>      S390_FEAT_GROUP_MULTIPLE_EPOCH_PTFF,
> diff --git a/target/s390x/kvm.c b/target/s390x/kvm.c
> index d923cf4240..af83955e5f 100644
> --- a/target/s390x/kvm.c
> +++ b/target/s390x/kvm.c
> @@ -493,6 +493,12 @@ int kvm_arch_put_registers(CPUState *cs, int level)
>          cs->kvm_run->kvm_dirty_regs |= KVM_SYNC_BPBC;
>      }
>  
> +    if (can_sync_regs(cs, KVM_SYNC_ETOKEN)) {
> +        cs->kvm_run->s.regs.etoken = env->etoken;
> +        cs->kvm_run->s.regs.etoken_extension  = env->etoken_extension;
> +        cs->kvm_run->kvm_dirty_regs |= KVM_SYNC_ETOKEN;
> +    }
> +
>      /* Finally the prefix */
>      if (can_sync_regs(cs, KVM_SYNC_PREFIX)) {
>          cs->kvm_run->s.regs.prefix = env->psa;
> @@ -607,6 +613,11 @@ int kvm_arch_get_registers(CPUState *cs)
>          env->bpbc = cs->kvm_run->s.regs.bpbc;
>      }
>  
> +    if (can_sync_regs(cs, KVM_SYNC_ETOKEN)) {
> +        env->etoken = cs->kvm_run->s.regs.etoken;
> +        env->etoken_extension = cs->kvm_run->s.regs.etoken_extension;
> +    }
> +
>      /* pfault parameters */
>      if (can_sync_regs(cs, KVM_SYNC_PFAULT)) {
>          env->pfault_token = cs->kvm_run->s.regs.pft;
> diff --git a/target/s390x/machine.c b/target/s390x/machine.c
> index bd3230d027..cb792aa103 100644
> --- a/target/s390x/machine.c
> +++ b/target/s390x/machine.c
> @@ -1,7 +1,7 @@
>  /*
>   * S390x machine definitions and functions
>   *
> - * Copyright IBM Corp. 2014
> + * Copyright IBM Corp. 2014, 2018
>   *
>   * Authors:
>   *   Thomas Huth <address@hidden>
> @@ -216,6 +216,23 @@ const VMStateDescription vmstate_bpbc = {
>      }
>  };
>  
> +static bool etoken_needed(void *opaque)
> +{
> +    return s390_has_feat(S390_FEAT_ETOKEN);
> +}
> +
> +const VMStateDescription vmstate_etoken = {
> +    .name = "cpu/etoken",
> +    .version_id = 1,
> +    .minimum_version_id = 1,
> +    .needed = etoken_needed,
> +    .fields = (VMStateField[]) {
> +        VMSTATE_UINT64(env.etoken, S390CPU),
> +        VMSTATE_UINT64(env.etoken_extension, S390CPU),
> +        VMSTATE_END_OF_LIST()
> +    }
> +};
> +
>  const VMStateDescription vmstate_s390_cpu = {
>      .name = "cpu",
>      .post_load = cpu_post_load,
> @@ -251,6 +268,7 @@ const VMStateDescription vmstate_s390_cpu = {
>          &vmstate_exval,
>          &vmstate_gscb,
>          &vmstate_bpbc,
> +        &vmstate_etoken,
>          NULL
>      },
>  };
> 

Apart from the capital letter, this looks good to me!

Reviewed-by: David Hildenbrand <address@hidden>

-- 

Thanks,

David / dhildenb



reply via email to

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