Received: by 2002:a05:6500:1b8f:b0:1fa:5c73:8e2d with SMTP id df15csp449342lqb; Tue, 28 May 2024 23:44:19 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCWSdf6m70Lw3TnrA8STHFhSofGbhaPbAMEN+hE5gvScEZrgQ9AB1IW10D3uirzs5IBpO++sdtGnC47NPLIx3ebkFUR2q2DLxoVeinRLJw== X-Google-Smtp-Source: AGHT+IEOMrqCIlRrTUsC6TAij840AzxKhfOlnmeqaijWiPBBOYOyceRlKslDCare0QUlCF34TvOR X-Received: by 2002:a17:906:a857:b0:a59:aa9d:3142 with SMTP id a640c23a62f3a-a62643ecbcdmr830768666b.37.1716965059111; Tue, 28 May 2024 23:44:19 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1716965059; cv=pass; d=google.com; s=arc-20160816; b=jVOwahiQc1du/OOp+loD7Pl5N+2laPruPzoKRPMJXhX+4SZPjAAL1CManChhKbydbf JzFlPOCj7y3SE8SMDetIPDo9G7WcgxWipJroLjR0kX0/wbUMlMSeIF9Mvp1GPq9PTTXw nKHEQN9ONQF418NRtAD0NrPYbdaF/tiQlrtxD5jUV/7zltgqDE3XxVUIEz+HouLwVlgt aDGnkDar7dCquJwSGjMSKNbSi6vWFaO73XtXkjttG4ihUHsryCB18NmpWo1aJL0oq8Y7 +j+Zvk+BlhL6BP392mcMo6b7092oGrIbZyoJQqgVbbGy7LxFVLAIyvn3yUVH0LGD6wQT 0J9w== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:references:in-reply-to:message-id :date:subject:cc:to:from:dkim-signature; bh=Oh0u1FFtBdKOkkvCvBwLL7aqjHVh4jPPZH5l/lgWqEM=; fh=7D8bWqELNqJM6KF7zbibUOya8038rGAdDMFXsJMRu8c=; b=qBFlTmn2shSbbH0YdLMTsSFVyaKGV5++pMRxFSIqWsVBc5e7mo1nKZl6QlPija9R/s BNwUQt0+RVY/cxKQO78KlOZeIXMzgNLkSWkR9uGcFpyJAv5Mw/niAj2TKMA1B9OG3dDx vGTvFzH0taLC8p1bbt8Jj4GTDzPH7T5WtBNSMfPxQpIl+l0/0KcBbNeqFOj8YW/QTCcc dRaKoZw1jqOdUkx1vrPi6rTSAsaQS5ZFweZc8m7fdkrXr6ebVLlezNxdneSlEKENukXl xdFpoYmFgaxWCpIvrHXl1Y6oNlv5cnHaiRxqOqRgauOu5Q7BFzmZHUp5pI51Maa8oRRH jHJQ==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=laznxfcN; arc=pass (i=1 spf=pass spfdomain=intel.com dkim=pass dkdomain=intel.com dmarc=pass fromdomain=intel.com); spf=pass (google.com: domain of linux-kernel+bounces-193534-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) smtp.mailfrom="linux-kernel+bounces-193534-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from am.mirrors.kernel.org (am.mirrors.kernel.org. [147.75.80.249]) by mx.google.com with ESMTPS id a640c23a62f3a-a626cc68d3fsi622655366b.680.2024.05.28.23.44.19 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 28 May 2024 23:44:19 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-193534-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) client-ip=147.75.80.249; Authentication-Results: mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=laznxfcN; arc=pass (i=1 spf=pass spfdomain=intel.com dkim=pass dkdomain=intel.com dmarc=pass fromdomain=intel.com); spf=pass (google.com: domain of linux-kernel+bounces-193534-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) smtp.mailfrom="linux-kernel+bounces-193534-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by am.mirrors.kernel.org (Postfix) with ESMTPS id D06691F26A31 for ; Wed, 29 May 2024 06:44:18 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 84E55167287; Wed, 29 May 2024 06:43:40 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=intel.com header.i=@intel.com header.b="laznxfcN" Received: from mgamail.intel.com (mgamail.intel.com [192.198.163.13]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 19B771607BA; Wed, 29 May 2024 06:43:38 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=192.198.163.13 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1716965019; cv=none; b=iHF4lYITVBaPpseJMTM6JvkVX/cwIU25KBkrqUCv2itCUWlvk8pJW694j9nKvZdL5cwWLdD4w4GXagHRwxurF7TiPTNDqsQLF0JEhN9HdXgEx5SiRUAtJ4sRjSsS63Sq/Npmv0XTKGe1uU0nwykQYVsZTs3FDhAdayGlhpBVNC8= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1716965019; c=relaxed/simple; bh=D4C6WFVBIrNKMzQpypbEq0h3+qQtDtOXTakBiNHlGUw=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=YLagGSIIdLr3vF1hGAHJIpcI/4exSvXangwncOblCiFdPDQw6WvXh0mrgvfUfa1Q0vFeH6QwwSD0LOCGp32HwP/90LyzT0tUVHTI2j2rrMAizjkniC3b9ni7mqY2f4CQYhtHBm/fmkPImj/mbAHObY/T90dLlWN3WXdt/IP7lpQ= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=intel.com; spf=pass smtp.mailfrom=intel.com; dkim=pass (2048-bit key) header.d=intel.com header.i=@intel.com header.b=laznxfcN; arc=none smtp.client-ip=192.198.163.13 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=intel.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=intel.com DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1716965018; x=1748501018; h=from:to:cc:subject:date:message-id:in-reply-to: references:mime-version:content-transfer-encoding; bh=D4C6WFVBIrNKMzQpypbEq0h3+qQtDtOXTakBiNHlGUw=; b=laznxfcNmrA3brt2S9ZzYvOaEORb7UyvYKCn6/KmmYgxyP87RxYQT6i0 7MRhalOfuodhdkdEJ27DZv5r+ySGTSfejRE6Wcy0HSonJ3yWSIkqUn+DX IB88r6SfmOLGgZfLGTBL/l0HMBQWaioFJrloWuzVRQ3gsu8pAt8JNMkL3 fvPRJOOgDF25v2BT6OJpyCmmca3q5O56uOcI1XAXkwYVKWfngk6IpKd3J 2Qd6YIOQfGf9q67h2GHEVjJHX5MHF9e+ZXz2UN/ojY/jY1L8Ss9SylE6d qdhAXeOSt/9FUCm4hEI4S24MMjcHajkx3d6Vbhc+itwPKF6JQImTIMxtL A==; X-CSE-ConnectionGUID: QCVxeF1DQfC3pF5a8A5+GQ== X-CSE-MsgGUID: UskdZxaYT6mrUpXv2QLD0g== X-IronPort-AV: E=McAfee;i="6600,9927,11085"; a="16297997" X-IronPort-AV: E=Sophos;i="6.08,197,1712646000"; d="scan'208";a="16297997" Received: from fmviesa005.fm.intel.com ([10.60.135.145]) by fmvoesa107.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 28 May 2024 23:43:36 -0700 X-CSE-ConnectionGUID: Y/yo6mlLTEODHStpp//8Qw== X-CSE-MsgGUID: Ri9XV5ZZQV2X2R+5amdZSg== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="6.08,197,1712646000"; d="scan'208";a="39759293" Received: from fl31ca102ks0602.deacluster.intel.com (HELO gnr-bkc.deacluster.intel.com) ([10.75.133.163]) by fmviesa005.fm.intel.com with ESMTP; 28 May 2024 23:43:35 -0700 From: weilin.wang@intel.com To: weilin.wang@intel.com, Namhyung Kim , Ian Rogers , Arnaldo Carvalho de Melo , Peter Zijlstra , Ingo Molnar , Alexander Shishkin , Jiri Olsa , Adrian Hunter , Kan Liang Cc: linux-perf-users@vger.kernel.org, linux-kernel@vger.kernel.org, Perry Taylor , Samantha Alt , Caleb Biggers Subject: [RFC PATCH v10 4/8] perf stat: Plugin retire_lat value from sampled data to evsel Date: Wed, 29 May 2024 02:43:20 -0400 Message-ID: <20240529064327.4080674-5-weilin.wang@intel.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20240529064327.4080674-1-weilin.wang@intel.com> References: <20240529064327.4080674-1-weilin.wang@intel.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit From: Weilin Wang In current :R parsing implementation, the parser would recognize events with retire_latency modifier and insert them into the evlist like a normal event. Ideally, we need to avoid counting these events. In this commit, at the time when a retire_latency evsel is read, set the retire latency value processed from the sampled data to count value. This sampled retire latency value will be used for metric calculation and final event count print out. No special metric calculation and event print out code required for retire_latency events. Signed-off-by: Weilin Wang --- tools/perf/arch/x86/util/evlist.c | 6 ++++++ tools/perf/util/evsel.c | 15 +++++++++++++++ tools/perf/util/evsel.h | 5 +++++ 3 files changed, 26 insertions(+) diff --git a/tools/perf/arch/x86/util/evlist.c b/tools/perf/arch/x86/util/evlist.c index b1ce0c52d88d..cebdd483149e 100644 --- a/tools/perf/arch/x86/util/evlist.c +++ b/tools/perf/arch/x86/util/evlist.c @@ -89,6 +89,12 @@ int arch_evlist__cmp(const struct evsel *lhs, const struct evsel *rhs) return 1; } + /* Retire latency event should not be group leader*/ + if (lhs->retire_lat && !rhs->retire_lat) + return 1; + if (!lhs->retire_lat && rhs->retire_lat) + return -1; + /* Default ordering by insertion index. */ return lhs->core.idx - rhs->core.idx; } diff --git a/tools/perf/util/evsel.c b/tools/perf/util/evsel.c index 4157db30c3e7..e892d69e7839 100644 --- a/tools/perf/util/evsel.c +++ b/tools/perf/util/evsel.c @@ -58,6 +58,7 @@ #include #include #include +#include "util/intel-tpebs.h" #include @@ -1523,6 +1524,11 @@ static int evsel__read_one(struct evsel *evsel, int cpu_map_idx, int thread) return perf_evsel__read(&evsel->core, cpu_map_idx, thread, count); } +static int evsel__read_retire_lat(struct evsel *evsel, int cpu_map_idx, int thread) +{ + return tpebs_set_evsel(evsel, cpu_map_idx, thread); +} + static void evsel__set_count(struct evsel *counter, int cpu_map_idx, int thread, u64 val, u64 ena, u64 run, u64 lost) { @@ -1530,6 +1536,12 @@ static void evsel__set_count(struct evsel *counter, int cpu_map_idx, int thread, count = perf_counts(counter->counts, cpu_map_idx, thread); + if (counter->retire_lat) { + evsel__read_retire_lat(counter, cpu_map_idx, thread); + perf_counts__set_loaded(counter->counts, cpu_map_idx, thread, true); + return; + } + count->val = val; count->ena = ena; count->run = run; @@ -1778,6 +1790,9 @@ int evsel__read_counter(struct evsel *evsel, int cpu_map_idx, int thread) if (evsel__is_tool(evsel)) return evsel__read_tool(evsel, cpu_map_idx, thread); + if (evsel__is_retire_lat(evsel)) + return evsel__read_retire_lat(evsel, cpu_map_idx, thread); + if (evsel->core.attr.read_format & PERF_FORMAT_GROUP) return evsel__read_group(evsel, cpu_map_idx, thread); diff --git a/tools/perf/util/evsel.h b/tools/perf/util/evsel.h index bd8e84954e34..aaf572317e92 100644 --- a/tools/perf/util/evsel.h +++ b/tools/perf/util/evsel.h @@ -303,6 +303,11 @@ static inline bool evsel__is_tool(const struct evsel *evsel) return evsel->tool_event != PERF_TOOL_NONE; } +static inline bool evsel__is_retire_lat(const struct evsel *evsel) +{ + return evsel->retire_lat; +} + const char *evsel__group_name(struct evsel *evsel); int evsel__group_desc(struct evsel *evsel, char *buf, size_t size); -- 2.43.0