3 # objdiff - a small script for validating that a commit or series of commits
4 # didn't change object code.
6 # Copyright 2014, Jason Cooper <jason@lakedaemon.net>
8 # Licensed under the terms of the GNU GPL version 2
12 # $ git checkout COMMIT_A
13 # $ <your fancy build command here>
14 # $ ./scripts/objdiff record path/to/*.o
16 # $ git checkout COMMIT_B
17 # $ <your fancy build command here>
18 # $ ./scripts/objdiff record path/to/*.o
20 # $ ./scripts/objdiff diff COMMIT_A COMMIT_B
23 # And to clean up (everything is in .tmp_objdiff/*)
24 # $ ./scripts/objdiff clean all
26 # Note: 'make mrproper' will also remove .tmp_objdiff
28 GIT_DIR
="`git rev-parse --git-dir`"
30 if [ -d "$GIT_DIR" ]; then
31 TMPD
="${GIT_DIR%git}tmp_objdiff"
33 [ -d "$TMPD" ] || mkdir
"$TMPD"
35 echo "ERROR: git directory not found."
40 echo "Usage: $0 <command> <args>"
41 echo " record <list of object files>"
42 echo " diff <commitA> <commitB>"
43 echo " clean all | <commit>"
52 CMT
="`git rev-parse --short HEAD`"
54 OBJDUMP
="${CROSS_COMPILE}objdump"
57 [ ! -d "$OBJDIFFD" ] && mkdir
-p "$OBJDIFFD"
63 [ ! -d "$OBJDIFFD/$dn" ] && mkdir
-p "$OBJDIFFD/$dn"
65 # remove addresses for a more clear diff
66 # http://dummdida.tumblr.com/post/60924060451/binary-diff-between-libc-from-scientificlinux-and
67 $OBJDUMP -D "$f" |
sed "s/^[[:space:]]\+[0-9a-f]\+//" \
73 [ $# -ne 2 ] && [ $# -ne 0 ] && usage
76 SRC
="`git rev-parse --short HEAD^`"
77 DST
="`git rev-parse --short HEAD`"
79 SRC
="`git rev-parse --short $1`"
80 DST
="`git rev-parse --short $2`"
83 DIFF
="`which colordiff`"
85 if [ ${#DIFF} -eq 0 ] ||
[ ! -x "$DIFF" ]; then
92 if [ ! -d "$SRCD" ]; then
93 echo "ERROR: $SRCD doesn't exist"
97 if [ ! -d "$DSTD" ]; then
98 echo "ERROR: $DSTD doesn't exist"
102 $DIFF -Nurd $SRCD $DSTD
106 [ $# -eq 0 ] && usage
107 [ $# -gt 1 ] && usage
109 if [ "x$1" = "xall" ]; then
112 CMT
="`git rev-parse --short $1`"
114 if [ -d "$TMPD/$CMT" ]; then
117 echo "$CMT not found"
122 [ $# -eq 0 ] && usage
138 echo "Unrecognized command '$1'"