Received: by 2002:a05:7412:37c9:b0:e2:908c:2ebd with SMTP id jz9csp1100865rdb; Tue, 19 Sep 2023 22:28:17 -0700 (PDT) X-Google-Smtp-Source: AGHT+IHAjjxukyykix84x0XVkZ9eku2tp0058955vX++u7aXmOBZ9whNnwSFzCwSNJQ9ul/D2E8T X-Received: by 2002:a05:6358:2921:b0:134:d282:92e9 with SMTP id y33-20020a056358292100b00134d28292e9mr1822567rwb.29.1695187696840; Tue, 19 Sep 2023 22:28:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1695187696; cv=none; d=google.com; s=arc-20160816; b=ks3By94wxverzPUBeaqa6awnJ5eDYt6uDz30DuV9HT/QW9Yv4d17zPlBbUvFauVxGz Jf9jJ04VRxbMEj46PIDsCt+uP6i4IvrfkFvlE8d2VtnQlbOc6H33PTlU1DEmLCQSF0pq qaAHcNW3djFwZjzQGlS2lpSqSYVZemxPmJqhjJ7rquChSiPzOmEB8z+X9LTYHebXkl+Z SHhmHu6bGT3JCTgSsnko7KLTffS9QOm9cAR7ee353AAclv2MGFntMmk5mQKdqYfvg+II ccsRUaCThoplTE3K55FTsXtVNgKfPejcoccrMt7iD6Ci8lTSxdveR34pfpNEnZI6iRuh aLMg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=FdkiLvHF9gidro/3KgiAkGZtbptKxwZzl5vmZkiG0XI=; fh=nyUiyAsrvrmzhT78twm/HjZK3HoXiwGs/QcgTn/TSA0=; b=cxZuLiJ04US3MtFVC5anmmi2MyFtCioS2QBik0EOzwNnp81UbIl+3n4NiDoJvN1jZO 2SgtmWlx3XYEm6hWGwcrP60BKX8gHx0ahb2amoEjafcW4JQucK1P11lhsw8jjOjeqENq wuX3H6Gcty2Kfi75fxQLQTzu6ZlLn1OQZiyaysHAL3xM5ljYw7eemZWgYktnT4FJVBnq oi/SmLi+PKOYfBlLXC27xmNT2jGsH5juo8Lsn2VjnTvzSKETZ0FMhuHDTLPxE8wulSNH Tc03V0mqxJJPL+XGiVAiW9+PyuuFqB2XeBUr6uUmhJOC+624szqTL3AySDUeaK+LOrXL 15Gw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ventanamicro.com header.s=google header.b=pfbgTOqT; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.32 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from agentk.vger.email (agentk.vger.email. [23.128.96.32]) by mx.google.com with ESMTPS id bv189-20020a632ec6000000b00564929df8besi10884612pgb.568.2023.09.19.22.28.15 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 19 Sep 2023 22:28:16 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.32 as permitted sender) client-ip=23.128.96.32; Authentication-Results: mx.google.com; dkim=pass header.i=@ventanamicro.com header.s=google header.b=pfbgTOqT; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.32 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 066FF82195EA; Tue, 19 Sep 2023 22:26:09 -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 S233009AbjITF0H (ORCPT + 99 others); Wed, 20 Sep 2023 01:26:07 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:53072 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233002AbjITFZs (ORCPT ); Wed, 20 Sep 2023 01:25:48 -0400 Received: from mail-wm1-x333.google.com (mail-wm1-x333.google.com [IPv6:2a00:1450:4864:20::333]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 131461BC7 for ; Tue, 19 Sep 2023 22:24:19 -0700 (PDT) Received: by mail-wm1-x333.google.com with SMTP id 5b1f17b1804b1-403004a96a4so70991415e9.3 for ; Tue, 19 Sep 2023 22:24:18 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ventanamicro.com; s=google; t=1695187457; x=1695792257; darn=vger.kernel.org; h=in-reply-to:content-disposition:mime-version:references:message-id :subject:cc:to:from:date:from:to:cc:subject:date:message-id:reply-to; bh=FdkiLvHF9gidro/3KgiAkGZtbptKxwZzl5vmZkiG0XI=; b=pfbgTOqTiO1vDHPOs14bnMfDFcq6ArOs6YkseWn6RGBFn0eE6NZjx5HcAh8TAfXe2V wCvqU9QLrSFUAQp84GDbt4XIfn9aB2JQMhBeOvwBV9g8ZccaL8x1WSF74tlIpNwAVyY9 e9ba5lO8edqd27wyab4D89ytr6QK5yq5PkVDAWv8SHphWvOAMJbo68VLjSCM4QcY/5Ri e1waB+96Cqq7pApLH8MBrQT7pRvgm0qnfiK4YsnQY6HkgxBw+Li5viidv7084f9slMUt OB1xAarbWxe5TJn/Jv25Ybq0K/MGUNie78mLQM2P6qJQMgErftOPgbIOQNLGSY57OgcO 7VSw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1695187457; x=1695792257; h=in-reply-to:content-disposition:mime-version:references:message-id :subject:cc:to:from:date:x-gm-message-state:from:to:cc:subject:date :message-id:reply-to; bh=FdkiLvHF9gidro/3KgiAkGZtbptKxwZzl5vmZkiG0XI=; b=B1ng+t7Sv2DxZfnPyiXFUVoM/2V+BcrGA0sNQgwaNym1qzg8zbEHYHJ35JrXbT3Dgm keLQXywlPrSOXiu6TPaB6wbOPIiIlMKcpqRH4tG18ZHanhyhqyz10rTX4Lgx135hwKrt Q/JFGKTo86uiWAWnZU3+Hvludz3lAxLMPQQOwUYRhNucPGWiDvlRMultDFaiprGv9Dxi LDhmxAiaX4JRAndhGR24jChrT6CZMQLeiBw1JUiWVWjvXDDP23QzIzNtxvnWW1kEKN5f mwaId8cWsPJ166MU/Px3V48eg/W6iwSj/IyBtgR4zaIAw5bIGBQT2NoXjfuBB1TYlgKl fK+w== X-Gm-Message-State: AOJu0Yyt8MvRr0A9+IrTwBNIocq1V/a3ZhPVPhMIusU3t/1hNeBqYp5i mXhMmt7Zew+CcHs4fwoZFPb/LA== X-Received: by 2002:a1c:f702:0:b0:402:f5c4:2e5a with SMTP id v2-20020a1cf702000000b00402f5c42e5amr1429426wmh.37.1695187457228; Tue, 19 Sep 2023 22:24:17 -0700 (PDT) Received: from localhost (cst2-173-16.cust.vodafone.cz. [31.30.173.16]) by smtp.gmail.com with ESMTPSA id p5-20020a7bcc85000000b003fe407ca05bsm874397wma.37.2023.09.19.22.24.16 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 19 Sep 2023 22:24:16 -0700 (PDT) Date: Wed, 20 Sep 2023 07:24:16 +0200 From: Andrew Jones To: Anup Patel 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 Subject: Re: [PATCH 4/4] KVM: riscv: selftests: Selectively filter-out AIA registers Message-ID: <20230920-d524c40b616536d0ad8213c3@orel> References: <20230918180646.1398384-1-apatel@ventanamicro.com> <20230918180646.1398384-5-apatel@ventanamicro.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20230918180646.1398384-5-apatel@ventanamicro.com> 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]); Tue, 19 Sep 2023 22:26:09 -0700 (PDT) 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/testing/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 disabled */ > + 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; No need for the '? true : false' > 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] = { 0 }; nit: I think we prefer reverse xmas tree in kselftests, but whatever. > + > + for (int i = 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 = 0; i < KVM_RISCV_ISA_EXT_MAX; i++) > - __vcpu_set_reg(vcpu, RISCV_ISA_EXT_REG(i), 0); > + for (int i = 0; i < KVM_RISCV_ISA_EXT_MAX; i++) { > + rc = __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 return 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. > + isa_ext_cant_disable[i] = true; > + } > > for_each_sublist(c, s) { > if (!s->feature) > -- > 2.34.1 > Thanks, drew