Received: by 2002:a05:7412:37c9:b0:e2:908c:2ebd with SMTP id jz9csp1750293rdb; Wed, 20 Sep 2023 20:15:38 -0700 (PDT) X-Google-Smtp-Source: AGHT+IFAX4j142YhJji7YZVpQ9rJ14cJFoO2imNH8wRh0SbgzMHs3+0uFCol6LM+GNQRCjteaO3h X-Received: by 2002:a05:6870:95aa:b0:1d5:b442:5de7 with SMTP id k42-20020a05687095aa00b001d5b4425de7mr4367602oao.35.1695266138249; Wed, 20 Sep 2023 20:15:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1695266138; cv=none; d=google.com; s=arc-20160816; b=QykCppJza/WQDd5XHayS7FD3bnXS7W7gKWcd8/0pydctSa3xDz9l8vtS0T0QLzjftS q0i3icoLIJewR1kP5BppDFctmcJ/cxA74iot5a6BJSEESymS4d+X7KT3kcSFVlgMvvY1 wE43puGeuO9+CFMLExVG0TWqzdb5dycd6bwIUEcH8Hm7GiDFiKllAp/+4BV24/MqJjrF zgJujCt8hpZ/b85gOK0fKFyMcTcxU5yA9qycjxiQ3kpSHIgIHusg0jFeOgfAymb1/5eS e9It9LRe/kPAQuzJF6A2kfwGiXKShK0a0+Hg4RSBNqACZmY1FQ1lHYgeCTocIjNi1+cq FaWA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:cc:to:subject :message-id:date:from:in-reply-to:references:mime-version :dkim-signature; bh=FzKUIkp2N4mFsPMBkGOtGZ83qroR9oeUcPf9C3+REGI=; fh=A07UykoNowvCS/XB4wrapAq8Pn2Qnt/Yr/ezxJenYLA=; b=Os301eeKC+xv3yy25Dly8zJo0r3AfvuztjLM8V8cXnMvNiGEuzpSZSFG7Xn7UW6pjT y9foxJWri5CTZAE/87xLvgi8j9x9oKO1KUlPUpNPANSqXrfXDRDqyeaPyvoYTXebjMJE wlmM2ynuEd0GPGOAZ96AiaEVY+/zRQRFTNru+J9Fz8fG0m90e5+uyHZoy6Y3MWv20wL2 0WYV1se4T2BecAY4iooHgSYlYaaFoMbqUOuFm1KnwwioCZMmFS9etD4hTU+0sf5IGSjH g0XIl3ZA+ka82/dKhEGJMkDqwOYz8lEbmF01oq0/4E9Lt6pudgzq9nXxVUXg2+9BZqak DaiQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ventanamicro.com header.s=google header.b=Afz5XzDw; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:2 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from agentk.vger.email (agentk.vger.email. [2620:137:e000::3:2]) by mx.google.com with ESMTPS id n13-20020a65488d000000b005777bea0b6asi434579pgs.859.2023.09.20.20.15.37 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 20 Sep 2023 20:15:38 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:2 as permitted sender) client-ip=2620:137:e000::3:2; Authentication-Results: mx.google.com; dkim=pass header.i=@ventanamicro.com header.s=google header.b=Afz5XzDw; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:2 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by agentk.vger.email (Postfix) with ESMTP id 939F6825AC13; Wed, 20 Sep 2023 06:52:24 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at agentk.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236373AbjITNwQ (ORCPT + 99 others); Wed, 20 Sep 2023 09:52:16 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:54596 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234796AbjITNwO (ORCPT ); Wed, 20 Sep 2023 09:52:14 -0400 Received: from mail-pg1-x52c.google.com (mail-pg1-x52c.google.com [IPv6:2607:f8b0:4864:20::52c]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id EFA87B9 for ; Wed, 20 Sep 2023 06:52:08 -0700 (PDT) Received: by mail-pg1-x52c.google.com with SMTP id 41be03b00d2f7-578af21ff50so1617168a12.1 for ; Wed, 20 Sep 2023 06:52:08 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ventanamicro.com; s=google; t=1695217928; x=1695822728; darn=vger.kernel.org; h=content-transfer-encoding:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:from:to:cc:subject:date :message-id:reply-to; bh=FzKUIkp2N4mFsPMBkGOtGZ83qroR9oeUcPf9C3+REGI=; b=Afz5XzDwptMY7dWBZQPXw2i0KdFVRR6oMLfCqIQ9e7jBl6L8qTcD5KYq5ZThPKHSv4 t49sU10OIwYxFm0vm2HM9LJjDpPlhBxYQtQvW5PKAuFvf1h9nRVSFgW409JijUhfwDtk FM31hIqH8mmQ50yRJXCu4e28aNrpm2h6MKLutBcb6EgpzMsS3DP0DIkzK4rBBi30cJOR 1+VWSEmGmvo6XyqtYLfIRrZyeojrpCbKjoiQi+7AZRzIAN8JcOYDrgfqOO2VwMvTTjku KbuRfhoEThYJGT1bSb8+FdOLSG3cX9hqSd18DLatbNq0Ewvilc62/H2UcUU/ftddgtn4 sofQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1695217928; x=1695822728; h=content-transfer-encoding:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=FzKUIkp2N4mFsPMBkGOtGZ83qroR9oeUcPf9C3+REGI=; b=JVo9vi5Y790JlStG7j0qAefvvvO6OR1pYALJLAwAtOSe+2VtLQNXssimvW9YYRZBXo QdJdajSALiGe2l7UC31XxhpkDRxv2s3mhXSAoANnD4/pCf31Kja6jvevuGZrDP3N0QqM Xszmi7rVVI/WteTqmVN+a0wNTVhITEVrAYOvNf/blfG9zGJt9cqqx20CnNRhke//tOtx AmRgXy6CyogKloysq/iFqXniDtqZfw1x+i7Tjk6yqJwYf4+O0mj1KcB1KXnBGHumt3Y0 fom/Jw286CWhetzNy4PHOAK6Uv5WVfSICazHpPj1XnJ4lWO6O6qDgCu9r1QO58ToP5Yl s3Vg== X-Gm-Message-State: AOJu0YzAMj6N7sVbAZtEP85UPPO3MTZjjSTY1d182wTXmWlwia6bmk88 u7vJlq4MVzWUlaLlw1nw9myackM0BDSNSt5Npo0KjQ== X-Received: by 2002:a17:90a:3d43:b0:26b:7d8e:edf9 with SMTP id o3-20020a17090a3d4300b0026b7d8eedf9mr2256888pjf.49.1695217928154; Wed, 20 Sep 2023 06:52:08 -0700 (PDT) MIME-Version: 1.0 References: <20230918180646.1398384-1-apatel@ventanamicro.com> <20230918180646.1398384-5-apatel@ventanamicro.com> In-Reply-To: From: Anup Patel Date: Wed, 20 Sep 2023 19:21:56 +0530 Message-ID: Subject: Re: [PATCH 4/4] KVM: riscv: selftests: Selectively filter-out AIA registers To: Atish Patra Cc: Paolo Bonzini , Shuah Khan , Palmer Dabbelt , Paul Walmsley , Andrew Jones , kvm@vger.kernel.org, kvm-riscv@lists.infradead.org, linux-riscv@lists.infradead.org, linux-kernel@vger.kernel.org, linux-kselftest@vger.kernel.org Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable X-Spam-Status: No, score=-0.9 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI, SPF_HELO_NONE,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on agentk.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (agentk.vger.email [0.0.0.0]); Wed, 20 Sep 2023 06:52:24 -0700 (PDT) On Wed, Sep 20, 2023 at 1:43=E2=80=AFAM Atish Patra = wrote: > > On Mon, Sep 18, 2023 at 11:07=E2=80=AFAM Anup Patel wrote: > > > > Currently the AIA ONE_REG registers are reported by get-reg-list > > as new registers for various vcpu_reg_list configs whenever Ssaia > > is available on the host because Ssaia extension can only be > > disabled by Smstateen extension which is not always available. > > > > To tackle this, we should filter-out AIA ONE_REG registers only > > when Ssaia can't be disabled for a VCPU. > > > > Fixes: 477069398ed6 ("KVM: riscv: selftests: Add get-reg-list test") > > Signed-off-by: Anup Patel > > --- > > .../selftests/kvm/riscv/get-reg-list.c | 23 +++++++++++++++++-- > > 1 file changed, 21 insertions(+), 2 deletions(-) > > > > diff --git a/tools/testing/selftests/kvm/riscv/get-reg-list.c b/tools/t= esting/selftests/kvm/riscv/get-reg-list.c > > index 76c0ad11e423..85907c86b835 100644 > > --- a/tools/testing/selftests/kvm/riscv/get-reg-list.c > > +++ b/tools/testing/selftests/kvm/riscv/get-reg-list.c > > @@ -12,6 +12,8 @@ > > > > #define REG_MASK (KVM_REG_ARCH_MASK | KVM_REG_SIZE_MASK) > > > > +static bool isa_ext_cant_disable[KVM_RISCV_ISA_EXT_MAX]; > > + > > bool filter_reg(__u64 reg) > > { > > switch (reg & ~REG_MASK) { > > @@ -48,6 +50,15 @@ bool filter_reg(__u64 reg) > > case KVM_REG_RISCV_ISA_EXT | KVM_RISCV_ISA_EXT_ZIFENCEI: > > case KVM_REG_RISCV_ISA_EXT | KVM_RISCV_ISA_EXT_ZIHPM: > > return true; > > + /* AIA registers are always available when Ssaia can't be disab= led */ > > + case KVM_REG_RISCV_CSR | KVM_REG_RISCV_CSR_AIA | KVM_REG_RISCV_= CSR_AIA_REG(siselect): > > + case KVM_REG_RISCV_CSR | KVM_REG_RISCV_CSR_AIA | KVM_REG_RISCV_= CSR_AIA_REG(iprio1): > > + case KVM_REG_RISCV_CSR | KVM_REG_RISCV_CSR_AIA | KVM_REG_RISCV_= CSR_AIA_REG(iprio2): > > + case KVM_REG_RISCV_CSR | KVM_REG_RISCV_CSR_AIA | KVM_REG_RISCV_= CSR_AIA_REG(sieh): > > + case KVM_REG_RISCV_CSR | KVM_REG_RISCV_CSR_AIA | KVM_REG_RISCV_= CSR_AIA_REG(siph): > > + case KVM_REG_RISCV_CSR | KVM_REG_RISCV_CSR_AIA | KVM_REG_RISCV_= CSR_AIA_REG(iprio1h): > > + case KVM_REG_RISCV_CSR | KVM_REG_RISCV_CSR_AIA | KVM_REG_RISCV_= CSR_AIA_REG(iprio2h): > > + return isa_ext_cant_disable[KVM_RISCV_ISA_EXT_SSAIA] ? = true : false; > > Ahh I guess. you do need the switch case for AIA CSRs but for ISA > extensions can be avoided as it is contiguous. Fow now, let's leave it as-is because this way get-reg-list will complain if some new ONE_REG register is missed out. > > > default: > > break; > > } > > @@ -71,14 +82,22 @@ static inline bool vcpu_has_ext(struct kvm_vcpu *vc= pu, int ext) > > > > void finalize_vcpu(struct kvm_vcpu *vcpu, struct vcpu_reg_list *c) > > { > > + int rc; > > struct vcpu_reg_sublist *s; > > + unsigned long isa_ext_state[KVM_RISCV_ISA_EXT_MAX] =3D { 0 }; > > + > > + for (int i =3D 0; i < KVM_RISCV_ISA_EXT_MAX; i++) > > + __vcpu_get_reg(vcpu, RISCV_ISA_EXT_REG(i), &isa_ext_sta= te[i]); > > > > /* > > * Disable all extensions which were enabled by default > > * if they were available in the risc-v host. > > */ > > - for (int i =3D 0; i < KVM_RISCV_ISA_EXT_MAX; i++) > > - __vcpu_set_reg(vcpu, RISCV_ISA_EXT_REG(i), 0); > > + for (int i =3D 0; i < KVM_RISCV_ISA_EXT_MAX; i++) { > > + rc =3D __vcpu_set_reg(vcpu, RISCV_ISA_EXT_REG(i), 0); > > + if (rc && isa_ext_state[i]) > > + isa_ext_cant_disable[i] =3D true; > > + } > > > > for_each_sublist(c, s) { > > if (!s->feature) > > -- > > 2.34.1 > > > > Otherwise, LGTM. > > Reviewed-by: Atish Patra > > -- > Regards, > Atish Regards, Anup