Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp838498ybt; Fri, 26 Jun 2020 12:48:13 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyp5xi+3BQUF9FO9AC1n/Y5XM+YisKEfqJBxWje9HVMIKUotCDdK/bhz6abG+2jaGFwkowO X-Received: by 2002:a17:906:191a:: with SMTP id a26mr4215866eje.315.1593200893565; Fri, 26 Jun 2020 12:48:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1593200893; cv=none; d=google.com; s=arc-20160816; b=xYv+PMOijDk1SobltzrA6e6twVKkD6XZHkAortBiMhPWEZNzyhjgqNywKJdUPKL/c3 h4Kbei7/dqTvi/imrueniCeSQgyqi9w2EF0tvz+taa2mpxK07XSzXmQtU4WZXwN9Ha5t f2tZhzNksVx0g4z3M20mnV19SyjeJHKOqwhS1LRHx2gE3bzLxrtuVWp/32db4Ch1fafd eUe2EhNRcym5OmKR+BbaY4HC3Jk23Ev+mYCSW8QrsHGdDtJw525a1v/+BqpCvCnAMSRW MOUQWypxbnj+CUIM+Vrs4lc26uqqJcrmP+o41SpDsWjGtU6FFeMemckJKD9lTylk/TZR YYDQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=pdaBtEZKt4jdhIBHfPpgUYXIDa+U2l3b3B5zM3JBlA0=; b=qk9jFFu2ywAttMQ096B5gH7K1nEHhYPVdSrdPHLhHgdooaa5SbEZLGocc/teU5SXzS 7RgFEmcwJCzl+aqyPjq9Un3lzmUKG52xGOw9TnpESKqUW7dZBCDUD6fpOiSL/mUn09kO eJJDM9esMDKegJyma7Hgga2waNQTlyG+L6NdaxFEgqUmomeUfuiFqb/NGqlRYKWaoijj K58KNSYY7HNWhqpoExCp4iVr490ykABnQxAZQV+hkCJAw43o8wNAUyR83UZU4F943+uc Vg4zg/aRqjmn9bM3DympOmvMwmCg49vEjRC84NRfJKELmtj7ieqzODTRGJSP8SnXPqQI CrUA== ARC-Authentication-Results: i=1; mx.google.com; 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=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id z26si13303030edx.269.2020.06.26.12.47.49; Fri, 26 Jun 2020 12:48:13 -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; 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=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1725816AbgFZTrf convert rfc822-to-8bit (ORCPT + 99 others); Fri, 26 Jun 2020 15:47:35 -0400 Received: from us-smtp-delivery-1.mimecast.com ([207.211.31.120]:46661 "EHLO us-smtp-1.mimecast.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1725780AbgFZTre (ORCPT ); Fri, 26 Jun 2020 15:47:34 -0400 Received: from mimecast-mx01.redhat.com (mimecast-mx01.redhat.com [209.132.183.4]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-473-nYgGaCzNO7uQPSaE8dbi6g-1; Fri, 26 Jun 2020 15:47:27 -0400 X-MC-Unique: nYgGaCzNO7uQPSaE8dbi6g-1 Received: from smtp.corp.redhat.com (int-mx05.intmail.prod.int.phx2.redhat.com [10.5.11.15]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id A1302107ACCA; Fri, 26 Jun 2020 19:47:24 +0000 (UTC) Received: from krava.redhat.com (unknown [10.40.193.230]) by smtp.corp.redhat.com (Postfix) with ESMTP id 4B17B7FE8B; Fri, 26 Jun 2020 19:47:21 +0000 (UTC) From: Jiri Olsa To: Arnaldo Carvalho de Melo Cc: lkml , Ingo Molnar , Namhyung Kim , Alexander Shishkin , Peter Zijlstra , Michael Petlan , Andi Kleen , Kajol Jain , John Garry , "Paul A. Clarke" , Stephane Eranian , Ian Rogers Subject: [RFC 00/10] perf tools: Add support to reuse metric Date: Fri, 26 Jun 2020 21:47:10 +0200 Message-Id: <20200626194720.2915044-1-jolsa@kernel.org> MIME-Version: 1.0 X-Scanned-By: MIMEDefang 2.79 on 10.5.11.15 X-Mimecast-Spam-Score: 0 X-Mimecast-Originator: kernel.org Content-Type: text/plain; charset=WINDOWS-1252 Content-Transfer-Encoding: 8BIT Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org hi, this patchset is adding the support to reused metric in another metric. The metric needs to be referenced by 'metric:' prefix. For example, to define IPC by using CPI with change like: "BriefDescription": "Instructions Per Cycle (per Logical Processor)", - "MetricExpr": "INST_RETIRED.ANY / CPU_CLK_UNHALTED.THREAD", + "MetricExpr": "1/metric:CPI", "MetricGroup": "TopDownL1", "MetricName": "IPC" I won't be able to find all the possible places we could use this at, so I wonder you guys (who was asking for this) would try it and come up with comments if there's something missing or we could already use it at some places. It's based on Arnaldo's tmp.perf/core. Also available in here: git://git.kernel.org/pub/scm/linux/kernel/git/jolsa/perf.git perf/metric thanks, jirka --- Jiri Olsa (10): perf tools: Rename expr__add_id to expr__add_val perf tools: Add struct expr_parse_data to keep expr value perf tools: Add expr__add_id function perf tools: Change expr__get_id to return struct expr_parse_data perf tools: Add expr__del_id function perf tools: Collect other metrics in struct egroup perf tools: Collect other metrics in struct metric_expr perf tools: Add other metrics to hash data perf tools: Compute other metrics perf tests: Add cache_miss_cycles to metric parse test tools/perf/pmu-events/arch/x86/skylake/skl-metrics.json | 2 +- tools/perf/tests/expr.c | 7 ++-- tools/perf/tests/parse-metric.c | 33 +++++++++++++++++ tools/perf/tests/pmu-events.c | 4 +-- tools/perf/util/expr.c | 115 +++++++++++++++++++++++++++++++++++++++++++++------------- tools/perf/util/expr.h | 24 +++++++++++-- tools/perf/util/expr.y | 34 ++++++++++++++---- tools/perf/util/metricgroup.c | 187 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-------- tools/perf/util/metricgroup.h | 6 ++++ tools/perf/util/stat-shadow.c | 23 +++++++----- 10 files changed, 374 insertions(+), 61 deletions(-)