projects
/
deliverable
/
binutils-gdb.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Automatic date update in version.in
[deliverable/binutils-gdb.git]
/
bfd
/
elf32-xstormy16.c
diff --git
a/bfd/elf32-xstormy16.c
b/bfd/elf32-xstormy16.c
index 57445ba6f89de2aa1bb43d7fe6359bf3fc9a8381..cab0f23794dce6938251fb1c2ada053927437325 100644
(file)
--- a/
bfd/elf32-xstormy16.c
+++ b/
bfd/elf32-xstormy16.c
@@
-1,6
+1,5
@@
/* Xstormy16-specific support for 32-bit ELF.
/* Xstormy16-specific support for 32-bit ELF.
- Copyright 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2010, 2011, 2012
- Free Software Foundation, Inc.
+ Copyright (C) 2000-2016 Free Software Foundation, Inc.
This file is part of BFD, the Binary File Descriptor library.
This file is part of BFD, the Binary File Descriptor library.
@@
-74,11
+73,11
@@
static reloc_howto_type xstormy16_elf_howto_table [] =
/* This reloc does nothing. */
HOWTO (R_XSTORMY16_NONE, /* type */
0, /* rightshift */
/* This reloc does nothing. */
HOWTO (R_XSTORMY16_NONE, /* type */
0, /* rightshift */
-
2
, /* size (0 = byte, 1 = short, 2 = long) */
-
32,
/* bitsize */
+
3
, /* size (0 = byte, 1 = short, 2 = long) */
+
0,
/* bitsize */
FALSE, /* pc_relative */
0, /* bitpos */
FALSE, /* pc_relative */
0, /* bitpos */
- complain_overflow_
bitfield
, /* complain_on_overflow */
+ complain_overflow_
dont
, /* complain_on_overflow */
bfd_elf_generic_reloc, /* special_function */
"R_XSTORMY16_NONE", /* name */
FALSE, /* partial_inplace */
bfd_elf_generic_reloc, /* special_function */
"R_XSTORMY16_NONE", /* name */
FALSE, /* partial_inplace */
@@
-335,7
+334,7
@@
xstormy16_reloc_type_lookup (bfd * abfd ATTRIBUTE_UNUSED,
{
unsigned int i;
{
unsigned int i;
- for (i = ARRAY_SIZE (xstormy16_reloc_map);
--i
;)
+ for (i = ARRAY_SIZE (xstormy16_reloc_map);
i--
;)
{
const reloc_map * entry;
{
const reloc_map * entry;
@@
-412,7
+411,7
@@
xstormy16_elf_check_relocs (bfd *abfd,
asection *splt;
bfd *dynobj;
asection *splt;
bfd *dynobj;
- if (
info->relocatable
)
+ if (
bfd_link_relocatable (info)
)
return TRUE;
symtab_hdr = &elf_tdata(abfd)->symtab_hdr;
return TRUE;
symtab_hdr = &elf_tdata(abfd)->symtab_hdr;
@@
-437,6
+436,10
@@
xstormy16_elf_check_relocs (bfd *abfd,
while (h->root.type == bfd_link_hash_indirect
|| h->root.type == bfd_link_hash_warning)
h = (struct elf_link_hash_entry *) h->root.u.i.link;
while (h->root.type == bfd_link_hash_indirect
|| h->root.type == bfd_link_hash_warning)
h = (struct elf_link_hash_entry *) h->root.u.i.link;
+
+ /* PR15323, ref flags aren't set for references in the same
+ object. */
+ h->root.non_ir_ref = 1;
}
switch (ELF32_R_TYPE (rel->r_info))
}
switch (ELF32_R_TYPE (rel->r_info))
@@
-456,18
+459,15
@@
xstormy16_elf_check_relocs (bfd *abfd,
elf_hash_table (info)->dynobj = dynobj = abfd;
if (splt == NULL)
{
elf_hash_table (info)->dynobj = dynobj = abfd;
if (splt == NULL)
{
- splt = bfd_get_
section_by_name
(dynobj, ".plt");
+ splt = bfd_get_
linker_section
(dynobj, ".plt");
if (splt == NULL)
{
if (splt == NULL)
{
- splt = bfd_make_section_with_flags (dynobj, ".plt",
- (SEC_ALLOC
- | SEC_LOAD
- | SEC_HAS_CONTENTS
- | SEC_IN_MEMORY
- | SEC_LINKER_CREATED
- | SEC_READONLY
- | SEC_CODE));
+ flagword flags = (SEC_ALLOC | SEC_LOAD | SEC_HAS_CONTENTS
+ | SEC_IN_MEMORY | SEC_LINKER_CREATED
+ | SEC_READONLY | SEC_CODE);
+ splt = bfd_make_section_anyway_with_flags (dynobj, ".plt",
+ flags);
if (splt == NULL
|| ! bfd_set_section_alignment (dynobj, splt, 1))
return FALSE;
if (splt == NULL
|| ! bfd_set_section_alignment (dynobj, splt, 1))
return FALSE;
@@
-589,7
+589,7
@@
xstormy16_elf_relax_section (bfd *dynobj,
/* Assume nothing changes. */
*again = FALSE;
/* Assume nothing changes. */
*again = FALSE;
- if (
info->relocatable
)
+ if (
bfd_link_relocatable (info)
)
return TRUE;
/* We only relax the .plt section at the moment. */
return TRUE;
/* We only relax the .plt section at the moment. */
@@
-610,7
+610,7
@@
xstormy16_elf_relax_section (bfd *dynobj,
/* Likewise for local symbols, though that's somewhat less convenient
as we have to walk the list of input bfds and swap in symbol data. */
/* Likewise for local symbols, though that's somewhat less convenient
as we have to walk the list of input bfds and swap in symbol data. */
- for (ibfd = info->input_bfds; ibfd ; ibfd = ibfd->link
_
next)
+ for (ibfd = info->input_bfds; ibfd ; ibfd = ibfd->link
.
next)
{
bfd_vma *local_plt_offsets = elf_local_got_offsets (ibfd);
Elf_Internal_Shdr *symtab_hdr;
{
bfd_vma *local_plt_offsets = elf_local_got_offsets (ibfd);
Elf_Internal_Shdr *symtab_hdr;
@@
-684,7
+684,7
@@
xstormy16_elf_relax_section (bfd *dynobj,
elf_link_hash_traverse (elf_hash_table (info),
xstormy16_relax_plt_realloc, &entry);
elf_link_hash_traverse (elf_hash_table (info),
xstormy16_relax_plt_realloc, &entry);
- for (ibfd = info->input_bfds; ibfd ; ibfd = ibfd->link
_
next)
+ for (ibfd = info->input_bfds; ibfd ; ibfd = ibfd->link
.
next)
{
bfd_vma *local_plt_offsets = elf_local_got_offsets (ibfd);
unsigned int nlocals = elf_tdata (ibfd)->symtab_hdr.sh_info;
{
bfd_vma *local_plt_offsets = elf_local_got_offsets (ibfd);
unsigned int nlocals = elf_tdata (ibfd)->symtab_hdr.sh_info;
@@
-712,14
+712,14
@@
xstormy16_elf_always_size_sections (bfd *output_bfd ATTRIBUTE_UNUSED,
bfd *dynobj;
asection *splt;
bfd *dynobj;
asection *splt;
- if (
info->relocatable
)
+ if (
bfd_link_relocatable (info)
)
return TRUE;
dynobj = elf_hash_table (info)->dynobj;
if (dynobj == NULL)
return TRUE;
return TRUE;
dynobj = elf_hash_table (info)->dynobj;
if (dynobj == NULL)
return TRUE;
- splt = bfd_get_
section_by_name
(dynobj, ".plt");
+ splt = bfd_get_
linker_section
(dynobj, ".plt");
BFD_ASSERT (splt != NULL);
splt->contents = bfd_zalloc (dynobj, splt->size);
BFD_ASSERT (splt != NULL);
splt->contents = bfd_zalloc (dynobj, splt->size);
@@
-783,7
+783,7
@@
xstormy16_elf_relocate_section (bfd * output_bfd ATTRIBUTE_UNU
dynobj = elf_hash_table (info)->dynobj;
splt = NULL;
if (dynobj != NULL)
dynobj = elf_hash_table (info)->dynobj;
splt = NULL;
if (dynobj != NULL)
- splt = bfd_get_
section_by_name
(dynobj, ".plt");
+ splt = bfd_get_
linker_section
(dynobj, ".plt");
for (rel = relocs; rel < relend; rel ++)
{
for (rel = relocs; rel < relend; rel ++)
{
@@
-817,19
+817,19
@@
xstormy16_elf_relocate_section (bfd * output_bfd ATTRIBUTE_UNU
}
else
{
}
else
{
- bfd_boolean unresolved_reloc, warned;
+ bfd_boolean unresolved_reloc, warned
, ignored
;
RELOC_FOR_GLOBAL_SYMBOL (info, input_bfd, input_section, rel,
r_symndx, symtab_hdr, sym_hashes,
h, sec, relocation,
RELOC_FOR_GLOBAL_SYMBOL (info, input_bfd, input_section, rel,
r_symndx, symtab_hdr, sym_hashes,
h, sec, relocation,
- unresolved_reloc, warned);
+ unresolved_reloc, warned
, ignored
);
}
if (sec != NULL && discarded_section (sec))
RELOC_AGAINST_DISCARDED_SECTION (info, input_bfd, input_section,
}
if (sec != NULL && discarded_section (sec))
RELOC_AGAINST_DISCARDED_SECTION (info, input_bfd, input_section,
- rel,
relend, howto
, contents);
+ rel,
1, relend, howto, 0
, contents);
- if (
info->relocatable
)
+ if (
bfd_link_relocatable (info)
)
continue;
if (h != NULL)
continue;
if (h != NULL)
@@
-920,15
+920,14
@@
xstormy16_elf_relocate_section (bfd * output_bfd ATTRIBUTE_UNU
switch (r)
{
case bfd_reloc_overflow:
switch (r)
{
case bfd_reloc_overflow:
- r = info->callbacks->reloc_overflow
+ (*info->callbacks->reloc_overflow)
(info, (h ? &h->root : NULL), name, howto->name,
(bfd_vma) 0, input_bfd, input_section, rel->r_offset);
break;
case bfd_reloc_undefined:
(info, (h ? &h->root : NULL), name, howto->name,
(bfd_vma) 0, input_bfd, input_section, rel->r_offset);
break;
case bfd_reloc_undefined:
- r = info->callbacks->undefined_symbol
- (info, name, input_bfd, input_section, rel->r_offset,
- TRUE);
+ (*info->callbacks->undefined_symbol)
+ (info, name, input_bfd, input_section, rel->r_offset, TRUE);
break;
case bfd_reloc_outofrange:
break;
case bfd_reloc_outofrange:
@@
-949,11
+948,8
@@
xstormy16_elf_relocate_section (bfd * output_bfd ATTRIBUTE_UNU
}
if (msg)
}
if (msg)
- r = info->callbacks->warning
- (info, msg, name, input_bfd, input_section, rel->r_offset);
-
- if (! r)
- return FALSE;
+ (*info->callbacks->warning) (info, msg, name, input_bfd,
+ input_section, rel->r_offset);
}
}
}
}
@@
-973,7
+969,7
@@
xstormy16_elf_finish_dynamic_sections (bfd *abfd ATTRIBUTE_UNUSED,
been filled in. */
if ((dynobj = elf_hash_table (info)->dynobj) != NULL
been filled in. */
if ((dynobj = elf_hash_table (info)->dynobj) != NULL
- && (splt = bfd_get_
section_by_name
(dynobj, ".plt")) != NULL)
+ && (splt = bfd_get_
linker_section
(dynobj, ".plt")) != NULL)
{
bfd_byte *contents = splt->contents;
unsigned int i, size = splt->size;
{
bfd_byte *contents = splt->contents;
unsigned int i, size = splt->size;
@@
-1014,7
+1010,7
@@
xstormy16_elf_gc_mark_hook (asection *sec,
#define ELF_MACHINE_CODE EM_XSTORMY16
#define ELF_MAXPAGESIZE 0x100
#define ELF_MACHINE_CODE EM_XSTORMY16
#define ELF_MAXPAGESIZE 0x100
-#define TARGET_LITTLE_SYM
bfd_elf32_xstormy16
_vec
+#define TARGET_LITTLE_SYM
xstormy16_elf32
_vec
#define TARGET_LITTLE_NAME "elf32-xstormy16"
#define elf_info_to_howto_rel NULL
#define TARGET_LITTLE_NAME "elf32-xstormy16"
#define elf_info_to_howto_rel NULL
This page took
0.028033 seconds
and
4
git commands to generate.