Received: by 10.223.176.5 with SMTP id f5csp2983975wra; Mon, 29 Jan 2018 07:09:53 -0800 (PST) X-Google-Smtp-Source: AH8x225Q8RVnTjDhnav43oxzxJtRG83hmYh0HPmyMB3gOwku1pyTPeVYClb/S6PalOvIvkpvETgD X-Received: by 2002:a17:902:69c5:: with SMTP id m5-v6mr21803802pln.347.1517238593796; Mon, 29 Jan 2018 07:09:53 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1517238593; cv=none; d=google.com; s=arc-20160816; b=OwJpfEkcVxIec1f3Q4WyT4tqsHTubfwPQmICDTxLWA0NEUsik7pBohEXvsFYIKLima lN9YXYfullu+602M4jOl5gu21/bIj62xMiFnW0rIhuRwHpu6B9x5+BZ2o5avRczg40uZ aXOhOEshZaAP/YFFaOgevWamSkD+3sBWh0Y1SXlQG/CWXW6fzUvt5qT0l4gjwB3yNcNE jeIP7gBulz8LQe90ndaU8MhhRx6vLUNwqM/0683YIHxsE85T/Y+q0svfo3S9QBswpN8q D0Ko4QfemKQraMy6pN6kFKV+q5H9S7ZxtUifu3qFsPfoBd4u4qgpxKgUbQuWpC8Mk0fY YEnA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :from:cc:references:to:subject:arc-authentication-results; bh=3iR6ZYN0mSwLrLZZX8cJ6uSLzGvf+gk0hrC3HstopdY=; b=SS6XGDgzRs9yxzNfXgU548w++ZFySfGtGmsiCPjA3USnJcjGEBks6pDhjCS/8d9i/N K8c1aK8TxVyzc+L9sbJevlTqEwHxycCoS7niyiOUPKHO54RAQK9qwuW3/aD9OnF5Ei6L sfJQFJ8/qRjJEsUaal1T6/y3X0t+3ED49/wuEG1ouSYnuSg6r2w3GKq9wBaUQ/t4CM1f zjATQ4Z+YqpgB2Gmb7Tv0fnMoCCEfWFKzAHWKfB2Nv7dBQYvb75DIHtKV1qH/v87GVDo GQwCYuJFzSxwS8HRnwRA/1lY+7iu7KOj4f6+z4ZdTvwz2ZgAp7vZV2goa3Zi1c3a1cAF 51+g== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=ibm.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id r10si7531412pgd.329.2018.01.29.07.09.39; Mon, 29 Jan 2018 07:09:53 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=ibm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752023AbeA2PJJ (ORCPT + 99 others); Mon, 29 Jan 2018 10:09:09 -0500 Received: from mx0b-001b2d01.pphosted.com ([148.163.158.5]:33714 "EHLO mx0a-001b2d01.pphosted.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1751599AbeA2PJH (ORCPT ); Mon, 29 Jan 2018 10:09:07 -0500 Received: from pps.filterd (m0098414.ppops.net [127.0.0.1]) by mx0b-001b2d01.pphosted.com (8.16.0.22/8.16.0.22) with SMTP id w0TF3dVv136085 for ; Mon, 29 Jan 2018 10:09:07 -0500 Received: from e06smtp15.uk.ibm.com (e06smtp15.uk.ibm.com [195.75.94.111]) by mx0b-001b2d01.pphosted.com with ESMTP id 2ft46cdnur-1 (version=TLSv1.2 cipher=AES256-SHA bits=256 verify=NOT) for ; Mon, 29 Jan 2018 10:09:06 -0500 Received: from localhost by e06smtp15.uk.ibm.com with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted for from ; Mon, 29 Jan 2018 15:09:04 -0000 Received: from b06cxnps4076.portsmouth.uk.ibm.com (9.149.109.198) by e06smtp15.uk.ibm.com (192.168.101.145) with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted; Mon, 29 Jan 2018 15:09:00 -0000 Received: from d06av23.portsmouth.uk.ibm.com (d06av23.portsmouth.uk.ibm.com [9.149.105.59]) by b06cxnps4076.portsmouth.uk.ibm.com (8.14.9/8.14.9/NCO v10.0) with ESMTP id w0TF8xKT44302436; Mon, 29 Jan 2018 15:08:59 GMT Received: from d06av23.portsmouth.uk.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id 9F82AA404D; Mon, 29 Jan 2018 15:02:33 +0000 (GMT) Received: from d06av23.portsmouth.uk.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id 679AAA4051; Mon, 29 Jan 2018 15:02:27 +0000 (GMT) Received: from [9.77.193.90] (unknown [9.77.193.90]) by d06av23.portsmouth.uk.ibm.com (Postfix) with ESMTP; Mon, 29 Jan 2018 15:02:27 +0000 (GMT) Subject: Re: [tip:perf/core] perf trace: Allow overriding global --max-stack per event To: acme@redhat.com References: Cc: jolsa@kernel.org, tglx@linutronix.de, adrian.hunter@intel.com, mingo@kernel.org, wangnan0@huawei.com, linux-kernel@vger.kernel.org, hpa@zytor.com, dsahern@gmail.com, brueckner@linux.vnet.ibm.com, namhyung@kernel.org, tmricht@linux.vnet.ibm.com, linux-tip-commits@vger.kernel.org, Ravi Bangoria From: Ravi Bangoria Date: Mon, 29 Jan 2018 20:40:32 +0530 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.5.2 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 7bit Content-Language: en-US X-TM-AS-GCONF: 00 x-cbid: 18012915-0020-0000-0000-000003EFEB3C X-IBM-AV-DETECTION: SAVI=unused REMOTE=unused XFE=unused x-cbparentid: 18012915-0021-0000-0000-0000428248D3 Message-Id: <4a483e53-c5e6-5f00-c76e-fceb287dae69@linux.vnet.ibm.com> X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10432:,, definitions=2018-01-29_08:,, signatures=0 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 spamscore=0 suspectscore=1 malwarescore=0 lowpriorityscore=0 phishscore=0 adultscore=0 bulkscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.0.1-1709140000 definitions=main-1801290199 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Arnaldo, This commit seems to be causing a regression: $ ./perf trace record -g ls Perf compiled from acme/perf/core: $ ./perf trace -i perf.data 0.200 ( 0.016 ms): ls/19722 brk( 0.367 ( 0.024 ms): ls/19722 access(filename: 0xa1438b70, mode: R 0.401 ( 0.019 ms): ls/19722 open(filename: 0xa1438978, flags: CLOEXEC Missing calltraces ^^^^^^^^^ Distro perf: $ perf trace -i perf.data 0.200 ( 0.016 ms): ls/19722 brk( do_syscall_trace_leave ([kernel.kallsyms]) [0] ([unknown]) syscall_exit_work ([kernel.kallsyms]) brk (/usr/lib64/ld-2.17.so) _dl_sysdep_start (/usr/lib64/ld-2.17.so) _dl_start_final (/usr/lib64/ld-2.17.so) _dl_start (/usr/lib64/ld-2.17.so) _start (/usr/lib64/ld-2.17.so) 0.367 ( 0.024 ms): ls/19722 access(filename: 0xa1438b70, mode: R do_syscall_trace_leave ([kernel.kallsyms]) [0] ([unknown]) syscall_exit_work ([kernel.kallsyms]) access (/usr/lib64/ld-2.17.so) dl_main (/usr/lib64/ld-2.17.so) _dl_sysdep_start (/usr/lib64/ld-2.17.so) _dl_start_final (/usr/lib64/ld-2.17.so) _dl_start (/usr/lib64/ld-2.17.so) _start (/usr/lib64/ld-2.17.so) 0.401 ( 0.019 ms): ls/19722 open(filename: 0xa1438978, flags: CLOEXEC do_syscall_trace_leave ([kernel.kallsyms]) [0] ([unknown]) syscall_exit_work ([kernel.kallsyms]) open64 (/usr/lib64/ld-2.17.so) Patch something like below should fix the issue ?? diff --git a/tools/perf/builtin-trace.c b/tools/perf/builtin-trace.c index 531d43b..d0ace22 100644 --- a/tools/perf/builtin-trace.c +++ b/tools/perf/builtin-trace.c @@ -1642,9 +1642,12 @@ static int trace__resolve_callchain(struct trace *trace, struct perf_evsel *evse struct callchain_cursor *cursor) { struct addr_location al; + int max_stack = evsel->attr.sample_max_stack ? + evsel->attr.sample_max_stack: + trace->max_stack; if (machine__resolve(trace->host, &al, sample) < 0 || - thread__resolve_callchain(al.thread, cursor, evsel, sample, NULL, NULL, evsel->attr.sample_max_stack)) + thread__resolve_callchain(al.thread, cursor, evsel, sample, NULL, NULL, max_stack)) return -1; return 0; Thanks, Ravi On 01/17/2018 10:04 PM, tip-bot for Arnaldo Carvalho de Melo wrote: > Commit-ID: bd3dda9ab0fbdb8a91a2e869d93a0c9692b8444f > Gitweb: https://git.kernel.org/tip/bd3dda9ab0fbdb8a91a2e869d93a0c9692b8444f > Author: Arnaldo Carvalho de Melo > AuthorDate: Mon, 15 Jan 2018 11:33:53 -0300 > Committer: Arnaldo Carvalho de Melo > CommitDate: Wed, 17 Jan 2018 10:23:33 -0300 > > perf trace: Allow overriding global --max-stack per event > > The per-event max-stack setting wasn't overriding the global --max-stack > setting: > > # perf trace --no-syscalls --max-stack 4 -e probe_libc:inet_pton/call-graph=dwarf,max-stack=2/ ping -6 -c 1 ::1 > PING ::1(::1) 56 data bytes > 64 bytes from ::1: icmp_seq=1 ttl=64 time=0.072 ms > > --- ::1 ping statistics --- > 1 packets transmitted, 1 received, 0% packet loss, time 0ms > rtt min/avg/max/mdev = 0.072/0.072/0.072/0.000 ms > 0.000 probe_libc:inet_pton:(7feb7a998350)) > __inet_pton (inlined) > gaih_inet.constprop.7 (/usr/lib64/libc-2.26.so) > __GI_getaddrinfo (inlined) > [0xffffaa39b6108f3f] (/usr/bin/ping) > # > > Fix it: > > # perf trace --no-syscalls --max-stack 4 -e probe_libc:inet_pton/call-graph=dwarf,max-stack=2/ ping -6 -c 1 ::1 > PING ::1(::1) 56 data bytes > 64 bytes from ::1: icmp_seq=1 ttl=64 time=0.073 ms > > --- ::1 ping statistics --- > 1 packets transmitted, 1 received, 0% packet loss, time 0ms > rtt min/avg/max/mdev = 0.073/0.073/0.073/0.000 ms > 0.000 probe_libc:inet_pton:(7f1083221350)) > __inet_pton (inlined) > gaih_inet.constprop.7 (/usr/lib64/libc-2.26.so) > # > > Cc: Adrian Hunter > Cc: David Ahern > Cc: Hendrick Brueckner > Cc: Jiri Olsa > Cc: Namhyung Kim > Cc: Thomas Richter > Cc: Wang Nan > Link: https://lkml.kernel.org/n/tip-ic3g837xg8ob3kcpkspxwz0g@git.kernel.org > Signed-off-by: Arnaldo Carvalho de Melo > --- > tools/perf/builtin-trace.c | 14 +++++++++++++- > 1 file changed, 13 insertions(+), 1 deletion(-) > > diff --git a/tools/perf/builtin-trace.c b/tools/perf/builtin-trace.c > index ee85c29..531d43b 100644 > --- a/tools/perf/builtin-trace.c > +++ b/tools/perf/builtin-trace.c > @@ -1644,7 +1644,7 @@ static int trace__resolve_callchain(struct trace *trace, struct perf_evsel *evse > struct addr_location al; > > if (machine__resolve(trace->host, &al, sample) < 0 || > - thread__resolve_callchain(al.thread, cursor, evsel, sample, NULL, NULL, trace->max_stack)) > + thread__resolve_callchain(al.thread, cursor, evsel, sample, NULL, NULL, evsel->attr.sample_max_stack)) > return -1; > > return 0; > @@ -2423,6 +2423,18 @@ static int trace__run(struct trace *trace, int argc, const char **argv) > trace->multiple_threads = thread_map__pid(evlist->threads, 0) == -1 || > evlist->threads->nr > 1 || > perf_evlist__first(evlist)->attr.inherit; > + > + /* > + * Now that we already used evsel->attr to ask the kernel to setup the > + * events, lets reuse evsel->attr.sample_max_stack as the limit in > + * trace__resolve_callchain(), allowing per-event max-stack settings > + * to override an explicitely set --max-stack global setting. > + */ > + evlist__for_each_entry(evlist, evsel) { > + if ((evsel->attr.sample_type & PERF_SAMPLE_CALLCHAIN) && > + evsel->attr.sample_max_stack == 0) > + evsel->attr.sample_max_stack = trace->max_stack; > + } > again: > before = trace->nr_events; > >