Received: by 2002:ab2:6d45:0:b0:1fb:d597:ff75 with SMTP id d5csp81993lqr; Tue, 4 Jun 2024 22:25:06 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCVw0Ci5oJnJNT27LXvOp/98bEv8dfQnHK8oBMYYqiyvIWSg5YLSbtX5anhfbrygPiGPsab5NRywPQuZSfGF4wKrDBhBbB6J9KPbjmXAZA== X-Google-Smtp-Source: AGHT+IEtsERSoo8uoXC817vBDktPhas0JPzJLmab1LClV1K3ybjUNGGKeZRZ/W0FG+hforVYno3W X-Received: by 2002:a05:6358:5f01:b0:199:669:488b with SMTP id e5c5f4694b2df-19c6c6923fbmr200603255d.13.1717565106033; Tue, 04 Jun 2024 22:25:06 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1717565105; cv=pass; d=google.com; s=arc-20160816; b=bQ/IUwt89HhoXSlmnU/dxVW4W6pIYal1589k8yQw6Q9jtyj2Yh5riI9R3NRj405tG5 SgIsxaP895GE6segpqDt8cO2fqkeyVwy0LAoC6KQydCPgjQxMm+vzYzJ2WElrVBWD7aW t1q076+fOWofBfI2XFgFtm1i6snUunJ91ZyDSfRcpNQW8EyqSIWVCNn24i4fsMWm5yrx zPMl5KZ4P0suXT953dKInoyzXJCKxiMfcwLQAWdp2h6I7+/+s4w7pT0nQIQbxca86RO2 zsmQ13toa4+GLglWSjSflXYgZWTdEEbTU6FwuDs+7rmDyjRQhJ+uFIwN94Uy3Qz3QYWD mNpw== 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=SqmVEwQwSopD45zrYhAUZ2jHlgnTYFs2MwjfgCoJXGeQhhxjib07KYuemN3qa+qJQO 4y7npyQtvyGkYL1YwF25K1R9Tc5xRayH3+OPV4GehPDoqM0SeQl4xLKrltFOZ8wR4Wzf HFccnHk37SABvgA31NgPR95Er3N71WadQUWHiheuPZt2g63/pcqSyiYIeapo/EHfJTPa 6ZWfNIG1wui1/NfFuPaITZHyERYycvbCZdTMWMFhu8aqMXOawHQEGXLSZbeOJpGPAJ8G dRRAifzF/he4N61G3CjY3yjy13SF6RLwzAPbKocTlV79vAe6LgW+IK4LZXJxLhDOusJO BSaA==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=njSRWVQi; 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-201770-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-201770-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-6c35d973cb8si2795687a12.889.2024.06.04.22.25.05 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 04 Jun 2024 22:25:05 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-201770-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=njSRWVQi; 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-201770-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-201770-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 DC153B266B9 for ; Wed, 5 Jun 2024 05:23:31 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 9752913DDAA; Wed, 5 Jun 2024 05:22:19 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=intel.com header.i=@intel.com header.b="njSRWVQi" Received: from mgamail.intel.com (mgamail.intel.com [198.175.65.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 CD51513BACE; Wed, 5 Jun 2024 05:22:16 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=198.175.65.13 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1717564938; cv=none; b=bKrsU0hfpKLC9zDJMhoCBBOo3NGaNUkhGd9Sjgr7s7BIBjD8GCDkhUQStswSMvGKdcvIfPoIiJmzs+tUQKoARtFC3Onx50VButtZTOsxNj4sivdEIpHiTVgiFFAgk/cijXKedKFGAiXHpnPgQV2BGa/tf/WAtVGet0SfIoY7RXA= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1717564938; c=relaxed/simple; bh=JFZfvPynPzZ2TE0Vt2lqzId/TgulfeakQxZrwtr+l44=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version:Content-Type; b=g3yXCR4osauH/ko1wtt6VF04cD1TkPgVIpTVLTLnil0BnxVMsFYwsqmypOHA5ilv485k/JDTIgv1J2IwtxA9Qs5k340iXG619aj9tLhWQSnO13htaonYM4S6WT8RllN3JezR2NRGUxvZIzj1/XZ+VTv0BiX0TIG7lnASck146sk= 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=njSRWVQi; arc=none smtp.client-ip=198.175.65.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=1717564937; x=1749100937; h=from:to:cc:subject:date:message-id:in-reply-to: references:mime-version:content-transfer-encoding; bh=JFZfvPynPzZ2TE0Vt2lqzId/TgulfeakQxZrwtr+l44=; b=njSRWVQi2PzP9LKZpW5l3g0lGfkByjoBEcJ6WbUuyzF3RWFoNiv/CJoQ 5WrTA0jO+Ds/7353xkIYaUe5nLDpqzmH8Wrfazymj4tJRuGcLqqQfDWtP ueJjnmVv2qg/uwAmfHcub/AfTXNDzNrfUUbuFGjCY1begq6kQp5lrcfmw iTp1FKiQOcRV9v8iumczh28GvCjPqit5vHLEG3mGURzKM2aUgrx1H4Yid JQ4houAhmbE9Us3fTBjTb3E8Idq9dubT6tBXhoGDWMv1ChynUP3vGkqa9 wmQ5s+XPIiJSKdQer1Qv6Q0FDo1Vi2dA9tXztzFxtxOgZqD5U4lrANGMc Q==; X-CSE-ConnectionGUID: 6vbaG4T5QS+0BZDZ/4gACw== X-CSE-MsgGUID: bH6icdXBSwKnJCjQsPyRPw== X-IronPort-AV: E=McAfee;i="6600,9927,11093"; a="25258820" X-IronPort-AV: E=Sophos;i="6.08,215,1712646000"; d="scan'208";a="25258820" Received: from orviesa009.jf.intel.com ([10.64.159.149]) by orvoesa105.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 04 Jun 2024 22:22:12 -0700 X-CSE-ConnectionGUID: bfFgv1xGQU6Wtz+4EGpr0g== X-CSE-MsgGUID: p0Om1wp1S2eg1CZCFRUeng== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="6.08,215,1712646000"; d="scan'208";a="37525762" Received: from fl31ca102ks0602.deacluster.intel.com (HELO gnr-bkc.deacluster.intel.com) ([10.75.133.163]) by orviesa009.jf.intel.com with ESMTP; 04 Jun 2024 22:22:12 -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 v11 7/8] perf Document: Add TPEBS to Documents Date: Wed, 5 Jun 2024 01:21:48 -0400 Message-ID: <20240605052200.4143205-8-weilin.wang@intel.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20240605052200.4143205-1-weilin.wang@intel.com> References: <20240605052200.4143205-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