diff options
Diffstat (limited to 'binutils')
-rw-r--r-- | binutils/debug.c | 9 | ||||
-rw-r--r-- | binutils/doc/binutils.texi | 17 | ||||
-rw-r--r-- | binutils/testsuite/binutils-all/compress.exp | 16 | ||||
-rw-r--r-- | binutils/testsuite/binutils-all/loongarch64/dis-options-multi.d | 10 | ||||
-rw-r--r-- | binutils/testsuite/binutils-all/loongarch64/dis-options-no-alises.d | 10 | ||||
-rw-r--r-- | binutils/testsuite/binutils-all/loongarch64/dis-options-numeric.d | 10 | ||||
-rw-r--r-- | binutils/testsuite/binutils-all/loongarch64/dis-options.s | 3 | ||||
-rw-r--r-- | binutils/testsuite/binutils-all/objdump.exp | 34 |
8 files changed, 78 insertions, 31 deletions
diff --git a/binutils/debug.c b/binutils/debug.c index dcc8ccd..465b18e 100644 --- a/binutils/debug.c +++ b/binutils/debug.c @@ -2554,9 +2554,6 @@ debug_write_type (struct debug_handle *info, case DEBUG_KIND_UNION_CLASS: return debug_write_class_type (info, fns, fhandle, type, tag); case DEBUG_KIND_ENUM: - if (type->u.kenum == NULL) - return (*fns->enum_type) (fhandle, tag, (const char **) NULL, - (bfd_signed_vma *) NULL); return (*fns->enum_type) (fhandle, tag, type->u.kenum->names, type->u.kenum->values); case DEBUG_KIND_POINTER: @@ -3097,9 +3094,9 @@ debug_type_samep (struct debug_handle *info, struct debug_type_s *t1, break; case DEBUG_KIND_ENUM: - if (t1->u.kenum == NULL) - ret = t2->u.kenum == NULL; - else if (t2->u.kenum == NULL) + if (t1->u.kenum->names == NULL) + ret = t2->u.kenum->names == NULL; + else if (t2->u.kenum->names == NULL) ret = false; else { diff --git a/binutils/doc/binutils.texi b/binutils/doc/binutils.texi index 73848e3..5bf5d80 100644 --- a/binutils/doc/binutils.texi +++ b/binutils/doc/binutils.texi @@ -2701,6 +2701,23 @@ If you disassemble without giving a CPU selection, a default will be chosen from information gleaned by BFD from the object files headers, but the result again may not be as you expect. +For RISC-V, the following options are supported: + +@table @code +@item numeric +Print numeric register names, rather than ABI names (e.g., print @code{x2} +instead of @code{sp}). + +@item no-aliases +Disassemble only into canonical instructions. For example, compressed +instructions will be represented as such (@code{addi sp,sp,-128} will be +@code{c.addi16sp sp,-128}). + +@item priv-spec=@var{SPEC} +Print the CSR according to the chosen privilege spec version (e.g., +@code{1.10}, @code{1.11}, @code{1.12}). +@end table + For MIPS, this option controls the printing of instruction mnemonic names and register names in disassembled instructions. Multiple selections from the following may be specified as a comma separated diff --git a/binutils/testsuite/binutils-all/compress.exp b/binutils/testsuite/binutils-all/compress.exp index 5db9417..db167f0 100644 --- a/binutils/testsuite/binutils-all/compress.exp +++ b/binutils/testsuite/binutils-all/compress.exp @@ -163,24 +163,24 @@ if ![string match "" $got] then { } set testname "objdump compress debug sections" -set got [remote_exec host "$OBJDUMP -W ${compressedfile}.o" "" "/dev/null" "objdump.out"] +set got [remote_exec host "$OBJDUMP -W ${compressedfile}.o" "" "/dev/null" "tmpdir/objdump.out"] if { [lindex $got 0] != 0 || ![string match "" [lindex $got 1]] } then { fail "$testname" send_log "$got\n" } -if { [regexp_diff objdump.out $srcdir/$subdir/dw2-1.W] } then { +if { [regexp_diff tmpdir/objdump.out $srcdir/$subdir/dw2-1.W] } then { fail "$testname" } else { pass "$testname" } set testname "objdump compress debug sections 3" -set got [remote_exec host "$OBJDUMP -W ${compressedfile3}.o" "" "/dev/null" "objdump.out"] +set got [remote_exec host "$OBJDUMP -W ${compressedfile3}.o" "" "/dev/null" "tmpdir/objdump.out"] if { [lindex $got 0] != 0 || ![string match "" [lindex $got 1]] } then { fail "$testname" send_log "$got\n" } -if { [regexp_diff objdump.out $srcdir/$subdir/dw2-3.W] } then { +if { [regexp_diff tmpdir/objdump.out $srcdir/$subdir/dw2-3.W] } then { fail "$testname" } else { pass "$testname" @@ -565,12 +565,12 @@ if ![string match "" $got] then { } set testname "objdump compress debug sections 3 with zlib-gabi" -set got [remote_exec host "$OBJDUMP -W ${compressedfile3}gabi.o" "" "/dev/null" "objdump.out"] +set got [remote_exec host "$OBJDUMP -W ${compressedfile3}gabi.o" "" "/dev/null" "tmpdir/objdump.out"] if { [lindex $got 0] != 0 || ![string match "" [lindex $got 1]] } then { fail "$testname" send_log "$got\n" } -if { [regexp_diff objdump.out $srcdir/$subdir/dw2-3gabi.W] } then { +if { [regexp_diff tmpdir/objdump.out $srcdir/$subdir/dw2-3gabi.W] } then { fail "$testname" } else { pass "$testname" @@ -639,7 +639,7 @@ proc convert_test { testname as_flags objcop_flags } { return } - set got [remote_exec host "$OBJDUMP -W ${copyfile}.o" "" "/dev/null" "objdump.out"] + set got [remote_exec host "$OBJDUMP -W ${copyfile}.o" "" "/dev/null" "tmpdir/objdump.out"] if { [lindex $got 0] != 0 || ![string match "" [lindex $got 1]] } then { fail "$testname (reason: unexpected output)" @@ -648,7 +648,7 @@ proc convert_test { testname as_flags objcop_flags } { return } - if { [regexp_diff objdump.out $srcdir/$subdir/dw2-3.W] } then { + if { [regexp_diff tmpdir/objdump.out $srcdir/$subdir/dw2-3.W] } then { fail "$testname" } else { pass "$testname" diff --git a/binutils/testsuite/binutils-all/loongarch64/dis-options-multi.d b/binutils/testsuite/binutils-all/loongarch64/dis-options-multi.d new file mode 100644 index 0000000..2f34cb8 --- /dev/null +++ b/binutils/testsuite/binutils-all/loongarch64/dis-options-multi.d @@ -0,0 +1,10 @@ +#name: LoongArch disassembler options: multiple +#source: dis-options.s +#objdump: -d --no-show-raw-insn -M no-aliases,numeric + +#... +Disassembly of section \.text: + +[0-9a-f]+ <\.text>: + [0-9a-f]+:[ ]+or[ ]+\$r4, \$r21, \$r0 + [0-9a-f]+:[ ]+jirl[ ]+\$r0, \$r1, 0 diff --git a/binutils/testsuite/binutils-all/loongarch64/dis-options-no-alises.d b/binutils/testsuite/binutils-all/loongarch64/dis-options-no-alises.d new file mode 100644 index 0000000..eb4ea62 --- /dev/null +++ b/binutils/testsuite/binutils-all/loongarch64/dis-options-no-alises.d @@ -0,0 +1,10 @@ +#name: LoongArch disassembler options: no-aliases +#source: dis-options.s +#objdump: -d --no-show-raw-insn -M no-aliases + +#... +Disassembly of section \.text: + +[0-9a-f]+ <\.text>: + [0-9a-f]+:[ ]+or[ ]+\$a0, \$r21, \$zero + [0-9a-f]+:[ ]+jirl[ ]+\$zero, \$ra, 0 diff --git a/binutils/testsuite/binutils-all/loongarch64/dis-options-numeric.d b/binutils/testsuite/binutils-all/loongarch64/dis-options-numeric.d new file mode 100644 index 0000000..e669cef --- /dev/null +++ b/binutils/testsuite/binutils-all/loongarch64/dis-options-numeric.d @@ -0,0 +1,10 @@ +#name: LoongArch disassembler options: numeric +#source: dis-options.s +#objdump: -d --no-show-raw-insn -M numeric + +#... +Disassembly of section \.text: + +[0-9a-f]+ <\.text>: + [0-9a-f]+:[ ]+move[ ]+\$r4, \$r21 + [0-9a-f]+:[ ]+ret diff --git a/binutils/testsuite/binutils-all/loongarch64/dis-options.s b/binutils/testsuite/binutils-all/loongarch64/dis-options.s new file mode 100644 index 0000000..a3a4469 --- /dev/null +++ b/binutils/testsuite/binutils-all/loongarch64/dis-options.s @@ -0,0 +1,3 @@ +.text + move $a0, $r21 + ret diff --git a/binutils/testsuite/binutils-all/objdump.exp b/binutils/testsuite/binutils-all/objdump.exp index 76ee30f..f3142b1 100644 --- a/binutils/testsuite/binutils-all/objdump.exp +++ b/binutils/testsuite/binutils-all/objdump.exp @@ -454,7 +454,7 @@ if { ![is_elf_format] } then { set compressed_testfile tmpdir/dw2-compressed.${obj} } - set got [remote_exec host "$OBJDUMP $OBJDUMPFLAGS -s -j .zdebug_abbrev $compressed_testfile" "" "/dev/null" "objdump.out"] + set got [remote_exec host "$OBJDUMP $OBJDUMPFLAGS -s -j .zdebug_abbrev $compressed_testfile" "" "/dev/null" "tmpdir/objdump.out"] if { [lindex $got 0] != 0 || ![string match "" [lindex $got 1]] } then { fail "objdump -s -j .zdebug_abbrev (reason: unexpected output)" @@ -462,7 +462,7 @@ if { ![is_elf_format] } then { send_log "\n" } - if { [regexp_diff objdump.out $srcdir/$subdir/objdump.s] } then { + if { [regexp_diff tmpdir/objdump.out $srcdir/$subdir/objdump.s] } then { fail "objdump -s -j .zdebug_abbrev" } else { pass "objdump -s -j .zdebug_abbrev" @@ -470,7 +470,7 @@ if { ![is_elf_format] } then { # Test objdump -W on a file that contains some compressed .debug sections - set got [remote_exec host "$OBJDUMP $OBJDUMPFLAGS -W $compressed_testfile" "" "/dev/null" "objdump.out"] + set got [remote_exec host "$OBJDUMP $OBJDUMPFLAGS -W $compressed_testfile" "" "/dev/null" "tmpdir/objdump.out"] if { [lindex $got 0] != 0 || ![string match "" [lindex $got 1]] } then { fail "objdump -W (reason: unexpected output)" @@ -478,7 +478,7 @@ if { ![is_elf_format] } then { send_log "\n" } - if { [regexp_diff objdump.out $srcdir/$subdir/objdump.W] } then { + if { [regexp_diff tmpdir/objdump.out $srcdir/$subdir/objdump.W] } then { fail "objdump -W" } else { pass "objdump -W" @@ -486,7 +486,7 @@ if { ![is_elf_format] } then { # Test objdump -Z -s on a file that contains some compressed .debug sections - set got [remote_exec host "$OBJDUMP $OBJDUMPFLAGS -Z -s -j .zdebug_abbrev $compressed_testfile" "" "/dev/null" "objdump.out"] + set got [remote_exec host "$OBJDUMP $OBJDUMPFLAGS -Z -s -j .zdebug_abbrev $compressed_testfile" "" "/dev/null" "tmpdir/objdump.out"] if { [lindex $got 0] != 0 || ![string match "" [lindex $got 1]] } then { fail "objdump -Z -s (reason: unexpected output)" @@ -494,7 +494,7 @@ if { ![is_elf_format] } then { send_log "\n" } - if { [regexp_diff objdump.out $srcdir/$subdir/objdump.Zs] } then { + if { [regexp_diff tmpdir/objdump.out $srcdir/$subdir/objdump.Zs] } then { fail "objdump -Z -s" } else { pass "objdump -Z -s" @@ -530,7 +530,7 @@ if { ![is_elf_format] set decodedline_testfile tmpdir/dw2-decodedline.${obj} } - set got [remote_exec host "$OBJDUMP $OBJDUMPFLAGS -WL $decodedline_testfile" "" "/dev/null" "objdump.out"] + set got [remote_exec host "$OBJDUMP $OBJDUMPFLAGS -WL $decodedline_testfile" "" "/dev/null" "tmpdir/objdump.out"] if { [lindex $got 0] != 0 || ![string match "" [lindex $got 1]] } then { fail "objdump -WL (reason: unexpected output)" @@ -538,7 +538,7 @@ if { ![is_elf_format] send_log "\n" } - if { [regexp_diff objdump.out $srcdir/$subdir/objdump.WL] } then { + if { [regexp_diff tmpdir/objdump.out $srcdir/$subdir/objdump.WL] } then { fail "objdump -WL" } else { pass "objdump -WL" @@ -558,7 +558,7 @@ if { ![is_elf_format] } then { set ranges_testfile tmpdir/dw2-ranges.${obj} } - set got [remote_exec host "$OBJDUMP $OBJDUMPFLAGS --dwarf=Ranges $ranges_testfile" "" "/dev/null" "objdump.out"] + set got [remote_exec host "$OBJDUMP $OBJDUMPFLAGS --dwarf=Ranges $ranges_testfile" "" "/dev/null" "tmpdir/objdump.out"] if { [lindex $got 0] != 0 || ![string match "" [lindex $got 1]] } then { fail "objdump -W for debug_ranges (reason: unexpected output)" @@ -567,7 +567,7 @@ if { ![is_elf_format] } then { } setup_xfail "msp430-*-*" - if { [regexp_diff objdump.out $srcdir/$subdir/dw2-ranges.W] } then { + if { [regexp_diff tmpdir/objdump.out $srcdir/$subdir/dw2-ranges.W] } then { fail "objdump -W for debug_ranges" } else { pass "objdump -W for debug_ranges" @@ -587,7 +587,7 @@ if { ![is_elf_format] } then { set op_testfile tmpdir/dw5-op.${obj} } - set got [remote_exec host "$OBJDUMP $OBJDUMPFLAGS -Wi $op_testfile" "" "/dev/null" "objdump.out"] + set got [remote_exec host "$OBJDUMP $OBJDUMPFLAGS -Wi $op_testfile" "" "/dev/null" "tmpdir/objdump.out"] if { [lindex $got 0] != 0 || ![string match "" [lindex $got 1]] } then { fail "objdump -Wi (reason: unexpected output)" @@ -595,8 +595,8 @@ if { ![is_elf_format] } then { send_log "\n" } - set got [remote_exec host "tail -n +4 objdump.out" "" "/dev/null" "objdump.out"] - set output [remote_upload host objdump.out] + set got [remote_exec host "tail -n +4 tmpdir/objdump.out" "" "/dev/null" "tmpdir/objdump.tail"] + set output [remote_upload host tmpdir/objdump.tail] if ![file size $output] then { # If the output file is empty, then this target does not @@ -606,7 +606,7 @@ if { ![is_elf_format] } then { return } - if { [regexp_diff objdump.out $srcdir/$subdir/dw5-op.W] } then { + if { [regexp_diff tmpdir/objdump.tail $srcdir/$subdir/dw5-op.W] } then { fail "objdump -Wi for DW_OP_*" } else { pass "objdump -Wi for DW_OP_*" @@ -712,7 +712,7 @@ if { [is_elf_format] } then { set testfile tmpdir/debuglink.${obj} } - set got [remote_exec host "$OBJDUMP $OBJDUMPFLAGS -Wk -WN $testfile" "" "/dev/null" "objdump.out"] + set got [remote_exec host "$OBJDUMP $OBJDUMPFLAGS -Wk -WN $testfile" "" "/dev/null" "tmpdir/objdump.out"] if { [lindex $got 0] != 0 || ![string match "" [lindex $got 1]] } then { fail "objdump -Wk (reason: unexpected output)" @@ -720,7 +720,7 @@ if { [is_elf_format] } then { send_log "\n" } - if { [regexp_diff objdump.out $srcdir/$subdir/objdump.Wk] } then { + if { [regexp_diff tmpdir/objdump.out $srcdir/$subdir/objdump.Wk] } then { fail "objdump -Wk (reason: output does not match expectations)" } else { pass "objdump -Wk" @@ -764,7 +764,7 @@ proc test_follow_debuglink { options dumpfile } { if { [regexp_diff tmpdir/objdump.out $srcdir/$subdir/$dumpfile] } then { fail $test - verbose "output is \n[file_contents objdump.out]" 2 + verbose "output is \n[file_contents tmpdir/objdump.out]" 2 return } |