]> git.proxmox.com Git - mirror_ubuntu-jammy-kernel.git/commitdiff
scripts/faddr2line: make the new code listing format optional
authorPeter Zijlstra (Intel) <peterz@infradead.org>
Mon, 4 Jun 2018 18:48:31 +0000 (13:48 -0500)
committerLinus Torvalds <torvalds@linux-foundation.org>
Tue, 5 Jun 2018 16:04:37 +0000 (09:04 -0700)
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 merit 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 <changbin.du@intel.com>
Fixes: 6870c0165feaa5 ("scripts/faddr2line: show the code context")
Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Signed-off-by: Josh Poimboeuf <jpoimboe@redhat.com>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
scripts/faddr2line

index 1876a741087cc531645f4dc5383a7a234de6f5bd..a0149db00be752555ff4178f66540543a5835955 100755 (executable)
@@ -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 <object file> <func+offset> <func+offset>..." >&2
+       echo "usage: faddr2line [--list] <object file> <func+offset> <func+offset>..." >&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