Received: by 2002:a05:6358:c692:b0:131:369:b2a3 with SMTP id fe18csp3931949rwb; Sun, 30 Jul 2023 20:30:20 -0700 (PDT) X-Google-Smtp-Source: APBJJlHJDJYHxtKS63E0VxToYvZW3U49M1KhinQopmLwb/xcXLq95TOMTWKgs1iAhj9zJLIh4fsh X-Received: by 2002:a05:6a20:12d6:b0:133:6816:c889 with SMTP id v22-20020a056a2012d600b001336816c889mr11511473pzg.40.1690774219914; Sun, 30 Jul 2023 20:30:19 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1690774219; cv=none; d=google.com; s=arc-20160816; b=WGLIUH1UU1PC6MJobI8Q6Ke3GAsECwmLECxqu90nyuxb9zYkBxLujlniPNbseJY5WP UFSSIHAk6FNd8rZVH5CRvRV6aPmLQGA9JXqkA9OnVI5AkZE5FV6uLKb94wDv7V4v6bf3 njY3ECOUFTj2ju2JQTzDrJLZNWEHcBNvkIo41LVK/Av2GaZIyNF9/rHJ5xnYumxl5mKh K1CsGnEXrZVoabyYHJpC1L/KQvyClYBsHRVKzCnaWOujGg2ROAAmLlzchubQjNDq/fR7 xwbMV1BcZZ8ntarx6MqFroJjaXYHCqs1rdI8NK7gTlLBNBrpkLugC0FjKYZNKsNd96fN r6tg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id; bh=ujMgVkXseW0PPhO6oiySifdUgl1B25RlP/ork4/2n1g=; fh=mspiG0sUm6yuRXFGm2epq1nC4PCPBHlKD2mIAwTyjkc=; b=vR6eVrQoMOUASeUaU2+tZp0nC8kLWFX69hkkJDJtrxOKBuKwHP5sH/6IEuUCeYVa8C q7arQ0a+IXAw4LFPwHhGPqQ3duKlyEpZ+4PBzUD/FK7O3lpr7y1r/6Im7vnrG40G53MR vU8AMygKpkliy/6Fh6ny9XwbYl6ZhWDtCy2aIo7fwaN9UD1ZGHSWLAOxpVd8Miykia1o RKGl+omvto4BH6HNSGFoh82M8CWDmwURxSn9A1tx6yg7OIoWAv4Abtvck9eLK3wOcNHH OsN3egrK/NN4J9vhFDoansG97nL3JpV1RM7WsYo/qkfkUobdrRJjBSpr1e3nJ+pkskWp dvWw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id q5-20020a632a05000000b0055b4ef605cesi6100244pgq.802.2023.07.30.20.30.08; Sun, 30 Jul 2023 20:30:19 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229799AbjGaCdf (ORCPT + 99 others); Sun, 30 Jul 2023 22:33:35 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:37298 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229749AbjGaCdb (ORCPT ); Sun, 30 Jul 2023 22:33:31 -0400 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 4AFC5E7B; Sun, 30 Jul 2023 19:33:29 -0700 (PDT) Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 118A01650; Sun, 30 Jul 2023 19:34:12 -0700 (PDT) Received: from [10.162.41.7] (a077893.blr.arm.com [10.162.41.7]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 34B663F6C4; Sun, 30 Jul 2023 19:33:23 -0700 (PDT) Message-ID: <937468a1-b325-7d05-8daf-765f911c9240@arm.com> Date: Mon, 31 Jul 2023 08:03:21 +0530 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.13.0 Subject: Re: [PATCH V13 - RESEND 02/10] arm64/perf: Add BRBE registers and fields Content-Language: en-US To: James Clark , Will Deacon Cc: linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, catalin.marinas@arm.com, mark.rutland@arm.com, Mark Brown , Rob Herring , Marc Zyngier , Suzuki Poulose , Peter Zijlstra , Ingo Molnar , Arnaldo Carvalho de Melo , linux-perf-users@vger.kernel.org References: <20230711082455.215983-1-anshuman.khandual@arm.com> <20230711082455.215983-3-anshuman.khandual@arm.com> <20230728162011.GA22050@willie-the-truck> <89ce4bc4-00c5-a763-3179-e1d3e9f198b7@arm.com> From: Anshuman Khandual In-Reply-To: <89ce4bc4-00c5-a763-3179-e1d3e9f198b7@arm.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-4.3 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_MED,SPF_HELO_NONE,SPF_NONE,T_SCC_BODY_TEXT_LINE 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 On 7/28/23 22:22, James Clark wrote: > > > On 28/07/2023 17:20, Will Deacon wrote: >> On Tue, Jul 11, 2023 at 01:54:47PM +0530, Anshuman Khandual wrote: >>> This adds BRBE related register definitions and various other related field >>> macros there in. These will be used subsequently in a BRBE driver which is >>> being added later on. >>> >>> Cc: Catalin Marinas >>> Cc: Will Deacon >>> Cc: Marc Zyngier >>> Cc: Mark Rutland >>> Cc: linux-arm-kernel@lists.infradead.org >>> Cc: linux-kernel@vger.kernel.org >>> Tested-by: James Clark >>> Reviewed-by: Mark Brown >>> Signed-off-by: Anshuman Khandual >>> --- >>> arch/arm64/include/asm/sysreg.h | 103 +++++++++++++++++++++ >>> arch/arm64/tools/sysreg | 158 ++++++++++++++++++++++++++++++++ >>> 2 files changed, 261 insertions(+) >>> >>> diff --git a/arch/arm64/include/asm/sysreg.h b/arch/arm64/include/asm/sysreg.h >>> index b481935e9314..f95e30c13c8b 100644 >>> --- a/arch/arm64/include/asm/sysreg.h >>> +++ b/arch/arm64/include/asm/sysreg.h >>> @@ -163,6 +163,109 @@ >>> #define SYS_DBGDTRTX_EL0 sys_reg(2, 3, 0, 5, 0) >>> #define SYS_DBGVCR32_EL2 sys_reg(2, 4, 0, 7, 0) >>> >>> +#define __SYS_BRBINFO(n) sys_reg(2, 1, 8, ((n) & 0xf), ((((n) & 0x10)) >> 2 + 0)) >>> +#define __SYS_BRBSRC(n) sys_reg(2, 1, 8, ((n) & 0xf), ((((n) & 0x10)) >> 2 + 1)) >>> +#define __SYS_BRBTGT(n) sys_reg(2, 1, 8, ((n) & 0xf), ((((n) & 0x10)) >> 2 + 2)) >> >> It's that time on a Friday but... aren't these macros busted? I think you >> need brackets before adding the offset, otherwise wouldn't, for example, >> target registers 0-15 all access info register 0 and __SYS_BRBTGT(16) would >> then start accessing source register 0? >> >> I'm surprised that the compiler doesn't warn about this, but even more >> surprised that you managed to test this. >> >> Please tell me I'm wrong! >> >> Will > > No I think you are right, it is wrong. Luckily there is already an > extraneous bracket so you you can fix it by moving one a place down: > > sys_reg(2, 1, 8, ((n) & 0xf), ((((n) & 0x10) >> 2) + 2)) > > It's interesting because the test [1] is doing quite a bit and looking > at the branch info, and that src and targets match up to function names. > I also manually looked at the branch buffers and didn't see anything > obviously wrong like things that looked like branch infos in the source > or target fields. Will have to take another look to see if it would be > possible for the test to catch this. > > James > > [1]: > https://gitlab.arm.com/linux-arm/linux-jc/-/commit/3a7ddce70c2daadb63fcc511de0a89055ca48b32 ((((n) & 0x10)) >> 2 + 2) ---> ((((n) & 0x10) >> 2) + 2) The additional brackets are useful in explicitly telling the compiler but what it the compiler is just doing the right thing implicitly i.e computing the shifting operation before doing the offset addition. During testing, all those captured branch records looked alright. But that is no excuse, for not doing the right thing to begin with i.e adding explicit brackets. I will fix these in next version.