Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp3611205imm; Tue, 29 May 2018 10:08:45 -0700 (PDT) X-Google-Smtp-Source: AB8JxZqDEYQj1GDhgmUh/6NC4lciBlg3lS0iHede9K+5PplfDWxk2TCDG4/wgye3fnZ4h8cOAO6q X-Received: by 2002:a62:e04c:: with SMTP id f73-v6mr18251626pfh.88.1527613725380; Tue, 29 May 2018 10:08:45 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1527613725; cv=none; d=google.com; s=arc-20160816; b=JJFOq7WntLcetgIoVY9XRSAHVEsbFlmDNi/uEtj+WYMVJ6KBQy7yVxX4Tp9ucYMExm T7IOmpBwReEABlGXnOm/GAXBi/Q1YcMlaiEp9k+QWFGOnDr/f2K+B6BrPpIe4G9taNyO RpP7hPnZeBxB3h3oORUCwp+6w4oVBULGvJ28D3XwE4e5DQnd5T9C4YEkSkLP4UJAS+K7 nq5ZOI5UcupcIkty36uZ+n2kC2j+VrUn5UkyA3cYnDEBVesp7XbLgBBGYb2fsn36SsmX l6I4uaUzQZ530r0338trYeIa5XXOdNwjgVhnk6W2Hhtf5BYBHCuTWbeJQxCplHxqHFwD lEoQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:arc-authentication-results; bh=yH2upXvsMluU7BWtC9WkMHmstvbycP22kAPa8lcAnGA=; b=tptTGAV7buroszz6Fr9prodXSXfYx4lmBuIrRokdw9foIWpZC9+1U9pbqSZhsUnDb6 61LPYwnD4FkKsBtrI+YKbqDLetDPgCSyA50i1mwNi7f4fukOigOkC7UuJBnl+6owSgvz SCKUO19wcZeMcwZ29Ivb2ZnZyuqq2GFsY/oEid6WLmXHSVMCwsKjU/MYTWR6jLBN1fVg 9bqXwE0Tl5frCER8wZidJwxU8NbDWbEBYOWYbJLwZCanq7hU0AbSdhgVYKy4yIY2UUQA /Q7NevGFHVi9nw1Uoy6qGXHPhiHfiCl/dqd9CfQLNvEIU2yiyxs2Oq5DipQ+4h3myRNG s9GA== 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=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id a24-v6si8985485pgw.213.2018.05.29.10.08.30; Tue, 29 May 2018 10:08:45 -0700 (PDT) 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=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S965383AbeE2RHP (ORCPT + 99 others); Tue, 29 May 2018 13:07:15 -0400 Received: from mx3-rdu2.redhat.com ([66.187.233.73]:56062 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S964848AbeE2RHM (ORCPT ); Tue, 29 May 2018 13:07:12 -0400 Received: from smtp.corp.redhat.com (int-mx06.intmail.prod.int.rdu2.redhat.com [10.11.54.6]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id 2C1358163AD2; Tue, 29 May 2018 17:07:12 +0000 (UTC) Received: from treble (ovpn-126-4.rdu2.redhat.com [10.10.126.4]) by smtp.corp.redhat.com (Postfix) with ESMTPS id AF2D42166BB2; Tue, 29 May 2018 17:07:11 +0000 (UTC) Date: Tue, 29 May 2018 12:07:10 -0500 From: Josh Poimboeuf To: Peter Zijlstra Cc: changbin.du@intel.com, akpm@linux-foundation.org, tglx@linutronix.de, pombredanne@nexb.com, neilb@suse.com, linux-kernel@vger.kernel.org Subject: Re: [PATCH] scripts/faddr2line: show the code context Message-ID: <20180529170710.q33dcw5l7a4bwd4t@treble> References: <1521444205-2259-1-git-send-email-changbin.du@intel.com> <20180529160332.GD12258@hirez.programming.kicks-ass.net> <20180529162636.GW12235@hirez.programming.kicks-ass.net> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <20180529162636.GW12235@hirez.programming.kicks-ass.net> User-Agent: NeoMutt/20180323 X-Scanned-By: MIMEDefang 2.78 on 10.11.54.6 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.11.55.8]); Tue, 29 May 2018 17:07:12 +0000 (UTC) X-Greylist: inspected by milter-greylist-4.5.16 (mx1.redhat.com [10.11.55.8]); Tue, 29 May 2018 17:07:12 +0000 (UTC) for IP:'10.11.54.6' DOMAIN:'int-mx06.intmail.prod.int.rdu2.redhat.com' HELO:'smtp.corp.redhat.com' FROM:'jpoimboe@redhat.com' RCPT:'' Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, May 29, 2018 at 06:26:36PM +0200, Peter Zijlstra wrote: > On Tue, May 29, 2018 at 06:03:32PM +0200, Peter Zijlstra wrote: > > On Mon, Mar 19, 2018 at 03:23:25PM +0800, changbin.du@intel.com wrote: > > > From: Changbin Du > > > > > > Inspired by gdb command 'list', show the code context of target lines. > > > Here is a example: > > > > > > $ scripts/faddr2line vmlinux native_write_msr+0x6 > > > native_write_msr+0x6/0x20: > > > arch_static_branch at arch/x86/include/asm/msr.h:105 > > > 100 return EAX_EDX_VAL(val, low, high); > > > 101 } > > > 102 > > > 103 static inline void notrace __wrmsr(unsigned int msr, u32 low, u32 high) > > > 104 { > > > 105 asm volatile("1: wrmsr\n" > > > 106 "2:\n" > > > 107 _ASM_EXTABLE_HANDLE(1b, 2b, ex_handler_wrmsr_unsafe) > > > 108 : : "c" (msr), "a"(low), "d" (high) : "memory"); > > > 109 } > > > 110 > > > (inlined by) static_key_false at include/linux/jump_label.h:142 > > > 137 #define JUMP_TYPE_LINKED 2UL > > > 138 #define JUMP_TYPE_MASK 3UL > > > 139 > > > 140 static __always_inline bool static_key_false(struct static_key *key) > > > 141 { > > > 142 return arch_static_branch(key, false); > > > 143 } > > > 144 > > > 145 static __always_inline bool static_key_true(struct static_key *key) > > > 146 { > > > 147 return !arch_static_branch(key, true); > > > (inlined by) native_write_msr at arch/x86/include/asm/msr.h:150 > > > 145 static inline void notrace > > > 146 native_write_msr(unsigned int msr, u32 low, u32 high) > > > 147 { > > > 148 __wrmsr(msr, low, high); > > > 149 > > > 150 if (msr_tracepoint_active(__tracepoint_write_msr)) > > > 151 do_trace_write_msr(msr, ((u64)high << 32 | low), 0); > > > 152 } > > > 153 > > > 154 /* Can be uninlined because referenced by paravirt */ > > > 155 static inline int notrace > > > > Not a fan of this :-/ And you didn't even make it optional. Nor did you > > Cc the original author of the tool. > > Something like so fixes it up and attempts to make the --list version > more readable. > > --- > scripts/faddr2line | 18 ++++++++++++++++-- > 1 file changed, 16 insertions(+), 2 deletions(-) > > diff --git a/scripts/faddr2line b/scripts/faddr2line > index 1876a741087c..a0149db00be7 100755 > --- a/scripts/faddr2line > +++ b/scripts/faddr2line > @@ -56,7 +56,7 @@ command -v ${SIZE} >/dev/null 2>&1 || die "size isn't installed" > command -v ${NM} >/dev/null 2>&1 || die "nm isn't installed" > > usage() { > - echo "usage: faddr2line ..." >&2 > + echo "usage: faddr2line [--list] ..." >&2 > exit 1 > } > > @@ -166,15 +166,25 @@ __faddr2line() { > local file_lines=$(${ADDR2LINE} -fpie $objfile $addr | sed "s; $dir_prefix\(\./\)*; ;") > [[ -z $file_lines ]] && return > > + if [[ $LIST = 0 ]]; then > + echo "$file_lines" | while read -r line > + do > + echo $line > + done > + DONE=1; > + return > + fi > + > # show each line with context > echo "$file_lines" | while read -r line > do > + echo > echo $line > n=$(echo $line | sed 's/.*:\([0-9]\+\).*/\1/g') > n1=$[$n-5] > n2=$[$n+5] > f=$(echo $line | sed 's/.*at \(.\+\):.*/\1/g') > - awk 'NR>=strtonum("'$n1'") && NR<=strtonum("'$n2'") {printf("%d\t%s\n", NR, $0)}' $f > + awk 'NR>=strtonum("'$n1'") && NR<=strtonum("'$n2'") { if (NR=='$n') printf(">%d<", NR); else printf(" %d ", NR); printf("\t%s\n", $0)}' $f > done > > DONE=1 > @@ -185,6 +195,10 @@ __faddr2line() { > [[ $# -lt 2 ]] && usage > > objfile=$1 > + > +LIST=0 > +[[ "$objfile" == "--list" ]] && LIST=1 && shift && objfile=$1 > + > [[ ! -f $objfile ]] && die "can't find objfile $objfile" > shift Yeah, this change really should have been an optional arg. It hurt the readability and compactness of the output. The above looks good to me. Care to send a proper patch? If you send it to Linus he might apply it directly as he did with my original patches. -- Josh