mirror of
https://github.com/bminor/binutils-gdb.git
synced 2025-12-05 15:15:42 +00:00
Set BFD_DECOMPRESS to decompress debug sections
We should set BFD_DECOMPRESS to decompress debug sections when reading in DWARF debug sections. bfd/ PR binutils/19523 * dwarf2.c (_bfd_dwarf2_slurp_debug_info): Set BFD_DECOMPRESS to decompress debug sections. binutils/ PR binutils/19523 * Makefile.am (check-DEJAGNU): Pass CC and CC_FOR_BUILD to runtest. * Makefile.in: Regenerated. * testsuite/binutils-all/compress.exp (test_gnu_debuglink): New proc. Run test_gnu_debuglink for native ELF build.
This commit is contained in:
@@ -1,3 +1,9 @@
|
|||||||
|
2016-01-28 H.J. Lu <hongjiu.lu@intel.com>
|
||||||
|
|
||||||
|
PR binutils/19523
|
||||||
|
* dwarf2.c (_bfd_dwarf2_slurp_debug_info): Set BFD_DECOMPRESS to
|
||||||
|
decompress debug sections.
|
||||||
|
|
||||||
2016-01-25 Maciej W. Rozycki <macro@imgtec.com>
|
2016-01-25 Maciej W. Rozycki <macro@imgtec.com>
|
||||||
|
|
||||||
* elf32-arc.c (elf_arc_finish_dynamic_symbol): Rename `index' to
|
* elf32-arc.c (elf_arc_finish_dynamic_symbol): Rename `index' to
|
||||||
|
|||||||
@@ -3706,8 +3706,10 @@ _bfd_dwarf2_slurp_debug_info (bfd *abfd, bfd *debug_bfd,
|
|||||||
fail more quickly. */
|
fail more quickly. */
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
|
/* Set BFD_DECOMPRESS to decompress debug sections. */
|
||||||
if ((debug_bfd = bfd_openr (debug_filename, NULL)) == NULL
|
if ((debug_bfd = bfd_openr (debug_filename, NULL)) == NULL
|
||||||
|| ! bfd_check_format (debug_bfd, bfd_object)
|
|| !(debug_bfd->flags |= BFD_DECOMPRESS,
|
||||||
|
bfd_check_format (debug_bfd, bfd_object))
|
||||||
|| (msec = find_debug_info (debug_bfd,
|
|| (msec = find_debug_info (debug_bfd,
|
||||||
debug_sections, NULL)) == NULL
|
debug_sections, NULL)) == NULL
|
||||||
|| !bfd_generic_link_read_symbols (debug_bfd))
|
|| !bfd_generic_link_read_symbols (debug_bfd))
|
||||||
|
|||||||
@@ -1,3 +1,13 @@
|
|||||||
|
2016-01-28 H.J. Lu <hongjiu.lu@intel.com>
|
||||||
|
|
||||||
|
PR binutils/19523
|
||||||
|
* Makefile.am (check-DEJAGNU): Pass CC and CC_FOR_BUILD to
|
||||||
|
runtest.
|
||||||
|
* Makefile.in: Regenerated.
|
||||||
|
* testsuite/binutils-all/compress.exp (test_gnu_debuglink): New
|
||||||
|
proc.
|
||||||
|
Run test_gnu_debuglink for native ELF build.
|
||||||
|
|
||||||
2016-01-20 Nick Clifton <nickc@redhat.com>
|
2016-01-20 Nick Clifton <nickc@redhat.com>
|
||||||
|
|
||||||
PR 19495
|
PR 19495
|
||||||
|
|||||||
@@ -192,6 +192,7 @@ check-DEJAGNU: site.exp
|
|||||||
EXPECT=$(EXPECT); export EXPECT; \
|
EXPECT=$(EXPECT); export EXPECT; \
|
||||||
runtest=$(RUNTEST); \
|
runtest=$(RUNTEST); \
|
||||||
if $(SHELL) -c "$$runtest --version" > /dev/null 2>&1; then \
|
if $(SHELL) -c "$$runtest --version" > /dev/null 2>&1; then \
|
||||||
|
CC="$(CC)" CC_FOR_BUILD="$(CC_FOR_BUILD)" \
|
||||||
CC_FOR_TARGET="$(CC_FOR_TARGET)" CFLAGS_FOR_TARGET="$(CFLAGS)" \
|
CC_FOR_TARGET="$(CC_FOR_TARGET)" CFLAGS_FOR_TARGET="$(CFLAGS)" \
|
||||||
$$runtest --tool $(DEJATOOL) --srcdir $${srcdir}/testsuite \
|
$$runtest --tool $(DEJATOOL) --srcdir $${srcdir}/testsuite \
|
||||||
$(RUNTESTFLAGS); \
|
$(RUNTESTFLAGS); \
|
||||||
|
|||||||
@@ -1290,6 +1290,7 @@ check-DEJAGNU: site.exp
|
|||||||
EXPECT=$(EXPECT); export EXPECT; \
|
EXPECT=$(EXPECT); export EXPECT; \
|
||||||
runtest=$(RUNTEST); \
|
runtest=$(RUNTEST); \
|
||||||
if $(SHELL) -c "$$runtest --version" > /dev/null 2>&1; then \
|
if $(SHELL) -c "$$runtest --version" > /dev/null 2>&1; then \
|
||||||
|
CC="$(CC)" CC_FOR_BUILD="$(CC_FOR_BUILD)" \
|
||||||
CC_FOR_TARGET="$(CC_FOR_TARGET)" CFLAGS_FOR_TARGET="$(CFLAGS)" \
|
CC_FOR_TARGET="$(CC_FOR_TARGET)" CFLAGS_FOR_TARGET="$(CFLAGS)" \
|
||||||
$$runtest --tool $(DEJATOOL) --srcdir $${srcdir}/testsuite \
|
$$runtest --tool $(DEJATOOL) --srcdir $${srcdir}/testsuite \
|
||||||
$(RUNTESTFLAGS); \
|
$(RUNTESTFLAGS); \
|
||||||
|
|||||||
@@ -667,4 +667,97 @@ if { ([istarget "x86_64-*-elf*"]
|
|||||||
|
|
||||||
set testname "Convert x32 object to x86-64 (3)"
|
set testname "Convert x32 object to x86-64 (3)"
|
||||||
convert_test "$testname" "--nocompress-debug-sections --x32" "-O elf64-x86-64 --compress-debug-sections=zlib-gnu"
|
convert_test "$testname" "--nocompress-debug-sections --x32" "-O elf64-x86-64 --compress-debug-sections=zlib-gnu"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
proc test_gnu_debuglink {} {
|
||||||
|
global srcdir
|
||||||
|
global subdir
|
||||||
|
global env
|
||||||
|
global CC_FOR_TARGET
|
||||||
|
global STRIP
|
||||||
|
global OBJCOPY
|
||||||
|
global OBJDUMP
|
||||||
|
|
||||||
|
set test "gnu-debuglink"
|
||||||
|
if {![info exists CC_FOR_TARGET]} {
|
||||||
|
set CC_FOR_TARGET $env(CC)
|
||||||
|
}
|
||||||
|
if { $CC_FOR_TARGET == "" } {
|
||||||
|
unsupported $test
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if { [target_compile $srcdir/$subdir/testprog.c tmpdir/testprog exectuable debug] != "" } {
|
||||||
|
fail "$test (build)"
|
||||||
|
return
|
||||||
|
}
|
||||||
|
set got [remote_exec host "$OBJDUMP -S tmpdir/testprog" "" "/dev/null" "tmpdir/testprog.dump"]
|
||||||
|
if { [lindex $got 0] != 0 || ![string match "" [lindex $got 1]] } then {
|
||||||
|
fail "$test (objcopy dump)"
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if { [binutils_run $STRIP "--strip-debug --remove-section=.comment --remove-section=.note tmpdir/testprog -o tmpdir/testprog.strip"] != "" } {
|
||||||
|
fail "$test (strip)"
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if { [binutils_run $OBJCOPY "--only-keep-debug --decompress-debug-sections tmpdir/testprog tmpdir/testprog.decompress"] != "" } {
|
||||||
|
fail "$test (objcopy decompress)"
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if { [binutils_run $OBJCOPY "--only-keep-debug --compress-debug-sections tmpdir/testprog tmpdir/testprog.compress"] != "" } {
|
||||||
|
fail "$test (objcopy compress)"
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if { [binutils_run $OBJCOPY "--add-gnu-debuglink=tmpdir/testprog.decompress tmpdir/testprog.strip tmpdir/testprog"] != "" } {
|
||||||
|
fail "$test (objcopy link decompress)"
|
||||||
|
return
|
||||||
|
}
|
||||||
|
set got [remote_exec host "$OBJDUMP -S tmpdir/testprog" "" "/dev/null" "tmpdir/testprog.decompress.dump"]
|
||||||
|
if { [lindex $got 0] != 0 || ![string match "" [lindex $got 1]] } then {
|
||||||
|
fail "$test (objcopy dump decompress)"
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if { [binutils_run $OBJCOPY "--add-gnu-debuglink=tmpdir/testprog.compress tmpdir/testprog.strip tmpdir/testprog"] != "" } {
|
||||||
|
fail "$test (objcopy link compress)"
|
||||||
|
return
|
||||||
|
}
|
||||||
|
set got [remote_exec host "$OBJDUMP -S tmpdir/testprog" "" "/dev/null" "tmpdir/testprog.compress.dump"]
|
||||||
|
if { [lindex $got 0] != 0 || ![string match "" [lindex $got 1]] } then {
|
||||||
|
fail "$test (objcopy dump compress)"
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
set src1 tmpdir/testprog.dump
|
||||||
|
set src2 tmpdir/testprog.compress.dump
|
||||||
|
send_log "cmp ${src1} ${src2}\n"
|
||||||
|
verbose "cmp ${src1} ${src2}"
|
||||||
|
set status [remote_exec build cmp "${src1} ${src2}"]
|
||||||
|
set exec_output [lindex $status 1]
|
||||||
|
set exec_output [prune_warnings $exec_output]
|
||||||
|
if ![string match "" $exec_output] then {
|
||||||
|
send_log "$exec_output\n"
|
||||||
|
verbose "$exec_output" 1
|
||||||
|
fail "$test (objdump 1)"
|
||||||
|
} else {
|
||||||
|
pass "$test (objdump 1)"
|
||||||
|
}
|
||||||
|
|
||||||
|
set src1 tmpdir/testprog.decompress.dump
|
||||||
|
set src2 tmpdir/testprog.compress.dump
|
||||||
|
send_log "cmp ${src1} ${src2}\n"
|
||||||
|
verbose "cmp ${src1} ${src2}"
|
||||||
|
set status [remote_exec build cmp "${src1} ${src2}"]
|
||||||
|
set exec_output [lindex $status 1]
|
||||||
|
set exec_output [prune_warnings $exec_output]
|
||||||
|
if ![string match "" $exec_output] then {
|
||||||
|
send_log "$exec_output\n"
|
||||||
|
verbose "$exec_output" 1
|
||||||
|
fail "$test (objdump 2)"
|
||||||
|
} else {
|
||||||
|
pass "$test (objdump 2)"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if {[isnative] && [is_elf_format]} then {
|
||||||
|
test_gnu_debuglink
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user