Received: by 2002:a05:7412:37c9:b0:e2:908c:2ebd with SMTP id jz9csp1478917rdb; Wed, 20 Sep 2023 10:09:09 -0700 (PDT) X-Google-Smtp-Source: AGHT+IEwYr7pXtZWZsItfM5RQUrdOba4lBOwG6OtnOZaPofhu+c6w+aOHR5JXmfZ4ilj1nlTx7TM X-Received: by 2002:a17:903:32c5:b0:1bc:4415:3c1 with SMTP id i5-20020a17090332c500b001bc441503c1mr9293321plr.7.1695229749590; Wed, 20 Sep 2023 10:09:09 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1695229749; cv=none; d=google.com; s=arc-20160816; b=CD1jG83VvDVJJA5PYxn59U+lQ/lvA2dm/yyoBXBdvJBlj2G+6IGM7dyRAoAQ+s6htW FPxPeWmDyB4Unq/21oVWeMf45P5c4F1smM00dLJWD9JSV3d7w5k6gHg2z6d0kmkU3PBs qWaP849xI7AL2xSPuuTcRtL3mvaCpjq8rhqT7rGcTRxti6H7lzaLJG+bpRSvDoURpfnI puAzOgjj4s5BA4tzxTZH63Wx0faawh7Z9TcfcSsPF6QOJYoJ7FM8yKiQsxKyMqji63jk BOdiRDrJNpxzXjHyFu148/iEul5Pmvl3spuD8Zn2A8us5Q3lEWTzTYMLnWXWpiyPTWbO XmRA== 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-transfer-encoding :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=m1zNdUzVc6Pr4pcVKMskltzftfT89TOksGte9XFhwTk=; fh=+bPEwRvYNcp0BWRDulgrlTJsMRalHgU3rWVvFIZvRWc=; b=0W0TcXDtu9vI7X2N4T3bswzzDpOnuYJ9wHImEWxGGDxBI75ep62MnhF8vV+pphRdU1 3dZwXrBbwNM+ZnulAbE3gpI/hzXgIKN+fd+8rgcW7Mx9+lm2W43hx2JeF4R0pDwyPlXl MgtDswtIQi7uQMhW9T5moFL0fwjSl07thS+5gU26JLQMKHFi8BVa/ARA26lhuNNHHFae rAAsLOddlkOVHFKOEmynZ6JsVTJyeDCiEgUVk09egGVH6tETCwV4guMYz/yhw7tN6Q4H twZ5NPXNoWLzazUAZZZ0iXDLR9owjOcBJTAJcagOSgti9VmPWLCcQBIObAJ5Rp7h8mJ7 3CMw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ventanamicro.com header.s=google header.b=NNPGHjV5; 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 j190-20020a638bc7000000b00578b785d46csi3476759pge.193.2023.09.20.10.09.09 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 20 Sep 2023 10:09:09 -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=@ventanamicro.com header.s=google header.b=NNPGHjV5; 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 D727E80FD39C; Tue, 19 Sep 2023 21:48:29 -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 S231675AbjITEsX (ORCPT + 99 others); Wed, 20 Sep 2023 00:48:23 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:35608 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229770AbjITEsV (ORCPT ); Wed, 20 Sep 2023 00:48:21 -0400 Received: from mail-wm1-x330.google.com (mail-wm1-x330.google.com [IPv6:2a00:1450:4864:20::330]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id EF60D9C for ; Tue, 19 Sep 2023 21:48:14 -0700 (PDT) Received: by mail-wm1-x330.google.com with SMTP id 5b1f17b1804b1-4051f8e1ba0so5708335e9.1 for ; Tue, 19 Sep 2023 21:48:14 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ventanamicro.com; s=google; t=1695185293; x=1695790093; darn=vger.kernel.org; h=in-reply-to:content-transfer-encoding:content-disposition :mime-version:references:message-id:subject:cc:to:from:date:from:to :cc:subject:date:message-id:reply-to; bh=m1zNdUzVc6Pr4pcVKMskltzftfT89TOksGte9XFhwTk=; b=NNPGHjV53xANPWwuwjnbRMVW11TDIyX6tRzO2So/mXhIYKDkn8IPbQkLNlLe7CUGPR 2Dg5tYoH33JqtyKSPzztxF11jy3y+rR3RwAXA12dck7wlzlD5EthXdnHM/e0lp69VDyy L7wldaV8/Y5vX+Bf8SciY7BTDPlBYmvX9WV6BLpB6Vo4BkbZkQuahtxOzSrYTKJ3yS9l dJ0HQdmKQZrIVj6D0BBdnkBHzWEMGAotkoH9okLmzWnStK2bsmT/fSoIIvWaEmeMjBN3 ywegrRZYL7yRHCAR4ofb6n5vdWjIXby6b8ArjfriVqIdY4ak1yUqs7i8f2AdNvOh84Cz J+zg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1695185293; x=1695790093; h=in-reply-to:content-transfer-encoding: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=m1zNdUzVc6Pr4pcVKMskltzftfT89TOksGte9XFhwTk=; b=ucaI8gezjTcICy0tmHVqh1IBvUR+Din34ZbHmFXjcGF00fOqunatyzqRcYqtbezNjJ gZW1mOAPZkoWKiT0I1rD8cZmBEvWDTMseUv2sJzVnieExVs/7B49P/zHVjZTRlGa7wRq LJ/3qHNg2mxSFbxD+xlKR0ChH1JZZwyjxOG2gkrDdfauMp6Kgg723IonBWCLLE1K3IDS ahiTeJblOGnUcm9cZB5tXR+3lhTadBEQ3WCrBJP12CY2JzkmlQVD+4lMQaBvSka7pa0H v9i7CHzkFu9P+FcfJsamlq/ZvcKA3sCS5PjppjE7GDEQM1B8cyj0de5BxX9HiQ9e3nBO G2hw== X-Gm-Message-State: AOJu0Yz87nn7WJh7gR4cJq/cOkpSrKNjAuHZ1vAb04LqJo3E6AWWhnNd JwrR+0F2qGGaAUxuRED3qM8NZw== X-Received: by 2002:a7b:cd8c:0:b0:401:d2cb:e6f3 with SMTP id y12-20020a7bcd8c000000b00401d2cbe6f3mr1247667wmj.1.1695185293390; Tue, 19 Sep 2023 21:48:13 -0700 (PDT) Received: from localhost (cst2-173-16.cust.vodafone.cz. [31.30.173.16]) by smtp.gmail.com with ESMTPSA id 15-20020a05600c020f00b00401d8810c8bsm805326wmi.15.2023.09.19.21.48.12 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 19 Sep 2023 21:48:12 -0700 (PDT) Date: Wed, 20 Sep 2023 06:48:11 +0200 From: Andrew Jones To: Atish Patra Cc: Anup Patel , Paolo Bonzini , 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-bc0e3956d144be651727e252@orel> References: <20230918180646.1398384-1-apatel@ventanamicro.com> <20230918180646.1398384-5-apatel@ventanamicro.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: 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_BLOCKED, 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 21:48:30 -0700 (PDT) On Tue, Sep 19, 2023 at 01:12:47PM -0700, Atish Patra wrote: > On Mon, Sep 18, 2023 at 11:07 AM 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; > > Ahh I guess. you do need the switch case for AIA CSRs but for ISA > extensions can be avoided as it is contiguous. I guess we could so something like case KVM_REG_RISCV_ISA_EXT ... KVM_REG_RISCV_ISA_EXT | KVM_RISCV_ISA_EXT_MAX: for the ISA extensions. Thanks, drew