From e49d43ff73a309548dd2b576bb7b602f62be66d6 Mon Sep 17 00:00:00 2001 From: Tristan Gingold Date: Fri, 20 Nov 2015 17:24:52 +0100 Subject: [PATCH] opcodes: handle mach-o for thumb/arm disambiguation. opcodes/ * arm-dis.c (print_insn): Also set is_thumb for Mach-O. --- opcodes/ChangeLog | 4 ++++ opcodes/arm-dis.c | 8 ++++++++ 2 files changed, 12 insertions(+) diff --git a/opcodes/ChangeLog b/opcodes/ChangeLog index c661b9a31d..08f0c1b751 100644 --- a/opcodes/ChangeLog +++ b/opcodes/ChangeLog @@ -1,3 +1,7 @@ +2015-11-23 Tristan Gingold + + * arm-dis.c (print_insn): Also set is_thumb for Mach-O. + 2015-11-20 Matthew Wahab * aarch64-opc.c (aarch64_sys_regs): Add spsr_el12, elr_el12, diff --git a/opcodes/arm-dis.c b/opcodes/arm-dis.c index 430da08863..cff4b3fcb6 100644 --- a/opcodes/arm-dis.c +++ b/opcodes/arm-dis.c @@ -34,6 +34,7 @@ #include "elf-bfd.h" #include "elf/internal.h" #include "elf/arm.h" +#include "mach-o.h" /* FIXME: Belongs in global header. */ #ifndef strneq @@ -6374,6 +6375,13 @@ print_insn (bfd_vma pc, struct disassemble_info *info, bfd_boolean little) == ST_BRANCH_TO_THUMB) || type == STT_ARM_16BIT); } + else if (bfd_asymbol_flavour (*info->symbols) + == bfd_target_mach_o_flavour) + { + bfd_mach_o_asymbol *asym = (bfd_mach_o_asymbol *)*info->symbols; + + is_thumb = (asym->n_desc & BFD_MACH_O_N_ARM_THUMB_DEF); + } } if (force_thumb) -- 2.34.1