projects
/
binutils-gdb.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
* elf-bfd.h (RELOC_AGAINST_DISCARDED_SECTION): Handle compound
[binutils-gdb.git]
/
bfd
/
coff-tic80.c
diff --git
a/bfd/coff-tic80.c
b/bfd/coff-tic80.c
index 4185e7b18d81f615a242c639d64e278d38d98617..6455e492334c9c5aea02328861b13db89959ac77 100644
(file)
--- a/
bfd/coff-tic80.c
+++ b/
bfd/coff-tic80.c
@@
-1,32
+1,41
@@
/* BFD back-end for Texas Instruments TMS320C80 Multimedia Video Processor (MVP).
/* BFD back-end for Texas Instruments TMS320C80 Multimedia Video Processor (MVP).
- Copyright 1996, 1997, 1999, 2000, 2001, 2002 Free Software Foundation, Inc.
+ Copyright 1996, 1997, 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2007, 2008
+ Free Software Foundation, Inc.
Written by Fred Fish (fnf@cygnus.com)
There is nothing new under the sun. This file draws a lot on other
coff files.
Written by Fred Fish (fnf@cygnus.com)
There is nothing new under the sun. This file draws a lot on other
coff files.
-This file is part of BFD, the Binary File Descriptor library.
+
This file is part of BFD, the Binary File Descriptor library.
-This program is free software; you can redistribute it and/or modify
-it under the terms of the GNU General Public License as published by
-
the Free Software Foundation; either version 2
of the License, or
-(at your option) any later version.
+
This program is free software; you can redistribute it and/or modify
+
it under the terms of the GNU General Public License as published by
+
the Free Software Foundation; either version 3
of the License, or
+
(at your option) any later version.
-This program is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-GNU General Public License for more details.
+
This program is distributed in the hope that it will be useful,
+
but WITHOUT ANY WARRANTY; without even the implied warranty of
+
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+
GNU General Public License for more details.
-You should have received a copy of the GNU General Public License
-along with this program; if not, write to the Free Software
-
Foundation, 59 Temple Place - Suite 330
,
-
Boston, MA 02111-1307
, USA. */
+
You should have received a copy of the GNU General Public License
+
along with this program; if not, write to the Free Software
+
Foundation, 51 Franklin Street - Fifth Floor
,
+
Boston, MA 02110-1301
, USA. */
+#include "sysdep.h"
#include "bfd.h"
#include "bfdlink.h"
#include "bfd.h"
#include "bfdlink.h"
-#include "sysdep.h"
#include "libbfd.h"
#include "libbfd.h"
+#ifdef _CONST
+/* Newlib-based hosts define _CONST as a STDC-safe alias for const,
+ but to the tic80 toolchain it means something altogether different.
+ Since sysdep.h will have pulled in stdio.h and hence _ansi.h which
+ contains this definition, we must undef it before including the
+ tic80-specific definition. */
+#undef _CONST
+#endif /* _CONST */
#include "coff/tic80.h"
#include "coff/internal.h"
#include "libcoff.h"
#include "coff/tic80.h"
#include "coff/internal.h"
#include "libcoff.h"
@@
-576,7
+585,7
@@
coff_tic80_relocate_section (output_bfd, info, input_bfd,
+ sec->output_offset);
}
+ sec->output_offset);
}
- else if (! info->relocat
e
able)
+ else if (! info->relocatable)
{
if (! ((*info->callbacks->undefined_symbol)
(info, h->root.root.string, input_bfd, input_section,
{
if (! ((*info->callbacks->undefined_symbol)
(info, h->root.root.string, input_bfd, input_section,
@@
-683,10
+692,8
@@
coff_tic80_relocate_section (output_bfd, info, input_bfd,
break;
case bfd_reloc_outofrange:
(*_bfd_error_handler)
break;
case bfd_reloc_outofrange:
(*_bfd_error_handler)
- (_("%s: bad reloc address 0x%lx in section `%s'"),
- bfd_archive_filename (input_bfd),
- (unsigned long) rel->r_vaddr,
- bfd_get_section_name (input_bfd, input_section));
+ (_("%B: bad reloc address 0x%lx in section `%A'"),
+ input_bfd, input_section, (unsigned long) rel->r_vaddr);
return FALSE;
case bfd_reloc_overflow:
{
return FALSE;
case bfd_reloc_overflow:
{
@@
-696,7
+703,7
@@
coff_tic80_relocate_section (output_bfd, info, input_bfd,
if (symndx == -1)
name = "*ABS*";
else if (h != NULL)
if (symndx == -1)
name = "*ABS*";
else if (h != NULL)
- name =
h->root.root.string
;
+ name =
NULL
;
else
{
name = _bfd_coff_internal_syment_name (input_bfd, sym, buf);
else
{
name = _bfd_coff_internal_syment_name (input_bfd, sym, buf);
@@
-705,8
+712,9
@@
coff_tic80_relocate_section (output_bfd, info, input_bfd,
}
if (! ((*info->callbacks->reloc_overflow)
}
if (! ((*info->callbacks->reloc_overflow)
- (info, name, howto->name, (bfd_vma) 0, input_bfd,
- input_section, rel->r_vaddr - input_section->vma)))
+ (info, (h ? &h->root : NULL), name, howto->name,
+ (bfd_vma) 0, input_bfd, input_section,
+ rel->r_vaddr - input_section->vma)))
return FALSE;
}
}
return FALSE;
}
}
@@
-714,9
+722,23
@@
coff_tic80_relocate_section (output_bfd, info, input_bfd,
return TRUE;
}
\f
return TRUE;
}
\f
+/* Clear the r_reserved field in relocs. */
+#define SWAP_OUT_RELOC_EXTRA(abfd,src,dst) \
+ do \
+ { \
+ dst->r_reserved[0] = 0; \
+ dst->r_reserved[1] = 0; \
+ } \
+ while (0)
+
#define TIC80COFF 1 /* Customize coffcode.h */
#undef C_AUTOARG /* Clashes with TIc80's C_UEXT */
#undef C_LASTENT /* Clashes with TIc80's C_STATLAB */
#define TIC80COFF 1 /* Customize coffcode.h */
#undef C_AUTOARG /* Clashes with TIc80's C_UEXT */
#undef C_LASTENT /* Clashes with TIc80's C_STATLAB */
+
+#ifndef bfd_pe_print_pdata
+#define bfd_pe_print_pdata NULL
+#endif
+
#include "coffcode.h"
#include "coffcode.h"
-CREATE_LITTLE_COFF_TARGET_VEC (tic80coff_vec, "coff-tic80", D_PAGED, 0, '_', NULL)
+CREATE_LITTLE_COFF_TARGET_VEC (tic80coff_vec, "coff-tic80", D_PAGED, 0, '_', NULL
, COFF_SWAP_TABLE
)