Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp524402pxb; Wed, 27 Jan 2021 13:52:54 -0800 (PST) X-Google-Smtp-Source: ABdhPJxXY5V8WZCGdL+YtrFntxIImM/QXgNquI2auxUCsQlG/U6Sz30H4zj1oRNuZyYIVDK2058Y X-Received: by 2002:a50:8a90:: with SMTP id j16mr10462053edj.334.1611784374451; Wed, 27 Jan 2021 13:52:54 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1611784374; cv=none; d=google.com; s=arc-20160816; b=GMDY9SPx7aD+xCoiC7uCALpAByPIUY0lUvLLoVg2dZLqC/lkKFBrVnP5+YyaBstcNq 9OVXfF6aKit0ZQq6jZMCB9/Yl8PCQ7DcrsGVyMAYJ5lWNsPY+hAu6Cc6/3KIYoSvNDkS +PeZSrraoYPELnnElXTYWFIS2VBWm26a3ybOxjCJLvIPP9BYoB1mJDZVL/MvxzFSAb1P 5SeH0cTxDdjWKnAyqOrerSzJjMxxXY7I7ALBZIh3/SAfiSds/9TSF7HdG8YMq6kHOQQK rpdS/I4NmvdUTyMH4E1ql60vOr/jVyQxf/CMtpXRPwsGqNWQ7Zbhm7nqqmzsOJmkNmPD jUjA== 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; bh=0mIl+jZKMm+r77upmxm8SiZc6w/s7wz/2dl9pKHphgA=; b=w/SBcmmFRewYIprnwtju5V4v3Nh90HBoNASTPJaPkQrYULOfxvIe0R8lI8qBV4Ho+k GDiGuhZL+whytcP2KLnC3I3NitIKziW+O6h1Boj0KIx06g1TTYqXnFnwXMUrgFLJRSkP 2cGvFY9uq705Jtn+0//cLYra0MiSEArYxd+dRoNU9RHEEw2Vkunva0N6BckvvUfwTpLo ec0D7w1XXaxKitlj3ZEeuMhcMAsh4MpY2yieWbColNIh0ZtnC9CKnfaQHm74xemmS7j8 0XKED+xKmaGKh+7i3HXCG+QlpbmPsnrPcw99BndXQzXcRuit+A1htuE4Ef4liFjLT9hy QOgg== 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=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id gw2si1368590ejb.264.2021.01.27.13.52.28; Wed, 27 Jan 2021 13:52:54 -0800 (PST) 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=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235134AbhA0Jt5 (ORCPT + 99 others); Wed, 27 Jan 2021 04:49:57 -0500 Received: from foss.arm.com ([217.140.110.172]:32966 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233985AbhA0I7I (ORCPT ); Wed, 27 Jan 2021 03:59:08 -0500 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id EB41B152D; Wed, 27 Jan 2021 00:56:13 -0800 (PST) Received: from p8cg001049571a15.arm.com (unknown [10.163.91.246]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPA id BC0003F66B; Wed, 27 Jan 2021 00:56:10 -0800 (PST) From: Anshuman Khandual To: linux-arm-kernel@lists.infradead.org, coresight@lists.linaro.org Cc: mathieu.poirier@linaro.org, suzuki.poulose@arm.com, mike.leach@linaro.org, lcherian@marvell.com, linux-kernel@vger.kernel.org, Anshuman Khandual , Peter Zijlstra , Leo Yan Subject: [PATCH V3 14/14] coresight: etm-perf: Add support for trace buffer format Date: Wed, 27 Jan 2021 14:25:38 +0530 Message-Id: <1611737738-1493-15-git-send-email-anshuman.khandual@arm.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1611737738-1493-1-git-send-email-anshuman.khandual@arm.com> References: <1611737738-1493-1-git-send-email-anshuman.khandual@arm.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Suzuki K Poulose CoreSight PMU supports aux-buffer for the ETM tracing. The trace generated by the ETM (associated with individual CPUs, like Intel PT) is captured by a separate IP (CoreSight TMC-ETR/ETF until now). The TMC-ETR applies formatting of the raw ETM trace data, as it can collect traces from multiple ETMs, with the TraceID to indicate the source of a given trace packet. Arm Trace Buffer Extension is new "sink" IP, attached to individual CPUs and thus do not provide additional formatting, like TMC-ETR. Additionally, a system could have both TRBE *and* TMC-ETR for the trace collection. e.g, TMC-ETR could be used as a single trace buffer to collect data from multiple ETMs to correlate the traces from different CPUs. It is possible to have a perf session where some events end up collecting the trace in TMC-ETR while the others in TRBE. Thus we need a way to identify the type of the trace for each AUX record. Define the trace formats exported by the CoreSight PMU. We don't define the flags following the "ETM" as this information is available to the user when issuing the session. What is missing is the additional formatting applied by the "sink" which is decided at the runtime and the user may not have a control on. So we define : - CORESIGHT format (indicates the Frame format) - RAW format (indicates the format of the source) The default value is CORESIGHT format for all the records (i,e == 0). Add the RAW format for the TRBE sink driver. Cc: Peter Zijlstra Cc: Mike Leach Cc: Mathieu Poirier Cc: Leo Yan Cc: Anshuman Khandual Signed-off-by: Suzuki K Poulose Signed-off-by: Anshuman Khandual --- drivers/hwtracing/coresight/coresight-trbe.c | 2 ++ include/uapi/linux/perf_event.h | 4 ++++ 2 files changed, 6 insertions(+) diff --git a/drivers/hwtracing/coresight/coresight-trbe.c b/drivers/hwtracing/coresight/coresight-trbe.c index 1464d8b..7c0e691 100644 --- a/drivers/hwtracing/coresight/coresight-trbe.c +++ b/drivers/hwtracing/coresight/coresight-trbe.c @@ -511,6 +511,7 @@ static unsigned long arm_trbe_update_buffer(struct coresight_device *csdev, if (cpudata->mode != CS_MODE_PERF) return -EINVAL; + perf_aux_output_flag(handle, PERF_AUX_FLAG_CORESIGHT_FORMAT_RAW); /* * If the TRBE was disabled due to lack of space in the AUX buffer or a * spurious fault, the driver leaves it disabled, truncating the buffer. @@ -606,6 +607,7 @@ static void trbe_handle_overflow(struct perf_output_handle *handle) size = offset - PERF_IDX2OFF(handle->head, buf); if (buf->snapshot) handle->head = offset; + perf_aux_output_flag(handle, PERF_AUX_FLAG_CORESIGHT_FORMAT_RAW); perf_aux_output_end(handle, size); event_data = perf_aux_output_begin(handle, event); diff --git a/include/uapi/linux/perf_event.h b/include/uapi/linux/perf_event.h index 9a5ca45..169e6b3 100644 --- a/include/uapi/linux/perf_event.h +++ b/include/uapi/linux/perf_event.h @@ -1111,6 +1111,10 @@ enum perf_callchain_context { #define PERF_AUX_FLAG_COLLISION 0x08 /* sample collided with another */ #define PERF_AUX_FLAG_PMU_FORMAT_TYPE_MASK 0xff00 /* PMU specific trace format type */ +/* CoreSight PMU AUX buffer formats */ +#define PERF_AUX_FLAG_CORESIGHT_FORMAT_CORESIGHT 0x0000 /* Default for backward compatibility */ +#define PERF_AUX_FLAG_CORESIGHT_FORMAT_RAW 0x0100 /* Raw format of the source */ + #define PERF_FLAG_FD_NO_GROUP (1UL << 0) #define PERF_FLAG_FD_OUTPUT (1UL << 1) #define PERF_FLAG_PID_CGROUP (1UL << 2) /* pid=cgroup id, per-cpu mode only */ -- 2.7.4