Received: by 2002:a05:6a10:5bc5:0:0:0:0 with SMTP id os5csp3980987pxb; Sat, 6 Nov 2021 04:32:00 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwmenlahVJ7zXkbQm7B7Cj0+fzXTROAmEKkwtNb+jYNAWnSiufk+MxDhe2tgRzBzvUAuUzD X-Received: by 2002:a17:906:b2d0:: with SMTP id cf16mr33326485ejb.52.1636198320287; Sat, 06 Nov 2021 04:32:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1636198320; cv=none; d=google.com; s=arc-20160816; b=dCw5sY0QnV7YH0v7PMB+SFjnJNW+YP7onHa6MT6Rlq+EC1FP5oaJFXroA9idLyrAUv uorAa2N/9azKxJ0cMRexis8/4RVpKOg7jQP65IMACozZOV/hq2siLk74LUIgpWC0kgnm Gu1BJklLo1QLh/MVCqEHf9VcpLd/6RNEL8fZlShgKmjFmhspNK8mi4beULT5HtY3qDVJ z19IpenSTNaGPKXVpXB7wsZPo91fpPNUo6T+ElgdJKQ2Lrc1upVHys1G/CBXvyY6KL5l 9+PptSSlT2Ayjbi910cKx649wDpibtZ6X+SO1PNM6RCty2dLWnz0MLGnAEWPl5fOBuda QFqg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=YY2yROP/RTZn4kLLVf2pxBx6PraWK6o1QIaMf35Sqmw=; b=wC0KIvEXGioFFpIf+zUwtcEJBcsnUa8u6O2TsD3ZI4uoN11T4xNp3orXxWAZKqtupf Lv4UXKpm4+DkWj4VMp9C0FRC4gIncc7jCxhODditbwiN8Z6okoZ/VsqIjZKRmN8nmF/k WBuPsbY6SYhnOuGY0etwTNTM0EHQKzJRf/TW3csKqSOSME3iG09STms6VV7OKtt+JSrG SLN1ncZJkkM/UQ7BOMJ6DvCDMu3qHnvuIH0Ega8/TExKG3AYXP7JsmYNQ9VH60zj1hEV pjPZ9OfGCOihYMTEBLGurxc3FDcDd7/SHR7zu0P3Uqg/319hu2L588JY/mN8H3nxTsPE eCmA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=fip6mcen; 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=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id b13si6857093edz.312.2021.11.06.04.31.15; Sat, 06 Nov 2021 04:32:00 -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; dkim=pass header.i=@linaro.org header.s=google header.b=fip6mcen; 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=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233214AbhKFDbz (ORCPT + 99 others); Fri, 5 Nov 2021 23:31:55 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59650 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232715AbhKFDby (ORCPT ); Fri, 5 Nov 2021 23:31:54 -0400 Received: from mail-pj1-x1036.google.com (mail-pj1-x1036.google.com [IPv6:2607:f8b0:4864:20::1036]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 17088C061570 for ; Fri, 5 Nov 2021 20:29:14 -0700 (PDT) Received: by mail-pj1-x1036.google.com with SMTP id w9-20020a17090a1b8900b001a6b3b7ec17so4573373pjc.3 for ; Fri, 05 Nov 2021 20:29:14 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to; bh=YY2yROP/RTZn4kLLVf2pxBx6PraWK6o1QIaMf35Sqmw=; b=fip6mcenQtkDGEeS3eGubOC8kkjNwPGdbKl4wiy8GVwrR7+gCYDENj2vCPY6wQc0b5 OrH5+AFy3eCMw+bkbCbS0rlTtamxK+kzOD9qHGMF8bp3q8h3m2l606GOGlLCT17VzaRC 5L0z9A1grNoc28fW6FZlwk6u3Us/ZNjUEAZl4fkavMFI+avLVOFy3Fk7+jkXzmUpGf/+ USp7M2KkqToanvio/zZvbcuwukj29ImxKrc1Vl7jV/APA7qLekEpq//0xYsInoOHFaR2 vzFHnDG14UPO6h15MLtUK1psCHta+QYpoda0kubZSj0zoFx3o9QdX3M8H6rabeonap+m 2Dcw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to; bh=YY2yROP/RTZn4kLLVf2pxBx6PraWK6o1QIaMf35Sqmw=; b=0oOSs+CGK7+R+0Y6oZCaZ9oHrS6qIgzruq3xaJmUTlTGqO56W6Ix/vVpcOFbUAgqAG 1mAfPfHx8cTH2u9+2yTXZBjcCIJtYy0hqX0mftcOVXJUsi+wjn6wLtSf/owuPuI5CgBI u0jCpU5BtCpRlQ5Hp9HRhwPj36hRT29aO7EZcaiqH11BCbeeMru+0PxYO3CfKryVsjXm Mbiii8PT7scoqStem2ZGx9G+8xQGHUcyc/Z26TcyZxSWJc09z04o7l6jLREkB3mkyG+F 43OLcg8+6BbS6a4A2Y6jPWWGKRJYbctWxgyprgeJM5vY5gtbX7OWSJO6fw0JVEgbbBh+ 8gjg== X-Gm-Message-State: AOAM530/JnNu8RknKS2PuzPW8exU2oktbecpBquapIvBcwdkNgL9Tw4q 4jNIvAoNAsOn0sFz77O5EhAh+Q== X-Received: by 2002:a17:90a:fec:: with SMTP id 99mr35452489pjz.193.1636169353433; Fri, 05 Nov 2021 20:29:13 -0700 (PDT) Received: from leoy-ThinkPad-X240s ([134.195.101.46]) by smtp.gmail.com with ESMTPSA id j3sm7695065pfc.47.2021.11.05.20.29.09 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 05 Nov 2021 20:29:12 -0700 (PDT) Date: Sat, 6 Nov 2021 11:29:07 +0800 From: Leo Yan To: German Gomez Cc: linux-kernel@vger.kernel.org, linux-perf-users@vger.kernel.org, acme@kernel.org, Namhyung Kim , John Garry , Will Deacon , Mathieu Poirier , Mark Rutland , Alexander Shishkin , Jiri Olsa , linux-arm-kernel@lists.infradead.org Subject: Re: [PATCH 1/3] perf arm-spe: Track task context switch for cpu-mode events Message-ID: <20211106032907.GG477387@leoy-ThinkPad-X240s> References: <20211102180739.18049-1-german.gomez@arm.com> <20211102180739.18049-2-german.gomez@arm.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20211102180739.18049-2-german.gomez@arm.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi German, On Tue, Nov 02, 2021 at 06:07:37PM +0000, German Gomez wrote: > When perf report synthesize events from ARM SPE data, it refers to > current cpu, pid and tid in the machine. But there's no place to set > them in the ARM SPE decoder. I'm seeing all pid/tid is set to -1 and > user symbols are not resolved in the output. > > # perf record -a -e arm_spe_0/ts_enable=1/ sleep 1 > > # perf report -q | head > 8.77% 8.77% :-1 [kernel.kallsyms] [k] format_decode > 7.02% 7.02% :-1 [kernel.kallsyms] [k] seq_printf > 7.02% 7.02% :-1 [unknown] [.] 0x0000ffff9f687c34 > 5.26% 5.26% :-1 [kernel.kallsyms] [k] vsnprintf > 3.51% 3.51% :-1 [kernel.kallsyms] [k] string > 3.51% 3.51% :-1 [unknown] [.] 0x0000ffff9f66ae20 > 3.51% 3.51% :-1 [unknown] [.] 0x0000ffff9f670b3c > 3.51% 3.51% :-1 [unknown] [.] 0x0000ffff9f67c040 > 1.75% 1.75% :-1 [kernel.kallsyms] [k] ___cache_free > 1.75% 1.75% :-1 [kernel.kallsyms] [k] > __count_memcg_events > > Like Intel PT, add context switch records to track task info. As ARM > SPE support was added later than PERF_RECORD_SWITCH_CPU_WIDE, I think > we can safely set the attr.context_switch bit and use it. > > Signed-off-by: Namhyung Kim > Signed-off-by: German Gomez Reviewed-by: Leo Yan Note for one thing, please keep "Namhyung Kim" as the author for this patch, thanks. Leo > --- > tools/perf/arch/arm64/util/arm-spe.c | 6 +++++- > tools/perf/util/arm-spe.c | 25 +++++++++++++++++++++++++ > 2 files changed, 30 insertions(+), 1 deletion(-) > > diff --git a/tools/perf/arch/arm64/util/arm-spe.c b/tools/perf/arch/arm64/util/arm-spe.c > index a4420d4df..58ba8d15c 100644 > --- a/tools/perf/arch/arm64/util/arm-spe.c > +++ b/tools/perf/arch/arm64/util/arm-spe.c > @@ -166,8 +166,12 @@ static int arm_spe_recording_options(struct auxtrace_record *itr, > tracking_evsel->core.attr.sample_period = 1; > > /* In per-cpu case, always need the time of mmap events etc */ > - if (!perf_cpu_map__empty(cpus)) > + if (!perf_cpu_map__empty(cpus)) { > evsel__set_sample_bit(tracking_evsel, TIME); > + evsel__set_sample_bit(tracking_evsel, CPU); > + /* also track task context switch */ > + tracking_evsel->core.attr.context_switch = 1; > + } > > return 0; > } > diff --git a/tools/perf/util/arm-spe.c b/tools/perf/util/arm-spe.c > index 58b7069c5..230bc7ab2 100644 > --- a/tools/perf/util/arm-spe.c > +++ b/tools/perf/util/arm-spe.c > @@ -681,6 +681,25 @@ static int arm_spe_process_timeless_queues(struct arm_spe *spe, pid_t tid, > return 0; > } > > +static int arm_spe_context_switch(struct arm_spe *spe, union perf_event *event, > + struct perf_sample *sample) > +{ > + pid_t pid, tid; > + int cpu; > + > + if (!(event->header.misc & PERF_RECORD_MISC_SWITCH_OUT)) > + return 0; > + > + pid = event->context_switch.next_prev_pid; > + tid = event->context_switch.next_prev_tid; > + cpu = sample->cpu; > + > + if (tid == -1) > + pr_warning("context_switch event has no tid\n"); > + > + return machine__set_current_tid(spe->machine, cpu, pid, tid); > +} > + > static int arm_spe_process_event(struct perf_session *session, > union perf_event *event, > struct perf_sample *sample, > @@ -718,6 +737,12 @@ static int arm_spe_process_event(struct perf_session *session, > } > } else if (timestamp) { > err = arm_spe_process_queues(spe, timestamp); > + if (err) > + return err; > + > + if (event->header.type == PERF_RECORD_SWITCH_CPU_WIDE || > + event->header.type == PERF_RECORD_SWITCH) > + err = arm_spe_context_switch(spe, event, sample); > } > > return err; > -- > 2.25.1 >