Received: by 2002:a05:6602:18e:0:0:0:0 with SMTP id m14csp745536ioo; Thu, 26 May 2022 13:55:08 -0700 (PDT) X-Google-Smtp-Source: ABdhPJydVusoEHxn1c5VVx7+RARW4lr3+wq2uROEovSJxoNAFqskXHg8qTz1mc3iIJNNFYsZHgPN X-Received: by 2002:a17:907:9243:b0:6fe:976a:e117 with SMTP id kb3-20020a170907924300b006fe976ae117mr34477183ejb.398.1653598508211; Thu, 26 May 2022 13:55:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1653598508; cv=none; d=google.com; s=arc-20160816; b=wqvq6zoB+OOWdK/5E7kp+BwzJrdDY3+8ZphsxL2zW4MBSovsstudzd3+y/B8/tewLy XMsG2+p+IDq9e7Wox6wBJxZkqSh7EHKnkyKC7Fo2sutZAq3KqeybV79DPjVRLNZ4Pb57 FL7q+MirebpZMxDnV7HB6uYcALwo1E2EfcgBuOo9gLf/Z3guom3WjE6zjTe6MXViUP86 o2w1x7njgAHZFWh+Y/SqgARJUzwPKQcKDRm8S4oN/tHPkpkRSkyxZlOCTS2MlIrKT6b5 O6iD8A2Hek7y0zfaJhMTr+oDlU3jXygVRrylWCNBLzzAXjKeTu8MmFSD/7i5F8QKgcUW gsTw== 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=WGOB9EyQRUr24YCN5rB/LhSsI3XPu4uR9O5zWC75Ejw=; b=GDrBIcmaffNHD2PteqYxh613lVkur2s1IH0QrOSK/ydIDRJPEnXGuH3h0eYuuwdSt5 s2Ggo8bJz3Qw5kPOhkdldEZQtIWPaJzR8cRQG/Ip432CxA+zbu7osZnp3jpPHbv6HfCY 1Mx8vY6ZBvItnLcGUT6YRF3jjJFqPKErL8mJ9/Yox8x1eY7h3rrLR/1afALKlytDeD/W U5cA24noYPEoDSrqz5pGE10FIhNJA7dcEW7A76jRXae39j8HVjlpQKlPDjYK/s0/RllL ylj9eUAG4VYCW2Q+Djn2lkL/nBj3Ef7xvMSiT4PhZMc+WUlHlyF5E0OJUt7eNfEtAC/y e4EQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@infradead.org header.s=desiato.20200630 header.b=akkmAKWf; 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 Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id hr16-20020a1709073f9000b006fe9d22875esi2872777ejc.761.2022.05.26.13.54.40; Thu, 26 May 2022 13:55:08 -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; dkim=pass header.i=@infradead.org header.s=desiato.20200630 header.b=akkmAKWf; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S240595AbiEZJ7S (ORCPT + 99 others); Thu, 26 May 2022 05:59:18 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33804 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232463AbiEZJ7R (ORCPT ); Thu, 26 May 2022 05:59:17 -0400 Received: from desiato.infradead.org (desiato.infradead.org [IPv6:2001:8b0:10b:1:d65d:64ff:fe57:4e05]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id AF55EC9ED3; Thu, 26 May 2022 02:59:16 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=desiato.20200630; h=In-Reply-To:Content-Type:MIME-Version: References:Message-ID:Subject:Cc:To:From:Date:Sender:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description; bh=WGOB9EyQRUr24YCN5rB/LhSsI3XPu4uR9O5zWC75Ejw=; b=akkmAKWfJArmhsc20vQ7CaYxqX RrUe0QW6Mnle97C+rOFusEhaTPAmYLvUW6RzeM01pxP1ORJ0CUOfWwA0LiOi7FOrXicjx0khLDeVZ qWtdsHyBlL8KEacR6Kq5R8xdyl0BoD2fN5g32xeUILFoHEq5Oif0QJTRsnyPySjH9Qbsc5xugrhgr hXXu+jBrSuVzuCzAG8s7TK755Epkpo303LrMnRMvDsZo09BjJWCsIcRX4tc8w0+otIfLNRcygFLyE 9CtUqTdyqLrGQKZlu1DPgxXuzS6hi1hOBt7usGsqOXLCqlGyFLixUYkTxWrSZG37tuwH/sXeF/wYn xn/D3npA==; Received: from j217100.upc-j.chello.nl ([24.132.217.100] helo=worktop.programming.kicks-ass.net) by desiato.infradead.org with esmtpsa (Exim 4.94.2 #2 (Red Hat Linux)) id 1nuAEM-001rsn-6k; Thu, 26 May 2022 09:58:35 +0000 Received: by worktop.programming.kicks-ass.net (Postfix, from userid 1000) id BB3F6981124; Thu, 26 May 2022 11:56:33 +0200 (CEST) Date: Thu, 26 May 2022 11:56:33 +0200 From: Peter Zijlstra To: Ravi Bangoria Cc: acme@kernel.org, jolsa@kernel.org, namhyung@kernel.org, eranian@google.com, irogers@google.com, jmario@redhat.com, leo.yan@linaro.org, alisaidi@amazon.com, ak@linux.intel.com, kan.liang@linux.intel.com, dave.hansen@linux.intel.com, hpa@zytor.com, mingo@redhat.com, mark.rutland@arm.com, alexander.shishkin@linux.intel.com, tglx@linutronix.de, bp@alien8.de, x86@kernel.org, linux-perf-users@vger.kernel.org, linux-kernel@vger.kernel.org, sandipan.das@amd.com, ananth.narayan@amd.com, kim.phillips@amd.com, santosh.shukla@amd.com Subject: Re: [PATCH 06/13] perf/x86/amd: Support PERF_SAMPLE_PHY_ADDR using IBS_DC_PHYSADDR Message-ID: <20220526095633.GO2578@worktop.programming.kicks-ass.net> References: <20220525093938.4101-1-ravi.bangoria@amd.com> <20220525093938.4101-7-ravi.bangoria@amd.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: X-Spam-Status: No, score=-4.4 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,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 Thu, May 26, 2022 at 02:16:28PM +0530, Ravi Bangoria wrote: > On 25-May-22 4:51 PM, Peter Zijlstra wrote: > > On Wed, May 25, 2022 at 03:09:31PM +0530, Ravi Bangoria wrote: > >> IBS_DC_PHYSADDR provides the physical data address for the tagged load/ > >> store operation. Populate perf sample physical address using it. > >> > >> Signed-off-by: Ravi Bangoria > >> --- > >> arch/x86/events/amd/ibs.c | 26 +++++++++++++++++++++++++- > >> 1 file changed, 25 insertions(+), 1 deletion(-) > >> > >> diff --git a/arch/x86/events/amd/ibs.c b/arch/x86/events/amd/ibs.c > >> index b57736357e25..c719020c0e83 100644 > >> --- a/arch/x86/events/amd/ibs.c > >> +++ b/arch/x86/events/amd/ibs.c > >> @@ -986,13 +986,35 @@ static void perf_ibs_get_data_addr(struct perf_event *event, > >> data->addr = ibs_data->regs[ibs_op_msr_idx(MSR_AMD64_IBSDCLINAD)]; > >> } > >> > >> +static void perf_ibs_get_phy_addr(struct perf_event *event, > >> + struct perf_ibs_data *ibs_data, > >> + struct perf_sample_data *data) > >> +{ > >> + union perf_mem_data_src *data_src = &data->data_src; > >> + u64 op_data3 = ibs_data->regs[ibs_op_msr_idx(MSR_AMD64_IBSOPDATA3)]; > >> + u64 phy_addr_valid = op_data3 & IBS_DC_PHY_ADDR_VALID_MASK; > >> + > >> + if (!(event->attr.sample_type & PERF_SAMPLE_DATA_SRC)) > >> + perf_ibs_get_mem_op(op_data3, data); > >> + > >> + if ((data_src->mem_op != PERF_MEM_OP_LOAD && > >> + data_src->mem_op != PERF_MEM_OP_STORE) || > >> + !phy_addr_valid) { > >> + data->phys_addr = 0x0; > >> + return; > >> + } > >> + > >> + data->phys_addr = ibs_data->regs[ibs_op_msr_idx(MSR_AMD64_IBSDCPHYSAD)]; > >> +} > > > > perf_prepare_sample() will unconditionally overwrite data->phys_addr. > > There is currently no facility to let the driver set this field. > > Thanks for pointing it Peter. Would you mind if I add: I think it's best if you extend/mimic the __PERF_SAMPLE_CALLCHAIN_EARLY hack. It's more or less the same problem and then at least the solution is consistent.