Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp3625825imm; Tue, 29 May 2018 10:25:47 -0700 (PDT) X-Google-Smtp-Source: AB8JxZo1T6gwCROdaam4lAhBiXIuwBxvCoFfmPskna2pc/sou9A8ga3cdsh7KV6VgUagLGz4US10 X-Received: by 2002:a62:ce4e:: with SMTP id y75-v6mr17929449pfg.175.1527614747234; Tue, 29 May 2018 10:25:47 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1527614747; cv=none; d=google.com; s=arc-20160816; b=ZiO8/b4PO4+R2Rf2//SYb54GSsoirdyZAonSoPWDnWDEAmZJ9LiAFjV6Op8/E1pYGd 4V4C9zctI7SW9zigS9stVVxqtJQ/vVh13nRvJGfvHLHmKEq0L4BIdyjEaI9n12TCVxBs OcP83SdPixhjj7haVwwH6bwW9HJVHrRurO4rvayCeYzUuoH6zzAn1Y8A+pQ86TJ7pnKn jvjrOFzmhdvgid6vO6+T+7UL88cKZ69bHEILmWb3OTUVFYobqboWp88t/xPF7SBrJODb H62ImL+iOhE+BtMLreoiuNCAiC5rPtF9077DIvWgZNeXxx8JUP1igR1hIvW+I8rfIQpq 1q0A== 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:dkim-signature:arc-authentication-results; bh=9n1v8hmJCkPzr60BeslmwXkE+JIcGqfmMEB9co6DujA=; b=lrYWzdxJrHokXF9iJV+5+8J52G5PV4omXznQrn+O0olsqEGF/URAONOXb3+5t8afD6 VHNKxfm+aiCZCeZES/LCLVjpBL+T7CFtRNRVJ4kODHPdE5B883LkPMJr/iqusJ+sX+Y+ BCGOYgFdC4bHyf8bMA7402qoCUD3+AQTZrA6na+WRlQv4roGU8pU9IgnP65RK2ASC2xS uFyCocmBt64RekggwR95mrMnvcrK3evUZOzYsEvVxMBtf+k1lpbUMMvV2KSK2Un4JI7n S7maWYROiAjn7/l+ZG6gLiRkEQlDXuvix4zahmxyTrJmQO7bVuyyDw5dYQWTly+ZwCy/ w6Ew== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@infradead.org header.s=bombadil.20170209 header.b=AunzUjKm; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id v6-v6si33744629plp.60.2018.05.29.10.25.33; Tue, 29 May 2018 10:25:47 -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; dkim=fail header.i=@infradead.org header.s=bombadil.20170209 header.b=AunzUjKm; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S965415AbeE2RYs (ORCPT + 99 others); Tue, 29 May 2018 13:24:48 -0400 Received: from bombadil.infradead.org ([198.137.202.133]:48860 "EHLO bombadil.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S965356AbeE2RYi (ORCPT ); Tue, 29 May 2018 13:24:38 -0400 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=bombadil.20170209; h=In-Reply-To:Content-Type:MIME-Version :References:Message-ID:Subject:Cc:To:From:Date:Sender:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Id: List-Help:List-Unsubscribe:List-Subscribe:List-Post:List-Owner:List-Archive; bh=9n1v8hmJCkPzr60BeslmwXkE+JIcGqfmMEB9co6DujA=; b=AunzUjKmMW10l/iU/wiS0NLH7 kV3MAHxG80SGbykfJPYtrTUE3FUTFnzdB03gMbPXUPdyksTcS5m3Xb1bySqpCsPAskReWFWEUibSV UsRdlrXE4Ik9c6u2+CSjxnnpb8EA2goc/OB9SNN234i3CTAicfsaDpl1htvZJcsv3Nfxi5j9nsrGO K5soiSJMMPPCZP4cfTUT1/9adX2jo05ePlWlLRsc/rYaW0ZeNEBD7biWwgaGOu46R8n9YC9w2W7oL vlTqIAzHmupxGxvToSqKLfjkSR2hY68EXTDsi6MvmwPKMsFzC+5v4Ioo0eg3hFO59TK4eDQ8KmTkl zzA1GaNvA==; Received: from j217100.upc-j.chello.nl ([24.132.217.100] helo=hirez.programming.kicks-ass.net) by bombadil.infradead.org with esmtpsa (Exim 4.90_1 #2 (Red Hat Linux)) id 1fNiMJ-0000M0-Tf; Tue, 29 May 2018 17:24:32 +0000 Received: by hirez.programming.kicks-ass.net (Postfix, from userid 1000) id 23C062029F869; Tue, 29 May 2018 19:24:30 +0200 (CEST) Date: Tue, 29 May 2018 19:24:30 +0200 From: Peter Zijlstra To: Josh Poimboeuf Cc: changbin.du@intel.com, akpm@linux-foundation.org, tglx@linutronix.de, pombredanne@nexb.com, neilb@suse.com, linux-kernel@vger.kernel.org, Linus Torvalds Subject: Re: [PATCH] scripts/faddr2line: show the code context Message-ID: <20180529172430.GB12180@hirez.programming.kicks-ass.net> 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> <20180529170710.q33dcw5l7a4bwd4t@treble> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20180529170710.q33dcw5l7a4bwd4t@treble> User-Agent: Mutt/1.9.5 (2018-04-13) 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 12:07:10PM -0500, Josh Poimboeuf wrote: > 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. --- From: Peter Zijlstra (Intel) Commit 6870c0165feaa5 ("scripts/faddr2line: show the code context") radically altered the output format of the faddr2line tool. And while the new list output format might have merrit it broke my vim usage and was hard to read. Make the new format optional; using a '--list' argument and attempt to make the output slightly easier to read by adding a little whitespace to separate the different files and explicitly mark the line in question. Cc: Changbin Du Acked-by: Josh Poimboeuf Fixes: 6870c0165feaa5 ("scripts/faddr2line: show the code context") Signed-off-by: Peter Zijlstra (Intel) --- 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