blob: aae7a035242b28dfde756de4ce9e03e3fbce15db [file] [log] [blame]
Randy Dunlapdcecc6c2007-07-15 23:41:15 -07001#!/bin/sh
2# Disassemble the Code: line in Linux oopses
3# usage: decodecode < oops.file
4#
5# options: set env. variable AFLAGS=options to pass options to "as";
6# e.g., to decode an i386 oops on an x86_64 system, use:
7# AFLAGS=--32 decodecode < 386.oops
8
Randy Dunlapfa220d82008-01-14 15:18:31 -08009cleanup() {
Rabin Vincent5358db02010-01-05 20:27:58 +053010 rm -f $T $T.s $T.o $T.oo $T.aa $T.dis
Randy Dunlapfa220d82008-01-14 15:18:31 -080011 exit 1
12}
13
14die() {
15 echo "$@"
16 exit 1
17}
18
19trap cleanup EXIT
20
21T=`mktemp` || die "cannot create temp file"
Randy Dunlapdcecc6c2007-07-15 23:41:15 -070022code=
23
24while read i ; do
25
26case "$i" in
27*Code:*)
28 code=$i
29 ;;
30esac
31
32done
33
34if [ -z "$code" ]; then
Randy Dunlapfa220d82008-01-14 15:18:31 -080035 rm $T
Randy Dunlapdcecc6c2007-07-15 23:41:15 -070036 exit
37fi
38
39echo $code
40code=`echo $code | sed -e 's/.*Code: //'`
41
Rabin Vincent5358db02010-01-05 20:27:58 +053042width=`expr index "$code" ' '`
Rabin Vincentb396aa02010-06-03 22:48:12 +053043width=$((($width-1)/2))
Rabin Vincent5358db02010-01-05 20:27:58 +053044case $width in
451) type=byte ;;
462) type=2byte ;;
474) type=4byte ;;
48esac
49
50disas() {
Rabin Vincentb396aa02010-06-03 22:48:12 +053051 ${CROSS_COMPILE}as $AFLAGS -o $1.o $1.s > /dev/null 2>&1
Rabin Vincent5358db02010-01-05 20:27:58 +053052
Rabin Vincentb396aa02010-06-03 22:48:12 +053053 if [ "$ARCH" = "arm" ]; then
54 if [ $width -eq 2 ]; then
Rabin Vincent5358db02010-01-05 20:27:58 +053055 OBJDUMPFLAGS="-M force-thumb"
56 fi
57
58 ${CROSS_COMPILE}strip $1.o
59 fi
60
61 ${CROSS_COMPILE}objdump $OBJDUMPFLAGS -S $1.o | \
Rabin Vincentb396aa02010-06-03 22:48:12 +053062 grep -v "/tmp\|Disassembly\|\.text\|^$" > $1.dis 2>&1
Rabin Vincent5358db02010-01-05 20:27:58 +053063}
64
Randy Dunlapdcecc6c2007-07-15 23:41:15 -070065marker=`expr index "$code" "\<"`
66if [ $marker -eq 0 ]; then
67 marker=`expr index "$code" "\("`
68fi
69
Arjan van de Ven846442c2008-12-01 14:21:06 -080070touch $T.oo
Randy Dunlapdcecc6c2007-07-15 23:41:15 -070071if [ $marker -ne 0 ]; then
Arjan van de Ven846442c2008-12-01 14:21:06 -080072 echo All code >> $T.oo
73 echo ======== >> $T.oo
74 beforemark=`echo "$code"`
Rabin Vincent5358db02010-01-05 20:27:58 +053075 echo -n " .$type 0x" > $T.s
76 echo $beforemark | sed -e 's/ /,0x/g; s/[<>()]//g' >> $T.s
77 disas $T
78 cat $T.dis >> $T.oo
79 rm -f $T.o $T.s $T.dis
Randy Dunlapdcecc6c2007-07-15 23:41:15 -070080
81# and fix code at-and-after marker
82 code=`echo "$code" | cut -c$((${marker} + 1))-`
83fi
Arjan van de Ven846442c2008-12-01 14:21:06 -080084echo Code starting with the faulting instruction > $T.aa
85echo =========================================== >> $T.aa
Rabin Vincent5358db02010-01-05 20:27:58 +053086code=`echo $code | sed -e 's/ [<(]/ /;s/[>)] / /;s/ /,0x/g; s/[>)]$//'`
87echo -n " .$type 0x" > $T.s
Randy Dunlapdcecc6c2007-07-15 23:41:15 -070088echo $code >> $T.s
Rabin Vincent5358db02010-01-05 20:27:58 +053089disas $T
90cat $T.dis >> $T.aa
Arjan van de Ven846442c2008-12-01 14:21:06 -080091
Borislav Petkov18ff44b2013-04-29 15:05:54 -070092# (lines of whole $T.oo) - (lines of $T.aa, i.e. "Code starting") + 3,
93# i.e. the title + the "===..=" line (sed is counting from 1, 0 address is
94# special)
95faultlinenum=$(( $(wc -l $T.oo | cut -d" " -f1) - \
96 $(wc -l $T.aa | cut -d" " -f1) + 3))
97
Borislav Petkov2a95e372012-08-15 13:00:51 +020098faultline=`cat $T.dis | head -1 | cut -d":" -f2-`
Rabin Vincent5358db02010-01-05 20:27:58 +053099faultline=`echo "$faultline" | sed -e 's/\[/\\\[/g; s/\]/\\\]/g'`
Arjan van de Ven846442c2008-12-01 14:21:06 -0800100
Ivan Delalandee03e0f12020-05-07 18:35:53 -0700101cat $T.oo | sed -e "${faultlinenum}s/^\([^:]*:\)\(.*\)/\1\*\2\t\t<-- trapping instruction/"
Arjan van de Ven846442c2008-12-01 14:21:06 -0800102echo
103cat $T.aa
104cleanup