Received: by 2002:a05:7412:37c9:b0:e2:908c:2ebd with SMTP id jz9csp1143507rdb; Wed, 20 Sep 2023 00:16:25 -0700 (PDT) X-Google-Smtp-Source: AGHT+IEmugZY1ZlnnFcTmjQDbTSAPGsOVGrAbw8rkK0gciq6MLrjvHGG3sox+yrl8UTddWaPU4jn X-Received: by 2002:a05:6358:909:b0:139:a0fd:780a with SMTP id r9-20020a056358090900b00139a0fd780amr2421599rwi.12.1695194185185; Wed, 20 Sep 2023 00:16:25 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1695194185; cv=none; d=google.com; s=arc-20160816; b=P2T/lJs+pPdeOYK/sDUVtlzokjTBHDnEonrZIJCxz8338SZ+a8qq124m8xZQlEQ200 dNE7obsb0wPwO1BQotAYZQFKzoSrbTy725WhTdHWvyDJucdear4LwRNW2+nUQ+IlKDSP M/E3OfZhoK7LAY1rkPrRO+rUq8uZZ2TqrEhqtv4M5nCjHuDdrAeUPVcwX67H872ZtaqR gkuepDc9t2s+F1a8QyIwISozIs/DOI2r0bGYk6UwA0OT9tRBVBInqZ9aiqhumVDP/nYG 4VfSZLBHxU2LzLSad9CBNShdAeMLuBIXpmhiKlovX7qL7+VFa1ZM7GgmlwQLm4DWsxMD xU3w== 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=nA7XftN55Rzt443xAle+6ZlQo/LHZ8P1ArIv8UK8Is8=; fh=nyUiyAsrvrmzhT78twm/HjZK3HoXiwGs/QcgTn/TSA0=; b=ipCO4p+D6p0PBbbeIEDWxa73wGS2ao72RD2GgT4zRvuQyy8AtCHclzhlTfiamr9H7L U5M2Mft6c+uq/jH7xKYz5oAejKfrEb0tBSfg8iYdHEQamc1eNHAVDKxO3RpqR3fgWEwS PC5pQPId2F08qtT0kmJQALcknVdPvd62dmxa4rhO6A415uxOrbXWZFOHNKTDHaU9cqSN dSGez7bMO4bsYEW/TrYrKdoh6SysKCltKzyh5jG4URvupA/zwxHGD+PcI6KYo+q5cuug cu5Q1AUHyXwRj5JvY9+n2Gm2eE1WWr95ejAmVcJboRvRc3MVpqpfV4L/p+pYkdV9SAfj 9OHQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ventanamicro.com header.s=google header.b=fU3GI35x; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.31 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from morse.vger.email (morse.vger.email. [23.128.96.31]) by mx.google.com with ESMTPS id p126-20020a634284000000b0056536fc7901si10530130pga.593.2023.09.20.00.16.24 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 20 Sep 2023 00:16:25 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.31 as permitted sender) client-ip=23.128.96.31; Authentication-Results: mx.google.com; dkim=pass header.i=@ventanamicro.com header.s=google header.b=fU3GI35x; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.31 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 morse.vger.email (Postfix) with ESMTP id 7974582B514B; Tue, 19 Sep 2023 22:14:20 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at morse.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232160AbjITFOG (ORCPT + 99 others); Wed, 20 Sep 2023 01:14:06 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:50588 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229521AbjITFOC (ORCPT ); Wed, 20 Sep 2023 01:14:02 -0400 Received: from mail-wr1-x42e.google.com (mail-wr1-x42e.google.com [IPv6:2a00:1450:4864:20::42e]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 1BD84AF for ; Tue, 19 Sep 2023 22:13:56 -0700 (PDT) Received: by mail-wr1-x42e.google.com with SMTP id ffacd0b85a97d-313e742a787so292853f8f.1 for ; Tue, 19 Sep 2023 22:13:56 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ventanamicro.com; s=google; t=1695186833; x=1695791633; 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=nA7XftN55Rzt443xAle+6ZlQo/LHZ8P1ArIv8UK8Is8=; b=fU3GI35xj4gIYlDA3e/SMKhU/TvT+tXvgDBJgWDGhrBrk6looZWCFtbi3bMa/cRf2D q6354kv8kQ6h3yibaETrhqqvBFYpf+q1CyyfwafIsMzc1XS4zhV7yhFLuQ3VlcR1smPs TMIoh2Krr/h2605PuoogUFjAfHRyESTL/s6WSApIHYE7thAOrzmcg4UcHtqzmqEmGhi0 CDqGom2IrMxEmY6oAuCw6R+nEhjl9fCuUsTUQwAC2yydUMwDiaxhgVBFkCiT4CCCnBxr vbeMRZO0CeEkOS6vr/SC1hXol0P0yFOCvZQr0TzTcReUkLry1KcIPQ3d8M/6Fr5TH96Y XrZA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1695186833; x=1695791633; 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=nA7XftN55Rzt443xAle+6ZlQo/LHZ8P1ArIv8UK8Is8=; b=YIUF/xPyWe56TKo+/HptMZe5msbM+YsvoC1EHnMUy3RuACXsdfbVXm8IxjGWUWmnsa DNjfDg4QK6vT5IRMQU+9cQnz6BstHW4vqJXIWT3gKqqFFZJ34p+PdOjGm72JQQCbC8ws pCqJPiwSbAd//60qjOIKYBKkeX+/jtT8AKFBwtEUSjVhJbAKy1maxZRzmk64zt8T8h8l 4ZYrxW0LN2qZ0BmO4sYVzMf2AGZnRYPRzVw7ruygUncWmdlmTUx3mOuJJ9KSygPt4f92 s/FIzDc+0BXDuBiXPmxsXG5qVSNC4KdX33hCC96OjlYgFFqjVZyELYBtDmkDoNyvSdyg fY7w== X-Gm-Message-State: AOJu0Yy42QnQHXP0bL0TqAnv89pHQo8Pa/IUbWdT1/F9mg+e/QZiivfG 018OezEgy3E8CBv4h7yw5ZjF0Q== X-Received: by 2002:adf:f9c5:0:b0:31f:f9e8:3fce with SMTP id w5-20020adff9c5000000b0031ff9e83fcemr3545885wrr.16.1695186833161; Tue, 19 Sep 2023 22:13:53 -0700 (PDT) Received: from localhost (cst2-173-16.cust.vodafone.cz. [31.30.173.16]) by smtp.gmail.com with ESMTPSA id l21-20020a7bc455000000b003fee8502999sm863420wmi.18.2023.09.19.22.13.52 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 19 Sep 2023 22:13:52 -0700 (PDT) Date: Wed, 20 Sep 2023 07:13:52 +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 3/4] KVM: riscv: selftests: Fix ISA_EXT register handling in get-reg-list Message-ID: <20230920-c166b288c4c1c17144dc3709@orel> References: <20230918180646.1398384-1-apatel@ventanamicro.com> <20230918180646.1398384-4-apatel@ventanamicro.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20230918180646.1398384-4-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 morse.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 (morse.vger.email [0.0.0.0]); Tue, 19 Sep 2023 22:14:20 -0700 (PDT) On Mon, Sep 18, 2023 at 11:36:45PM +0530, Anup Patel wrote: > Same set of ISA_EXT registers are not present on all host because > ISA_EXT registers are visible to the KVM user space based on the > ISA extensions available on the host. Also, disabling an ISA > extension using corresponding ISA_EXT register does not affect > the visibility of the ISA_EXT register itself. > > Based on the above, we should filter-out all ISA_EXT registers. > > Fixes: 477069398ed6 ("KVM: riscv: selftests: Add get-reg-list test") > Signed-off-by: Anup Patel > --- > .../selftests/kvm/riscv/get-reg-list.c | 35 +++++++++++-------- > 1 file changed, 21 insertions(+), 14 deletions(-) > > diff --git a/tools/testing/selftests/kvm/riscv/get-reg-list.c b/tools/testing/selftests/kvm/riscv/get-reg-list.c > index d8ecacd03ecf..76c0ad11e423 100644 > --- a/tools/testing/selftests/kvm/riscv/get-reg-list.c > +++ b/tools/testing/selftests/kvm/riscv/get-reg-list.c > @@ -14,17 +14,33 @@ > > bool filter_reg(__u64 reg) > { > + switch (reg & ~REG_MASK) { > /* > - * Some ISA extensions are optional and not present on all host, > - * but they can't be disabled through ISA_EXT registers when present. > - * So, to make life easy, just filtering out these kind of registers. > + * Same set of ISA_EXT registers are not present on all host because > + * ISA_EXT registers are visible to the KVM user space based on the > + * ISA extensions available on the host. Also, disabling an ISA > + * extension using corresponding ISA_EXT register does not affect > + * the visibility of the ISA_EXT register itself. > + * > + * Based on above, we should filter-out all ISA_EXT registers. > */ > - switch (reg & ~REG_MASK) { > + case KVM_REG_RISCV_ISA_EXT | KVM_RISCV_ISA_EXT_A: > + case KVM_REG_RISCV_ISA_EXT | KVM_RISCV_ISA_EXT_C: > + case KVM_REG_RISCV_ISA_EXT | KVM_RISCV_ISA_EXT_D: > + case KVM_REG_RISCV_ISA_EXT | KVM_RISCV_ISA_EXT_F: > + case KVM_REG_RISCV_ISA_EXT | KVM_RISCV_ISA_EXT_H: > + case KVM_REG_RISCV_ISA_EXT | KVM_RISCV_ISA_EXT_I: > + case KVM_REG_RISCV_ISA_EXT | KVM_RISCV_ISA_EXT_M: > + case KVM_REG_RISCV_ISA_EXT | KVM_RISCV_ISA_EXT_SVPBMT: > case KVM_REG_RISCV_ISA_EXT | KVM_RISCV_ISA_EXT_SSTC: > case KVM_REG_RISCV_ISA_EXT | KVM_RISCV_ISA_EXT_SVINVAL: > case KVM_REG_RISCV_ISA_EXT | KVM_RISCV_ISA_EXT_ZIHINTPAUSE: > + case KVM_REG_RISCV_ISA_EXT | KVM_RISCV_ISA_EXT_ZICBOM: > + case KVM_REG_RISCV_ISA_EXT | KVM_RISCV_ISA_EXT_ZICBOZ: > case KVM_REG_RISCV_ISA_EXT | KVM_RISCV_ISA_EXT_ZBB: > case KVM_REG_RISCV_ISA_EXT | KVM_RISCV_ISA_EXT_SSAIA: > + case KVM_REG_RISCV_ISA_EXT | KVM_RISCV_ISA_EXT_V: > + case KVM_REG_RISCV_ISA_EXT | KVM_RISCV_ISA_EXT_SVNAPOT: > case KVM_REG_RISCV_ISA_EXT | KVM_RISCV_ISA_EXT_ZBA: > case KVM_REG_RISCV_ISA_EXT | KVM_RISCV_ISA_EXT_ZBS: > case KVM_REG_RISCV_ISA_EXT | KVM_RISCV_ISA_EXT_ZICNTR: > @@ -50,12 +66,7 @@ static inline bool vcpu_has_ext(struct kvm_vcpu *vcpu, int ext) > unsigned long value; > > ret = __vcpu_get_reg(vcpu, RISCV_ISA_EXT_REG(ext), &value); > - if (ret) { > - printf("Failed to get ext %d", ext); > - return false; > - } > - > - return !!value; > + return (ret) ? false : !!value; This is an unrelated change, but OK. It's consistent with the plan[1] we have on the timer test series [1] https://lore.kernel.org/all/20230914-d6645bbc5ac80999674e9685@orel/ > } > > void finalize_vcpu(struct kvm_vcpu *vcpu, struct vcpu_reg_list *c) > @@ -506,10 +517,6 @@ static __u64 base_regs[] = { > KVM_REG_RISCV | KVM_REG_SIZE_U64 | KVM_REG_RISCV_TIMER | KVM_REG_RISCV_TIMER_REG(time), > KVM_REG_RISCV | KVM_REG_SIZE_U64 | KVM_REG_RISCV_TIMER | KVM_REG_RISCV_TIMER_REG(compare), > KVM_REG_RISCV | KVM_REG_SIZE_U64 | KVM_REG_RISCV_TIMER | KVM_REG_RISCV_TIMER_REG(state), > - KVM_REG_RISCV | KVM_REG_SIZE_ULONG | KVM_REG_RISCV_ISA_EXT | KVM_RISCV_ISA_EXT_A, > - KVM_REG_RISCV | KVM_REG_SIZE_ULONG | KVM_REG_RISCV_ISA_EXT | KVM_RISCV_ISA_EXT_C, > - KVM_REG_RISCV | KVM_REG_SIZE_ULONG | KVM_REG_RISCV_ISA_EXT | KVM_RISCV_ISA_EXT_I, > - KVM_REG_RISCV | KVM_REG_SIZE_ULONG | KVM_REG_RISCV_ISA_EXT | KVM_RISCV_ISA_EXT_M, > KVM_REG_RISCV | KVM_REG_SIZE_ULONG | KVM_REG_RISCV_SBI_EXT | KVM_REG_RISCV_SBI_SINGLE | KVM_RISCV_SBI_EXT_V01, > KVM_REG_RISCV | KVM_REG_SIZE_ULONG | KVM_REG_RISCV_SBI_EXT | KVM_REG_RISCV_SBI_SINGLE | KVM_RISCV_SBI_EXT_TIME, > KVM_REG_RISCV | KVM_REG_SIZE_ULONG | KVM_REG_RISCV_SBI_EXT | KVM_REG_RISCV_SBI_SINGLE | KVM_RISCV_SBI_EXT_IPI, > -- > 2.34.1 > Reviewed-by: Andrew Jones Thanks, drew