Received: by 2002:a05:6500:1b8f:b0:1fa:5c73:8e2d with SMTP id df15csp454559lqb; Wed, 29 May 2024 00:00:34 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCUvXzB8pFX1aE6Cyg8iAh3jkrz56A2cnll5NLJ9rxmn3ZDLQ5+cLXEk3Cp3Wa66meNx9uvjJefqWdEd03qyIPx9PK/jn+N8IgKpv6glMA== X-Google-Smtp-Source: AGHT+IF60l3wEOT9uLXA5qsmBf/bz7CPmjsxXt+YBs9XuuTLAMtnz6anMAzww0J4yxjphWBS8v3Q X-Received: by 2002:a05:6a20:12d1:b0:1af:f6b9:e3e4 with SMTP id adf61e73a8af0-1b212cc7637mr17004243637.12.1716966034586; Wed, 29 May 2024 00:00:34 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1716966034; cv=pass; d=google.com; s=arc-20160816; b=RGQOuyGQU3fbnVTuiNybOpNRkGTA9MXfcAS9nGhNZAGLhPhalXqpMKpfDy5Nks4bOd HoLQUItXS/8j4KFbGTDCOzOLAtv00xavfoEB7LIqc7HU/ZI40/GlF11z24MhJJkzdcpQ csYWAw0UR12FmPJGhMEL8zIOORFmPzBnAqqJh40/STCEwi9LhDGf+1CiWYx3JSqJsZGe px5LwPn2KzYz8oprl5rvDqns9rGSqKgeDOoUgEiU6dE1T9AuYo0/ZN2y3tJ17O0Pu24H n1bUuUpMu+keazl6n03I2110YT22UkOCp4jpxE4lfwAB4STo5IF3KJt4K+7QNZZVPfaH fRRA== 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=lIACNVr1MxuxSUXhZqD7Su2kcVtkIladBJFg6uZwAJo=; fh=7D8bWqELNqJM6KF7zbibUOya8038rGAdDMFXsJMRu8c=; b=ID/txrGgpY9LQh4Tqg45IrqxIZK5VP29WTmxfYndiuVKaws46DNGRl+NmpxyBn4Bls h/3Nm7ulPIA9n0yCECj3A+LoG9nVr9NQBXf68kLq387slVZhfnrpK9WgdSk7sYEiCDbW owQGYLFIiFOJqe4tXSsHbVSOqWMA0eUUhLGE9RhslhWw9W/+YfG9K5mLoBsyn+DEkAgH 6ntgbnf8CqwWBfrNybEbeGe32Ey1vBbJD+KQRwYoN/gALRf7GwVq3yfUblfFVMq7+RqE +UunEdS6UWL3xxTaUWYwt0BNfkcO/GTYa4++YofiXVC0xLxzeOCOQ0/3/0b9gbOYgA95 ynAg==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=YCeL8Tuz; 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-193536-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-193536-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from sy.mirrors.kernel.org (sy.mirrors.kernel.org. [2604:1380:40f1:3f00::1]) by mx.google.com with ESMTPS id 41be03b00d2f7-682bd32665esi9682832a12.545.2024.05.29.00.00.34 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 29 May 2024 00:00:34 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-193536-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) client-ip=2604:1380:40f1:3f00::1; Authentication-Results: mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=YCeL8Tuz; 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-193536-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-193536-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 sy.mirrors.kernel.org (Postfix) with ESMTPS id C16A1B254FF for ; Wed, 29 May 2024 06:44:45 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 51C04167DBB; Wed, 29 May 2024 06:43:42 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=intel.com header.i=@intel.com header.b="YCeL8Tuz" 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 B95CE1667E9; Wed, 29 May 2024 06:43:39 +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=1716965021; cv=none; b=FKYXbjAZJs8lstdk3Hk0QqlCNDzsyxGY1LNnGXyZHjlTSu8hHEypID9zv6/ts0R8YEYpH723JWHlpd/ciTNOzjxbCgZwi5xVBlcmn8302fQIrth4N0vHCdCG6vAyTgEGm+kue9iIPNDOuMNxfQ2q7yePkuRAov3GpIWcpuQZ2rs= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1716965021; c=relaxed/simple; bh=JFZfvPynPzZ2TE0Vt2lqzId/TgulfeakQxZrwtr+l44=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version:Content-Type; b=Q0iyIgEwUPM4T8qO1J7fQb2Jruwv+mjnVULyA7C5GeTci/8a7XhxMOrzGjOeu57woir0el3kesOdss/MZiuM5l3FdqhlH11eTvZ7M6okONRIiudbgm5iYpct7s0LTnHVTEdhphaeo7kanwdPC3v+2xkchw4kTbxk0CLYef4RXyk= 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=YCeL8Tuz; 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=1716965020; x=1748501020; h=from:to:cc:subject:date:message-id:in-reply-to: references:mime-version:content-transfer-encoding; bh=JFZfvPynPzZ2TE0Vt2lqzId/TgulfeakQxZrwtr+l44=; b=YCeL8TuzXn6h3WuEV+l53tXNaUQL7hn79pWvtATspXjXfd/MeyOGUpb1 /mrBoO6uom0YtBc7iyXxzeSoMIr+vX8j7NqoDgZ8xFkB8VaRCacJbAVFk liB8B+nmrtI2nhuGpHXCOzngahGCh257MQTc7PU/7A3rMoTI6ybo4TG4t u8GUoevPaxuMxT4ARdGIT71I1MiYPbnjWBbJfQ5UzwkwzCAUtdr6L0m5n Hpc8/gtJ9hfwm1EuFjRq37SsjKP8GC6GK/cpOpkPvF+Tlz/RVTYt+2p3v xpXcMQIY+IJIXkhY5xG7VEE1KmpGFJd38m9qD06cfKxksLPPegOqbXfFE w==; X-CSE-ConnectionGUID: yfLiLjrzQbeHNTQGi7aPfA== X-CSE-MsgGUID: PLpyiLDZT8iomWGYyB9CWQ== X-IronPort-AV: E=McAfee;i="6600,9927,11085"; a="16298012" X-IronPort-AV: E=Sophos;i="6.08,197,1712646000"; d="scan'208";a="16298012" 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:37 -0700 X-CSE-ConnectionGUID: 7ECo2PnjQvqYqGgqNS7igQ== X-CSE-MsgGUID: HI5qvP+tSkmyzpjGkj2Vug== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="6.08,197,1712646000"; d="scan'208";a="39759328" 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:36 -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 7/8] perf Document: Add TPEBS to Documents Date: Wed, 29 May 2024 02:43:23 -0400 Message-ID: <20240529064327.4080674-8-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-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit From: Weilin Wang TPEBS is a new feature Intel PMU from Granite Rapids microarchitecture. It will be used in new TMA releases. Adding related introduction to documents while adding new code to support it in perf stat. Signed-off-by: Weilin Wang --- tools/perf/Documentation/perf-list.txt | 1 + tools/perf/Documentation/topdown.txt | 30 ++++++++++++++++++++++++++ 2 files changed, 31 insertions(+) diff --git a/tools/perf/Documentation/perf-list.txt b/tools/perf/Documentation/perf-list.txt index 6bf2468f59d3..dea005410ec0 100644 --- a/tools/perf/Documentation/perf-list.txt +++ b/tools/perf/Documentation/perf-list.txt @@ -72,6 +72,7 @@ counted. The following modifiers exist: W - group is weak and will fallback to non-group if not schedulable, e - group or event are exclusive and do not share the PMU b - use BPF aggregration (see perf stat --bpf-counters) + R - retire latency value of the event The 'p' modifier can be used for specifying how precise the instruction address should be. The 'p' modifier can be specified multiple times: diff --git a/tools/perf/Documentation/topdown.txt b/tools/perf/Documentation/topdown.txt index ae0aee86844f..98e5503552f5 100644 --- a/tools/perf/Documentation/topdown.txt +++ b/tools/perf/Documentation/topdown.txt @@ -325,6 +325,36 @@ other four level 2 metrics by subtracting corresponding metrics as below. Fetch_Bandwidth = Frontend_Bound - Fetch_Latency Core_Bound = Backend_Bound - Memory_Bound +TPEBS in TopDown +================ + +TPEBS (Timed PEBS) is one of the new Intel PMU features provided since Granite +Rapids microarchitecture. The TPEBS feature adds a 16 bit retire_latency field +in the Basic Info group of the PEBS record. It records the Core cycles since the +retirement of the previous instruction to the retirement of current instruction. +Please refer to Section 8.4.1 of "Intel® Architecture Instruction Set Extensions +Programming Reference" for more details about this feature. Because this feature +extends PEBS record, sampling with weight option is required to get the +retire_latency value. + + perf record -e event_name -W ... + +In the most recent release of TMA, the metrics begin to use event retire_latency +values in some of the metrics’ formulas on processors that support TPEBS feature. +For previous generations that do not support TPEBS, the values are static and +predefined per processor family by the hardware architects. Due to the diversity +of workloads in execution environments, retire_latency values measured at real +time are more accurate. Therefore, new TMA metrics that use TPEBS will provide +more accurate performance analysis results. + +To support TPEBS in TMA metrics, a new modifier :R on event is added. Perf would +capture retire_latency value of required events(event with :R in metric formula) +with perf record. The retire_latency value would be used in metric calculation. +Currently, this feature is supported through perf stat + + perf stat -M metric_name --enable-tpebs-recording ... + + [1] https://software.intel.com/en-us/top-down-microarchitecture-analysis-method-win [2] https://sites.google.com/site/analysismethods/yasin-pubs -- 2.43.0