bfd/mmo.c: handle "objcopy --extract-symbols" generating and reading back.
bfd: * mmo.c (struct mmo_data_struct): New members symbol_consistency_override_calculated and ignore_symbol_consistency. (mmo_section_has_contents, mmo_ignore_symbol_consistency): New functions. (mmo_create_symbol): Check with mmo_ignore_symbol_consistency if to report an error for unexpected value of Main. (mmo_write_symbols_and_terminator): Similar.
This commit is contained in:
parent
282b7d7b65
commit
c287bfe429
@ -1,3 +1,13 @@
|
|||||||
|
2015-10-22 Hans-Peter Nilsson <hp@bitrange.com>
|
||||||
|
|
||||||
|
* mmo.c (struct mmo_data_struct): New members
|
||||||
|
symbol_consistency_override_calculated and ignore_symbol_consistency.
|
||||||
|
(mmo_section_has_contents, mmo_ignore_symbol_consistency): New
|
||||||
|
functions.
|
||||||
|
(mmo_create_symbol): Check with mmo_ignore_symbol_consistency if to
|
||||||
|
report an error for unexpected value of Main.
|
||||||
|
(mmo_write_symbols_and_terminator): Similar.
|
||||||
|
|
||||||
2015-10-22 H.J. Lu <hongjiu.lu@intel.com>
|
2015-10-22 H.J. Lu <hongjiu.lu@intel.com>
|
||||||
|
|
||||||
* elf32-i386.c (elf_i386_convert_load): Use call_nop_byte and
|
* elf32-i386.c (elf_i386_convert_load): Use call_nop_byte and
|
||||||
|
44
bfd/mmo.c
44
bfd/mmo.c
@ -330,6 +330,14 @@ struct mmo_data_struct
|
|||||||
|
|
||||||
/* We also need a buffer to hold the bytes we count reading or writing. */
|
/* We also need a buffer to hold the bytes we count reading or writing. */
|
||||||
bfd_byte buf[4];
|
bfd_byte buf[4];
|
||||||
|
|
||||||
|
/* Whether we've calculated symbol consistency requirement yet. We do this
|
||||||
|
when-needed, which must be at some time after all section
|
||||||
|
contents is known. */
|
||||||
|
bfd_boolean symbol_consistency_override_calculated;
|
||||||
|
|
||||||
|
/* Whether to consistency-check symbol values, in particular "Main". */
|
||||||
|
bfd_boolean ignore_symbol_consistency;
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct mmo_data_struct tdata_type;
|
typedef struct mmo_data_struct tdata_type;
|
||||||
@ -585,6 +593,34 @@ mmo_mkobject (bfd *abfd)
|
|||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bfd_boolean
|
||||||
|
mmo_section_has_contents (bfd *abfd ATTRIBUTE_UNUSED, asection *sec, void *p ATTRIBUTE_UNUSED)
|
||||||
|
{
|
||||||
|
/* The point is to match what --extract-symbols does (well, negated). */
|
||||||
|
return bfd_get_section_size (sec) != 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Find out whether we should omit symbol consistency checks for this
|
||||||
|
bfd and cache the value.
|
||||||
|
|
||||||
|
This function must only be called when all section contents is
|
||||||
|
known. However, calculating symbol consistency at the time the
|
||||||
|
private BFD data is initialized is too late for some uses. */
|
||||||
|
|
||||||
|
static bfd_boolean
|
||||||
|
mmo_ignore_symbol_consistency (bfd *abfd)
|
||||||
|
{
|
||||||
|
if (!abfd->tdata.mmo_data->symbol_consistency_override_calculated)
|
||||||
|
{
|
||||||
|
abfd->tdata.mmo_data->ignore_symbol_consistency =
|
||||||
|
bfd_sections_find_if (abfd, mmo_section_has_contents, NULL) == NULL;
|
||||||
|
|
||||||
|
abfd->tdata.mmo_data->symbol_consistency_override_calculated = TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
return abfd->tdata.mmo_data->ignore_symbol_consistency;
|
||||||
|
}
|
||||||
|
|
||||||
static bfd_boolean
|
static bfd_boolean
|
||||||
mmo_bfd_copy_private_bfd_data (bfd *ibfd, bfd *obfd)
|
mmo_bfd_copy_private_bfd_data (bfd *ibfd, bfd *obfd)
|
||||||
{
|
{
|
||||||
@ -1208,7 +1244,8 @@ mmo_create_symbol (bfd *abfd, const char *symname, bfd_vma addr, enum
|
|||||||
object. For written objects, we do it while setting the symbol
|
object. For written objects, we do it while setting the symbol
|
||||||
table. */
|
table. */
|
||||||
if (strcmp (symname, MMIX_START_SYMBOL_NAME) == 0
|
if (strcmp (symname, MMIX_START_SYMBOL_NAME) == 0
|
||||||
&& bfd_get_start_address (abfd) != addr)
|
&& bfd_get_start_address (abfd) != addr
|
||||||
|
&& !mmo_ignore_symbol_consistency (abfd))
|
||||||
{
|
{
|
||||||
(*_bfd_error_handler)
|
(*_bfd_error_handler)
|
||||||
(_("%s: invalid mmo file: initialization value for $255 is not `Main'\n"),
|
(_("%s: invalid mmo file: initialization value for $255 is not `Main'\n"),
|
||||||
@ -2900,13 +2937,14 @@ mmo_write_symbols_and_terminator (bfd *abfd)
|
|||||||
= (mainsym->value
|
= (mainsym->value
|
||||||
+ mainsym->section->output_section->vma
|
+ mainsym->section->output_section->vma
|
||||||
+ mainsym->section->output_offset);
|
+ mainsym->section->output_offset);
|
||||||
memcpy (table + 1, orig_table, i * sizeof (asymbol *));
|
memcpy (table + 1, orig_table, i * sizeof (asymbol *));
|
||||||
table[0] = mainsym;
|
table[0] = mainsym;
|
||||||
|
|
||||||
/* Check that the value assigned to :Main is the same as the entry
|
/* Check that the value assigned to :Main is the same as the entry
|
||||||
address. The default linker script asserts this. This is as
|
address. The default linker script asserts this. This is as
|
||||||
good a place as any to check this consistency. */
|
good a place as any to check this consistency. */
|
||||||
if (mainvalue != bfd_get_start_address (abfd))
|
if (mainvalue != bfd_get_start_address (abfd)
|
||||||
|
&& !mmo_ignore_symbol_consistency (abfd))
|
||||||
{
|
{
|
||||||
/* Arbitrary buffer to hold the printable representation of a
|
/* Arbitrary buffer to hold the printable representation of a
|
||||||
vma. */
|
vma. */
|
||||||
|
Loading…
Reference in New Issue
Block a user