summaryrefslogtreecommitdiff
path: root/utils/codegen-diff
diff options
context:
space:
mode:
authorBrian Gaeke <gaeke@uiuc.edu>2003-07-03 21:44:32 +0000
committerBrian Gaeke <gaeke@uiuc.edu>2003-07-03 21:44:32 +0000
commit3fb290e41f2eafdfed43613691232943112618fb (patch)
treeb23a06b1a86e3c73440cc657fe181f1dac190399 /utils/codegen-diff
parent6bc3b7c701233308353fa649dd289672da92703d (diff)
downloadllvm-3fb290e41f2eafdfed43613691232943112618fb.tar.gz
llvm-3fb290e41f2eafdfed43613691232943112618fb.tar.bz2
llvm-3fb290e41f2eafdfed43613691232943112618fb.tar.xz
Add -d option to trust the disassembler.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@7105 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'utils/codegen-diff')
-rwxr-xr-xutils/codegen-diff19
1 files changed, 18 insertions, 1 deletions
diff --git a/utils/codegen-diff b/utils/codegen-diff
index 35a6c00403..9b2930b47e 100755
--- a/utils/codegen-diff
+++ b/utils/codegen-diff
@@ -1,5 +1,7 @@
#!/usr/bin/perl
+use Getopt::Std;
+
sub parse_objdump_file {
my ($filename) = @_;
my @result;
@@ -55,12 +57,14 @@ sub binary_diffs {
my $d1 = $file1[$i];
my $d2 = $file2[$i];
if ($d1->{'bytes'} ne $d2->{'bytes'}) {
+ next if (($d1->{'instr'} eq $d2->{'instr'}) && $opt_d);
printf "0x%08x:\t%30s \t%s\n", 0+$d1->{'addr'}, $d1->{'bytes'}, $d1->{'instr'};
printf "0x%08x:\t%30s \t%s\n\n", 0+$d2->{'addr'}, $d2->{'bytes'}, $d2->{'instr'};
}
}
}
+&getopts('d');
$objdump_file = $ARGV[0];
$gdb_file = $ARGV[1];
binary_diffs ($objdump_file, $gdb_file);
@@ -74,7 +78,7 @@ codegen-diff
=head1 SYNOPSIS
-codegen-diff I<OBJDUMP-OUTPUT-FILE> I<GDB-DISASSEMBLY-FILE>
+codegen-diff [-d] I<OBJDUMP-OUTPUT-FILE> I<GDB-DISASSEMBLY-FILE>
=head1 DESCRIPTION
@@ -97,6 +101,19 @@ Finally, you run B<codegen-diff>, as indicated in the Synopsis section of
this manpage. It will print out a two-line stanza for each mismatched
instruction, with the B<llc> version first, and the B<lli> version second.
+=head1 OPTIONS
+
+=over 4
+
+=item -d
+
+Don't show instructions where the bytes are different but they
+disassemble to the same thing. This puts a lot of trust in the
+disassembler, but it might help you highlight the more egregious cases
+of misassembly.
+
+=back
+
=head1 AUTHOR
B<codegen-diff> was written by Brian Gaeke.