Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp3507098pxf; Mon, 22 Mar 2021 08:01:56 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxcISt340lfbAVJs4nTfY0jJiki4a3tNXXClZ8WVNGoprRHvlt9ddvQAdsSLSM3++Q/+VGE X-Received: by 2002:a1c:7515:: with SMTP id o21mr266807wmc.90.1616425316320; Mon, 22 Mar 2021 08:01:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1616425316; cv=none; d=google.com; s=arc-20160816; b=be/pPBOVbl9bwRi+ocik7pGfPGRrRmAEe4EKQ1mdH+Z+pN3ffj80AQe661ltoBEo/y MKVMPJqsqzfaXq9JoPdTjEEr3nis7jj30fNHH0/iUKCA5daa5tYvbAfuIOjwNpDzHr+i CvNoaH7FDrkUk4Rlh7RI7GFATXryIk7+6/TdKSnnAdZ1lxnl0RwK0n0R4ENKmFJ3KJa2 BC8yVIFvucAEHhOgGxbWA+mFKo8YnRVfz8UC2WXkzLQUq/udZn2Da1O1hQUFcZgwxzTJ k0N6ArDmEvlzpxDoFH3jPjcuJnQUgEMwZ4NjNxlSTxjzTmrAnSej3qimJkweApB/TyUz CSDQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:message-id:date:subject :cc:to:from:dkim-signature; bh=zUIUWjxwKAmhfwp0C87yjnpPih0I2lwe3bq6OeTiBU4=; b=BCuNMyrXoe3HBkGL0R1G48JSpKIj0sEjvayk3UPeTgcvvm1b9LPTLTdVZLsSc/vGaP 7UgkQU9YGQtTYeURZD5n5mjN/YULLaTciReeS6h4PvcVTl3bD7EBY1vFuZXFtNMtrAXP OppAv2XUZqH1DeiAIqg9pC16Y76GiqL1qJ0CX9An63FsfKNrNYBSNVRKdAr+6PmItphk WFSt8J74NTxfKU+AuevClc52Wx0i7+IS7A3t2GMxapgx8dxXsETrJf+o4A84QD3g1WvR YWFijGW0AzQshQpMjfuLHoOkD1OOLN6z7RxsoLc/7eZG+arR2FnU+dtkBihkQzN1E5oI p7JA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ibm.com header.s=pp1 header.b=XOPRf902; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=ibm.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y21si11678274edo.16.2021.03.22.08.01.33; Mon, 22 Mar 2021 08:01:56 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@ibm.com header.s=pp1 header.b=XOPRf902; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=ibm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231354AbhCVO6X (ORCPT + 99 others); Mon, 22 Mar 2021 10:58:23 -0400 Received: from mx0a-001b2d01.pphosted.com ([148.163.156.1]:60450 "EHLO mx0a-001b2d01.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231319AbhCVO6A (ORCPT ); Mon, 22 Mar 2021 10:58:00 -0400 Received: from pps.filterd (m0098393.ppops.net [127.0.0.1]) by mx0a-001b2d01.pphosted.com (8.16.0.43/8.16.0.43) with SMTP id 12MEYmqD089743; Mon, 22 Mar 2021 10:57:44 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ibm.com; h=from : to : cc : subject : date : message-id : in-reply-to : references; s=pp1; bh=zUIUWjxwKAmhfwp0C87yjnpPih0I2lwe3bq6OeTiBU4=; b=XOPRf902/fHJ9DTeE00Jzv3FFSVk8WucDXoI4CqWQgGpSIJM6ZlqwVY7Ukwd4BL1QKhH S1o8UVfpnkg1wvNF4RmQV0L2ItDfH0gGLg4DgDfP9kPYsrd4e8l663dXgeDqpkbeFKLp RV2FVVfxF+G6ngOVP4/n3GkgvwU5liRuL76J0GxCe0TEyfvGkQiOTbxaLF3EpAkjtdTd I2DvciUWF38v2L2xaZTocmBw/zHAHwEY2p/wJWceKGOH0DxEbo1NJVIJLhCdbB53Wvhi s5rf+xXoRb+/5SqoTKBhEp18dbMORmrqqLboUav2BX+DVZrWWJGcv/Dw0cMkl0DwLGsE zg== Received: from ppma04ams.nl.ibm.com (63.31.33a9.ip4.static.sl-reverse.com [169.51.49.99]) by mx0a-001b2d01.pphosted.com with ESMTP id 37dx4a3q0d-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Mon, 22 Mar 2021 10:57:44 -0400 Received: from pps.filterd (ppma04ams.nl.ibm.com [127.0.0.1]) by ppma04ams.nl.ibm.com (8.16.0.43/8.16.0.43) with SMTP id 12MEhlnq013515; Mon, 22 Mar 2021 14:57:42 GMT Received: from b06cxnps4074.portsmouth.uk.ibm.com (d06relay11.portsmouth.uk.ibm.com [9.149.109.196]) by ppma04ams.nl.ibm.com with ESMTP id 37d99raf0m-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Mon, 22 Mar 2021 14:57:42 +0000 Received: from d06av22.portsmouth.uk.ibm.com (d06av22.portsmouth.uk.ibm.com [9.149.105.58]) by b06cxnps4074.portsmouth.uk.ibm.com (8.14.9/8.14.9/NCO v10.0) with ESMTP id 12MEvdSZ36045122 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Mon, 22 Mar 2021 14:57:39 GMT Received: from d06av22.portsmouth.uk.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id 4F7B14C040; Mon, 22 Mar 2021 14:57:39 +0000 (GMT) Received: from d06av22.portsmouth.uk.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id AB1224C04E; Mon, 22 Mar 2021 14:57:36 +0000 (GMT) Received: from localhost.localdomain.localdomain (unknown [9.124.209.79]) by d06av22.portsmouth.uk.ibm.com (Postfix) with ESMTP; Mon, 22 Mar 2021 14:57:36 +0000 (GMT) From: Athira Rajeev To: linuxppc-dev@lists.ozlabs.org, linux-kernel@vger.kernel.org, linux-perf-users@vger.kernel.org, mpe@ellerman.id.au, acme@kernel.org, jolsa@kernel.org Cc: maddy@linux.ibm.com, ravi.bangoria@linux.ibm.com, kjain@linux.ibm.com, kan.liang@linux.intel.com, peterz@infradead.org Subject: [PATCH V2 2/5] tools/perf: Add dynamic headers for perf report columns Date: Mon, 22 Mar 2021 10:57:24 -0400 Message-Id: <1616425047-1666-3-git-send-email-atrajeev@linux.vnet.ibm.com> X-Mailer: git-send-email 1.8.3.1 In-Reply-To: <1616425047-1666-1-git-send-email-atrajeev@linux.vnet.ibm.com> References: <1616425047-1666-1-git-send-email-atrajeev@linux.vnet.ibm.com> X-TM-AS-GCONF: 00 X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:6.0.369,18.0.761 definitions=2021-03-22_07:2021-03-22,2021-03-22 signatures=0 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 phishscore=0 impostorscore=0 spamscore=0 suspectscore=0 mlxlogscore=999 priorityscore=1501 mlxscore=0 adultscore=0 bulkscore=0 malwarescore=0 lowpriorityscore=0 clxscore=1015 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2009150000 definitions=main-2103220107 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Currently the header string for different columns in perf report is fixed. Some fields of perf sample could have different meaning for different architectures than the meaning conveyed by the header string. An example is the new field 'var2_w' of perf_sample_weight structure. This is presently captured as 'Local INSTR Latency' in perf mem report. But this could be used to denote a different latency cycle in another architecture. Introduce a weak function arch_perf_header_entry() to set the arch specific header string for the fields which can contain dynamic header. If the architecture do not have this function, fall back to the default header string value. Signed-off-by: Athira Rajeev --- tools/perf/util/event.h | 1 + tools/perf/util/sort.c | 19 ++++++++++++++++++- 2 files changed, 19 insertions(+), 1 deletion(-) diff --git a/tools/perf/util/event.h b/tools/perf/util/event.h index f603edbbbc6f..6106a9c134c9 100644 --- a/tools/perf/util/event.h +++ b/tools/perf/util/event.h @@ -427,5 +427,6 @@ void cpu_map_data__synthesize(struct perf_record_cpu_map_data *data, struct per void arch_perf_parse_sample_weight(struct perf_sample *data, const __u64 *array, u64 type); void arch_perf_synthesize_sample_weight(const struct perf_sample *data, __u64 *array, u64 type); +const char *arch_perf_header_entry(const char *se_header); #endif /* __PERF_RECORD_H */ diff --git a/tools/perf/util/sort.c b/tools/perf/util/sort.c index 552b590485bf..eeb03e749181 100644 --- a/tools/perf/util/sort.c +++ b/tools/perf/util/sort.c @@ -25,6 +25,7 @@ #include #include "mem-events.h" #include "annotate.h" +#include "event.h" #include "time-utils.h" #include "cgroup.h" #include "machine.h" @@ -45,6 +46,7 @@ regex_t ignore_callees_regex; int have_ignore_callees = 0; enum sort_mode sort__mode = SORT_MODE__NORMAL; +const char *dynamic_headers[] = {"local_ins_lat"}; /* * Replaces all occurrences of a char used with the: @@ -1816,6 +1818,16 @@ struct sort_dimension { int taken; }; +const char * __weak arch_perf_header_entry(const char *se_header) +{ + return se_header; +} + +static void sort_dimension_add_dynamic_header(struct sort_dimension *sd) +{ + sd->entry->se_header = arch_perf_header_entry(sd->entry->se_header); +} + #define DIM(d, n, func) [d] = { .name = n, .entry = &(func) } static struct sort_dimension common_sort_dimensions[] = { @@ -2739,7 +2751,7 @@ int sort_dimension__add(struct perf_hpp_list *list, const char *tok, struct evlist *evlist, int level) { - unsigned int i; + unsigned int i, j; for (i = 0; i < ARRAY_SIZE(common_sort_dimensions); i++) { struct sort_dimension *sd = &common_sort_dimensions[i]; @@ -2747,6 +2759,11 @@ int sort_dimension__add(struct perf_hpp_list *list, const char *tok, if (strncasecmp(tok, sd->name, strlen(tok))) continue; + for (j = 0; j < ARRAY_SIZE(dynamic_headers); j++) { + if (!strcmp(dynamic_headers[j], sd->name)) + sort_dimension_add_dynamic_header(sd); + } + if (sd->entry == &sort_parent) { int ret = regcomp(&parent_regex, parent_pattern, REG_EXTENDED); if (ret) { -- 1.8.3.1