From: Hans-Peter Nilsson Date: Mon, 21 Jan 2002 21:57:48 +0000 (+0000) Subject: * elf32-cris.c (cris_elf_relocate_section) : X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=58255df39cc133d5e5f2eab79e22113c7fd0289f;p=binutils-gdb.git * elf32-cris.c (cris_elf_relocate_section) : Check for and emit error if sgot is NULL at this point. --- diff --git a/bfd/ChangeLog b/bfd/ChangeLog index bf19404d634..f6a30259c71 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,8 @@ +2002-01-21 Hans-Peter Nilsson + + * elf32-cris.c (cris_elf_relocate_section) : + Check for and emit error if sgot is NULL at this point. + 2002-01-21 Jason Thorpe * config.bfd (ia64*-*-netbsd*): New target. diff --git a/bfd/elf32-cris.c b/bfd/elf32-cris.c index 2e3add10af6..6feb292c191 100644 --- a/bfd/elf32-cris.c +++ b/bfd/elf32-cris.c @@ -1162,6 +1162,20 @@ cris_elf_relocate_section (output_bfd, info, input_bfd, input_section, return false; } + /* This can happen if we get a link error with the input ELF + variant mismatching the output variant. Emit an error so + it's noticed if it happens elsewhere. */ + if (sgot == NULL) + { + (*_bfd_error_handler) + (_("%s: relocation %s in section %s with no GOT created"), + bfd_archive_filename (input_bfd), + cris_elf_howto_table[r_type].name, + bfd_get_section_name (input_bfd, input_section)); + bfd_set_error (bfd_error_bad_value); + return false; + } + /* This relocation is like a PC-relative one, except the reference point is the location of GOT. Note that sgot->output_offset is not involved in this calculation. We