diff options
author | Matthew Wahab <matthew.wahab@arm.com> | 2015-11-27 15:25:08 +0000 |
---|---|---|
committer | Matthew Wahab <matthew.wahab@arm.com> | 2015-11-27 15:28:42 +0000 |
commit | d685192a58d4c198633bd0e69cfe0a114576e98a (patch) | |
tree | 8b57e30467eb5a4d74ddf557c3822dd8f1016070 /gas | |
parent | e19616610d7327664f99215a69cb326682742dc3 (diff) | |
download | gdb-d685192a58d4c198633bd0e69cfe0a114576e98a.zip gdb-d685192a58d4c198633bd0e69cfe0a114576e98a.tar.gz gdb-d685192a58d4c198633bd0e69cfe0a114576e98a.tar.bz2 |
[AArch64] Add ARMv8.2 instructions BFC and REV64.
ARMv8.2 adds two new instructions: BFC as an alias for BFM and REV64 as
an alias for REV. This patch set adds support for these to binutils,
enabled when the -march=armv8.2-a is given. It depends on the support
for an instruction being its preferred form which was added in an
earlier patch.
This patch adds the alias BFC <Rd>, #<imm>, #<width> as the preferred
form for BFM when the source is a zero register and the conditions for
using the BFI form are met (in other words, BFC is the preferred form
for BFI <Rd>, <Rs>, #<imm>, #<width> when the <Rs> is a zero register).
gas/testsuite/
2015-11-27 Matthew Wahab <matthew.wahab@arm.com>
* gas/aarch64/alias-2.d: New.
* gas/aarch64/alias-2.s: New.
include/opcode/
2015-11-27 Matthew Wahab <matthew.wahab@arm.com>
* aarch64.h (aarch64_op): Add OP_BFC.
opcodes/
2015-11-27 Matthew Wahab <matthew.wahab@arm.com>
* aarch64-asm-2.c: Regenerate.
* aarch64-asm.c (convert_bfc_to_bfm): New.
(convert_to_real): Add case for OP_BFC.
* aarch64-dis-2.c: Regenerate.
* aarch64-dis.c: (convert_bfm_to_bfc): New.
(convert_to_alias): Add case for OP_BFC.
* aarch64-opc-2.c: Regenerate.
* aarch64-opc.c (operand_general_constraint_met_p): Weaken assert
to allow width operand in three-operand instructions.
* aarch64-tbl.h (QL_BF1): New.
(aarch64_feature_v8_2): New.
(ARMV8_2): New.
(aarch64_opcode_table): Add "bfc".
Change-Id: I6efe318b2538ba11f0caece7c6d70957441c872b
Diffstat (limited to 'gas')
-rw-r--r-- | gas/testsuite/ChangeLog | 5 | ||||
-rw-r--r-- | gas/testsuite/gas/aarch64/alias-2.d | 98 | ||||
-rw-r--r-- | gas/testsuite/gas/aarch64/alias-2.s | 31 |
3 files changed, 134 insertions, 0 deletions
diff --git a/gas/testsuite/ChangeLog b/gas/testsuite/ChangeLog index faf5282..29e501a 100644 --- a/gas/testsuite/ChangeLog +++ b/gas/testsuite/ChangeLog @@ -1,5 +1,10 @@ 2015-11-27 Matthew Wahab <matthew.wahab@arm.com> + * gas/aarch64/alias-2.d: New. + * gas/aarch64/alias-2.s: New. + +2015-11-27 Matthew Wahab <matthew.wahab@arm.com> + * gas/aarch64/sysreg-2.d: New. * gas/aarch64/sysreg-2.s: New. diff --git a/gas/testsuite/gas/aarch64/alias-2.d b/gas/testsuite/gas/aarch64/alias-2.d new file mode 100644 index 0000000..92ed58f --- /dev/null +++ b/gas/testsuite/gas/aarch64/alias-2.d @@ -0,0 +1,98 @@ +#objdump: -dr +#as: -march=armv8.2-a + +.*: file format .* + +Disassembly of section \.text: + +0000000000000000 <.*>: + [0-9a-f]+: b34107e0 bfxil x0, xzr, #1, #1 + [0-9a-f]+: b3410420 bfxil x0, x1, #1, #1 + [0-9a-f]+: b341043f bfxil xzr, x1, #1, #1 + [0-9a-f]+: b34107ff bfxil xzr, xzr, #1, #1 + [0-9a-f]+: b34123e0 bfxil x0, xzr, #1, #8 + [0-9a-f]+: b3412020 bfxil x0, x1, #1, #8 + [0-9a-f]+: b341203f bfxil xzr, x1, #1, #8 + [0-9a-f]+: b34123ff bfxil xzr, xzr, #1, #8 + [0-9a-f]+: b3413fe0 bfxil x0, xzr, #1, #15 + [0-9a-f]+: b3413c20 bfxil x0, x1, #1, #15 + [0-9a-f]+: b3413c3f bfxil xzr, x1, #1, #15 + [0-9a-f]+: b3413fff bfxil xzr, xzr, #1, #15 + [0-9a-f]+: b35007e0 bfc x0, #48, #2 + [0-9a-f]+: b3500420 bfi x0, x1, #48, #2 + [0-9a-f]+: b350043f bfi xzr, x1, #48, #2 + [0-9a-f]+: b35007ff bfc xzr, #48, #2 + [0-9a-f]+: b35023e0 bfc x0, #48, #9 + [0-9a-f]+: b3502020 bfi x0, x1, #48, #9 + [0-9a-f]+: b350203f bfi xzr, x1, #48, #9 + [0-9a-f]+: b35023ff bfc xzr, #48, #9 + [0-9a-f]+: b3503fe0 bfc x0, #48, #16 + [0-9a-f]+: b3503c20 bfi x0, x1, #48, #16 + [0-9a-f]+: b3503c3f bfi xzr, x1, #48, #16 + [0-9a-f]+: b3503fff bfc xzr, #48, #16 + [0-9a-f]+: b35f07e0 bfc x0, #33, #2 + [0-9a-f]+: b35f0420 bfi x0, x1, #33, #2 + [0-9a-f]+: b35f043f bfi xzr, x1, #33, #2 + [0-9a-f]+: b35f07ff bfc xzr, #33, #2 + [0-9a-f]+: b35f23e0 bfc x0, #33, #9 + [0-9a-f]+: b35f2020 bfi x0, x1, #33, #9 + [0-9a-f]+: b35f203f bfi xzr, x1, #33, #9 + [0-9a-f]+: b35f23ff bfc xzr, #33, #9 + [0-9a-f]+: b35f3fe0 bfc x0, #33, #16 + [0-9a-f]+: b35f3c20 bfi x0, x1, #33, #16 + [0-9a-f]+: b35f3c3f bfi xzr, x1, #33, #16 + [0-9a-f]+: b35f3fff bfc xzr, #33, #16 + [0-9a-f]+: b37f03e0 bfc x0, #1, #1 + [0-9a-f]+: b37f0020 bfi x0, x1, #1, #1 + [0-9a-f]+: b37f003f bfi xzr, x1, #1, #1 + [0-9a-f]+: b37f03ff bfc xzr, #1, #1 + [0-9a-f]+: b37f1fe0 bfc x0, #1, #8 + [0-9a-f]+: b37f1c20 bfi x0, x1, #1, #8 + [0-9a-f]+: b37f1c3f bfi xzr, x1, #1, #8 + [0-9a-f]+: b37f1fff bfc xzr, #1, #8 + [0-9a-f]+: b37f3be0 bfc x0, #1, #15 + [0-9a-f]+: b37f3820 bfi x0, x1, #1, #15 + [0-9a-f]+: b37f383f bfi xzr, x1, #1, #15 + [0-9a-f]+: b37f3bff bfc xzr, #1, #15 + [0-9a-f]+: b37003e0 bfc x0, #16, #1 + [0-9a-f]+: b3700020 bfi x0, x1, #16, #1 + [0-9a-f]+: b370003f bfi xzr, x1, #16, #1 + [0-9a-f]+: b37003ff bfc xzr, #16, #1 + [0-9a-f]+: b3701fe0 bfc x0, #16, #8 + [0-9a-f]+: b3701c20 bfi x0, x1, #16, #8 + [0-9a-f]+: b3701c3f bfi xzr, x1, #16, #8 + [0-9a-f]+: b3701fff bfc xzr, #16, #8 + [0-9a-f]+: b3703be0 bfc x0, #16, #15 + [0-9a-f]+: b3703820 bfi x0, x1, #16, #15 + [0-9a-f]+: b370383f bfi xzr, x1, #16, #15 + [0-9a-f]+: b3703bff bfc xzr, #16, #15 + [0-9a-f]+: b36103e0 bfc x0, #31, #1 + [0-9a-f]+: b3610020 bfi x0, x1, #31, #1 + [0-9a-f]+: b361003f bfi xzr, x1, #31, #1 + [0-9a-f]+: b36103ff bfc xzr, #31, #1 + [0-9a-f]+: b3611fe0 bfc x0, #31, #8 + [0-9a-f]+: b3611c20 bfi x0, x1, #31, #8 + [0-9a-f]+: b3611c3f bfi xzr, x1, #31, #8 + [0-9a-f]+: b3611fff bfc xzr, #31, #8 + [0-9a-f]+: b3613be0 bfc x0, #31, #15 + [0-9a-f]+: b3613820 bfi x0, x1, #31, #15 + [0-9a-f]+: b361383f bfi xzr, x1, #31, #15 + [0-9a-f]+: b3613bff bfc xzr, #31, #15 + [0-9a-f]+: b34003e0 bfxil x0, xzr, #0, #1 + [0-9a-f]+: b36103ff bfc xzr, #31, #1 + [0-9a-f]+: b3401fe0 bfxil x0, xzr, #0, #8 + [0-9a-f]+: b3611fff bfc xzr, #31, #8 + [0-9a-f]+: b3403be0 bfxil x0, xzr, #0, #15 + [0-9a-f]+: b3613bff bfc xzr, #31, #15 + [0-9a-f]+: b34003e0 bfxil x0, xzr, #0, #1 + [0-9a-f]+: b36103ff bfc xzr, #31, #1 + [0-9a-f]+: b3401fe0 bfxil x0, xzr, #0, #8 + [0-9a-f]+: b3611fff bfc xzr, #31, #8 + [0-9a-f]+: b3403be0 bfxil x0, xzr, #0, #15 + [0-9a-f]+: b3613bff bfc xzr, #31, #15 + [0-9a-f]+: b34003e0 bfxil x0, xzr, #0, #1 + [0-9a-f]+: b36103ff bfc xzr, #31, #1 + [0-9a-f]+: b3401fe0 bfxil x0, xzr, #0, #8 + [0-9a-f]+: b3611fff bfc xzr, #31, #8 + [0-9a-f]+: b3403be0 bfxil x0, xzr, #0, #15 + [0-9a-f]+: b3613bff bfc xzr, #31, #15 diff --git a/gas/testsuite/gas/aarch64/alias-2.s b/gas/testsuite/gas/aarch64/alias-2.s new file mode 100644 index 0000000..d952c97 --- /dev/null +++ b/gas/testsuite/gas/aarch64/alias-2.s @@ -0,0 +1,31 @@ +/* alias-2.s Test file for ARMv8.2 AArch64 instructions aliases or disassembly + preference. */ + + /* <bfm> [Xd|xzr], [xzr|<Xr>], <imm>, <width> */ + .macro bfm_inst op imm width + \op x0, xzr, #\imm, #\width + \op x0, x1, #\imm, #\width + \op xzr, x1, #\imm, #\width + \op xzr, xzr, #\imm, #\width + .endm + + /* bfc [Xd|xzr], <imm>, <width> */ + .macro bfc_inst imm width + bfc x0, #\imm, #\width + bfc xzr, #\imm, #\width + .endm + +.text + .irp op, bfm, bfi + .irp imm, 1, 16, 31 + .irp width, 1, 8, 15 + bfm_inst \op, \imm, \width + .endr + .endr + .endr + + .irp imm, 1, 16, 31 + .irp width, 1, 8, 15 + bfc_inst \imm, \width + .endr + .endr |