[PATCH, BINUTILS, ARM, 3/3] Add Execution and Data Prediction instructions for AArch32
Sudakshina Das
sudi.das@arm.com
Mon Sep 24 16:16:00 GMT 2018
Hi Richard
On 20/09/18 14:15, Richard Earnshaw (lists) wrote:
> On 19/09/18 15:36, Sudakshina Das wrote:
>> Hi
>>
>> This patch is part of the patch series to add support for ARMv8.5-A
>> extensions.
>> (https://developer.arm.com/products/architecture/cpu-architecture/a-profile/exploration-tools)
>>
>>
>> This patch adds the Execution and Data Prediction Restriction
>> instructions (that is, cfprctx, dvprxtc, cpprctx). These are all aliases
>> to MCR and are disassembled as such.
>>
>> This instruction is retrospectively made optional for all versions of
>> the architecture from ARMv8.0 to ARMv8.4 and is mandatory from ARMv8.5.
>> Hence adding a new +predres for older versions of the architecture.
>>
>> Testing done: Builds and reg tests all pass on arm-none-eabi.
>> Added new tests.
>>
>> Ok for trunk?
>>
>
> This has the same problem as the previous patch, the constant is too
> large for the storage on a 32-bit host. Also, please keep the #defines
> grouped and sorted in order, so that we know which bits have been used.
>
> R.
>
Sorry about the overlook, I missed out on the macro values completely.
The list of the extensions, where I added these two are oddly going in a
descending order (with an exception of FPU_ENDIAN_BIG). I guess I should
add them at the bottom with the next lowest values. I will send the
edited patches soon.
Thanks
Sudi
>> Thanks
>> Sudi
>> PS. I do not have commit access so if OK can someone apply for me?
>>
>> *** include/ChangeLog ***
>>
>> 2018-xx-xx Sudakshina Das <sudi.das@arm.com>
>>
>> Â Â Â Â * opcode/arm.h (PREDRES_EXT_ARMV8): New.
>> Â Â Â Â (ARM_ARCH_V8_5A): Add PREDRES_EXT_ARMV8 by default.
>>
>> *** gas/ChangeLog ***
>>
>> 2018-xx-xx Sudakshina Das <sudi.das@arm.com>
>>
>> Â Â Â Â * config/tc-arm.c (predres_ext_armv8): New.
>> Â Â Â Â (insns): Add new cfprctx, dvprctx and cpprctx instructions.
>> Â Â Â Â (arm_extensions): Add "predres".
>> Â Â Â Â * doc/c-arm.texi: Document the above.
>> Â Â Â Â * testsuite/gas/arm/predres-bad.d: New test.
>> Â Â Â Â * testsuite/gas/arm/predres-bad.l: New test.
>> Â Â Â Â * testsuite/gas/arm/predres.s: New test.
>> Â Â Â Â * testsuite/gas/arm/predres1.d: New test.
>> Â Â Â Â * testsuite/gas/arm/predres2.d: New test.
>>
>>
>>
>> rb9985.patch
>>
>>
>> diff --git a/gas/config/tc-arm.c b/gas/config/tc-arm.c
>> index e4c7dcb56a28ad7663d3b19a9b76e43d94fbe6a8..f1e46f99182fa3300cdcf8c86588cd72fc03f586 100644
>> --- a/gas/config/tc-arm.c
>> +++ b/gas/config/tc-arm.c
>> @@ -317,6 +317,8 @@ static const arm_feature_set fpu_neon_ext_dotprod =
>> ARM_FEATURE_COPROC (FPU_NEON_EXT_DOTPROD);
>> static const arm_feature_set sb_ext_armv8 =
>> ARM_FEATURE_COPROC (SB_EXT_ARMV8);
>> +static const arm_feature_set predres_ext_armv8 =
>> + ARM_FEATURE_COPROC (PREDRES_EXT_ARMV8);
>>
>> static int mfloat_abi_opt = -1;
>> /* Architecture feature bits selected by the last -mcpu/-march or .cpu/.arch
>> @@ -21525,6 +21527,14 @@ static const struct asm_opcode insns[] =
>> #define THUMB_VARIANT & sb_ext_armv8
>> TUF("sb", 57ff070, f3bf8f70, 0, (), noargs, noargs),
>>
>> +#undef ARM_VARIANT
>> +#define ARM_VARIANT & predres_ext_armv8
>> +#undef THUMB_VARIANT
>> +#define THUMB_VARIANT & predres_ext_armv8
>> + CE("cfprctx", e070f93, 1, (RRnpc), rd),
>> + CE("dvprctx", e070fb3, 1, (RRnpc), rd),
>> + CE("cpprctx", e070ff3, 1, (RRnpc), rd),
>> +
>> /* ARMv8-M instructions. */
>> #undef ARM_VARIANT
>> #define ARM_VARIANT NULL
>> @@ -26421,6 +26431,9 @@ static const struct arm_option_extension_value_table arm_extensions[] =
>> ARM_EXT_OPT ("pan", ARM_FEATURE_CORE_HIGH (ARM_EXT2_PAN),
>> ARM_FEATURE (ARM_EXT_V8, ARM_EXT2_PAN, 0),
>> ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8A)),
>> + ARM_EXT_OPT ("predres", ARM_FEATURE_COPROC (PREDRES_EXT_ARMV8),
>> + ARM_FEATURE_COPROC (PREDRES_EXT_ARMV8),
>> + ARM_ARCH_V8A),
>> ARM_EXT_OPT ("ras", ARM_FEATURE_CORE_HIGH (ARM_EXT2_RAS),
>> ARM_FEATURE (ARM_EXT_V8, ARM_EXT2_RAS, 0),
>> ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8A)),
>> diff --git a/gas/doc/c-arm.texi b/gas/doc/c-arm.texi
>> index b9910dab6118af0828d1d812ccead0aef5b8eb9e..5dbb5bdf2f0122324988673ba9620bd56b37e3f4 100644
>> --- a/gas/doc/c-arm.texi
>> +++ b/gas/doc/c-arm.texi
>> @@ -189,6 +189,8 @@ The following extensions are currently supported:
>> @code{mp} (Multiprocessing Extensions for v7-A and v7-R
>> architectures),
>> @code{os} (Operating System for v6M architecture),
>> +@code{predres} (Execution and Data Prediction Restriction Instruction for
>> +v8-A archtectures, added by default from v8.5-A),
>> @code{sb} (Speculation Barrier Instruction for v8-A archtectures, added by
>> default from v8.5-A),
>> @code{sec} (Security Extensions for v6K and v7-A architectures),
>> diff --git a/gas/testsuite/gas/arm/predres-bad.d b/gas/testsuite/gas/arm/predres-bad.d
>> new file mode 100644
>> index 0000000000000000000000000000000000000000..7fc8ca077799da0a8ddd3ab21f87ac2a4eee9eb3
>> --- /dev/null
>> +++ b/gas/testsuite/gas/arm/predres-bad.d
>> @@ -0,0 +1,4 @@
>> +#name: Error for Prediction Restriction instructions without +predres
>> +#source: predres.s
>> +#as: -march=armv8-a
>> +#error-output: predres-bad.l
>> diff --git a/gas/testsuite/gas/arm/predres-bad.l b/gas/testsuite/gas/arm/predres-bad.l
>> new file mode 100644
>> index 0000000000000000000000000000000000000000..3f7efc62b069d678dcfeb48f6e93be7c328c16de
>> --- /dev/null
>> +++ b/gas/testsuite/gas/arm/predres-bad.l
>> @@ -0,0 +1,4 @@
>> +[^:]*: Assembler messages:
>> +[^:]*:4: Error: selected processor does not support `cfprctx r1' in ARM mode
>> +[^:]*:5: Error: selected processor does not support `dvprctx r2' in ARM mode
>> +[^:]*:6: Error: selected processor does not support `cpprctx r3' in ARM mode
>> diff --git a/gas/testsuite/gas/arm/predres.s b/gas/testsuite/gas/arm/predres.s
>> new file mode 100644
>> index 0000000000000000000000000000000000000000..6cfb1f166fe1d3744a9f081758bf25b090e3fa1a
>> --- /dev/null
>> +++ b/gas/testsuite/gas/arm/predres.s
>> @@ -0,0 +1,6 @@
>> +@ Test case to validate Prediction Restriction Instructions
>> +.section .text
>> +.syntax unified
>> + cfprctx r1
>> + dvprctx r2
>> + cpprctx r3
>> diff --git a/gas/testsuite/gas/arm/predres1.d b/gas/testsuite/gas/arm/predres1.d
>> new file mode 100644
>> index 0000000000000000000000000000000000000000..b3a900a3d4756da529e2b765b20be4831b1cf3df
>> --- /dev/null
>> +++ b/gas/testsuite/gas/arm/predres1.d
>> @@ -0,0 +1,11 @@
>> +#name: Execution and Data Prediction Restriction instructions
>> +#source: predres.s
>> +#as: -march=armv8.5-a
>> +#objdump: -dr --prefix-addresses --show-raw-insn
>> +
>> +.*: *file format .*arm.*
>> +
>> +Disassembly of section .text:
>> +.*> ee071f93 mcr 15, 0, r1, cr7, cr3, \{4\}
>> +.*> ee072fb3 mcr 15, 0, r2, cr7, cr3, \{5\}
>> +.*> ee073ff3 mcr 15, 0, r3, cr7, cr3, \{7\}
>> diff --git a/gas/testsuite/gas/arm/predres2.d b/gas/testsuite/gas/arm/predres2.d
>> new file mode 100644
>> index 0000000000000000000000000000000000000000..d17cf06eb0ea36977aa13853d4872daded805bc5
>> --- /dev/null
>> +++ b/gas/testsuite/gas/arm/predres2.d
>> @@ -0,0 +1,11 @@
>> +#name: Execution and Data Prediction Restriction instructions with +predres
>> +#source: predres.s
>> +#as: -march=armv8-a+predres
>> +#objdump: -dr --prefix-addresses --show-raw-insn
>> +
>> +.*: *file format .*arm.*
>> +
>> +Disassembly of section .text:
>> +.*> ee071f93 mcr 15, 0, r1, cr7, cr3, \{4\}
>> +.*> ee072fb3 mcr 15, 0, r2, cr7, cr3, \{5\}
>> +.*> ee073ff3 mcr 15, 0, r3, cr7, cr3, \{7\}
>> diff --git a/include/opcode/arm.h b/include/opcode/arm.h
>> index f4e0832ac662424899f91314fc1b20eabbce8507..e8800ca6d56886ff16be4485d7ae48ae8bd75694 100644
>> --- a/include/opcode/arm.h
>> +++ b/include/opcode/arm.h
>> @@ -76,6 +76,7 @@
>> #define ARM_CEXT_IWMMXT 0x00000004 /* Intel Wireless MMX technology coprocessor. */
>> #define ARM_CEXT_IWMMXT2 0x00000008 /* Intel Wireless MMX technology coprocessor version 2. */
>>
>> +#define PREDRES_EXT_ARMV8 0x200000000 /* Prediction Restriction insns. */
>> #define SB_EXT_ARMV8 0x100000000 /* SB instruction. */
>> #define FPU_ENDIAN_PURE 0x80000000 /* Pure-endian doubles. */
>> #define FPU_ENDIAN_BIG 0 /* Double words-big-endian. */
>> @@ -298,7 +299,8 @@
>> | FPU_NEON_EXT_DOTPROD)
>> #define ARM_ARCH_V8_5A ARM_FEATURE (ARM_AEXT_V8A, ARM_AEXT2_V8_5A, \
>> CRC_EXT_ARMV8 | FPU_NEON_EXT_RDMA \
>> - | FPU_NEON_EXT_DOTPROD | SB_EXT_ARMV8)
>> + | FPU_NEON_EXT_DOTPROD | SB_EXT_ARMV8 \
>> + | PREDRES_EXT_ARMV8)
>> #define ARM_ARCH_V8M_BASE ARM_FEATURE_CORE (ARM_AEXT_V8M_BASE, ARM_AEXT2_V8M)
>> #define ARM_ARCH_V8M_MAIN ARM_FEATURE_CORE (ARM_AEXT_V8M_MAIN, \
>> ARM_AEXT2_V8M_MAIN)
>>
>>
>
More information about the Binutils
mailing list