This is the mail archive of the
binutils@sourceware.cygnus.com
mailing list for the binutils project.
ld dumps core (from 2.9.4.0.8 on) - patch
- To: binutils at sourceware dot cygnus dot com
- Subject: ld dumps core (from 2.9.4.0.8 on) - patch
- From: jreising at frequentis dot com (Johannes Reisinger)
- Date: Mon, 6 Mar 2000 17:00:05 +0100
Bug report:
In binutils-2.9.4.0.8 (sorry, I don't know the original version number - only
the one from ftp.varesearch.com) a bug was introduced which causes ld to dump
core in my appliation.
The reason was a newly introduced piece of code in ld/ldfile.c:
..
141 if (bfd_check_format (entry->the_bfd, bfd_archive))
142 check = bfd_openr_next_archived_file (entry->the_bfd, NULL);
143 else
144 check = entry->the_bfd;
145
146 if (! bfd_check_format (check, bfd_object))
147 return true;
..
bfd_check_format assumes that its first element is non-NULL, but
bfd_openr_next_archived_file returns NULL in some cases.
I believe that it is best to fix the bug in bfd_check_format by
checking its first argument against NULL.
Please can anyone check my patch and, if it is correct, apply it to
the sources?
The patch seems to apply well to the newest sources too.
-jr
---------------------- cut here ---------------------------
# This is a patch for binutils-2.9.4.0.8 to update it to binutils-2.9.4.0.8.patched.
# It was generated by makepatch 1.93 (2.0BETA) on Mon Mar 6 12:42:32 2000.
#
# To apply this patch, chdir to source directory binutils-2.9.4.0.8 and enter
#
# patch -p1 -N < <this-file>
exit
# End of preamble.
# Patch input follows.
__DATA__
Index: bfd/format.c
####### binutils-2.9.4.0.8.patched/ => binutils-2.9.4.0.8.patched
*** binutils-2.9.4.0.8.patched/bfd/format.c Mon Mar 6 11:28:29 2000
--- binutils-2.9.4.0.8.patched/bfd/format.c Mon Mar 6 12:32:19 2000
***************
*** 123,129 ****
char **matching_vector = NULL;
int match_count;
! if (!bfd_read_p (abfd) ||
((int)(abfd->format) < (int)bfd_unknown) ||
((int)(abfd->format) >= (int)bfd_type_end)) {
bfd_set_error (bfd_error_invalid_operation);
--- 123,130 ----
char **matching_vector = NULL;
int match_count;
! if (abfd == NULL ||
! !bfd_read_p (abfd) ||
((int)(abfd->format) < (int)bfd_unknown) ||
((int)(abfd->format) >= (int)bfd_type_end)) {
bfd_set_error (bfd_error_invalid_operation);
End of Patch.
---------------------- cut here ---------------------------
--
Dr. Johannes Reisinger
System Design
FREQUENTIS
A-1120 Wien, Spittelbreitengasse 34
http://www.frequentis.com
Tel: +43/1/81150-2329, Fax -2299
mailto:jreising@frequentis.com