From: mephi42 Date: Tue, 21 Aug 2018 15:34:56 +0000 (+0100) Subject: Fix running objcopy on Mach-O binaries. X-Git-Url: http://git.efficios.com/?a=commitdiff_plain;ds=sidebyside;h=ae19acf3201ee0b921cde8e70e278fe123e82105;p=deliverable%2Fbinutils-gdb.git Fix running objcopy on Mach-O binaries. PR binutils/23315 * mach-o.c (bfd_mach_o_mangle_symbols): Update n_type even if data is already considered filled. --- diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 2ff9f4af87..3da70d65c4 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,9 @@ +2018-08-21 mephi42 + + PR binutils/23315 + * mach-o.c (bfd_mach_o_mangle_symbols): Update n_type even if + data is already considered filled. + 2018-08-21 Alan Modra * elf64-ppc.c (HOW): Define. diff --git a/bfd/mach-o.c b/bfd/mach-o.c index ce72a3dd2c..1b461f5988 100644 --- a/bfd/mach-o.c +++ b/bfd/mach-o.c @@ -2497,11 +2497,14 @@ bfd_mach_o_mangle_symbols (bfd *abfd) } else s->n_type = BFD_MACH_O_N_SECT; - - if (s->symbol.flags & BSF_GLOBAL) - s->n_type |= BFD_MACH_O_N_EXT; } + /* Update external symbol bit in case objcopy changed it. */ + if (s->symbol.flags & BSF_GLOBAL) + s->n_type |= BFD_MACH_O_N_EXT; + else + s->n_type &= ~BFD_MACH_O_N_EXT; + /* Put the section index in, where required. */ if ((s->symbol.section != bfd_abs_section_ptr && s->symbol.section != bfd_und_section_ptr