Received: by 2002:a05:7412:37c9:b0:e2:908c:2ebd with SMTP id jz9csp1124253rdb; Tue, 19 Sep 2023 23:30:57 -0700 (PDT) X-Google-Smtp-Source: AGHT+IGhn4QinmTch8+yGPyb6kOUeInCM/03r7wz/KolmtzA/nEyPEWuuZmnmwSzy3RJ0P63xDdT X-Received: by 2002:a17:902:8217:b0:1c3:90c7:b99d with SMTP id x23-20020a170902821700b001c390c7b99dmr1225862pln.41.1695191457547; Tue, 19 Sep 2023 23:30:57 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1695191457; cv=none; d=google.com; s=arc-20160816; b=Cb2i2l1vwGpSCE3a0xDiBD3xRywqbbNgQPGIJq8jsluX6vNbskAehUb4d1fH7bWUBY 8vsTzivabVaK9p8UjDl5zN1kqlzU64ijdwmut2oscTmcCMXNHlBeamAeP67YsCrfl5/d FUQisqBu9kDhmjjZsqehVzqd45ABJUackUifFQ7hp7TevsZQXsBq0rci665qSaHfY9b1 5JInPSbKXoyoZJFtSW7st2v+Q7KtGbyBaJ/ZgQr6UciaPLj/uV5uyt6cuIDfh1g6Ckvg DtRXWUMs11bEfNwrYVRlpsAXPul4nd5CqyxsNebpiwygb1cF2TOrTJO63BGCCEYK/oBp fGHQ== 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=p6ch6RWPf/XAfaKMkUuRJLYD6PuDcDg5GNJHK0YM5ng=; fh=Q5KFsCqdtJ06CcCAgyB8mcohzWvqjFprTxYkwhTQtOU=; b=FSk3uuIyktlk3kTTw5UeFuXh2UaQynC/tn/GaKS0IHujVtN9620MDKXc4qMZTaIHlD +jq65MOzRHZCxu3MVHolvEkeChkC61A3s0tevHRbgCqikyRB3NywklHoj1ISZuPHHCLU 6xIY+DCx1Ynqoj8Ft1hYDkaBvdBTL19na9R0JiOFSTzNc/02vH4D0wgqlKAM8P0T7eLJ VOAkPmwrYocdUWrGoQkUBjO8I0w1g3FGHK0g7hAlabWAPIOBTN6+w2PHYbtb+nwhuujT 5VK4E53eYA1mUqbLZipcPS3xmQItygG+D/0nQYNmcGArRUxV4kQYqqJCLO6r8kS8jSGq 2jjQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@atishpatra.org header.s=google header.b=H6azQLfU; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.34 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from howler.vger.email (howler.vger.email. [23.128.96.34]) by mx.google.com with ESMTPS id w2-20020a170902904200b001c32fe6cdf9si10628648plz.386.2023.09.19.23.30.56 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 19 Sep 2023 23:30:57 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.34 as permitted sender) client-ip=23.128.96.34; Authentication-Results: mx.google.com; dkim=pass header.i=@atishpatra.org header.s=google header.b=H6azQLfU; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.34 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 howler.vger.email (Postfix) with ESMTP id C76B1829BD5D; Tue, 19 Sep 2023 13:13:11 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at howler.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233178AbjISUNI (ORCPT + 99 others); Tue, 19 Sep 2023 16:13:08 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:57888 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232805AbjISUNH (ORCPT ); Tue, 19 Sep 2023 16:13:07 -0400 Received: from mail-lf1-x131.google.com (mail-lf1-x131.google.com [IPv6:2a00:1450:4864:20::131]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 9B21ABA for ; Tue, 19 Sep 2023 13:13:00 -0700 (PDT) Received: by mail-lf1-x131.google.com with SMTP id 2adb3069b0e04-502e6d632b6so9506733e87.0 for ; Tue, 19 Sep 2023 13:13:00 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=atishpatra.org; s=google; t=1695154379; x=1695759179; 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=p6ch6RWPf/XAfaKMkUuRJLYD6PuDcDg5GNJHK0YM5ng=; b=H6azQLfUcVLGTpySUHDi6XvpCGX2HO9hB5XSzuHOP3RtjKYFone6gtqnDhFzHEIczN WdtyCOBvauJoBFbgSex+/zf7Kf6W9xGvMyUFeM+ezVqJMQ3zOiDN7mPmkIIzVeL4tMza ujyp5w7M5my4mST117KQMABpl3UF/JXeTu9Jk= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1695154379; x=1695759179; 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=p6ch6RWPf/XAfaKMkUuRJLYD6PuDcDg5GNJHK0YM5ng=; b=J+jMjoLdK6yMRHobqn9jHEByTRBHeB9dxby/2czXYDi8MsOgvijAT08JiFCGolIjGK 6ui3SjXhyYJKts5+roK/6x0E2rnrYznMMv+aFYE20c+0k7SkO1rUKEqfn8CbnbDkB0hC XwR3i+9KPNvJqnnOd5JAJhQ4o/ZCawbZUNFO0ulb2zPT11wxCRZUum6Yau9O+B0aNFTO IBbR1B1zLVI0gV/Fpe04RzsRzJuGmZFZ1e2/WsYcLMH+skHHRkDktYJKJ3EvQ2MQzvtn alPudSGMH8sm2LXOZc9O/xsPccfh2ieZm072XHPkOeD5V1hOxx/mLF3gHG7qIa4gUb36 QbLg== X-Gm-Message-State: AOJu0YzaYJLgmQDUzFxt1iTyXz0DP4N3j8V8jpJItptwSKTQg8buZ4d1 w6icikqp6deFAaf7Dcl7j6zouODbAUesDPjPraqW X-Received: by 2002:ac2:4da7:0:b0:502:9fce:b6cc with SMTP id h7-20020ac24da7000000b005029fceb6ccmr589020lfe.11.1695154378656; Tue, 19 Sep 2023 13:12:58 -0700 (PDT) MIME-Version: 1.0 References: <20230918180646.1398384-1-apatel@ventanamicro.com> <20230918180646.1398384-5-apatel@ventanamicro.com> In-Reply-To: <20230918180646.1398384-5-apatel@ventanamicro.com> From: Atish Patra Date: Tue, 19 Sep 2023 13:12:47 -0700 Message-ID: Subject: Re: [PATCH 4/4] KVM: riscv: selftests: Selectively filter-out AIA registers To: Anup Patel 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=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, SPF_HELO_NONE,SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net 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 (howler.vger.email [0.0.0.0]); Tue, 19 Sep 2023 13:13:12 -0700 (PDT) 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/tes= ting/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; Ahh I guess. you do need the switch case for AIA CSRs but for ISA extensions can be avoided as it is contiguous. > default: > break; > } > @@ -71,14 +82,22 @@ static inline bool vcpu_has_ext(struct kvm_vcpu *vcpu= , 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_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]) > + isa_ext_cant_disable[i] =3D true; > + } > > for_each_sublist(c, s) { > if (!s->feature) > -- > 2.34.1 > Otherwise, LGTM. Reviewed-by: Atish Patra --=20 Regards, Atish