Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751839AbaDAHkZ (ORCPT ); Tue, 1 Apr 2014 03:40:25 -0400 Received: from mail9.hitachi.co.jp ([133.145.228.44]:57465 "EHLO mail9.hitachi.co.jp" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751089AbaDAHkU (ORCPT ); Tue, 1 Apr 2014 03:40:20 -0400 Message-ID: <533A6D5D.60306@hitachi.com> Date: Tue, 01 Apr 2014 16:40:13 +0900 From: Masami Hiramatsu Organization: Hitachi, Ltd., Japan User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:13.0) Gecko/20120614 Thunderbird/13.0.1 MIME-Version: 1.0 To: Namhyung Kim Cc: Arnaldo Carvalho de Melo , Peter Zijlstra , Ingo Molnar , Paul Mackerras , Namhyung Kim , LKML , Jiri Olsa Subject: Re: Re: [PATCH] perf probe: Fix --line option behavior References: <1396327677-3657-1-git-send-email-namhyung@kernel.org> <533A4839.60406@hitachi.com> In-Reply-To: Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org (2014/04/01 16:21), Namhyung Kim wrote: > Hi Masami, > > (Also adding Jiri in CC and changing email of acme) > > On Tue, Apr 1, 2014 at 5:01 AM, Masami Hiramatsu > wrote: >> (2014/04/01 13:47), Namhyung Kim wrote: >>> The commit 5a62257a3ddd1 ("perf probe: Replace line_list with >>> intlist") replaced line_list to intlist but it has a problem that if a >>> same line was added again, it'd return -EEXIST rather than 1. >> >> Ah, right! that's a different behavior. >> >>> Since line_range_walk_cb() only checks the result being negative, it >>> resulted in failure or segfault sometimes. >> >> Could you give me an example input of the segfault? I'd like to trace >> it down. > > Just used current acme/perf/core. > > $ git log -1 > commit 28b5724a61cc9d84f2cbef6675e8a85ae4b1bc57 > Author: Arnaldo Carvalho de Melo > Date: Thu Mar 27 17:36:14 2014 -0300 > > MAINTAINERS: Change e-mail to kernel.org one > > Leaving ghostprotocols.net for old networking stuff. > > ... > > $ perf --version > perf version 3.14.rc6.g28b572 > > $ perf probe -x ./perf -v -L map__load > Open Debuginfo file: /home/namhyung/project/linux/tools/perf/perf > fname: util/map.c, lineno:153 > New line range: 153 to 2147483647 > path: (null) > Segmentation fault (core dumped) > > > It seems like find_line_range_by_line() called for multiple times, > line_range_walk_cb returns 0 at first but as line_range_add_line() > returns -EEXIST, it freed lr->path and __show_line_range() ended up > accessing to NULL path. OK, thanks for this nice report! Hmm, line_range_inline_cb() must check the result of find_line_range_by_line() but ignored. That should be fixed too... Thank you, > > > (gdb) bt > #0 get_real_path (new_path=0x839ff8 , > comp_dir=0x1f994f0 "/home/namhyung/project/linux/tools/perf", > raw_path=0x0) at util/probe-event.c:518 > #1 __show_line_range (module=, lr=0x839fd8 ) > at util/probe-event.c:641 > #2 show_line_range (lr=lr@entry=0x839fd8 , > module=) at util/probe-event.c:699 > #3 0x000000000044667b in __cmd_probe (argc=, > argv=argv@entry=0x7fff7a770ba0, prefix=) > at builtin-probe.c:465 > #4 0x00000000004469f4 in cmd_probe (argc=, > argv=0x7fff7a770ba0, prefix=) at builtin-probe.c:520 > #5 0x00000000004241b5 in run_builtin (p=p@entry=0x7ebde0 , > argc=argc@entry=6, argv=argv@entry=0x7fff7a770ba0) at perf.c:319 > #6 0x0000000000423a29 in handle_internal_command (argv=0x7fff7a770ba0, > argc=6) at perf.c:376 > #7 run_argv (argv=0x7fff7a7709a0, argcp=0x7fff7a7709ac) at perf.c:420 > #8 main (argc=6, argv=0x7fff7a770ba0) at perf.c:529 > > > Thanks, > Namhyung > -- > To unsubscribe from this list: send the line "unsubscribe linux-kernel" in > the body of a message to majordomo@vger.kernel.org > More majordomo info at http://vger.kernel.org/majordomo-info.html > Please read the FAQ at http://www.tux.org/lkml/ > -- Masami HIRAMATSU IT Management Research Dept. Linux Technology Center Hitachi, Ltd., Yokohama Research Laboratory E-mail: masami.hiramatsu.pt@hitachi.com -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/