diff options
author | Andre Vieira <andre.simoesdiasvieira@arm.com> | 2024-11-08 10:06:26 +0000 |
---|---|---|
committer | Andre Vieira <andre.simoesdiasvieira@arm.com> | 2024-11-08 10:06:38 +0000 |
commit | 2c9d089c901afe818f4daa841ced44b87c517d82 (patch) | |
tree | e27d8ec7783e9d8feac433ebda912d05a51c50ff | |
parent | 39d45a7031659fcc9f169fa90d6eb2e4cb88167b (diff) | |
download | fsf-binutils-gdb-2c9d089c901afe818f4daa841ced44b87c517d82.zip fsf-binutils-gdb-2c9d089c901afe818f4daa841ced44b87c517d82.tar.gz fsf-binutils-gdb-2c9d089c901afe818f4daa841ced44b87c517d82.tar.bz2 |
arm, objdump: Make objdump use bfd's machine detection to drive disassembly
For any arm elf target, disable an old piece of code that forced disassembly to
disassemble for 'unknown architecture' which once upon a time meant it would
disassemble ANY arm instruction. This is no longer true with the addition of
Armv8.1-M Mainline, as there are conflicting encodings for different thumb
instructions.
BFD however can detect what architecture the object file was assembled for
using information in the notes section. So if available, we use that,
otherwise we default to the old 'unknown' behaviour.
With the changes above code, a mode changing 'bx lr' assembled for armv4 with
the option --fix-v4bx will result in an object file that is recognized by bfd
as one for the armv4 architecture. The disassembler now disassembles this
encoding as a BX even for Armv4 architectures, but warns the user when
disassembling for Armv4 that this instruction is only valid from Armv4T
onwards.
Remove the unused and wrongfully defined ARM_ARCH_V8A_CRC, and
define and use a ARM_ARCH_V8R_CRC to make sure instructions enabled by
-march=armv8-r+crc are disassembled correctly.
Patch up some of the tests cases, see a brief explanation for each below.
inst.d:
This test checks the assembly & disassembly of basic instructions in armv3m. I
changed the expected behaviour for teqp, cmnp cmpp and testp instructions to
properly print p when disassembling, whereas before, in the 'unknown' case it
would disassemble these as UNPREDICTABLE as they were changed in later
architectures.
nops.d:
Was missing an -march, added one to make sure we were testing the right
behavior of NOP<c> instructions.
unpredictable.d:
Was missing an -march, added armv6 as that reproduced the behaviour being
tested.
-rw-r--r-- | gas/testsuite/gas/arm/inst.d | 32 | ||||
-rw-r--r-- | gas/testsuite/gas/arm/nops.d | 1 | ||||
-rw-r--r-- | gas/testsuite/gas/arm/unpredictable.d | 1 | ||||
-rw-r--r-- | gas/testsuite/gas/arm/v4bx.d | 2 | ||||
-rw-r--r-- | include/opcode/arm.h | 4 | ||||
-rw-r--r-- | ld/testsuite/ld-arm/armv4-bx.d | 4 | ||||
-rw-r--r-- | opcodes/arm-dis.c | 27 |
7 files changed, 46 insertions, 25 deletions
diff --git a/gas/testsuite/gas/arm/inst.d b/gas/testsuite/gas/arm/inst.d index 6f642db..3fda946 100644 --- a/gas/testsuite/gas/arm/inst.d +++ b/gas/testsuite/gas/arm/inst.d @@ -95,22 +95,22 @@ Disassembly of section .text: 0+14c <[^>]*> e1720004 ? cmn r2, r4 0+150 <[^>]*> e1750287 ? cmn r5, r7, lsl #5 0+154 <[^>]*> e1710113 ? cmn r1, r3, lsl r1 -0+158 <[^>]*> e330f00a ? teq r0, #10 @ <UNPREDICTABLE> -0+15c <[^>]*> e132f004 ? teq r2, r4 @ <UNPREDICTABLE> -0+160 <[^>]*> e135f287 ? teq r5, r7, lsl #5 @ <UNPREDICTABLE> -0+164 <[^>]*> e131f113 ? teq r1, r3, lsl r1 @ <UNPREDICTABLE> -0+168 <[^>]*> e370f00a ? cmn r0, #10 @ <UNPREDICTABLE> -0+16c <[^>]*> e172f004 ? cmn r2, r4 @ <UNPREDICTABLE> -0+170 <[^>]*> e175f287 ? cmn r5, r7, lsl #5 @ <UNPREDICTABLE> -0+174 <[^>]*> e171f113 ? cmn r1, r3, lsl r1 @ <UNPREDICTABLE> -0+178 <[^>]*> e350f00a ? cmp r0, #10 @ <UNPREDICTABLE> -0+17c <[^>]*> e152f004 ? cmp r2, r4 @ <UNPREDICTABLE> -0+180 <[^>]*> e155f287 ? cmp r5, r7, lsl #5 @ <UNPREDICTABLE> -0+184 <[^>]*> e151f113 ? cmp r1, r3, lsl r1 @ <UNPREDICTABLE> -0+188 <[^>]*> e310f00a ? tst r0, #10 @ <UNPREDICTABLE> -0+18c <[^>]*> e112f004 ? tst r2, r4 @ <UNPREDICTABLE> -0+190 <[^>]*> e115f287 ? tst r5, r7, lsl #5 @ <UNPREDICTABLE> -0+194 <[^>]*> e111f113 ? tst r1, r3, lsl r1 @ <UNPREDICTABLE> +0+158 <[^>]*> e330f00a ? teqp r0, #10 +0+15c <[^>]*> e132f004 ? teqp r2, r4 +0+160 <[^>]*> e135f287 ? teqp r5, r7, lsl #5 +0+164 <[^>]*> e131f113 ? teqp r1, r3, lsl r1 +0+168 <[^>]*> e370f00a ? cmnp r0, #10 +0+16c <[^>]*> e172f004 ? cmnp r2, r4 +0+170 <[^>]*> e175f287 ? cmnp r5, r7, lsl #5 +0+174 <[^>]*> e171f113 ? cmnp r1, r3, lsl r1 +0+178 <[^>]*> e350f00a ? cmpp r0, #10 +0+17c <[^>]*> e152f004 ? cmpp r2, r4 +0+180 <[^>]*> e155f287 ? cmpp r5, r7, lsl #5 +0+184 <[^>]*> e151f113 ? cmpp r1, r3, lsl r1 +0+188 <[^>]*> e310f00a ? tstp r0, #10 +0+18c <[^>]*> e112f004 ? tstp r2, r4 +0+190 <[^>]*> e115f287 ? tstp r5, r7, lsl #5 +0+194 <[^>]*> e111f113 ? tstp r1, r3, lsl r1 0+198 <[^>]*> e0000291 ? mul r0, r1, r2 0+19c <[^>]*> e0110392 ? muls r1, r2, r3 0+1a0 <[^>]*> 10000091 ? mulne r0, r1, r0 diff --git a/gas/testsuite/gas/arm/nops.d b/gas/testsuite/gas/arm/nops.d index bda0c30..0f5de019 100644 --- a/gas/testsuite/gas/arm/nops.d +++ b/gas/testsuite/gas/arm/nops.d @@ -1,4 +1,5 @@ # name: NOP<c> instructions +# as: -march=armv7-a # objdump: -dr --prefix-addresses --show-raw-insn # skip: *-*-pe *-*-wince diff --git a/gas/testsuite/gas/arm/unpredictable.d b/gas/testsuite/gas/arm/unpredictable.d index 0781c18..0d3c14b 100644 --- a/gas/testsuite/gas/arm/unpredictable.d +++ b/gas/testsuite/gas/arm/unpredictable.d @@ -1,4 +1,5 @@ # name: Upredictable Instructions +# as: -march=armv6 # objdump: -D --prefix-addresses --show-raw-insn .*: +file format .*arm.* diff --git a/gas/testsuite/gas/arm/v4bx.d b/gas/testsuite/gas/arm/v4bx.d index a9b1b95..926f97e 100644 --- a/gas/testsuite/gas/arm/v4bx.d +++ b/gas/testsuite/gas/arm/v4bx.d @@ -6,5 +6,5 @@ .*: +file format .*arm.* Disassembly of section .text: -0+00 <[^>]+> e12fff1e bx lr +0+00 <[^>]+> e12fff1e bx lr @ from Armv4T onwards 0: R_ARM_V4BX \*ABS\* diff --git a/include/opcode/arm.h b/include/opcode/arm.h index a89c215..de1fcd4 100644 --- a/include/opcode/arm.h +++ b/include/opcode/arm.h @@ -354,8 +354,6 @@ #define ARM_ARCH_V7M ARM_FEATURE_CORE (ARM_AEXT_V7M, ARM_EXT2_V6T2_V8M) #define ARM_ARCH_V7EM ARM_FEATURE_CORE (ARM_AEXT_V7EM, ARM_EXT2_V6T2_V8M) #define ARM_ARCH_V8A ARM_FEATURE_CORE (ARM_AEXT_V8A, ARM_AEXT2_V8A) -#define ARM_ARCH_V8A_CRC ARM_FEATURE (ARM_AEXT_V8A, \ - ARM_AEXT2_V8A | ARM_EXT2_CRC) #define ARM_ARCH_V8_1A ARM_FEATURE (ARM_AEXT_V8A, ARM_AEXT2_V8_1A \ | ARM_EXT2_CRC, FPU_NEON_EXT_RDMA) #define ARM_ARCH_V8_2A ARM_FEATURE (ARM_AEXT_V8A, ARM_AEXT2_V8_2A \ @@ -381,6 +379,8 @@ #define ARM_ARCH_V8M_MAIN_DSP ARM_FEATURE_CORE (ARM_AEXT_V8M_MAIN_DSP, \ ARM_AEXT2_V8M_MAIN_DSP) #define ARM_ARCH_V8R ARM_FEATURE_CORE (ARM_AEXT_V8R, ARM_AEXT2_V8R) +#define ARM_ARCH_V8R_CRC ARM_FEATURE_CORE (ARM_AEXT_V8R, \ + ARM_AEXT2_V8R | ARM_EXT2_CRC) #define ARM_ARCH_V8_1M_MAIN ARM_FEATURE_CORE (ARM_AEXT_V8_1M_MAIN, \ ARM_AEXT2_V8_1M_MAIN) #define ARM_ARCH_V9A ARM_FEATURE_ALL(ARM_AEXT_V8A, \ diff --git a/ld/testsuite/ld-arm/armv4-bx.d b/ld/testsuite/ld-arm/armv4-bx.d index be2a4da..5ff0f82 100644 --- a/ld/testsuite/ld-arm/armv4-bx.d +++ b/ld/testsuite/ld-arm/armv4-bx.d @@ -11,9 +11,9 @@ Disassembly of section \.text: 0000800c <__bx_r14>: 800c: e31e0001 tst lr, #1 8010: 01a0f00e moveq pc, lr - 8014: e12fff1e bx lr + 8014: e12fff1e bx lr @ from Armv4T onwards 00008018 <__bx_r0>: 8018: e3100001 tst r0, #1 801c: 01a0f000 moveq pc, r0 - 8020: e12fff10 bx r0 + 8020: e12fff10 bx r0 @ from Armv4T onwards diff --git a/opcodes/arm-dis.c b/opcodes/arm-dis.c index d1d7ca3..b395cdc 100644 --- a/opcodes/arm-dis.c +++ b/opcodes/arm-dis.c @@ -3364,6 +3364,7 @@ static const struct mopcode32 mve_opcodes[] = %C print the PSR sub type. %U print barrier type. %P print address for pli instruction. + %T print 'from Armv4T onwards' %<bitfield>r print as an ARM register %<bitfield>T print as an ARM register + 1 @@ -3392,8 +3393,8 @@ static const struct opcode32 arm_opcodes[] = {ARM_FEATURE_CORE_LOW (ARM_EXT_V1), 0xe7f000f0, 0xfff000f0, "udf\t%{I:#%e%}"}, - {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T | ARM_EXT_V5), - 0x012FFF10, 0x0ffffff0, "bx%c\t%0-3r"}, + {ARM_FEATURE_CORE_LOW (ARM_EXT_V4), + 0x012FFF10, 0x0ffffff0, "bx%c\t%0-3r%T"}, {ARM_FEATURE_CORE_LOW (ARM_EXT_V2), 0x00000090, 0x0fe000f0, "mul%20's%c\t%16-19R, %0-3R, %8-11R"}, {ARM_FEATURE_CORE_LOW (ARM_EXT_V2), @@ -10103,6 +10104,18 @@ print_insn_arm (bfd_vma pc, struct disassemble_info *info, long given) value_in_comment = print_arm_address (pc, info, given | (1 << P_BIT)); break; + case 'T': + /* Armv4 does not have a BX instruction, however, when + assembled with the --fix-v4bx option GAS will accept + and assemble a BX instruction when assembling for + Armv4. When disassembling we also disassemble it as a + BX instruction, but do make the user aware that this + instruction is only supported on HW from Armv4T + onwards. */ + if (info->mach == bfd_mach_arm_4) + func (stream, dis_style_text, "\t@ from Armv4T onwards"); + break; + case 'S': allow_unpredictable = true; /* Fall through. */ @@ -12292,7 +12305,7 @@ select_arm_features (unsigned long mach, ARM_MERGE_FEATURE_SETS (arch_fset, arch_fset, armv8_6_ext_fset); break; } - case bfd_mach_arm_8R: ARM_SET_FEATURES (ARM_ARCH_V8R); break; + case bfd_mach_arm_8R: ARM_SET_FEATURES (ARM_ARCH_V8R_CRC); break; case bfd_mach_arm_8M_BASE: ARM_SET_FEATURES (ARM_ARCH_V8M_BASE); break; case bfd_mach_arm_8M_MAIN: ARM_SET_FEATURES (ARM_ARCH_V8M_MAIN); break; case bfd_mach_arm_8_1M_MAIN: @@ -12358,10 +12371,16 @@ print_insn (bfd_vma pc, struct disassemble_info *info, bool little) { static struct arm_private_data private; - if ((info->flags & USER_SPECIFIED_MACHINE_TYPE) == 0) + if (info->flavour != bfd_target_elf_flavour + && (info->flags & USER_SPECIFIED_MACHINE_TYPE) == 0) /* If the user did not use the -m command line switch then default to disassembling all types of ARM instruction. + If this is an arm elf target, build attributes will be used to + determine info->mach, which enable us to be more accurate when + disassembling since we know what the target architecture version is. + For any other target see the comment below: + The info->mach value has to be ignored as this will be based on the default archictecture for the target and/or hints in the notes section, but it will never be greater than the current largest arm |