Received: by 2002:a05:7412:37c9:b0:e2:908c:2ebd with SMTP id jz9csp1448882rdb; Wed, 20 Sep 2023 09:20:53 -0700 (PDT) X-Google-Smtp-Source: AGHT+IHKQcMMNu2Fi6E+6DTa6eG5qCFvuAikppwywmMtwoshGPbZDtXYzKugVPAcaA9eYPTOveVg X-Received: by 2002:a17:902:c94b:b0:1c3:c127:540 with SMTP id i11-20020a170902c94b00b001c3c1270540mr3087268pla.29.1695226853395; Wed, 20 Sep 2023 09:20:53 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1695226853; cv=none; d=google.com; s=arc-20160816; b=cPeBeOL2D4RBK/poVJ0tsD3sv+Z5Ar4G2ouUZL7hZLTnnunQQOawMQI4BS1Jei6zKe Lnl5equvzf4uTYz7v/HRJtpcOAEfte8Py416efd7llBeEpTLEOGBDljDQuJTxaXYqOUd GXvoixcws6WgeZiZsGGlMBU0M4Py0mX5k4Fd3yal6LwRYwC/LROctKcwBw+NDFBWg6R2 LWmzd2J5c55+cWFOMibOhHYd1Sp5vuURqLcLBtGPFoMnjvpOn/YQwpRvXvSENwTTWh86 AyRQncDldcwKLy+9Uwo91NzMlljugTQZ6BlEq/IfHHzXNOiwvRg2Ygr0TMcl6u/oRUZb IsKg== 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=lyKrFqZ6pe873R1m/St9homGtI5DVB4Bs4vDfySSmyA=; fh=4kjes2AuGTwSE6H98UCcV5p1A6gA7DjNR9klogUtRto=; b=rQlKaHQPY7mVqmMjTNLBmjz5iLIp3bfG2qX9fxFOEr1Wn7WzTpWqdm+HpJF6GnJulk 6XGSKmTsSYRyVhi4n+5jffAGYn+AAhsM/haAOCpb2crJoeDWOY9oLK7GSIEgGLvHhygg T1FBGqCHQsYAy/2GbUb31L5ag0vZk7OSTmwd+oV9uCq/kUUOq9sQIbZO/lY8u4nhK2Dq mHYD0icpnLTjWcBMY/plZNn9BbOuY5idIc3Nb1hlFxWRDKy8eFFWuwxRMsNl4EKiRvXw 1yPa83+TSlCrgsQGi3K5xl3CiM+89nmgTb2G1Eze/ep0+Y2OLJvHiq6fxE+T6VoPmKyM ZQ4w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ventanamicro.com header.s=google header.b=ov3W+Y1h; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.35 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from groat.vger.email (groat.vger.email. [23.128.96.35]) by mx.google.com with ESMTPS id f10-20020a170902ce8a00b001bda93595d9si12770844plg.604.2023.09.20.09.20.52 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 20 Sep 2023 09:20:53 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.35 as permitted sender) client-ip=23.128.96.35; Authentication-Results: mx.google.com; dkim=pass header.i=@ventanamicro.com header.s=google header.b=ov3W+Y1h; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.35 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 groat.vger.email (Postfix) with ESMTP id AB0A880A3640; Wed, 20 Sep 2023 06:50:16 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at groat.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236359AbjITNuD (ORCPT + 99 others); Wed, 20 Sep 2023 09:50:03 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:57464 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236231AbjITNuB (ORCPT ); Wed, 20 Sep 2023 09:50:01 -0400 Received: from mail-pg1-x530.google.com (mail-pg1-x530.google.com [IPv6:2607:f8b0:4864:20::530]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id B0915CA for ; Wed, 20 Sep 2023 06:49:54 -0700 (PDT) Received: by mail-pg1-x530.google.com with SMTP id 41be03b00d2f7-565e54cb93aso4031068a12.3 for ; Wed, 20 Sep 2023 06:49:54 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ventanamicro.com; s=google; t=1695217794; x=1695822594; 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=lyKrFqZ6pe873R1m/St9homGtI5DVB4Bs4vDfySSmyA=; b=ov3W+Y1h5haJhja/3rDUZDGJozRUmn71LF7tPrGTrzStr9/tMJHuqigqWG3EO3ygvo czFTEHZ6DPHB0hcXysYSBP1hULo6L4ovpB/K0mAJruNhTSyltm0ShmiiDL+MKPTFqJ/Q +Ox0xcSgWAKc5Zk5K9yrkhsn1Ghkl8TTZFkSCoVgIxgwCFDwfjlk7kIHIWgRntTLBYvH bhP4lduvHqoCeJsWdJ7t9bI+zPmrcWu9its1jJXlqNGHDXm6BBY4OJhW3aF/sl3/1uXp sKS6Z7ZuzejaKlgn65GYAqpLWmkodak7o65pQDxAMXF5TH+ewzrtaXaGx34Xz+uF1jHS VrWQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1695217794; x=1695822594; 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=lyKrFqZ6pe873R1m/St9homGtI5DVB4Bs4vDfySSmyA=; b=tFb6tTVXjJW7amOGaBYHgxdYm0hqzOhdTL7h/+Srb+frLCPvXHpm7zKLrC/db6IVkY P7cZeV6bMbL/GzQcwRgm0qu75vIkR671LeDEjix0pW9lmIi96FiHnk8vddbdXW0B8y3i G6eUHRmcDt9C52VVon6qq0KzCnCLsR/sq5OJiMMPVi2YcyFrFYuIzWgkxnTGNtioQKaZ F4PflFmKQpiuO305tXxwYdfMBiDKAIPvK5i/gUGAIYmhjMw8RJfMWqRUFTZ66wTtnM6F sFJCcX0A88Y2trcHzgBxtFwYuxjBUHUC+IPyvBdyOIkt736DElhXdNSl1Xu5XFOpzhzN OPHg== X-Gm-Message-State: AOJu0YyzzD6/WCTEoVwmZAF+W1tzLW78LnL3VBtWVRfDgEGZR+ZMHII+ wT6IDDkixzlO0S7Gf7yX0DxJmlg4IPtIFgoLt1nW5w== X-Received: by 2002:a17:90a:7c01:b0:274:b4ce:7049 with SMTP id v1-20020a17090a7c0100b00274b4ce7049mr2566829pjf.34.1695217793948; Wed, 20 Sep 2023 06:49:53 -0700 (PDT) MIME-Version: 1.0 References: <20230918180646.1398384-1-apatel@ventanamicro.com> <20230918180646.1398384-5-apatel@ventanamicro.com> <20230920-d524c40b616536d0ad8213c3@orel> In-Reply-To: <20230920-d524c40b616536d0ad8213c3@orel> From: Anup Patel Date: Wed, 20 Sep 2023 19:19:42 +0530 Message-ID: Subject: Re: [PATCH 4/4] KVM: riscv: selftests: Selectively filter-out AIA registers To: Andrew Jones Cc: Paolo Bonzini , Atish Patra , Shuah Khan , Palmer Dabbelt , Paul Walmsley , 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 groat.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 (groat.vger.email [0.0.0.0]); Wed, 20 Sep 2023 06:50:16 -0700 (PDT) On Wed, Sep 20, 2023 at 10:54=E2=80=AFAM Andrew Jones wrote: > > On Mon, Sep 18, 2023 at 11:36:46PM +0530, 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 disable= d */ > > + case KVM_REG_RISCV_CSR | KVM_REG_RISCV_CSR_AIA | KVM_REG_RISCV_CS= R_AIA_REG(siselect): > > + case KVM_REG_RISCV_CSR | KVM_REG_RISCV_CSR_AIA | KVM_REG_RISCV_CS= R_AIA_REG(iprio1): > > + case KVM_REG_RISCV_CSR | KVM_REG_RISCV_CSR_AIA | KVM_REG_RISCV_CS= R_AIA_REG(iprio2): > > + case KVM_REG_RISCV_CSR | KVM_REG_RISCV_CSR_AIA | KVM_REG_RISCV_CS= R_AIA_REG(sieh): > > + case KVM_REG_RISCV_CSR | KVM_REG_RISCV_CSR_AIA | KVM_REG_RISCV_CS= R_AIA_REG(siph): > > + case KVM_REG_RISCV_CSR | KVM_REG_RISCV_CSR_AIA | KVM_REG_RISCV_CS= R_AIA_REG(iprio1h): > > + case KVM_REG_RISCV_CSR | KVM_REG_RISCV_CSR_AIA | KVM_REG_RISCV_CS= R_AIA_REG(iprio2h): > > + return isa_ext_cant_disable[KVM_RISCV_ISA_EXT_SSAIA] ? tr= ue : false; > > No need for the '? true : false' Okay, I will update. > > > 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 }; > > nit: I think we prefer reverse xmas tree in kselftests, but whatever. Okay, I will update. > > > + > > + for (int i =3D 0; i < KVM_RISCV_ISA_EXT_MAX; i++) > > + __vcpu_get_reg(vcpu, RISCV_ISA_EXT_REG(i), &isa_ext_state= [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]) > > How helpful is it to check that isa_ext_state[i] isn't zero? The value of > the register could be zero, right? Shouldn't we instead capture the retur= n > values from __vcpu_get_reg and if the return value is zero for a get, > but nonzero for a set, then we know we have it, but can't disable it. The intent is to find-out the ISA_EXT registers which are enabled but we are not able to disable it. > > > + isa_ext_cant_disable[i] =3D true; > > + } > > > > for_each_sublist(c, s) { > > if (!s->feature) > > -- > > 2.34.1 > > > > Thanks, > drew Regards, Anup