|
|
diff -rup binutils.orig/gas/config/tc-arm.c binutils-2.27/gas/config/tc-arm.c |
|
|
--- binutils.orig/gas/config/tc-arm.c 2017-08-09 10:26:30.032741952 +0100 |
|
|
+++ binutils-2.27/gas/config/tc-arm.c 2017-08-09 11:17:17.747598541 +0100 |
|
|
@@ -147,8 +147,10 @@ static const arm_feature_set *legacy_cpu |
|
|
static const arm_feature_set *legacy_fpu = NULL; |
|
|
|
|
|
static const arm_feature_set *mcpu_cpu_opt = NULL; |
|
|
+static arm_feature_set *dyn_mcpu_ext_opt = NULL; |
|
|
static const arm_feature_set *mcpu_fpu_opt = NULL; |
|
|
static const arm_feature_set *march_cpu_opt = NULL; |
|
|
+static arm_feature_set *dyn_march_ext_opt = NULL; |
|
|
static const arm_feature_set *march_fpu_opt = NULL; |
|
|
static const arm_feature_set *mfpu_opt = NULL; |
|
|
static const arm_feature_set *object_arch = NULL; |
|
|
@@ -187,7 +189,6 @@ static const arm_feature_set arm_ext_v5j |
|
|
static const arm_feature_set arm_ext_v6 = ARM_FEATURE_CORE_LOW (ARM_EXT_V6); |
|
|
static const arm_feature_set arm_ext_v6k = ARM_FEATURE_CORE_LOW (ARM_EXT_V6K); |
|
|
static const arm_feature_set arm_ext_v6t2 = ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2); |
|
|
-static const arm_feature_set arm_ext_v6m = ARM_FEATURE_CORE_LOW (ARM_EXT_V6M); |
|
|
static const arm_feature_set arm_ext_v6_notm = |
|
|
ARM_FEATURE_CORE_LOW (ARM_EXT_V6_NOTM); |
|
|
static const arm_feature_set arm_ext_v6_dsp = |
|
|
@@ -201,11 +202,11 @@ static const arm_feature_set arm_ext_v7 |
|
|
static const arm_feature_set arm_ext_v7a = ARM_FEATURE_CORE_LOW (ARM_EXT_V7A); |
|
|
static const arm_feature_set arm_ext_v7r = ARM_FEATURE_CORE_LOW (ARM_EXT_V7R); |
|
|
#ifdef OBJ_ELF |
|
|
-static const arm_feature_set arm_ext_v7m = ARM_FEATURE_CORE_LOW (ARM_EXT_V7M); |
|
|
+static const arm_feature_set ATTRIBUTE_UNUSED arm_ext_v7m = ARM_FEATURE_CORE_LOW (ARM_EXT_V7M); |
|
|
#endif |
|
|
static const arm_feature_set arm_ext_v8 = ARM_FEATURE_CORE_LOW (ARM_EXT_V8); |
|
|
static const arm_feature_set arm_ext_m = |
|
|
- ARM_FEATURE_CORE (ARM_EXT_V6M | ARM_EXT_OS | ARM_EXT_V7M, |
|
|
+ ARM_FEATURE_CORE (ARM_EXT_V6M | ARM_EXT_V7M, |
|
|
ARM_EXT2_V8M | ARM_EXT2_V8M_MAIN); |
|
|
static const arm_feature_set arm_ext_mp = ARM_FEATURE_CORE_LOW (ARM_EXT_MP); |
|
|
static const arm_feature_set arm_ext_sec = ARM_FEATURE_CORE_LOW (ARM_EXT_SEC); |
|
|
@@ -234,14 +235,16 @@ static const arm_feature_set arm_ext_ras |
|
|
/* FP16 instructions. */ |
|
|
static const arm_feature_set arm_ext_fp16 = |
|
|
ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST); |
|
|
+static const arm_feature_set arm_ext_v8_3 = |
|
|
+ ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_3A); |
|
|
|
|
|
static const arm_feature_set arm_arch_any = ARM_ANY; |
|
|
+#ifdef OBJ_ELF |
|
|
+static const arm_feature_set fpu_any = FPU_ANY; |
|
|
+#endif |
|
|
static const arm_feature_set arm_arch_full ATTRIBUTE_UNUSED = ARM_FEATURE (-1, -1, -1); |
|
|
static const arm_feature_set arm_arch_t2 = ARM_ARCH_THUMB2; |
|
|
static const arm_feature_set arm_arch_none = ARM_ARCH_NONE; |
|
|
-#ifdef OBJ_ELF |
|
|
-static const arm_feature_set arm_arch_v6m_only = ARM_ARCH_V6M_ONLY; |
|
|
-#endif |
|
|
|
|
|
static const arm_feature_set arm_cext_iwmmxt2 = |
|
|
ARM_FEATURE_COPROC (ARM_CEXT_IWMMXT2); |
|
|
@@ -291,6 +294,8 @@ static const arm_feature_set crc_ext_arm |
|
|
ARM_FEATURE_COPROC (CRC_EXT_ARMV8); |
|
|
static const arm_feature_set fpu_neon_ext_v8_1 = |
|
|
ARM_FEATURE_COPROC (FPU_NEON_EXT_RDMA); |
|
|
+static const arm_feature_set fpu_neon_ext_dotprod = |
|
|
+ ARM_FEATURE_COPROC (FPU_NEON_EXT_DOTPROD); |
|
|
|
|
|
static int mfloat_abi_opt = -1; |
|
|
/* Record user cpu selection for object attributes. */ |
|
|
@@ -685,9 +690,11 @@ struct asm_opcode |
|
|
#define T2_SUBS_PC_LR 0xf3de8f00 |
|
|
|
|
|
#define DATA_OP_SHIFT 21 |
|
|
+#define SBIT_SHIFT 20 |
|
|
|
|
|
#define T2_OPCODE_MASK 0xfe1fffff |
|
|
#define T2_DATA_OP_SHIFT 21 |
|
|
+#define T2_SBIT_SHIFT 20 |
|
|
|
|
|
#define A_COND_MASK 0xf0000000 |
|
|
#define A_PUSH_POP_OP_MASK 0x0fff0000 |
|
|
@@ -1276,6 +1283,7 @@ arm_reg_alt_syntax (char **ccp, char *st |
|
|
if (*ccp != start && processor <= 15) |
|
|
return processor; |
|
|
} |
|
|
+ /* Fall through. */ |
|
|
|
|
|
case REG_TYPE_MMXWC: |
|
|
/* WC includes WCG. ??? I'm not sure this is true for all |
|
|
@@ -2705,7 +2713,7 @@ mapping_state (enum mstate state) |
|
|
|
|
|
Some Thumb instructions are alignment-sensitive modulo 4 bytes, |
|
|
but themselves require 2-byte alignment; this applies to some |
|
|
- PC- relative forms. However, these cases will invovle implicit |
|
|
+ PC- relative forms. However, these cases will involve implicit |
|
|
literal pool generation or an explicit .align >=2, both of |
|
|
which will cause the section to me marked with sufficient |
|
|
alignment. Thus, we don't handle those cases here. */ |
|
|
@@ -3042,7 +3050,7 @@ s_ccs_ref (int unused ATTRIBUTE_UNUSED) |
|
|
} |
|
|
|
|
|
/* If name is not NULL, then it is used for marking the beginning of a |
|
|
- function, wherease if it is NULL then it means the function end. */ |
|
|
+ function, whereas if it is NULL then it means the function end. */ |
|
|
static void |
|
|
asmfunc_debug (const char * name) |
|
|
{ |
|
|
@@ -3375,7 +3383,7 @@ tc_start_label_without_colon (void) |
|
|
} |
|
|
|
|
|
/* Can't use symbol_new here, so have to create a symbol and then at |
|
|
- a later date assign it a value. Thats what these functions do. */ |
|
|
+ a later date assign it a value. That's what these functions do. */ |
|
|
|
|
|
static void |
|
|
symbol_locate (symbolS * symbolP, |
|
|
@@ -4964,9 +4972,13 @@ parse_ifimm_zero (char **in) |
|
|
int error_code; |
|
|
|
|
|
if (!is_immediate_prefix (**in)) |
|
|
- return FALSE; |
|
|
- |
|
|
- ++*in; |
|
|
+ { |
|
|
+ /* In unified syntax, all prefixes are optional. */ |
|
|
+ if (!unified_syntax) |
|
|
+ return FALSE; |
|
|
+ } |
|
|
+ else |
|
|
+ ++*in; |
|
|
|
|
|
/* Accept #0x0 as a synonym for #0. */ |
|
|
if (strncmp (*in, "0x", 2) == 0) |
|
|
@@ -6530,6 +6542,8 @@ enum operand_parse_code |
|
|
OP_EXPi, /* same, with optional immediate prefix */ |
|
|
OP_EXPr, /* same, with optional relocation suffix */ |
|
|
OP_HALF, /* 0 .. 65535 or low/high reloc. */ |
|
|
+ OP_IROT1, /* VCADD rotate immediate: 90, 270. */ |
|
|
+ OP_IROT2, /* VCMLA rotate immediate: 0, 90, 180, 270. */ |
|
|
|
|
|
OP_CPSF, /* CPS flags */ |
|
|
OP_ENDI, /* Endianness specifier */ |
|
|
@@ -6541,7 +6555,7 @@ enum operand_parse_code |
|
|
OP_APSR_RR, /* ARM register or "APSR_nzcv". */ |
|
|
|
|
|
OP_RRnpc_I0, /* ARM register or literal 0 */ |
|
|
- OP_RR_EXr, /* ARM register or expression with opt. reloc suff. */ |
|
|
+ OP_RR_EXr, /* ARM register or expression with opt. reloc stuff. */ |
|
|
OP_RR_EXi, /* ARM register or expression with imm prefix */ |
|
|
OP_RF_IF, /* FPA register or immediate */ |
|
|
OP_RIWR_RIWC, /* iWMMXt R or C reg */ |
|
|
@@ -7178,8 +7192,14 @@ parse_operands (char *str, const unsigne |
|
|
{ |
|
|
if (inst.operands[i].reg == REG_PC) |
|
|
inst.error = BAD_PC; |
|
|
- else if (inst.operands[i].reg == REG_SP) |
|
|
- inst.error = BAD_SP; |
|
|
+ else if (inst.operands[i].reg == REG_SP |
|
|
+ /* The restriction on Rd/Rt/Rt2 on Thumb mode has been |
|
|
+ relaxed since ARMv8-A. */ |
|
|
+ && !ARM_CPU_HAS_FEATURE (cpu_variant, arm_ext_v8)) |
|
|
+ { |
|
|
+ gas_assert (thumb); |
|
|
+ inst.error = BAD_SP; |
|
|
+ } |
|
|
} |
|
|
break; |
|
|
|
|
|
@@ -7277,14 +7297,23 @@ parse_operands (char *str, const unsigne |
|
|
|
|
|
/* Reject "bad registers" for Thumb-2 instructions. Many Thumb-2 |
|
|
instructions are unpredictable if these registers are used. This |
|
|
- is the BadReg predicate in ARM's Thumb-2 documentation. */ |
|
|
-#define reject_bad_reg(reg) \ |
|
|
- do \ |
|
|
- if (reg == REG_SP || reg == REG_PC) \ |
|
|
- { \ |
|
|
- inst.error = (reg == REG_SP) ? BAD_SP : BAD_PC; \ |
|
|
- return; \ |
|
|
- } \ |
|
|
+ is the BadReg predicate in ARM's Thumb-2 documentation. |
|
|
+ |
|
|
+ Before ARMv8-A, REG_PC and REG_SP were not allowed in quite a few |
|
|
+ places, while the restriction on REG_SP was relaxed since ARMv8-A. */ |
|
|
+#define reject_bad_reg(reg) \ |
|
|
+ do \ |
|
|
+ if (reg == REG_PC) \ |
|
|
+ { \ |
|
|
+ inst.error = BAD_PC; \ |
|
|
+ return; \ |
|
|
+ } \ |
|
|
+ else if (reg == REG_SP \ |
|
|
+ && !ARM_CPU_HAS_FEATURE (cpu_variant, arm_ext_v8)) \ |
|
|
+ { \ |
|
|
+ inst.error = BAD_SP; \ |
|
|
+ return; \ |
|
|
+ } \ |
|
|
while (0) |
|
|
|
|
|
/* If REG is R13 (the stack pointer), warn that its use is |
|
|
@@ -7303,7 +7332,7 @@ parse_operands (char *str, const unsigne |
|
|
|
|
|
The only binary encoding difference is the Coprocessor number. Coprocessor |
|
|
9 is used for half-precision calculations or conversions. The format of the |
|
|
- instruction is the same as the equivalent Coprocessor 10 instuction that |
|
|
+ instruction is the same as the equivalent Coprocessor 10 instruction that |
|
|
exists for Single-Precision operation. */ |
|
|
|
|
|
static void |
|
|
@@ -7426,6 +7455,24 @@ encode_arm_vfp_reg (int reg, enum vfp_re |
|
|
static void |
|
|
encode_arm_shift (int i) |
|
|
{ |
|
|
+ /* Register-shifted register. */ |
|
|
+ if (inst.operands[i].immisreg) |
|
|
+ { |
|
|
+ int op_index; |
|
|
+ for (op_index = 0; op_index <= i; ++op_index) |
|
|
+ { |
|
|
+ /* Check the operand only when it's presented. In pre-UAL syntax, |
|
|
+ if the destination register is the same as the first operand, two |
|
|
+ register form of the instruction can be used. */ |
|
|
+ if (inst.operands[op_index].present && inst.operands[op_index].isreg |
|
|
+ && inst.operands[op_index].reg == REG_PC) |
|
|
+ as_warn (UNPRED_REG ("r15")); |
|
|
+ } |
|
|
+ |
|
|
+ if (inst.operands[i].imm == REG_PC) |
|
|
+ as_warn (UNPRED_REG ("r15")); |
|
|
+ } |
|
|
+ |
|
|
if (inst.operands[i].shift_kind == SHIFT_RRX) |
|
|
inst.instruction |= SHIFT_ROR << 5; |
|
|
else |
|
|
@@ -7930,17 +7977,13 @@ move_or_literal_pool (int i, enum lit_ty |
|
|
{ |
|
|
if (thumb_p) |
|
|
{ |
|
|
- /* This can be encoded only for a low register. */ |
|
|
- if ((v & ~0xFF) == 0 && (inst.operands[i].reg < 8)) |
|
|
- { |
|
|
- /* This can be done with a mov(1) instruction. */ |
|
|
- inst.instruction = T_OPCODE_MOV_I8 | (inst.operands[i].reg << 8); |
|
|
- inst.instruction |= v; |
|
|
- return TRUE; |
|
|
- } |
|
|
+ /* LDR should not use lead in a flag-setting instruction being |
|
|
+ chosen so we do not check whether movs can be used. */ |
|
|
|
|
|
- if (ARM_CPU_HAS_FEATURE (cpu_variant, arm_ext_v6t2) |
|
|
+ if ((ARM_CPU_HAS_FEATURE (cpu_variant, arm_ext_v6t2) |
|
|
|| ARM_CPU_HAS_FEATURE (cpu_variant, arm_ext_v6t2_v8m)) |
|
|
+ && inst.operands[i].reg != 13 |
|
|
+ && inst.operands[i].reg != 15) |
|
|
{ |
|
|
/* Check if on thumb2 it can be done with a mov.w, mvn or |
|
|
movw instruction. */ |
|
|
@@ -8326,6 +8369,12 @@ do_adr (void) |
|
|
inst.reloc.type = BFD_RELOC_ARM_IMMEDIATE; |
|
|
inst.reloc.pc_rel = 1; |
|
|
inst.reloc.exp.X_add_number -= 8; |
|
|
+ |
|
|
+ if (inst.reloc.exp.X_op == O_symbol |
|
|
+ && inst.reloc.exp.X_add_symbol != NULL |
|
|
+ && S_IS_DEFINED (inst.reloc.exp.X_add_symbol) |
|
|
+ && THUMB_IS_FUNC (inst.reloc.exp.X_add_symbol)) |
|
|
+ inst.reloc.exp.X_add_number += 1; |
|
|
} |
|
|
|
|
|
/* This is a pseudo-op of the form "adrl rd, label" to be converted |
|
|
@@ -8344,6 +8393,12 @@ do_adrl (void) |
|
|
inst.reloc.pc_rel = 1; |
|
|
inst.size = INSN_SIZE * 2; |
|
|
inst.reloc.exp.X_add_number -= 8; |
|
|
+ |
|
|
+ if (inst.reloc.exp.X_op == O_symbol |
|
|
+ && inst.reloc.exp.X_add_symbol != NULL |
|
|
+ && S_IS_DEFINED (inst.reloc.exp.X_add_symbol) |
|
|
+ && THUMB_IS_FUNC (inst.reloc.exp.X_add_symbol)) |
|
|
+ inst.reloc.exp.X_add_number += 1; |
|
|
} |
|
|
|
|
|
static void |
|
|
@@ -8622,7 +8677,7 @@ do_co_reg (void) |
|
|
|| inst.instruction == 0xfe000010) |
|
|
/* MCR, MCR2 */ |
|
|
reject_bad_reg (Rd); |
|
|
- else |
|
|
+ else if (!ARM_CPU_HAS_FEATURE (cpu_variant, arm_ext_v8)) |
|
|
/* MRC, MRC2 */ |
|
|
constraint (Rd == REG_SP, BAD_SP); |
|
|
} |
|
|
@@ -8691,6 +8746,14 @@ do_co_reg2c (void) |
|
|
constraint (Rn == REG_PC, BAD_PC); |
|
|
} |
|
|
|
|
|
+ /* Only check the MRRC{2} variants. */ |
|
|
+ if ((inst.instruction & 0x0FF00000) == 0x0C500000) |
|
|
+ { |
|
|
+ /* If Rd == Rn, error that the operation is |
|
|
+ unpredictable (example MRRC p3,#1,r1,r1,c4). */ |
|
|
+ constraint (Rd == Rn, BAD_OVERLAP); |
|
|
+ } |
|
|
+ |
|
|
inst.instruction |= inst.operands[0].reg << 8; |
|
|
inst.instruction |= inst.operands[1].imm << 4; |
|
|
inst.instruction |= Rd << 12; |
|
|
@@ -8916,7 +8979,7 @@ check_ldr_r15_aligned (void) |
|
|
&& (inst.operands[0].reg == REG_PC |
|
|
&& inst.operands[1].reg == REG_PC |
|
|
&& (inst.reloc.exp.X_add_number & 0x3)), |
|
|
- _("ldr to register 15 must be 4-byte alligned")); |
|
|
+ _("ldr to register 15 must be 4-byte aligned")); |
|
|
} |
|
|
|
|
|
static void |
|
|
@@ -9025,9 +9088,9 @@ do_mov16 (void) |
|
|
|
|
|
top = (inst.instruction & 0x00400000) != 0; |
|
|
constraint (top && inst.reloc.type == BFD_RELOC_ARM_MOVW, |
|
|
- _(":lower16: not allowed this instruction")); |
|
|
+ _(":lower16: not allowed in this instruction")); |
|
|
constraint (!top && inst.reloc.type == BFD_RELOC_ARM_MOVT, |
|
|
- _(":upper16: not allowed instruction")); |
|
|
+ _(":upper16: not allowed in this instruction")); |
|
|
inst.instruction |= inst.operands[0].reg << 12; |
|
|
if (inst.reloc.type == BFD_RELOC_UNUSED) |
|
|
{ |
|
|
@@ -9079,6 +9142,11 @@ do_vmrs (void) |
|
|
return; |
|
|
} |
|
|
|
|
|
+ /* MVFR2 is only valid at ARMv8-A. */ |
|
|
+ if (inst.operands[1].reg == 5) |
|
|
+ constraint (!ARM_CPU_HAS_FEATURE (cpu_variant, fpu_vfp_ext_armv8), |
|
|
+ _(BAD_FPU)); |
|
|
+ |
|
|
/* APSR_ sets isvec. All other refs to PC are illegal. */ |
|
|
if (!inst.operands[0].isvec && Rt == REG_PC) |
|
|
{ |
|
|
@@ -9105,6 +9173,11 @@ do_vmsr (void) |
|
|
return; |
|
|
} |
|
|
|
|
|
+ /* MVFR2 is only valid for ARMv8-A. */ |
|
|
+ if (inst.operands[0].reg == 5) |
|
|
+ constraint (!ARM_CPU_HAS_FEATURE (cpu_variant, fpu_vfp_ext_armv8), |
|
|
+ _(BAD_FPU)); |
|
|
+ |
|
|
/* If we get through parsing the register name, we just insert the number |
|
|
generated into the instruction without further validation. */ |
|
|
inst.instruction |= (inst.operands[0].reg << 16); |
|
|
@@ -10453,7 +10526,7 @@ do_t_add_sub_w (void) |
|
|
} |
|
|
|
|
|
/* Parse an add or subtract instruction. We get here with inst.instruction |
|
|
- equalling any of THUMB_OPCODE_add, adds, sub, or subs. */ |
|
|
+ equaling any of THUMB_OPCODE_add, adds, sub, or subs. */ |
|
|
|
|
|
static void |
|
|
do_t_add_sub (void) |
|
|
@@ -10484,7 +10557,8 @@ do_t_add_sub (void) |
|
|
{ |
|
|
int add; |
|
|
|
|
|
- constraint (Rd == REG_SP && Rs != REG_SP, BAD_SP); |
|
|
+ if (!ARM_CPU_HAS_FEATURE (cpu_variant, arm_ext_v8)) |
|
|
+ constraint (Rd == REG_SP && Rs != REG_SP, BAD_SP); |
|
|
|
|
|
add = (inst.instruction == T_MNEM_add |
|
|
|| inst.instruction == T_MNEM_adds); |
|
|
@@ -10608,7 +10682,8 @@ do_t_add_sub (void) |
|
|
} |
|
|
|
|
|
constraint (Rd == REG_PC, BAD_PC); |
|
|
- constraint (Rd == REG_SP && Rs != REG_SP, BAD_SP); |
|
|
+ if (!ARM_CPU_HAS_FEATURE (cpu_variant, arm_ext_v8)) |
|
|
+ constraint (Rd == REG_SP && Rs != REG_SP, BAD_SP); |
|
|
constraint (Rs == REG_PC, BAD_PC); |
|
|
reject_bad_reg (Rn); |
|
|
|
|
|
@@ -10701,9 +10776,14 @@ do_t_adr (void) |
|
|
inst.reloc.type = BFD_RELOC_ARM_THUMB_ADD; |
|
|
inst.reloc.exp.X_add_number -= 4; /* PC relative adjust. */ |
|
|
inst.reloc.pc_rel = 1; |
|
|
- |
|
|
inst.instruction |= Rd << 4; |
|
|
} |
|
|
+ |
|
|
+ if (inst.reloc.exp.X_op == O_symbol |
|
|
+ && inst.reloc.exp.X_add_symbol != NULL |
|
|
+ && S_IS_DEFINED (inst.reloc.exp.X_add_symbol) |
|
|
+ && THUMB_IS_FUNC (inst.reloc.exp.X_add_symbol)) |
|
|
+ inst.reloc.exp.X_add_number += 1; |
|
|
} |
|
|
|
|
|
/* Arithmetic instructions for which there is just one 16-bit |
|
|
@@ -11856,7 +11936,8 @@ do_t_mov_cmp (void) |
|
|
/* This is mov.w. */ |
|
|
constraint (Rn == REG_PC, BAD_PC); |
|
|
constraint (Rm == REG_PC, BAD_PC); |
|
|
- constraint (Rn == REG_SP && Rm == REG_SP, BAD_SP); |
|
|
+ if (!ARM_CPU_HAS_FEATURE (cpu_variant, arm_ext_v8)) |
|
|
+ constraint (Rn == REG_SP && Rm == REG_SP, BAD_SP); |
|
|
} |
|
|
} |
|
|
else |
|
|
@@ -12082,12 +12163,12 @@ do_t_mov16 (void) |
|
|
top = (inst.instruction & 0x00800000) != 0; |
|
|
if (inst.reloc.type == BFD_RELOC_ARM_MOVW) |
|
|
{ |
|
|
- constraint (top, _(":lower16: not allowed this instruction")); |
|
|
+ constraint (top, _(":lower16: not allowed in this instruction")); |
|
|
inst.reloc.type = BFD_RELOC_ARM_THUMB_MOVW; |
|
|
} |
|
|
else if (inst.reloc.type == BFD_RELOC_ARM_MOVT) |
|
|
{ |
|
|
- constraint (!top, _(":upper16: not allowed this instruction")); |
|
|
+ constraint (!top, _(":upper16: not allowed in this instruction")); |
|
|
inst.reloc.type = BFD_RELOC_ARM_THUMB_MOVT; |
|
|
} |
|
|
|
|
|
@@ -13049,17 +13130,6 @@ do_t_sxth (void) |
|
|
static void |
|
|
do_t_swi (void) |
|
|
{ |
|
|
- /* We have to do the following check manually as ARM_EXT_OS only applies |
|
|
- to ARM_EXT_V6M. */ |
|
|
- if (ARM_CPU_HAS_FEATURE (cpu_variant, arm_ext_v6m)) |
|
|
- { |
|
|
- if (!ARM_CPU_HAS_FEATURE (cpu_variant, arm_ext_os) |
|
|
- /* This only applies to the v6m howver, not later architectures. */ |
|
|
- && ! ARM_CPU_HAS_FEATURE (cpu_variant, arm_ext_v7)) |
|
|
- as_bad (_("SVC is not permitted on this architecture")); |
|
|
- ARM_MERGE_FEATURE_SETS (thumb_arch_used, thumb_arch_used, arm_ext_os); |
|
|
- } |
|
|
- |
|
|
inst.reloc.type = BFD_RELOC_ARM_SWI; |
|
|
} |
|
|
|
|
|
@@ -13077,7 +13147,8 @@ do_t_tb (void) |
|
|
Rn = inst.operands[0].reg; |
|
|
Rm = inst.operands[0].imm; |
|
|
|
|
|
- constraint (Rn == REG_SP, BAD_SP); |
|
|
+ if (!ARM_CPU_HAS_FEATURE (cpu_variant, arm_ext_v8)) |
|
|
+ constraint (Rn == REG_SP, BAD_SP); |
|
|
reject_bad_reg (Rm); |
|
|
|
|
|
constraint (!half && inst.operands[0].shifted, |
|
|
@@ -13317,6 +13388,8 @@ NEON_ENC_TAB |
|
|
X(3, (D, Q, S), MIXED), \ |
|
|
X(4, (D, D, D, I), DOUBLE), \ |
|
|
X(4, (Q, Q, Q, I), QUAD), \ |
|
|
+ X(4, (D, D, S, I), DOUBLE), \ |
|
|
+ X(4, (Q, Q, S, I), QUAD), \ |
|
|
X(2, (F, F), SINGLE), \ |
|
|
X(3, (F, F, F), SINGLE), \ |
|
|
X(2, (F, I), SINGLE), \ |
|
|
@@ -14390,6 +14463,11 @@ static void |
|
|
do_vfp_nsyn_push (void) |
|
|
{ |
|
|
nsyn_insert_sp (); |
|
|
+ |
|
|
+ constraint (inst.operands[1].imm < 1 || inst.operands[1].imm > 16, |
|
|
+ _("register list must contain at least 1 and at most 16 " |
|
|
+ "registers")); |
|
|
+ |
|
|
if (inst.operands[1].issingle) |
|
|
do_vfp_nsyn_opcode ("fstmdbs"); |
|
|
else |
|
|
@@ -14400,6 +14478,11 @@ static void |
|
|
do_vfp_nsyn_pop (void) |
|
|
{ |
|
|
nsyn_insert_sp (); |
|
|
+ |
|
|
+ constraint (inst.operands[1].imm < 1 || inst.operands[1].imm > 16, |
|
|
+ _("register list must contain at least 1 and at most 16 " |
|
|
+ "registers")); |
|
|
+ |
|
|
if (inst.operands[1].issingle) |
|
|
do_vfp_nsyn_opcode ("fldmias"); |
|
|
else |
|
|
@@ -14952,7 +15035,14 @@ do_neon_ceq (void) |
|
|
scalars, which are encoded in 5 bits, M : Rm. |
|
|
For 16-bit scalars, the register is encoded in Rm[2:0] and the index in |
|
|
M:Rm[3], and for 32-bit scalars, the register is encoded in Rm[3:0] and the |
|
|
- index in M. */ |
|
|
+ index in M. |
|
|
+ |
|
|
+ Dot Product instructions are similar to multiply instructions except elsize |
|
|
+ should always be 32. |
|
|
+ |
|
|
+ This function translates SCALAR, which is GAS's internal encoding of indexed |
|
|
+ scalar register, to raw encoding. There is also register and index range |
|
|
+ check based on ELSIZE. */ |
|
|
|
|
|
static unsigned |
|
|
neon_scalar_for_mul (unsigned scalar, unsigned elsize) |
|
|
@@ -17220,6 +17310,153 @@ do_vrintm (void) |
|
|
do_vrint_1 (neon_cvt_mode_m); |
|
|
} |
|
|
|
|
|
+static unsigned |
|
|
+neon_scalar_for_vcmla (unsigned opnd, unsigned elsize) |
|
|
+{ |
|
|
+ unsigned regno = NEON_SCALAR_REG (opnd); |
|
|
+ unsigned elno = NEON_SCALAR_INDEX (opnd); |
|
|
+ |
|
|
+ if (elsize == 16 && elno < 2 && regno < 16) |
|
|
+ return regno | (elno << 4); |
|
|
+ else if (elsize == 32 && elno == 0) |
|
|
+ return regno; |
|
|
+ |
|
|
+ first_error (_("scalar out of range")); |
|
|
+ return 0; |
|
|
+} |
|
|
+ |
|
|
+static void |
|
|
+do_vcmla (void) |
|
|
+{ |
|
|
+ constraint (!ARM_CPU_HAS_FEATURE (cpu_variant, fpu_neon_ext_armv8), |
|
|
+ _(BAD_FPU)); |
|
|
+ constraint (inst.reloc.exp.X_op != O_constant, _("expression too complex")); |
|
|
+ unsigned rot = inst.reloc.exp.X_add_number; |
|
|
+ constraint (rot != 0 && rot != 90 && rot != 180 && rot != 270, |
|
|
+ _("immediate out of range")); |
|
|
+ rot /= 90; |
|
|
+ if (inst.operands[2].isscalar) |
|
|
+ { |
|
|
+ enum neon_shape rs = neon_select_shape (NS_DDSI, NS_QQSI, NS_NULL); |
|
|
+ unsigned size = neon_check_type (3, rs, N_EQK, N_EQK, |
|
|
+ N_KEY | N_F16 | N_F32).size; |
|
|
+ unsigned m = neon_scalar_for_vcmla (inst.operands[2].reg, size); |
|
|
+ inst.is_neon = 1; |
|
|
+ inst.instruction = 0xfe000800; |
|
|
+ inst.instruction |= LOW4 (inst.operands[0].reg) << 12; |
|
|
+ inst.instruction |= HI1 (inst.operands[0].reg) << 22; |
|
|
+ inst.instruction |= LOW4 (inst.operands[1].reg) << 16; |
|
|
+ inst.instruction |= HI1 (inst.operands[1].reg) << 7; |
|
|
+ inst.instruction |= LOW4 (m); |
|
|
+ inst.instruction |= HI1 (m) << 5; |
|
|
+ inst.instruction |= neon_quad (rs) << 6; |
|
|
+ inst.instruction |= rot << 20; |
|
|
+ inst.instruction |= (size == 32) << 23; |
|
|
+ } |
|
|
+ else |
|
|
+ { |
|
|
+ enum neon_shape rs = neon_select_shape (NS_DDDI, NS_QQQI, NS_NULL); |
|
|
+ unsigned size = neon_check_type (3, rs, N_EQK, N_EQK, |
|
|
+ N_KEY | N_F16 | N_F32).size; |
|
|
+ neon_three_same (neon_quad (rs), 0, -1); |
|
|
+ inst.instruction &= 0x00ffffff; /* Undo neon_dp_fixup. */ |
|
|
+ inst.instruction |= 0xfc200800; |
|
|
+ inst.instruction |= rot << 23; |
|
|
+ inst.instruction |= (size == 32) << 20; |
|
|
+ } |
|
|
+} |
|
|
+ |
|
|
+static void |
|
|
+do_vcadd (void) |
|
|
+{ |
|
|
+ constraint (!ARM_CPU_HAS_FEATURE (cpu_variant, fpu_neon_ext_armv8), |
|
|
+ _(BAD_FPU)); |
|
|
+ constraint (inst.reloc.exp.X_op != O_constant, _("expression too complex")); |
|
|
+ unsigned rot = inst.reloc.exp.X_add_number; |
|
|
+ constraint (rot != 90 && rot != 270, _("immediate out of range")); |
|
|
+ enum neon_shape rs = neon_select_shape (NS_DDDI, NS_QQQI, NS_NULL); |
|
|
+ unsigned size = neon_check_type (3, rs, N_EQK, N_EQK, |
|
|
+ N_KEY | N_F16 | N_F32).size; |
|
|
+ neon_three_same (neon_quad (rs), 0, -1); |
|
|
+ inst.instruction &= 0x00ffffff; /* Undo neon_dp_fixup. */ |
|
|
+ inst.instruction |= 0xfc800800; |
|
|
+ inst.instruction |= (rot == 270) << 24; |
|
|
+ inst.instruction |= (size == 32) << 20; |
|
|
+} |
|
|
+ |
|
|
+/* Dot Product instructions encoding support. */ |
|
|
+ |
|
|
+static void |
|
|
+do_neon_dotproduct (int unsigned_p) |
|
|
+{ |
|
|
+ enum neon_shape rs; |
|
|
+ unsigned scalar_oprd2 = 0; |
|
|
+ int high8; |
|
|
+ |
|
|
+ if (inst.cond != COND_ALWAYS) |
|
|
+ as_warn (_("Dot Product instructions cannot be conditional, the behaviour " |
|
|
+ "is UNPREDICTABLE")); |
|
|
+ |
|
|
+ constraint (!ARM_CPU_HAS_FEATURE (cpu_variant, fpu_neon_ext_armv8), |
|
|
+ _(BAD_FPU)); |
|
|
+ |
|
|
+ /* Dot Product instructions are in three-same D/Q register format or the third |
|
|
+ operand can be a scalar index register. */ |
|
|
+ if (inst.operands[2].isscalar) |
|
|
+ { |
|
|
+ scalar_oprd2 = neon_scalar_for_mul (inst.operands[2].reg, 32); |
|
|
+ high8 = 0xfe000000; |
|
|
+ rs = neon_select_shape (NS_DDS, NS_QQS, NS_NULL); |
|
|
+ } |
|
|
+ else |
|
|
+ { |
|
|
+ high8 = 0xfc000000; |
|
|
+ rs = neon_select_shape (NS_DDD, NS_QQQ, NS_NULL); |
|
|
+ } |
|
|
+ |
|
|
+ if (unsigned_p) |
|
|
+ neon_check_type (3, rs, N_EQK, N_EQK, N_KEY | N_U8); |
|
|
+ else |
|
|
+ neon_check_type (3, rs, N_EQK, N_EQK, N_KEY | N_S8); |
|
|
+ |
|
|
+ /* The "U" bit in traditional Three Same encoding is fixed to 0 for Dot |
|
|
+ Product instruction, so we pass 0 as the "ubit" parameter. And the |
|
|
+ "Size" field are fixed to 0x2, so we pass 32 as the "size" parameter. */ |
|
|
+ neon_three_same (neon_quad (rs), 0, 32); |
|
|
+ |
|
|
+ /* Undo neon_dp_fixup. Dot Product instructions are using a slightly |
|
|
+ different NEON three-same encoding. */ |
|
|
+ inst.instruction &= 0x00ffffff; |
|
|
+ inst.instruction |= high8; |
|
|
+ /* Encode 'U' bit which indicates signedness. */ |
|
|
+ inst.instruction |= (unsigned_p ? 1 : 0) << 4; |
|
|
+ /* Re-encode operand2 if it's indexed scalar operand. What has been encoded |
|
|
+ from inst.operand[2].reg in neon_three_same is GAS's internal encoding, not |
|
|
+ the instruction encoding. */ |
|
|
+ if (inst.operands[2].isscalar) |
|
|
+ { |
|
|
+ inst.instruction &= 0xffffffd0; |
|
|
+ inst.instruction |= LOW4 (scalar_oprd2); |
|
|
+ inst.instruction |= HI1 (scalar_oprd2) << 5; |
|
|
+ } |
|
|
+} |
|
|
+ |
|
|
+/* Dot Product instructions for signed integer. */ |
|
|
+ |
|
|
+static void |
|
|
+do_neon_dotproduct_s (void) |
|
|
+{ |
|
|
+ return do_neon_dotproduct (0); |
|
|
+} |
|
|
+ |
|
|
+/* Dot Product instructions for unsigned integer. */ |
|
|
+ |
|
|
+static void |
|
|
+do_neon_dotproduct_u (void) |
|
|
+{ |
|
|
+ return do_neon_dotproduct (1); |
|
|
+} |
|
|
+ |
|
|
/* Crypto v1 instructions. */ |
|
|
static void |
|
|
do_crypto_2op_1 (unsigned elttype, int op) |
|
|
@@ -17401,6 +17638,16 @@ do_crc32cw (void) |
|
|
do_crc32_1 (1, 2); |
|
|
} |
|
|
|
|
|
+static void |
|
|
+do_vjcvt (void) |
|
|
+{ |
|
|
+ constraint (!ARM_CPU_HAS_FEATURE (cpu_variant, fpu_vfp_ext_armv8), |
|
|
+ _(BAD_FPU)); |
|
|
+ neon_check_type (2, NS_FD, N_S32, N_F64); |
|
|
+ do_vfp_sp_dp_cvt (); |
|
|
+ do_vfp_cond_or_thumb (); |
|
|
+} |
|
|
+ |
|
|
|
|
|
/* Overall per-instruction processing. */ |
|
|
|
|
|
@@ -17755,7 +18002,7 @@ opcode_lookup (char **str) |
|
|
case OT_odd_infix_unc: |
|
|
if (!unified_syntax) |
|
|
return 0; |
|
|
- /* else fall through */ |
|
|
+ /* Fall through. */ |
|
|
|
|
|
case OT_csuffix: |
|
|
case OT_csuffixF: |
|
|
@@ -17878,7 +18125,7 @@ now_it_add_mask (int cond) |
|
|
set_it_insn_type_last () ditto |
|
|
in_it_block () ditto |
|
|
it_fsm_post_encode () from md_assemble () |
|
|
- force_automatic_it_block_close () from label habdling functions |
|
|
+ force_automatic_it_block_close () from label handling functions |
|
|
|
|
|
Rationale: |
|
|
1) md_assemble () calls it_fsm_pre_encode () before calling tencode (), |
|
|
@@ -17911,7 +18158,7 @@ now_it_add_mask (int cond) |
|
|
for covering other cases. |
|
|
|
|
|
Calling handle_it_state () may not transition the IT block state to |
|
|
- OUTSIDE_IT_BLOCK immediatelly, since the (current) state could be |
|
|
+ OUTSIDE_IT_BLOCK immediately, since the (current) state could be |
|
|
still queried. Instead, if the FSM determines that the state should |
|
|
be transitioned to OUTSIDE_IT_BLOCK, a flag is marked to be closed |
|
|
after the tencode () function: that's what it_fsm_post_encode () does. |
|
|
@@ -18002,7 +18249,7 @@ handle_it_state (void) |
|
|
switch (inst.it_insn_type) |
|
|
{ |
|
|
case OUTSIDE_IT_INSN: |
|
|
- /* The closure of the block shall happen immediatelly, |
|
|
+ /* The closure of the block shall happen immediately, |
|
|
so any in_it_block () call reports the block as closed. */ |
|
|
force_automatic_it_block_close (); |
|
|
break; |
|
|
@@ -18236,6 +18483,13 @@ t32_insn_ok (arm_feature_set arch, const |
|
|
&& opcode->tencode == do_t_branch) |
|
|
return TRUE; |
|
|
|
|
|
+ /* MOV accepts T1/T3 encodings under Baseline, T3 encoding is 32bit. */ |
|
|
+ if (ARM_CPU_HAS_FEATURE (arch, arm_ext_v8m) |
|
|
+ && opcode->tencode == do_t_mov_cmp |
|
|
+ /* Make sure CMP instruction is not affected. */ |
|
|
+ && opcode->aencode == do_mov) |
|
|
+ return TRUE; |
|
|
+ |
|
|
/* Wide instruction variants of all instructions with narrow *and* wide |
|
|
variants become available with ARMv6t2. Other opcodes are either |
|
|
narrow-only or wide-only and are thus available if OPCODE is valid. */ |
|
|
@@ -18296,7 +18550,10 @@ md_assemble (char *str) |
|
|
|| (thumb_mode == 1 |
|
|
&& !ARM_CPU_HAS_FEATURE (variant, *opcode->tvariant))) |
|
|
{ |
|
|
- as_bad (_("selected processor does not support `%s' in Thumb mode"), str); |
|
|
+ if (opcode->tencode == do_t_swi) |
|
|
+ as_bad (_("SVC is not permitted on this architecture")); |
|
|
+ else |
|
|
+ as_bad (_("selected processor does not support `%s' in Thumb mode"), str); |
|
|
return; |
|
|
} |
|
|
if (inst.cond != COND_ALWAYS && !unified_syntax |
|
|
@@ -18663,6 +18920,7 @@ static const struct reg_entry reg_names[ |
|
|
REGDEF(FPINST,9,VFC), REGDEF(FPINST2,10,VFC), |
|
|
REGDEF(mvfr0,7,VFC), REGDEF(mvfr1,6,VFC), |
|
|
REGDEF(MVFR0,7,VFC), REGDEF(MVFR1,6,VFC), |
|
|
+ REGDEF(mvfr2,5,VFC), REGDEF(MVFR2,5,VFC), |
|
|
|
|
|
/* Maverick DSP coprocessor registers. */ |
|
|
REGSET(mvf,MVF), REGSET(mvd,MVD), REGSET(mvfx,MVFX), REGSET(mvdx,MVDX), |
|
|
@@ -18780,24 +19038,32 @@ static const struct asm_psr psrs[] = |
|
|
/* Table of V7M psr names. */ |
|
|
static const struct asm_psr v7m_psrs[] = |
|
|
{ |
|
|
- {"apsr", 0 }, {"APSR", 0 }, |
|
|
- {"iapsr", 1 }, {"IAPSR", 1 }, |
|
|
- {"eapsr", 2 }, {"EAPSR", 2 }, |
|
|
- {"psr", 3 }, {"PSR", 3 }, |
|
|
- {"xpsr", 3 }, {"XPSR", 3 }, {"xPSR", 3 }, |
|
|
- {"ipsr", 5 }, {"IPSR", 5 }, |
|
|
- {"epsr", 6 }, {"EPSR", 6 }, |
|
|
- {"iepsr", 7 }, {"IEPSR", 7 }, |
|
|
- {"msp", 8 }, {"MSP", 8 }, {"msp_s", 8 }, {"MSP_S", 8 }, |
|
|
- {"psp", 9 }, {"PSP", 9 }, {"psp_s", 9 }, {"PSP_S", 9 }, |
|
|
- {"primask", 16}, {"PRIMASK", 16}, |
|
|
- {"basepri", 17}, {"BASEPRI", 17}, |
|
|
- {"basepri_max", 18}, {"BASEPRI_MAX", 18}, |
|
|
- {"basepri_max", 18}, {"BASEPRI_MASK", 18}, /* Typo, preserved for backwards compatibility. */ |
|
|
- {"faultmask", 19}, {"FAULTMASK", 19}, |
|
|
- {"control", 20}, {"CONTROL", 20}, |
|
|
- {"msp_ns", 0x88}, {"MSP_NS", 0x88}, |
|
|
- {"psp_ns", 0x89}, {"PSP_NS", 0x89} |
|
|
+ {"apsr", 0x0 }, {"APSR", 0x0 }, |
|
|
+ {"iapsr", 0x1 }, {"IAPSR", 0x1 }, |
|
|
+ {"eapsr", 0x2 }, {"EAPSR", 0x2 }, |
|
|
+ {"psr", 0x3 }, {"PSR", 0x3 }, |
|
|
+ {"xpsr", 0x3 }, {"XPSR", 0x3 }, {"xPSR", 3 }, |
|
|
+ {"ipsr", 0x5 }, {"IPSR", 0x5 }, |
|
|
+ {"epsr", 0x6 }, {"EPSR", 0x6 }, |
|
|
+ {"iepsr", 0x7 }, {"IEPSR", 0x7 }, |
|
|
+ {"msp", 0x8 }, {"MSP", 0x8 }, |
|
|
+ {"psp", 0x9 }, {"PSP", 0x9 }, |
|
|
+ {"msplim", 0xa }, {"MSPLIM", 0xa }, |
|
|
+ {"psplim", 0xb }, {"PSPLIM", 0xb }, |
|
|
+ {"primask", 0x10}, {"PRIMASK", 0x10}, |
|
|
+ {"basepri", 0x11}, {"BASEPRI", 0x11}, |
|
|
+ {"basepri_max", 0x12}, {"BASEPRI_MAX", 0x12}, |
|
|
+ {"faultmask", 0x13}, {"FAULTMASK", 0x13}, |
|
|
+ {"control", 0x14}, {"CONTROL", 0x14}, |
|
|
+ {"msp_ns", 0x88}, {"MSP_NS", 0x88}, |
|
|
+ {"psp_ns", 0x89}, {"PSP_NS", 0x89}, |
|
|
+ {"msplim_ns", 0x8a}, {"MSPLIM_NS", 0x8a}, |
|
|
+ {"psplim_ns", 0x8b}, {"PSPLIM_NS", 0x8b}, |
|
|
+ {"primask_ns", 0x90}, {"PRIMASK_NS", 0x90}, |
|
|
+ {"basepri_ns", 0x91}, {"BASEPRI_NS", 0x91}, |
|
|
+ {"faultmask_ns", 0x93}, {"FAULTMASK_NS", 0x93}, |
|
|
+ {"control_ns", 0x94}, {"CONTROL_NS", 0x94}, |
|
|
+ {"sp_ns", 0x98}, {"SP_NS", 0x98 } |
|
|
}; |
|
|
|
|
|
/* Table of all shift-in-operand names. */ |
|
|
@@ -19112,8 +19378,6 @@ static const struct asm_opcode insns[] = |
|
|
tC3("ldmia", 8900000, _ldmia, 2, (RRw, REGLST), ldmstm, t_ldmstm), |
|
|
tC3("ldmfd", 8900000, _ldmia, 2, (RRw, REGLST), ldmstm, t_ldmstm), |
|
|
|
|
|
- TCE("swi", f000000, df00, 1, (EXPi), swi, t_swi), |
|
|
- TCE("svc", f000000, df00, 1, (EXPi), swi, t_swi), |
|
|
tCE("b", a000000, _b, 1, (EXPr), branch, t_branch), |
|
|
TCE("bl", b000000, f000f800, 1, (EXPr), bl, t_branch23), |
|
|
|
|
|
@@ -19142,6 +19406,12 @@ static const struct asm_opcode insns[] = |
|
|
TC3("rsbs", 0700000, ebd00000, 3, (RR, oRR, SH), arit, t_rsb), |
|
|
|
|
|
#undef THUMB_VARIANT |
|
|
+#define THUMB_VARIANT & arm_ext_os |
|
|
+ |
|
|
+ TCE("swi", f000000, df00, 1, (EXPi), swi, t_swi), |
|
|
+ TCE("svc", f000000, df00, 1, (EXPi), swi, t_swi), |
|
|
+ |
|
|
+#undef THUMB_VARIANT |
|
|
#define THUMB_VARIANT & arm_ext_v6 |
|
|
|
|
|
TCE("cpy", 1a00000, 4600, 2, (RR, RR), rd_rm, t_cpy), |
|
|
@@ -19729,6 +19999,21 @@ static const struct asm_opcode insns[] = |
|
|
TUE ("esb", 320f010, f3af8010, 0, (), noargs, noargs), |
|
|
|
|
|
#undef ARM_VARIANT |
|
|
+#define ARM_VARIANT & arm_ext_v8_3 |
|
|
+#undef THUMB_VARIANT |
|
|
+#define THUMB_VARIANT & arm_ext_v8_3 |
|
|
+ NCE (vjcvt, eb90bc0, 2, (RVS, RVD), vjcvt), |
|
|
+ NUF (vcmla, 0, 4, (RNDQ, RNDQ, RNDQ_RNSC, EXPi), vcmla), |
|
|
+ NUF (vcadd, 0, 4, (RNDQ, RNDQ, RNDQ, EXPi), vcadd), |
|
|
+ |
|
|
+#undef ARM_VARIANT |
|
|
+#define ARM_VARIANT & fpu_neon_ext_dotprod |
|
|
+#undef THUMB_VARIANT |
|
|
+#define THUMB_VARIANT & fpu_neon_ext_dotprod |
|
|
+ NUF (vsdot, d00, 3, (RNDQ, RNDQ, RNDQ_RNSC), neon_dotproduct_s), |
|
|
+ NUF (vudot, d00, 3, (RNDQ, RNDQ, RNDQ_RNSC), neon_dotproduct_u), |
|
|
+ |
|
|
+#undef ARM_VARIANT |
|
|
#define ARM_VARIANT & fpu_fpa_ext_v1 /* Core FPA instruction set (V1). */ |
|
|
#undef THUMB_VARIANT |
|
|
#define THUMB_VARIANT NULL |
|
|
@@ -21706,7 +21991,7 @@ arm_frag_align_code (int n, int max) |
|
|
Note - despite the name this initialisation is not done when the frag |
|
|
is created, but only when its type is assigned. A frag can be created |
|
|
and used a long time before its type is set, so beware of assuming that |
|
|
- this initialisationis performed first. */ |
|
|
+ this initialisation is performed first. */ |
|
|
|
|
|
#ifndef OBJ_ELF |
|
|
void |
|
|
@@ -21720,7 +22005,7 @@ arm_init_frag (fragS * fragP, int max_ch |
|
|
void |
|
|
arm_init_frag (fragS * fragP, int max_chars) |
|
|
{ |
|
|
- int frag_thumb_mode; |
|
|
+ bfd_boolean frag_thumb_mode; |
|
|
|
|
|
/* If the current ARM vs THUMB mode has not already |
|
|
been recorded into this frag then do so now. */ |
|
|
@@ -22731,6 +23016,23 @@ md_apply_fix (fixS * fixP, |
|
|
changing the opcode. */ |
|
|
if (newimm == (unsigned int) FAIL) |
|
|
newimm = negate_data_op (&temp, value); |
|
|
+ /* MOV accepts both ARM modified immediate (A1 encoding) and |
|
|
+ UINT16 (A2 encoding) when possible, MOVW only accepts UINT16. |
|
|
+ When disassembling, MOV is preferred when there is no encoding |
|
|
+ overlap. */ |
|
|
+ if (newimm == (unsigned int) FAIL |
|
|
+ && ((temp >> DATA_OP_SHIFT) & 0xf) == OPCODE_MOV |
|
|
+ && ARM_CPU_HAS_FEATURE (cpu_variant, arm_ext_v6t2) |
|
|
+ && !((temp >> SBIT_SHIFT) & 0x1) |
|
|
+ && value >= 0 && value <= 0xffff) |
|
|
+ { |
|
|
+ /* Clear bits[23:20] to change encoding from A1 to A2. */ |
|
|
+ temp &= 0xff0fffff; |
|
|
+ /* Encoding high 4bits imm. Code below will encode the remaining |
|
|
+ low 12bits. */ |
|
|
+ temp |= (value & 0x0000f000) << 4; |
|
|
+ newimm = value & 0x00000fff; |
|
|
+ } |
|
|
} |
|
|
|
|
|
if (newimm == (unsigned int) FAIL) |
|
|
@@ -22816,6 +23118,7 @@ md_apply_fix (fixS * fixP, |
|
|
case BFD_RELOC_ARM_OFFSET_IMM: |
|
|
if (!fixP->fx_done && seg->use_rela_p) |
|
|
value = 0; |
|
|
+ /* Fall through. */ |
|
|
|
|
|
case BFD_RELOC_ARM_LITERAL: |
|
|
sign = value > 0; |
|
|
@@ -23046,32 +23349,59 @@ md_apply_fix (fixS * fixP, |
|
|
newval |= md_chars_to_number (buf+2, THUMB_SIZE); |
|
|
|
|
|
newimm = FAIL; |
|
|
- if (fixP->fx_r_type == BFD_RELOC_ARM_T32_IMMEDIATE |
|
|
+ if ((fixP->fx_r_type == BFD_RELOC_ARM_T32_IMMEDIATE |
|
|
+ /* ARMv8-M Baseline MOV will reach here, but it doesn't support |
|
|
+ Thumb2 modified immediate encoding (T2). */ |
|
|
+ && ARM_CPU_HAS_FEATURE (cpu_variant, arm_ext_v6t2)) |
|
|
|| fixP->fx_r_type == BFD_RELOC_ARM_T32_ADD_IMM) |
|
|
{ |
|
|
newimm = encode_thumb32_immediate (value); |
|
|
if (newimm == (unsigned int) FAIL) |
|
|
newimm = thumb32_negate_data_op (&newval, value); |
|
|
} |
|
|
- if (fixP->fx_r_type != BFD_RELOC_ARM_T32_IMMEDIATE |
|
|
- && newimm == (unsigned int) FAIL) |
|
|
+ if (newimm == (unsigned int) FAIL) |
|
|
{ |
|
|
- /* Turn add/sum into addw/subw. */ |
|
|
- if (fixP->fx_r_type == BFD_RELOC_ARM_T32_ADD_IMM) |
|
|
- newval = (newval & 0xfeffffff) | 0x02000000; |
|
|
- /* No flat 12-bit imm encoding for addsw/subsw. */ |
|
|
- if ((newval & 0x00100000) == 0) |
|
|
+ if (fixP->fx_r_type != BFD_RELOC_ARM_T32_IMMEDIATE) |
|
|
{ |
|
|
- /* 12 bit immediate for addw/subw. */ |
|
|
- if (value < 0) |
|
|
+ /* Turn add/sum into addw/subw. */ |
|
|
+ if (fixP->fx_r_type == BFD_RELOC_ARM_T32_ADD_IMM) |
|
|
+ newval = (newval & 0xfeffffff) | 0x02000000; |
|
|
+ /* No flat 12-bit imm encoding for addsw/subsw. */ |
|
|
+ if ((newval & 0x00100000) == 0) |
|
|
{ |
|
|
- value = -value; |
|
|
- newval ^= 0x00a00000; |
|
|
+ /* 12 bit immediate for addw/subw. */ |
|
|
+ if (value < 0) |
|
|
+ { |
|
|
+ value = -value; |
|
|
+ newval ^= 0x00a00000; |
|
|
+ } |
|
|
+ if (value > 0xfff) |
|
|
+ newimm = (unsigned int) FAIL; |
|
|
+ else |
|
|
+ newimm = value; |
|
|
+ } |
|
|
+ } |
|
|
+ else |
|
|
+ { |
|
|
+ /* MOV accepts both Thumb2 modified immediate (T2 encoding) and |
|
|
+ UINT16 (T3 encoding), MOVW only accepts UINT16. When |
|
|
+ disassembling, MOV is preferred when there is no encoding |
|
|
+ overlap. |
|
|
+ NOTE: MOV is using ORR opcode under Thumb 2 mode. */ |
|
|
+ if (((newval >> T2_DATA_OP_SHIFT) & 0xf) == T2_OPCODE_ORR |
|
|
+ && ARM_CPU_HAS_FEATURE (cpu_variant, arm_ext_v6t2_v8m) |
|
|
+ && !((newval >> T2_SBIT_SHIFT) & 0x1) |
|
|
+ && value >= 0 && value <=0xffff) |
|
|
+ { |
|
|
+ /* Toggle bit[25] to change encoding from T2 to T3. */ |
|
|
+ newval ^= 1 << 25; |
|
|
+ /* Clear bits[19:16]. */ |
|
|
+ newval &= 0xfff0ffff; |
|
|
+ /* Encoding high 4bits imm. Code below will encode the |
|
|
+ remaining low 12bits. */ |
|
|
+ newval |= (value & 0x0000f000) << 4; |
|
|
+ newimm = value & 0x00000fff; |
|
|
} |
|
|
- if (value > 0xfff) |
|
|
- newimm = (unsigned int) FAIL; |
|
|
- else |
|
|
- newimm = value; |
|
|
} |
|
|
} |
|
|
|
|
|
@@ -23174,6 +23504,7 @@ md_apply_fix (fixS * fixP, |
|
|
newval = md_chars_to_number (buf, INSN_SIZE); |
|
|
fixP->fx_done = 0; |
|
|
} |
|
|
+ /* Fall through. */ |
|
|
|
|
|
case BFD_RELOC_ARM_PLT32: |
|
|
#endif |
|
|
@@ -23210,7 +23541,7 @@ md_apply_fix (fixS * fixP, |
|
|
/* We are going to store value (shifted right by two) in the |
|
|
instruction, in a 24 bit, signed field. Bits 26 through 32 either |
|
|
all clear or all set and bit 0 must be clear. For B/BL bit 1 must |
|
|
- also be be clear. */ |
|
|
+ also be clear. */ |
|
|
if (value & temp) |
|
|
as_bad_where (fixP->fx_file, fixP->fx_line, |
|
|
_("misaligned branch destination")); |
|
|
@@ -24066,6 +24397,7 @@ tc_gen_reloc (asection *section, fixS *f |
|
|
code = BFD_RELOC_8_PCREL; |
|
|
break; |
|
|
} |
|
|
+ /* Fall through. */ |
|
|
|
|
|
case BFD_RELOC_16: |
|
|
if (fixp->fx_pcrel) |
|
|
@@ -24073,6 +24405,7 @@ tc_gen_reloc (asection *section, fixS *f |
|
|
code = BFD_RELOC_16_PCREL; |
|
|
break; |
|
|
} |
|
|
+ /* Fall through. */ |
|
|
|
|
|
case BFD_RELOC_32: |
|
|
if (fixp->fx_pcrel) |
|
|
@@ -24080,6 +24413,7 @@ tc_gen_reloc (asection *section, fixS *f |
|
|
code = BFD_RELOC_32_PCREL; |
|
|
break; |
|
|
} |
|
|
+ /* Fall through. */ |
|
|
|
|
|
case BFD_RELOC_ARM_MOVW: |
|
|
if (fixp->fx_pcrel) |
|
|
@@ -24087,6 +24421,7 @@ tc_gen_reloc (asection *section, fixS *f |
|
|
code = BFD_RELOC_ARM_MOVW_PCREL; |
|
|
break; |
|
|
} |
|
|
+ /* Fall through. */ |
|
|
|
|
|
case BFD_RELOC_ARM_MOVT: |
|
|
if (fixp->fx_pcrel) |
|
|
@@ -24094,6 +24429,7 @@ tc_gen_reloc (asection *section, fixS *f |
|
|
code = BFD_RELOC_ARM_MOVT_PCREL; |
|
|
break; |
|
|
} |
|
|
+ /* Fall through. */ |
|
|
|
|
|
case BFD_RELOC_ARM_THUMB_MOVW: |
|
|
if (fixp->fx_pcrel) |
|
|
@@ -24101,6 +24437,7 @@ tc_gen_reloc (asection *section, fixS *f |
|
|
code = BFD_RELOC_ARM_THUMB_MOVW_PCREL; |
|
|
break; |
|
|
} |
|
|
+ /* Fall through. */ |
|
|
|
|
|
case BFD_RELOC_ARM_THUMB_MOVT: |
|
|
if (fixp->fx_pcrel) |
|
|
@@ -24108,6 +24445,7 @@ tc_gen_reloc (asection *section, fixS *f |
|
|
code = BFD_RELOC_ARM_THUMB_MOVT_PCREL; |
|
|
break; |
|
|
} |
|
|
+ /* Fall through. */ |
|
|
|
|
|
case BFD_RELOC_NONE: |
|
|
case BFD_RELOC_ARM_PCREL_BRANCH: |
|
|
@@ -24791,7 +25129,12 @@ md_begin (void) |
|
|
mcpu_cpu_opt = legacy_cpu; |
|
|
} |
|
|
else if (!mcpu_cpu_opt) |
|
|
- mcpu_cpu_opt = march_cpu_opt; |
|
|
+ { |
|
|
+ mcpu_cpu_opt = march_cpu_opt; |
|
|
+ dyn_mcpu_ext_opt = dyn_march_ext_opt; |
|
|
+ /* Avoid double free in arm_md_end. */ |
|
|
+ dyn_march_ext_opt = NULL; |
|
|
+ } |
|
|
|
|
|
if (legacy_fpu) |
|
|
{ |
|
|
@@ -24831,16 +25174,22 @@ md_begin (void) |
|
|
mcpu_cpu_opt = &cpu_default; |
|
|
selected_cpu = cpu_default; |
|
|
} |
|
|
- else if (no_cpu_selected ()) |
|
|
- selected_cpu = cpu_default; |
|
|
+ else if (dyn_mcpu_ext_opt) |
|
|
+ ARM_MERGE_FEATURE_SETS (selected_cpu, *mcpu_cpu_opt, *dyn_mcpu_ext_opt); |
|
|
+ else |
|
|
+ selected_cpu = *mcpu_cpu_opt; |
|
|
#else |
|
|
- if (mcpu_cpu_opt) |
|
|
+ if (mcpu_cpu_opt && dyn_mcpu_ext_opt) |
|
|
+ ARM_MERGE_FEATURE_SETS (selected_cpu, *mcpu_cpu_opt, *dyn_mcpu_ext_opt); |
|
|
+ else if (mcpu_cpu_opt) |
|
|
selected_cpu = *mcpu_cpu_opt; |
|
|
else |
|
|
mcpu_cpu_opt = &arm_arch_any; |
|
|
#endif |
|
|
|
|
|
ARM_MERGE_FEATURE_SETS (cpu_variant, *mcpu_cpu_opt, *mfpu_opt); |
|
|
+ if (dyn_mcpu_ext_opt) |
|
|
+ ARM_MERGE_FEATURE_SETS (cpu_variant, cpu_variant, *dyn_mcpu_ext_opt); |
|
|
|
|
|
autoselect_thumb_from_cpu_variant (); |
|
|
|
|
|
@@ -25215,6 +25564,7 @@ struct arm_cpu_option_table |
|
|
const char *name; |
|
|
size_t name_len; |
|
|
const arm_feature_set value; |
|
|
+ const arm_feature_set ext; |
|
|
/* For some CPUs we assume an FPU unless the user explicitly sets |
|
|
-mfpu=... */ |
|
|
const arm_feature_set default_fpu; |
|
|
@@ -25225,174 +25575,387 @@ struct arm_cpu_option_table |
|
|
|
|
|
/* This list should, at a minimum, contain all the cpu names |
|
|
recognized by GCC. */ |
|
|
-#define ARM_CPU_OPT(N, V, DF, CN) { N, sizeof (N) - 1, V, DF, CN } |
|
|
+#define ARM_CPU_OPT(N, CN, V, E, DF) { N, sizeof (N) - 1, V, E, DF, CN } |
|
|
static const struct arm_cpu_option_table arm_cpus[] = |
|
|
{ |
|
|
- ARM_CPU_OPT ("all", ARM_ANY, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm1", ARM_ARCH_V1, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm2", ARM_ARCH_V2, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm250", ARM_ARCH_V2S, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm3", ARM_ARCH_V2S, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm6", ARM_ARCH_V3, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm60", ARM_ARCH_V3, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm600", ARM_ARCH_V3, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm610", ARM_ARCH_V3, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm620", ARM_ARCH_V3, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm7", ARM_ARCH_V3, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm7m", ARM_ARCH_V3M, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm7d", ARM_ARCH_V3, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm7dm", ARM_ARCH_V3M, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm7di", ARM_ARCH_V3, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm7dmi", ARM_ARCH_V3M, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm70", ARM_ARCH_V3, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm700", ARM_ARCH_V3, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm700i", ARM_ARCH_V3, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm710", ARM_ARCH_V3, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm710t", ARM_ARCH_V4T, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm720", ARM_ARCH_V3, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm720t", ARM_ARCH_V4T, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm740t", ARM_ARCH_V4T, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm710c", ARM_ARCH_V3, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm7100", ARM_ARCH_V3, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm7500", ARM_ARCH_V3, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm7500fe", ARM_ARCH_V3, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm7t", ARM_ARCH_V4T, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm7tdmi", ARM_ARCH_V4T, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm7tdmi-s", ARM_ARCH_V4T, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm8", ARM_ARCH_V4, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm810", ARM_ARCH_V4, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("strongarm", ARM_ARCH_V4, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("strongarm1", ARM_ARCH_V4, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("strongarm110", ARM_ARCH_V4, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("strongarm1100", ARM_ARCH_V4, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("strongarm1110", ARM_ARCH_V4, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm9", ARM_ARCH_V4T, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm920", ARM_ARCH_V4T, FPU_ARCH_FPA, "ARM920T"), |
|
|
- ARM_CPU_OPT ("arm920t", ARM_ARCH_V4T, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm922t", ARM_ARCH_V4T, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm940t", ARM_ARCH_V4T, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("arm9tdmi", ARM_ARCH_V4T, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("fa526", ARM_ARCH_V4, FPU_ARCH_FPA, NULL), |
|
|
- ARM_CPU_OPT ("fa626", ARM_ARCH_V4, FPU_ARCH_FPA, NULL), |
|
|
+ ARM_CPU_OPT ("all", NULL, ARM_ANY, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm1", NULL, ARM_ARCH_V1, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm2", NULL, ARM_ARCH_V2, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm250", NULL, ARM_ARCH_V2S, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm3", NULL, ARM_ARCH_V2S, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm6", NULL, ARM_ARCH_V3, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm60", NULL, ARM_ARCH_V3, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm600", NULL, ARM_ARCH_V3, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm610", NULL, ARM_ARCH_V3, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm620", NULL, ARM_ARCH_V3, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm7", NULL, ARM_ARCH_V3, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm7m", NULL, ARM_ARCH_V3M, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm7d", NULL, ARM_ARCH_V3, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm7dm", NULL, ARM_ARCH_V3M, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm7di", NULL, ARM_ARCH_V3, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm7dmi", NULL, ARM_ARCH_V3M, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm70", NULL, ARM_ARCH_V3, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm700", NULL, ARM_ARCH_V3, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm700i", NULL, ARM_ARCH_V3, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm710", NULL, ARM_ARCH_V3, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm710t", NULL, ARM_ARCH_V4T, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm720", NULL, ARM_ARCH_V3, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm720t", NULL, ARM_ARCH_V4T, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm740t", NULL, ARM_ARCH_V4T, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm710c", NULL, ARM_ARCH_V3, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm7100", NULL, ARM_ARCH_V3, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm7500", NULL, ARM_ARCH_V3, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm7500fe", NULL, ARM_ARCH_V3, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm7t", NULL, ARM_ARCH_V4T, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm7tdmi", NULL, ARM_ARCH_V4T, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm7tdmi-s", NULL, ARM_ARCH_V4T, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm8", NULL, ARM_ARCH_V4, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm810", NULL, ARM_ARCH_V4, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("strongarm", NULL, ARM_ARCH_V4, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("strongarm1", NULL, ARM_ARCH_V4, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("strongarm110", NULL, ARM_ARCH_V4, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("strongarm1100", NULL, ARM_ARCH_V4, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("strongarm1110", NULL, ARM_ARCH_V4, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm9", NULL, ARM_ARCH_V4T, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm920", "ARM920T", ARM_ARCH_V4T, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm920t", NULL, ARM_ARCH_V4T, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm922t", NULL, ARM_ARCH_V4T, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm940t", NULL, ARM_ARCH_V4T, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("arm9tdmi", NULL, ARM_ARCH_V4T, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("fa526", NULL, ARM_ARCH_V4, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ ARM_CPU_OPT ("fa626", NULL, ARM_ARCH_V4, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_FPA), |
|
|
+ |
|
|
/* For V5 or later processors we default to using VFP; but the user |
|
|
should really set the FPU type explicitly. */ |
|
|
- ARM_CPU_OPT ("arm9e-r0", ARM_ARCH_V5TExP, FPU_ARCH_VFP_V2, NULL), |
|
|
- ARM_CPU_OPT ("arm9e", ARM_ARCH_V5TE, FPU_ARCH_VFP_V2, NULL), |
|
|
- ARM_CPU_OPT ("arm926ej", ARM_ARCH_V5TEJ, FPU_ARCH_VFP_V2, "ARM926EJ-S"), |
|
|
- ARM_CPU_OPT ("arm926ejs", ARM_ARCH_V5TEJ, FPU_ARCH_VFP_V2, "ARM926EJ-S"), |
|
|
- ARM_CPU_OPT ("arm926ej-s", ARM_ARCH_V5TEJ, FPU_ARCH_VFP_V2, NULL), |
|
|
- ARM_CPU_OPT ("arm946e-r0", ARM_ARCH_V5TExP, FPU_ARCH_VFP_V2, NULL), |
|
|
- ARM_CPU_OPT ("arm946e", ARM_ARCH_V5TE, FPU_ARCH_VFP_V2, "ARM946E-S"), |
|
|
- ARM_CPU_OPT ("arm946e-s", ARM_ARCH_V5TE, FPU_ARCH_VFP_V2, NULL), |
|
|
- ARM_CPU_OPT ("arm966e-r0", ARM_ARCH_V5TExP, FPU_ARCH_VFP_V2, NULL), |
|
|
- ARM_CPU_OPT ("arm966e", ARM_ARCH_V5TE, FPU_ARCH_VFP_V2, "ARM966E-S"), |
|
|
- ARM_CPU_OPT ("arm966e-s", ARM_ARCH_V5TE, FPU_ARCH_VFP_V2, NULL), |
|
|
- ARM_CPU_OPT ("arm968e-s", ARM_ARCH_V5TE, FPU_ARCH_VFP_V2, NULL), |
|
|
- ARM_CPU_OPT ("arm10t", ARM_ARCH_V5T, FPU_ARCH_VFP_V1, NULL), |
|
|
- ARM_CPU_OPT ("arm10tdmi", ARM_ARCH_V5T, FPU_ARCH_VFP_V1, NULL), |
|
|
- ARM_CPU_OPT ("arm10e", ARM_ARCH_V5TE, FPU_ARCH_VFP_V2, NULL), |
|
|
- ARM_CPU_OPT ("arm1020", ARM_ARCH_V5TE, FPU_ARCH_VFP_V2, "ARM1020E"), |
|
|
- ARM_CPU_OPT ("arm1020t", ARM_ARCH_V5T, FPU_ARCH_VFP_V1, NULL), |
|
|
- ARM_CPU_OPT ("arm1020e", ARM_ARCH_V5TE, FPU_ARCH_VFP_V2, NULL), |
|
|
- ARM_CPU_OPT ("arm1022e", ARM_ARCH_V5TE, FPU_ARCH_VFP_V2, NULL), |
|
|
- ARM_CPU_OPT ("arm1026ejs", ARM_ARCH_V5TEJ, FPU_ARCH_VFP_V2, |
|
|
- "ARM1026EJ-S"), |
|
|
- ARM_CPU_OPT ("arm1026ej-s", ARM_ARCH_V5TEJ, FPU_ARCH_VFP_V2, NULL), |
|
|
- ARM_CPU_OPT ("fa606te", ARM_ARCH_V5TE, FPU_ARCH_VFP_V2, NULL), |
|
|
- ARM_CPU_OPT ("fa616te", ARM_ARCH_V5TE, FPU_ARCH_VFP_V2, NULL), |
|
|
- ARM_CPU_OPT ("fa626te", ARM_ARCH_V5TE, FPU_ARCH_VFP_V2, NULL), |
|
|
- ARM_CPU_OPT ("fmp626", ARM_ARCH_V5TE, FPU_ARCH_VFP_V2, NULL), |
|
|
- ARM_CPU_OPT ("fa726te", ARM_ARCH_V5TE, FPU_ARCH_VFP_V2, NULL), |
|
|
- ARM_CPU_OPT ("arm1136js", ARM_ARCH_V6, FPU_NONE, "ARM1136J-S"), |
|
|
- ARM_CPU_OPT ("arm1136j-s", ARM_ARCH_V6, FPU_NONE, NULL), |
|
|
- ARM_CPU_OPT ("arm1136jfs", ARM_ARCH_V6, FPU_ARCH_VFP_V2, |
|
|
- "ARM1136JF-S"), |
|
|
- ARM_CPU_OPT ("arm1136jf-s", ARM_ARCH_V6, FPU_ARCH_VFP_V2, NULL), |
|
|
- ARM_CPU_OPT ("mpcore", ARM_ARCH_V6K, FPU_ARCH_VFP_V2, "MPCore"), |
|
|
- ARM_CPU_OPT ("mpcorenovfp", ARM_ARCH_V6K, FPU_NONE, "MPCore"), |
|
|
- ARM_CPU_OPT ("arm1156t2-s", ARM_ARCH_V6T2, FPU_NONE, NULL), |
|
|
- ARM_CPU_OPT ("arm1156t2f-s", ARM_ARCH_V6T2, FPU_ARCH_VFP_V2, NULL), |
|
|
- ARM_CPU_OPT ("arm1176jz-s", ARM_ARCH_V6KZ, FPU_NONE, NULL), |
|
|
- ARM_CPU_OPT ("arm1176jzf-s", ARM_ARCH_V6KZ, FPU_ARCH_VFP_V2, NULL), |
|
|
- ARM_CPU_OPT ("cortex-a5", ARM_ARCH_V7A_MP_SEC, |
|
|
- FPU_NONE, "Cortex-A5"), |
|
|
- ARM_CPU_OPT ("cortex-a7", ARM_ARCH_V7VE, FPU_ARCH_NEON_VFP_V4, |
|
|
- "Cortex-A7"), |
|
|
- ARM_CPU_OPT ("cortex-a8", ARM_ARCH_V7A_SEC, |
|
|
- ARM_FEATURE_COPROC (FPU_VFP_V3 |
|
|
- | FPU_NEON_EXT_V1), |
|
|
- "Cortex-A8"), |
|
|
- ARM_CPU_OPT ("cortex-a9", ARM_ARCH_V7A_MP_SEC, |
|
|
- ARM_FEATURE_COPROC (FPU_VFP_V3 |
|
|
- | FPU_NEON_EXT_V1), |
|
|
- "Cortex-A9"), |
|
|
- ARM_CPU_OPT ("cortex-a12", ARM_ARCH_V7VE, FPU_ARCH_NEON_VFP_V4, |
|
|
- "Cortex-A12"), |
|
|
- ARM_CPU_OPT ("cortex-a15", ARM_ARCH_V7VE, FPU_ARCH_NEON_VFP_V4, |
|
|
- "Cortex-A15"), |
|
|
- ARM_CPU_OPT ("cortex-a17", ARM_ARCH_V7VE, FPU_ARCH_NEON_VFP_V4, |
|
|
- "Cortex-A17"), |
|
|
- ARM_CPU_OPT ("cortex-a32", ARM_ARCH_V8A, FPU_ARCH_CRYPTO_NEON_VFP_ARMV8, |
|
|
- "Cortex-A32"), |
|
|
- ARM_CPU_OPT ("cortex-a35", ARM_ARCH_V8A, FPU_ARCH_CRYPTO_NEON_VFP_ARMV8, |
|
|
- "Cortex-A35"), |
|
|
- ARM_CPU_OPT ("cortex-a53", ARM_ARCH_V8A, FPU_ARCH_CRYPTO_NEON_VFP_ARMV8, |
|
|
- "Cortex-A53"), |
|
|
- ARM_CPU_OPT ("cortex-a57", ARM_ARCH_V8A, FPU_ARCH_CRYPTO_NEON_VFP_ARMV8, |
|
|
- "Cortex-A57"), |
|
|
- ARM_CPU_OPT ("cortex-a72", ARM_ARCH_V8A, FPU_ARCH_CRYPTO_NEON_VFP_ARMV8, |
|
|
- "Cortex-A72"), |
|
|
- ARM_CPU_OPT ("cortex-a73", ARM_ARCH_V8A, FPU_ARCH_CRYPTO_NEON_VFP_ARMV8, |
|
|
- "Cortex-A73"), |
|
|
- ARM_CPU_OPT ("cortex-r4", ARM_ARCH_V7R, FPU_NONE, "Cortex-R4"), |
|
|
- ARM_CPU_OPT ("cortex-r4f", ARM_ARCH_V7R, FPU_ARCH_VFP_V3D16, |
|
|
- "Cortex-R4F"), |
|
|
- ARM_CPU_OPT ("cortex-r5", ARM_ARCH_V7R_IDIV, |
|
|
- FPU_NONE, "Cortex-R5"), |
|
|
- ARM_CPU_OPT ("cortex-r7", ARM_ARCH_V7R_IDIV, |
|
|
- FPU_ARCH_VFP_V3D16, |
|
|
- "Cortex-R7"), |
|
|
- ARM_CPU_OPT ("cortex-r8", ARM_ARCH_V7R_IDIV, |
|
|
- FPU_ARCH_VFP_V3D16, |
|
|
- "Cortex-R8"), |
|
|
- ARM_CPU_OPT ("cortex-m7", ARM_ARCH_V7EM, FPU_NONE, "Cortex-M7"), |
|
|
- ARM_CPU_OPT ("cortex-m4", ARM_ARCH_V7EM, FPU_NONE, "Cortex-M4"), |
|
|
- ARM_CPU_OPT ("cortex-m3", ARM_ARCH_V7M, FPU_NONE, "Cortex-M3"), |
|
|
- ARM_CPU_OPT ("cortex-m1", ARM_ARCH_V6SM, FPU_NONE, "Cortex-M1"), |
|
|
- ARM_CPU_OPT ("cortex-m0", ARM_ARCH_V6SM, FPU_NONE, "Cortex-M0"), |
|
|
- ARM_CPU_OPT ("cortex-m0plus", ARM_ARCH_V6SM, FPU_NONE, "Cortex-M0+"), |
|
|
- ARM_CPU_OPT ("exynos-m1", ARM_ARCH_V8A, FPU_ARCH_CRYPTO_NEON_VFP_ARMV8, |
|
|
- "Samsung " \ |
|
|
- "Exynos M1"), |
|
|
- ARM_CPU_OPT ("qdf24xx", ARM_ARCH_V8A, FPU_ARCH_CRYPTO_NEON_VFP_ARMV8, |
|
|
- "Qualcomm " |
|
|
- "QDF24XX"), |
|
|
+ ARM_CPU_OPT ("arm9e-r0", NULL, ARM_ARCH_V5TExP, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V2), |
|
|
+ ARM_CPU_OPT ("arm9e", NULL, ARM_ARCH_V5TE, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V2), |
|
|
+ ARM_CPU_OPT ("arm926ej", "ARM926EJ-S", ARM_ARCH_V5TEJ, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V2), |
|
|
+ ARM_CPU_OPT ("arm926ejs", "ARM926EJ-S", ARM_ARCH_V5TEJ, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V2), |
|
|
+ ARM_CPU_OPT ("arm926ej-s", NULL, ARM_ARCH_V5TEJ, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V2), |
|
|
+ ARM_CPU_OPT ("arm946e-r0", NULL, ARM_ARCH_V5TExP, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V2), |
|
|
+ ARM_CPU_OPT ("arm946e", "ARM946E-S", ARM_ARCH_V5TE, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V2), |
|
|
+ ARM_CPU_OPT ("arm946e-s", NULL, ARM_ARCH_V5TE, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V2), |
|
|
+ ARM_CPU_OPT ("arm966e-r0", NULL, ARM_ARCH_V5TExP, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V2), |
|
|
+ ARM_CPU_OPT ("arm966e", "ARM966E-S", ARM_ARCH_V5TE, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V2), |
|
|
+ ARM_CPU_OPT ("arm966e-s", NULL, ARM_ARCH_V5TE, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V2), |
|
|
+ ARM_CPU_OPT ("arm968e-s", NULL, ARM_ARCH_V5TE, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V2), |
|
|
+ ARM_CPU_OPT ("arm10t", NULL, ARM_ARCH_V5T, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V1), |
|
|
+ ARM_CPU_OPT ("arm10tdmi", NULL, ARM_ARCH_V5T, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V1), |
|
|
+ ARM_CPU_OPT ("arm10e", NULL, ARM_ARCH_V5TE, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V2), |
|
|
+ ARM_CPU_OPT ("arm1020", "ARM1020E", ARM_ARCH_V5TE, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V2), |
|
|
+ ARM_CPU_OPT ("arm1020t", NULL, ARM_ARCH_V5T, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V1), |
|
|
+ ARM_CPU_OPT ("arm1020e", NULL, ARM_ARCH_V5TE, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V2), |
|
|
+ ARM_CPU_OPT ("arm1022e", NULL, ARM_ARCH_V5TE, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V2), |
|
|
+ ARM_CPU_OPT ("arm1026ejs", "ARM1026EJ-S", ARM_ARCH_V5TEJ, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V2), |
|
|
+ ARM_CPU_OPT ("arm1026ej-s", NULL, ARM_ARCH_V5TEJ, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V2), |
|
|
+ ARM_CPU_OPT ("fa606te", NULL, ARM_ARCH_V5TE, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V2), |
|
|
+ ARM_CPU_OPT ("fa616te", NULL, ARM_ARCH_V5TE, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V2), |
|
|
+ ARM_CPU_OPT ("fa626te", NULL, ARM_ARCH_V5TE, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V2), |
|
|
+ ARM_CPU_OPT ("fmp626", NULL, ARM_ARCH_V5TE, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V2), |
|
|
+ ARM_CPU_OPT ("fa726te", NULL, ARM_ARCH_V5TE, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V2), |
|
|
+ ARM_CPU_OPT ("arm1136js", "ARM1136J-S", ARM_ARCH_V6, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_NONE), |
|
|
+ ARM_CPU_OPT ("arm1136j-s", NULL, ARM_ARCH_V6, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_NONE), |
|
|
+ ARM_CPU_OPT ("arm1136jfs", "ARM1136JF-S", ARM_ARCH_V6, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V2), |
|
|
+ ARM_CPU_OPT ("arm1136jf-s", NULL, ARM_ARCH_V6, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V2), |
|
|
+ ARM_CPU_OPT ("mpcore", "MPCore", ARM_ARCH_V6K, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V2), |
|
|
+ ARM_CPU_OPT ("mpcorenovfp", "MPCore", ARM_ARCH_V6K, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_NONE), |
|
|
+ ARM_CPU_OPT ("arm1156t2-s", NULL, ARM_ARCH_V6T2, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_NONE), |
|
|
+ ARM_CPU_OPT ("arm1156t2f-s", NULL, ARM_ARCH_V6T2, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V2), |
|
|
+ ARM_CPU_OPT ("arm1176jz-s", NULL, ARM_ARCH_V6KZ, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_NONE), |
|
|
+ ARM_CPU_OPT ("arm1176jzf-s", NULL, ARM_ARCH_V6KZ, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V2), |
|
|
+ ARM_CPU_OPT ("cortex-a5", "Cortex-A5", ARM_ARCH_V7A, |
|
|
+ ARM_FEATURE_CORE_LOW (ARM_EXT_MP | ARM_EXT_SEC), |
|
|
+ FPU_NONE), |
|
|
+ ARM_CPU_OPT ("cortex-a7", "Cortex-A7", ARM_ARCH_V7VE, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_NEON_VFP_V4), |
|
|
+ ARM_CPU_OPT ("cortex-a8", "Cortex-A8", ARM_ARCH_V7A, |
|
|
+ ARM_FEATURE_CORE_LOW (ARM_EXT_SEC), |
|
|
+ ARM_FEATURE_COPROC (FPU_VFP_V3 | FPU_NEON_EXT_V1)), |
|
|
+ ARM_CPU_OPT ("cortex-a9", "Cortex-A9", ARM_ARCH_V7A, |
|
|
+ ARM_FEATURE_CORE_LOW (ARM_EXT_MP | ARM_EXT_SEC), |
|
|
+ ARM_FEATURE_COPROC (FPU_VFP_V3 | FPU_NEON_EXT_V1)), |
|
|
+ ARM_CPU_OPT ("cortex-a12", "Cortex-A12", ARM_ARCH_V7VE, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_NEON_VFP_V4), |
|
|
+ ARM_CPU_OPT ("cortex-a15", "Cortex-A15", ARM_ARCH_V7VE, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_NEON_VFP_V4), |
|
|
+ ARM_CPU_OPT ("cortex-a17", "Cortex-A17", ARM_ARCH_V7VE, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_NEON_VFP_V4), |
|
|
+ ARM_CPU_OPT ("cortex-a32", "Cortex-A32", ARM_ARCH_V8A, |
|
|
+ ARM_FEATURE_COPROC (CRC_EXT_ARMV8), |
|
|
+ FPU_ARCH_CRYPTO_NEON_VFP_ARMV8), |
|
|
+ ARM_CPU_OPT ("cortex-a35", "Cortex-A35", ARM_ARCH_V8A, |
|
|
+ ARM_FEATURE_COPROC (CRC_EXT_ARMV8), |
|
|
+ FPU_ARCH_CRYPTO_NEON_VFP_ARMV8), |
|
|
+ ARM_CPU_OPT ("cortex-a53", "Cortex-A53", ARM_ARCH_V8A, |
|
|
+ ARM_FEATURE_COPROC (CRC_EXT_ARMV8), |
|
|
+ FPU_ARCH_CRYPTO_NEON_VFP_ARMV8), |
|
|
+ ARM_CPU_OPT ("cortex-a55", "Cortex-A55", ARM_ARCH_V8_2A, |
|
|
+ ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST), |
|
|
+ FPU_ARCH_CRYPTO_NEON_VFP_ARMV8), |
|
|
+ ARM_CPU_OPT ("cortex-a57", "Cortex-A57", ARM_ARCH_V8A, |
|
|
+ ARM_FEATURE_COPROC (CRC_EXT_ARMV8), |
|
|
+ FPU_ARCH_CRYPTO_NEON_VFP_ARMV8), |
|
|
+ ARM_CPU_OPT ("cortex-a72", "Cortex-A72", ARM_ARCH_V8A, |
|
|
+ ARM_FEATURE_COPROC (CRC_EXT_ARMV8), |
|
|
+ FPU_ARCH_CRYPTO_NEON_VFP_ARMV8), |
|
|
+ ARM_CPU_OPT ("cortex-a73", "Cortex-A73", ARM_ARCH_V8A, |
|
|
+ ARM_FEATURE_COPROC (CRC_EXT_ARMV8), |
|
|
+ FPU_ARCH_CRYPTO_NEON_VFP_ARMV8), |
|
|
+ ARM_CPU_OPT ("cortex-a75", "Cortex-A75", ARM_ARCH_V8_2A, |
|
|
+ ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST), |
|
|
+ FPU_ARCH_CRYPTO_NEON_VFP_ARMV8), |
|
|
+ ARM_CPU_OPT ("cortex-r4", "Cortex-R4", ARM_ARCH_V7R, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_NONE), |
|
|
+ ARM_CPU_OPT ("cortex-r4f", "Cortex-R4F", ARM_ARCH_V7R, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V3D16), |
|
|
+ ARM_CPU_OPT ("cortex-r5", "Cortex-R5", ARM_ARCH_V7R, |
|
|
+ ARM_FEATURE_CORE_LOW (ARM_EXT_ADIV), |
|
|
+ FPU_NONE), |
|
|
+ ARM_CPU_OPT ("cortex-r7", "Cortex-R7", ARM_ARCH_V7R, |
|
|
+ ARM_FEATURE_CORE_LOW (ARM_EXT_ADIV), |
|
|
+ FPU_ARCH_VFP_V3D16), |
|
|
+ ARM_CPU_OPT ("cortex-r8", "Cortex-R8", ARM_ARCH_V7R, |
|
|
+ ARM_FEATURE_CORE_LOW (ARM_EXT_ADIV), |
|
|
+ FPU_ARCH_VFP_V3D16), |
|
|
+ ARM_CPU_OPT ("cortex-r52", "Cortex-R52", ARM_ARCH_V8R, |
|
|
+ ARM_FEATURE_COPROC (CRC_EXT_ARMV8), |
|
|
+ FPU_ARCH_NEON_VFP_ARMV8), |
|
|
+ ARM_CPU_OPT ("cortex-m33", "Cortex-M33", ARM_ARCH_V8M_MAIN, |
|
|
+ ARM_FEATURE_CORE_LOW (ARM_EXT_V5ExP | ARM_EXT_V6_DSP), |
|
|
+ FPU_NONE), |
|
|
+ ARM_CPU_OPT ("cortex-m23", "Cortex-M23", ARM_ARCH_V8M_BASE, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_NONE), |
|
|
+ ARM_CPU_OPT ("cortex-m7", "Cortex-M7", ARM_ARCH_V7EM, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_NONE), |
|
|
+ ARM_CPU_OPT ("cortex-m4", "Cortex-M4", ARM_ARCH_V7EM, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_NONE), |
|
|
+ ARM_CPU_OPT ("cortex-m3", "Cortex-M3", ARM_ARCH_V7M, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_NONE), |
|
|
+ ARM_CPU_OPT ("cortex-m1", "Cortex-M1", ARM_ARCH_V6SM, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_NONE), |
|
|
+ ARM_CPU_OPT ("cortex-m0", "Cortex-M0", ARM_ARCH_V6SM, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_NONE), |
|
|
+ ARM_CPU_OPT ("cortex-m0plus", "Cortex-M0+", ARM_ARCH_V6SM, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_NONE), |
|
|
+ ARM_CPU_OPT ("exynos-m1", "Samsung Exynos M1", ARM_ARCH_V8A, |
|
|
+ ARM_FEATURE_COPROC (CRC_EXT_ARMV8), |
|
|
+ FPU_ARCH_CRYPTO_NEON_VFP_ARMV8), |
|
|
|
|
|
/* ??? XSCALE is really an architecture. */ |
|
|
- ARM_CPU_OPT ("xscale", ARM_ARCH_XSCALE, FPU_ARCH_VFP_V2, NULL), |
|
|
+ ARM_CPU_OPT ("xscale", NULL, ARM_ARCH_XSCALE, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V2), |
|
|
+ |
|
|
/* ??? iwmmxt is not a processor. */ |
|
|
- ARM_CPU_OPT ("iwmmxt", ARM_ARCH_IWMMXT, FPU_ARCH_VFP_V2, NULL), |
|
|
- ARM_CPU_OPT ("iwmmxt2", ARM_ARCH_IWMMXT2,FPU_ARCH_VFP_V2, NULL), |
|
|
- ARM_CPU_OPT ("i80200", ARM_ARCH_XSCALE, FPU_ARCH_VFP_V2, NULL), |
|
|
+ ARM_CPU_OPT ("iwmmxt", NULL, ARM_ARCH_IWMMXT, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V2), |
|
|
+ ARM_CPU_OPT ("iwmmxt2", NULL, ARM_ARCH_IWMMXT2, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V2), |
|
|
+ ARM_CPU_OPT ("i80200", NULL, ARM_ARCH_XSCALE, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_VFP_V2), |
|
|
+ |
|
|
/* Maverick */ |
|
|
- ARM_CPU_OPT ("ep9312", ARM_FEATURE_LOW (ARM_AEXT_V4T, ARM_CEXT_MAVERICK), |
|
|
- FPU_ARCH_MAVERICK, "ARM920T"), |
|
|
+ ARM_CPU_OPT ("ep9312", "ARM920T", |
|
|
+ ARM_FEATURE_LOW (ARM_AEXT_V4T, ARM_CEXT_MAVERICK), |
|
|
+ ARM_ARCH_NONE, FPU_ARCH_MAVERICK), |
|
|
+ |
|
|
/* Marvell processors. */ |
|
|
- ARM_CPU_OPT ("marvell-pj4", ARM_FEATURE_CORE (ARM_AEXT_V7A | ARM_EXT_MP |
|
|
- | ARM_EXT_SEC, |
|
|
- ARM_EXT2_V6T2_V8M), |
|
|
- FPU_ARCH_VFP_V3D16, NULL), |
|
|
- ARM_CPU_OPT ("marvell-whitney", ARM_FEATURE_CORE (ARM_AEXT_V7A | ARM_EXT_MP |
|
|
- | ARM_EXT_SEC, |
|
|
- ARM_EXT2_V6T2_V8M), |
|
|
- FPU_ARCH_NEON_VFP_V4, NULL), |
|
|
+ ARM_CPU_OPT ("marvell-pj4", NULL, ARM_ARCH_V7A, |
|
|
+ ARM_FEATURE_CORE_LOW (ARM_EXT_MP | ARM_EXT_SEC), |
|
|
+ FPU_ARCH_VFP_V3D16), |
|
|
+ ARM_CPU_OPT ("marvell-whitney", NULL, ARM_ARCH_V7A, |
|
|
+ ARM_FEATURE_CORE_LOW (ARM_EXT_MP | ARM_EXT_SEC), |
|
|
+ FPU_ARCH_NEON_VFP_V4), |
|
|
+ |
|
|
/* APM X-Gene family. */ |
|
|
- ARM_CPU_OPT ("xgene1", ARM_ARCH_V8A, FPU_ARCH_CRYPTO_NEON_VFP_ARMV8, |
|
|
- "APM X-Gene 1"), |
|
|
- ARM_CPU_OPT ("xgene2", ARM_ARCH_V8A, FPU_ARCH_CRYPTO_NEON_VFP_ARMV8, |
|
|
- "APM X-Gene 2"), |
|
|
+ ARM_CPU_OPT ("xgene1", "APM X-Gene 1", ARM_ARCH_V8A, |
|
|
+ ARM_ARCH_NONE, |
|
|
+ FPU_ARCH_CRYPTO_NEON_VFP_ARMV8), |
|
|
+ ARM_CPU_OPT ("xgene2", "APM X-Gene 2", ARM_ARCH_V8A, |
|
|
+ ARM_FEATURE_COPROC (CRC_EXT_ARMV8), |
|
|
+ FPU_ARCH_CRYPTO_NEON_VFP_ARMV8), |
|
|
|
|
|
- { NULL, 0, ARM_ARCH_NONE, ARM_ARCH_NONE, NULL } |
|
|
+ { NULL, 0, ARM_ARCH_NONE, ARM_ARCH_NONE, ARM_ARCH_NONE, NULL } |
|
|
}; |
|
|
#undef ARM_CPU_OPT |
|
|
|
|
|
@@ -25459,6 +26022,8 @@ static const struct arm_arch_option_tabl |
|
|
ARM_ARCH_OPT ("armv8-a", ARM_ARCH_V8A, FPU_ARCH_VFP), |
|
|
ARM_ARCH_OPT ("armv8.1-a", ARM_ARCH_V8_1A, FPU_ARCH_VFP), |
|
|
ARM_ARCH_OPT ("armv8.2-a", ARM_ARCH_V8_2A, FPU_ARCH_VFP), |
|
|
+ ARM_ARCH_OPT ("armv8.3-a", ARM_ARCH_V8_3A, FPU_ARCH_VFP), |
|
|
+ ARM_ARCH_OPT ("armv8-r", ARM_ARCH_V8R, FPU_ARCH_VFP), |
|
|
ARM_ARCH_OPT ("xscale", ARM_ARCH_XSCALE, FPU_ARCH_VFP), |
|
|
ARM_ARCH_OPT ("iwmmxt", ARM_ARCH_IWMMXT, FPU_ARCH_VFP), |
|
|
ARM_ARCH_OPT ("iwmmxt2", ARM_ARCH_IWMMXT2,FPU_ARCH_VFP), |
|
|
@@ -25490,6 +26055,9 @@ static const struct arm_option_extension |
|
|
ARM_EXT_OPT ("crypto", FPU_ARCH_CRYPTO_NEON_VFP_ARMV8, |
|
|
ARM_FEATURE_COPROC (FPU_CRYPTO_ARMV8), |
|
|
ARM_FEATURE_CORE_LOW (ARM_EXT_V8)), |
|
|
+ ARM_EXT_OPT ("dotprod", FPU_ARCH_DOTPROD_NEON_VFP_ARMV8, |
|
|
+ ARM_FEATURE_COPROC (FPU_NEON_EXT_DOTPROD), |
|
|
+ ARM_ARCH_V8_2A), |
|
|
ARM_EXT_OPT ("dsp", ARM_FEATURE_CORE_LOW (ARM_EXT_V5ExP | ARM_EXT_V6_DSP), |
|
|
ARM_FEATURE_CORE_LOW (ARM_EXT_V5ExP | ARM_EXT_V6_DSP), |
|
|
ARM_FEATURE_CORE (ARM_EXT_V7M, ARM_EXT2_V8M)), |
|
|
@@ -25502,6 +26070,13 @@ static const struct arm_option_extension |
|
|
ARM_FEATURE_CORE_LOW (ARM_EXT_ADIV | ARM_EXT_DIV), |
|
|
ARM_FEATURE_CORE_LOW (ARM_EXT_V7A), |
|
|
ARM_FEATURE_CORE_LOW (ARM_EXT_V7R)), |
|
|
+ /* Duplicate entry for the purpose of allowing ARMv7 to match in presence of |
|
|
+ Thumb divide instruction. Due to this having the same name as the |
|
|
+ previous entry, this will be ignored when doing command-line parsing and |
|
|
+ only considered by build attribute selection code. */ |
|
|
+ ARM_EXT_OPT ("idiv", ARM_FEATURE_CORE_LOW (ARM_EXT_DIV), |
|
|
+ ARM_FEATURE_CORE_LOW (ARM_EXT_DIV), |
|
|
+ ARM_FEATURE_CORE_LOW (ARM_EXT_V7)), |
|
|
ARM_EXT_OPT ("iwmmxt",ARM_FEATURE_COPROC (ARM_CEXT_IWMMXT), |
|
|
ARM_FEATURE_COPROC (ARM_CEXT_IWMMXT), ARM_ARCH_NONE), |
|
|
ARM_EXT_OPT ("iwmmxt2", ARM_FEATURE_COPROC (ARM_CEXT_IWMMXT2), |
|
|
@@ -25517,13 +26092,13 @@ static const struct arm_option_extension |
|
|
ARM_FEATURE_CORE_LOW (ARM_EXT_V6M)), |
|
|
ARM_EXT_OPT ("pan", ARM_FEATURE_CORE_HIGH (ARM_EXT2_PAN), |
|
|
ARM_FEATURE (ARM_EXT_V8, ARM_EXT2_PAN, 0), |
|
|
- ARM_FEATURE_CORE_LOW (ARM_EXT_V8)), |
|
|
+ ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8A)), |
|
|
ARM_EXT_OPT ("ras", ARM_FEATURE_CORE_HIGH (ARM_EXT2_RAS), |
|
|
ARM_FEATURE (ARM_EXT_V8, ARM_EXT2_RAS, 0), |
|
|
- ARM_FEATURE_CORE_LOW (ARM_EXT_V8)), |
|
|
+ ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8A)), |
|
|
ARM_EXT_OPT ("rdma", FPU_ARCH_NEON_VFP_ARMV8_1, |
|
|
ARM_FEATURE_COPROC (FPU_NEON_ARMV8 | FPU_NEON_EXT_RDMA), |
|
|
- ARM_FEATURE_CORE_LOW (ARM_EXT_V8)), |
|
|
+ ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8A)), |
|
|
ARM_EXT_OPT2 ("sec", ARM_FEATURE_CORE_LOW (ARM_EXT_SEC), |
|
|
ARM_FEATURE_CORE_LOW (ARM_EXT_SEC), |
|
|
ARM_FEATURE_CORE_LOW (ARM_EXT_V6K), |
|
|
@@ -25581,6 +26156,7 @@ static const struct arm_option_fpu_value |
|
|
{"arm1136jf-s", FPU_ARCH_VFP_V2}, |
|
|
{"maverick", FPU_ARCH_MAVERICK}, |
|
|
{"neon", FPU_ARCH_VFP_V3_PLUS_NEON_V1}, |
|
|
+ {"neon-vfpv3", FPU_ARCH_VFP_V3_PLUS_NEON_V1}, |
|
|
{"neon-fp16", FPU_ARCH_NEON_FP16}, |
|
|
{"vfpv4", FPU_ARCH_VFP_V4}, |
|
|
{"vfpv4-d16", FPU_ARCH_VFP_V4D16}, |
|
|
@@ -25632,10 +26208,9 @@ struct arm_long_option_table |
|
|
}; |
|
|
|
|
|
static bfd_boolean |
|
|
-arm_parse_extension (const char *str, const arm_feature_set **opt_p) |
|
|
+arm_parse_extension (const char *str, const arm_feature_set *opt_set, |
|
|
+ arm_feature_set **ext_set_p) |
|
|
{ |
|
|
- arm_feature_set *ext_set = XNEW (arm_feature_set); |
|
|
- |
|
|
/* We insist on extensions being specified in alphabetical order, and with |
|
|
extensions being added before being removed. We achieve this by having |
|
|
the global ARM_EXTENSIONS table in alphabetical order, and using the |
|
|
@@ -25646,9 +26221,11 @@ arm_parse_extension (const char *str, co |
|
|
const arm_feature_set arm_any = ARM_ANY; |
|
|
int adding_value = -1; |
|
|
|
|
|
- /* Copy the feature set, so that we can modify it. */ |
|
|
- *ext_set = **opt_p; |
|
|
- *opt_p = ext_set; |
|
|
+ if (!*ext_set_p) |
|
|
+ { |
|
|
+ *ext_set_p = XNEW (arm_feature_set); |
|
|
+ **ext_set_p = arm_arch_none; |
|
|
+ } |
|
|
|
|
|
while (str != NULL && *str != 0) |
|
|
{ |
|
|
@@ -25716,7 +26293,7 @@ arm_parse_extension (const char *str, co |
|
|
/* Empty entry. */ |
|
|
if (ARM_FEATURE_EQUAL (opt->allowed_archs[i], arm_any)) |
|
|
continue; |
|
|
- if (ARM_FSET_CPU_SUBSET (opt->allowed_archs[i], *ext_set)) |
|
|
+ if (ARM_FSET_CPU_SUBSET (opt->allowed_archs[i], *opt_set)) |
|
|
break; |
|
|
} |
|
|
if (i == nb_allowed_archs) |
|
|
@@ -25727,10 +26304,15 @@ arm_parse_extension (const char *str, co |
|
|
|
|
|
/* Add or remove the extension. */ |
|
|
if (adding_value) |
|
|
- ARM_MERGE_FEATURE_SETS (*ext_set, *ext_set, opt->merge_value); |
|
|
+ ARM_MERGE_FEATURE_SETS (**ext_set_p, **ext_set_p, |
|
|
+ opt->merge_value); |
|
|
else |
|
|
- ARM_CLEAR_FEATURE (*ext_set, *ext_set, opt->clear_value); |
|
|
+ ARM_CLEAR_FEATURE (**ext_set_p, **ext_set_p, opt->clear_value); |
|
|
|
|
|
+ /* Allowing Thumb division instructions for ARMv7 in autodetection |
|
|
+ rely on this break so that duplicate extensions (extensions |
|
|
+ with the same name as a previous extension in the list) are not |
|
|
+ considered for command-line parsing. */ |
|
|
break; |
|
|
} |
|
|
|
|
|
@@ -25786,6 +26368,9 @@ arm_parse_cpu (const char *str) |
|
|
if (opt->name_len == len && strncmp (opt->name, str, len) == 0) |
|
|
{ |
|
|
mcpu_cpu_opt = &opt->value; |
|
|
+ if (!dyn_mcpu_ext_opt) |
|
|
+ dyn_mcpu_ext_opt = XNEW (arm_feature_set); |
|
|
+ *dyn_mcpu_ext_opt = opt->ext; |
|
|
mcpu_fpu_opt = &opt->default_fpu; |
|
|
if (opt->canonical_name) |
|
|
{ |
|
|
@@ -25805,7 +26390,7 @@ arm_parse_cpu (const char *str) |
|
|
} |
|
|
|
|
|
if (ext != NULL) |
|
|
- return arm_parse_extension (ext, &mcpu_cpu_opt); |
|
|
+ return arm_parse_extension (ext, mcpu_cpu_opt, &dyn_mcpu_ext_opt); |
|
|
|
|
|
return TRUE; |
|
|
} |
|
|
@@ -25840,7 +26425,7 @@ arm_parse_arch (const char *str) |
|
|
strcpy (selected_cpu_name, opt->name); |
|
|
|
|
|
if (ext != NULL) |
|
|
- return arm_parse_extension (ext, &march_cpu_opt); |
|
|
+ return arm_parse_extension (ext, march_cpu_opt, &dyn_march_ext_opt); |
|
|
|
|
|
return TRUE; |
|
|
} |
|
|
@@ -26080,30 +26665,62 @@ typedef struct |
|
|
arm_feature_set flags; |
|
|
} cpu_arch_ver_table; |
|
|
|
|
|
-/* Mapping from CPU features to EABI CPU arch values. As a general rule, table |
|
|
- must be sorted least features first but some reordering is needed, eg. for |
|
|
- Thumb-2 instructions to be detected as coming from ARMv6T2. */ |
|
|
+/* Mapping from CPU features to EABI CPU arch values. Table must be sorted |
|
|
+ chronologically for architectures, with an exception for ARMv6-M and |
|
|
+ ARMv6S-M due to legacy reasons. No new architecture should have a |
|
|
+ special case. This allows for build attribute selection results to be |
|
|
+ stable when new architectures are added. */ |
|
|
static const cpu_arch_ver_table cpu_arch_ver[] = |
|
|
{ |
|
|
+ {0, ARM_ARCH_V1}, |
|
|
+ {0, ARM_ARCH_V2}, |
|
|
+ {0, ARM_ARCH_V2S}, |
|
|
+ {0, ARM_ARCH_V3}, |
|
|
+ {0, ARM_ARCH_V3M}, |
|
|
+ {1, ARM_ARCH_V4xM}, |
|
|
{1, ARM_ARCH_V4}, |
|
|
+ {2, ARM_ARCH_V4TxM}, |
|
|
{2, ARM_ARCH_V4T}, |
|
|
+ {3, ARM_ARCH_V5xM}, |
|
|
{3, ARM_ARCH_V5}, |
|
|
+ {3, ARM_ARCH_V5TxM}, |
|
|
{3, ARM_ARCH_V5T}, |
|
|
+ {4, ARM_ARCH_V5TExP}, |
|
|
{4, ARM_ARCH_V5TE}, |
|
|
{5, ARM_ARCH_V5TEJ}, |
|
|
{6, ARM_ARCH_V6}, |
|
|
- {9, ARM_ARCH_V6K}, |
|
|
{7, ARM_ARCH_V6Z}, |
|
|
+ {7, ARM_ARCH_V6KZ}, |
|
|
+ {9, ARM_ARCH_V6K}, |
|
|
+ {8, ARM_ARCH_V6T2}, |
|
|
+ {8, ARM_ARCH_V6KT2}, |
|
|
+ {8, ARM_ARCH_V6ZT2}, |
|
|
+ {8, ARM_ARCH_V6KZT2}, |
|
|
+ |
|
|
+ /* When assembling a file with only ARMv6-M or ARMv6S-M instruction, GNU as |
|
|
+ always selected build attributes to match those of ARMv6-M |
|
|
+ (resp. ARMv6S-M). However, due to these architectures being a strict |
|
|
+ subset of ARMv7-M in terms of instructions available, ARMv7-M attributes |
|
|
+ would be selected when fully respecting chronology of architectures. |
|
|
+ It is thus necessary to make a special case of ARMv6-M and ARMv6S-M and |
|
|
+ move them before ARMv7 architectures. */ |
|
|
{11, ARM_ARCH_V6M}, |
|
|
{12, ARM_ARCH_V6SM}, |
|
|
- {8, ARM_ARCH_V6T2}, |
|
|
- {10, ARM_ARCH_V7VE}, |
|
|
+ |
|
|
+ {10, ARM_ARCH_V7}, |
|
|
+ {10, ARM_ARCH_V7A}, |
|
|
{10, ARM_ARCH_V7R}, |
|
|
{10, ARM_ARCH_V7M}, |
|
|
+ {10, ARM_ARCH_V7VE}, |
|
|
+ {13, ARM_ARCH_V7EM}, |
|
|
{14, ARM_ARCH_V8A}, |
|
|
+ {14, ARM_ARCH_V8_1A}, |
|
|
+ {14, ARM_ARCH_V8_2A}, |
|
|
+ {14, ARM_ARCH_V8_3A}, |
|
|
{16, ARM_ARCH_V8M_BASE}, |
|
|
{17, ARM_ARCH_V8M_MAIN}, |
|
|
- {0, ARM_ARCH_NONE} |
|
|
+ {15, ARM_ARCH_V8R}, |
|
|
+ {-1, ARM_ARCH_NONE} |
|
|
}; |
|
|
|
|
|
/* Set an attribute if it has not already been set by the user. */ |
|
|
@@ -26125,92 +26742,210 @@ aeabi_set_attribute_string (int tag, con |
|
|
bfd_elf_add_proc_attr_string (stdoutput, tag, value); |
|
|
} |
|
|
|
|
|
-/* Set the public EABI object attributes. */ |
|
|
-void |
|
|
-aeabi_set_public_attributes (void) |
|
|
+/* Return whether features in the *NEEDED feature set are available via |
|
|
+ extensions for the architecture whose feature set is *ARCH_FSET. */ |
|
|
+static bfd_boolean |
|
|
+have_ext_for_needed_feat_p (const arm_feature_set *arch_fset, |
|
|
+ const arm_feature_set *needed) |
|
|
{ |
|
|
- int arch; |
|
|
- char profile; |
|
|
- int virt_sec = 0; |
|
|
- int fp16_optional = 0; |
|
|
- arm_feature_set arm_arch = ARM_ARCH_NONE; |
|
|
- arm_feature_set flags; |
|
|
- arm_feature_set tmp; |
|
|
- arm_feature_set arm_arch_v8m_base = ARM_ARCH_V8M_BASE; |
|
|
- const cpu_arch_ver_table *p; |
|
|
- |
|
|
- /* Choose the architecture based on the capabilities of the requested cpu |
|
|
- (if any) and/or the instructions actually used. */ |
|
|
- ARM_MERGE_FEATURE_SETS (flags, arm_arch_used, thumb_arch_used); |
|
|
- ARM_MERGE_FEATURE_SETS (flags, flags, *mfpu_opt); |
|
|
- ARM_MERGE_FEATURE_SETS (flags, flags, selected_cpu); |
|
|
+ int i, nb_allowed_archs; |
|
|
+ arm_feature_set ext_fset; |
|
|
+ const struct arm_option_extension_value_table *opt; |
|
|
|
|
|
- if (ARM_CPU_HAS_FEATURE (arm_arch_used, arm_arch_any)) |
|
|
- ARM_MERGE_FEATURE_SETS (flags, flags, arm_ext_v1); |
|
|
+ ext_fset = arm_arch_none; |
|
|
+ for (opt = arm_extensions; opt->name != NULL; opt++) |
|
|
+ { |
|
|
+ /* Extension does not provide any feature we need. */ |
|
|
+ if (!ARM_CPU_HAS_FEATURE (*needed, opt->merge_value)) |
|
|
+ continue; |
|
|
|
|
|
- if (ARM_CPU_HAS_FEATURE (thumb_arch_used, arm_arch_any)) |
|
|
- ARM_MERGE_FEATURE_SETS (flags, flags, arm_ext_v4t); |
|
|
+ nb_allowed_archs = |
|
|
+ sizeof (opt->allowed_archs) / sizeof (opt->allowed_archs[0]); |
|
|
+ for (i = 0; i < nb_allowed_archs; i++) |
|
|
+ { |
|
|
+ /* Empty entry. */ |
|
|
+ if (ARM_FEATURE_EQUAL (opt->allowed_archs[i], arm_arch_any)) |
|
|
+ break; |
|
|
|
|
|
- selected_cpu = flags; |
|
|
+ /* Extension is available, add it. */ |
|
|
+ if (ARM_FSET_CPU_SUBSET (opt->allowed_archs[i], *arch_fset)) |
|
|
+ ARM_MERGE_FEATURE_SETS (ext_fset, ext_fset, opt->merge_value); |
|
|
+ } |
|
|
+ } |
|
|
|
|
|
- /* Allow the user to override the reported architecture. */ |
|
|
- if (object_arch) |
|
|
+ /* Can we enable all features in *needed? */ |
|
|
+ return ARM_FSET_CPU_SUBSET (*needed, ext_fset); |
|
|
+} |
|
|
+ |
|
|
+/* Select value for Tag_CPU_arch and Tag_CPU_arch_profile build attributes for |
|
|
+ a given architecture feature set *ARCH_EXT_FSET including extension feature |
|
|
+ set *EXT_FSET. Selection logic used depend on EXACT_MATCH: |
|
|
+ - if true, check for an exact match of the architecture modulo extensions; |
|
|
+ - otherwise, select build attribute value of the first superset |
|
|
+ architecture released so that results remains stable when new architectures |
|
|
+ are added. |
|
|
+ For -march/-mcpu=all the build attribute value of the most featureful |
|
|
+ architecture is returned. Tag_CPU_arch_profile result is returned in |
|
|
+ PROFILE. */ |
|
|
+static int |
|
|
+get_aeabi_cpu_arch_from_fset (const arm_feature_set *arch_ext_fset, |
|
|
+ const arm_feature_set *ext_fset, |
|
|
+ char *profile, int exact_match) |
|
|
+{ |
|
|
+ arm_feature_set arch_fset; |
|
|
+ const cpu_arch_ver_table *p_ver, *p_ver_ret = NULL; |
|
|
+ |
|
|
+ /* Select most featureful architecture with all its extensions if building |
|
|
+ for -march=all as the feature sets used to set build attributes. */ |
|
|
+ if (ARM_FEATURE_EQUAL (*arch_ext_fset, arm_arch_any)) |
|
|
{ |
|
|
- ARM_CLEAR_FEATURE (flags, flags, arm_arch_any); |
|
|
- ARM_MERGE_FEATURE_SETS (flags, flags, *object_arch); |
|
|
+ /* Force revisiting of decision for each new architecture. */ |
|
|
+ gas_assert (MAX_TAG_CPU_ARCH <= TAG_CPU_ARCH_V8M_MAIN); |
|
|
+ *profile = 'A'; |
|
|
+ return TAG_CPU_ARCH_V8; |
|
|
} |
|
|
|
|
|
- /* We need to make sure that the attributes do not identify us as v6S-M |
|
|
- when the only v6S-M feature in use is the Operating System Extensions. */ |
|
|
- if (ARM_CPU_HAS_FEATURE (flags, arm_ext_os)) |
|
|
- if (!ARM_CPU_HAS_FEATURE (flags, arm_arch_v6m_only)) |
|
|
- ARM_CLEAR_FEATURE (flags, flags, arm_ext_os); |
|
|
+ ARM_CLEAR_FEATURE (arch_fset, *arch_ext_fset, *ext_fset); |
|
|
|
|
|
- tmp = flags; |
|
|
- arch = 0; |
|
|
- for (p = cpu_arch_ver; p->val; p++) |
|
|
+ for (p_ver = cpu_arch_ver; p_ver->val != -1; p_ver++) |
|
|
{ |
|
|
- if (ARM_CPU_HAS_FEATURE (tmp, p->flags)) |
|
|
+ arm_feature_set known_arch_fset; |
|
|
+ |
|
|
+ ARM_CLEAR_FEATURE (known_arch_fset, p_ver->flags, fpu_any); |
|
|
+ if (exact_match) |
|
|
{ |
|
|
- arch = p->val; |
|
|
- arm_arch = p->flags; |
|
|
- ARM_CLEAR_FEATURE (tmp, tmp, p->flags); |
|
|
+ /* Base architecture match user-specified architecture and |
|
|
+ extensions, eg. ARMv6S-M matching -march=armv6-m+os. */ |
|
|
+ if (ARM_FEATURE_EQUAL (*arch_ext_fset, known_arch_fset)) |
|
|
+ { |
|
|
+ p_ver_ret = p_ver; |
|
|
+ goto found; |
|
|
+ } |
|
|
+ /* Base architecture match user-specified architecture only |
|
|
+ (eg. ARMv6-M in the same case as above). Record it in case we |
|
|
+ find a match with above condition. */ |
|
|
+ else if (p_ver_ret == NULL |
|
|
+ && ARM_FEATURE_EQUAL (arch_fset, known_arch_fset)) |
|
|
+ p_ver_ret = p_ver; |
|
|
} |
|
|
- } |
|
|
+ else |
|
|
+ { |
|
|
|
|
|
- /* The table lookup above finds the last architecture to contribute |
|
|
- a new feature. Unfortunately, Tag13 is a subset of the union of |
|
|
- v6T2 and v7-M, so it is never seen as contributing a new feature. |
|
|
- We can not search for the last entry which is entirely used, |
|
|
- because if no CPU is specified we build up only those flags |
|
|
- actually used. Perhaps we should separate out the specified |
|
|
- and implicit cases. Avoid taking this path for -march=all by |
|
|
- checking for contradictory v7-A / v7-M features. */ |
|
|
- if (arch == TAG_CPU_ARCH_V7 |
|
|
- && !ARM_CPU_HAS_FEATURE (flags, arm_ext_v7a) |
|
|
- && ARM_CPU_HAS_FEATURE (flags, arm_ext_v7m) |
|
|
- && ARM_CPU_HAS_FEATURE (flags, arm_ext_v6_dsp)) |
|
|
- { |
|
|
- arch = TAG_CPU_ARCH_V7E_M; |
|
|
- arm_arch = (arm_feature_set) ARM_ARCH_V7EM; |
|
|
+ /* Architecture has all features wanted. */ |
|
|
+ if (ARM_FSET_CPU_SUBSET (arch_fset, known_arch_fset)) |
|
|
+ { |
|
|
+ arm_feature_set added_fset; |
|
|
+ |
|
|
+ /* Compute features added by this architecture over the one |
|
|
+ recorded in p_ver_ret. */ |
|
|
+ if (p_ver_ret != NULL) |
|
|
+ ARM_CLEAR_FEATURE (added_fset, known_arch_fset, |
|
|
+ p_ver_ret->flags); |
|
|
+ /* First architecture that match incl. with extensions, or the |
|
|
+ only difference in features over the recorded match is |
|
|
+ features that were optional and are now mandatory. */ |
|
|
+ if (p_ver_ret == NULL |
|
|
+ || ARM_FSET_CPU_SUBSET (added_fset, arch_fset)) |
|
|
+ { |
|
|
+ p_ver_ret = p_ver; |
|
|
+ goto found; |
|
|
+ } |
|
|
+ } |
|
|
+ else if (p_ver_ret == NULL) |
|
|
+ { |
|
|
+ arm_feature_set needed_ext_fset; |
|
|
+ |
|
|
+ ARM_CLEAR_FEATURE (needed_ext_fset, arch_fset, known_arch_fset); |
|
|
+ |
|
|
+ /* Architecture has all features needed when using some |
|
|
+ extensions. Record it and continue searching in case there |
|
|
+ exist an architecture providing all needed features without |
|
|
+ the need for extensions (eg. ARMv6S-M Vs ARMv6-M with |
|
|
+ OS extension). */ |
|
|
+ if (have_ext_for_needed_feat_p (&known_arch_fset, |
|
|
+ &needed_ext_fset)) |
|
|
+ p_ver_ret = p_ver; |
|
|
+ } |
|
|
+ } |
|
|
} |
|
|
|
|
|
- ARM_CLEAR_FEATURE (tmp, flags, arm_arch_v8m_base); |
|
|
- if (arch == TAG_CPU_ARCH_V8M_BASE && ARM_CPU_HAS_FEATURE (tmp, arm_arch_any)) |
|
|
+ if (p_ver_ret == NULL) |
|
|
+ return -1; |
|
|
+ |
|
|
+found: |
|
|
+ /* Tag_CPU_arch_profile. */ |
|
|
+ if (ARM_CPU_HAS_FEATURE (p_ver_ret->flags, arm_ext_v7a) |
|
|
+ || ARM_CPU_HAS_FEATURE (p_ver_ret->flags, arm_ext_v8) |
|
|
+ || (ARM_CPU_HAS_FEATURE (p_ver_ret->flags, arm_ext_atomics) |
|
|
+ && !ARM_CPU_HAS_FEATURE (p_ver_ret->flags, arm_ext_v8m_m_only))) |
|
|
+ *profile = 'A'; |
|
|
+ else if (ARM_CPU_HAS_FEATURE (p_ver_ret->flags, arm_ext_v7r)) |
|
|
+ *profile = 'R'; |
|
|
+ else if (ARM_CPU_HAS_FEATURE (p_ver_ret->flags, arm_ext_m)) |
|
|
+ *profile = 'M'; |
|
|
+ else |
|
|
+ *profile = '\0'; |
|
|
+ return p_ver_ret->val; |
|
|
+} |
|
|
+ |
|
|
+/* Set the public EABI object attributes. */ |
|
|
+static void |
|
|
+aeabi_set_public_attributes (void) |
|
|
+{ |
|
|
+ char profile; |
|
|
+ int arch = -1; |
|
|
+ int virt_sec = 0; |
|
|
+ int fp16_optional = 0; |
|
|
+ int skip_exact_match = 0; |
|
|
+ arm_feature_set flags, flags_arch, flags_ext; |
|
|
+ |
|
|
+ /* Autodetection mode, choose the architecture based the instructions |
|
|
+ actually used. */ |
|
|
+ if (no_cpu_selected ()) |
|
|
{ |
|
|
- arch = TAG_CPU_ARCH_V8M_MAIN; |
|
|
- arm_arch = (arm_feature_set) ARM_ARCH_V8M_MAIN; |
|
|
+ ARM_MERGE_FEATURE_SETS (flags, arm_arch_used, thumb_arch_used); |
|
|
+ |
|
|
+ if (ARM_CPU_HAS_FEATURE (arm_arch_used, arm_arch_any)) |
|
|
+ ARM_MERGE_FEATURE_SETS (flags, flags, arm_ext_v1); |
|
|
+ |
|
|
+ if (ARM_CPU_HAS_FEATURE (thumb_arch_used, arm_arch_any)) |
|
|
+ ARM_MERGE_FEATURE_SETS (flags, flags, arm_ext_v4t); |
|
|
+ |
|
|
+ /* Code run during relaxation relies on selected_cpu being set. */ |
|
|
+ selected_cpu = flags; |
|
|
} |
|
|
+ /* Otherwise, choose the architecture based on the capabilities of the |
|
|
+ requested cpu. */ |
|
|
+ else |
|
|
+ flags = selected_cpu; |
|
|
+ ARM_MERGE_FEATURE_SETS (flags, flags, *mfpu_opt); |
|
|
|
|
|
- /* In cpu_arch_ver ARMv8-A is before ARMv8-M for atomics to be detected as |
|
|
- coming from ARMv8-A. However, since ARMv8-A has more instructions than |
|
|
- ARMv8-M, -march=all must be detected as ARMv8-A. */ |
|
|
- if (arch == TAG_CPU_ARCH_V8M_MAIN |
|
|
- && ARM_FEATURE_CORE_EQUAL (selected_cpu, arm_arch_any)) |
|
|
+ /* Allow the user to override the reported architecture. */ |
|
|
+ if (object_arch) |
|
|
{ |
|
|
- arch = TAG_CPU_ARCH_V8; |
|
|
- arm_arch = (arm_feature_set) ARM_ARCH_V8A; |
|
|
+ ARM_CLEAR_FEATURE (flags_arch, *object_arch, fpu_any); |
|
|
+ flags_ext = arm_arch_none; |
|
|
} |
|
|
+ else |
|
|
+ { |
|
|
+ ARM_CLEAR_FEATURE (flags_arch, flags, fpu_any); |
|
|
+ flags_ext = dyn_mcpu_ext_opt ? *dyn_mcpu_ext_opt : arm_arch_none; |
|
|
+ skip_exact_match = ARM_FEATURE_EQUAL (selected_cpu, arm_arch_any); |
|
|
+ } |
|
|
+ |
|
|
+ /* When this function is run again after relaxation has happened there is no |
|
|
+ way to determine whether an architecture or CPU was specified by the user: |
|
|
+ - selected_cpu is set above for relaxation to work; |
|
|
+ - march_cpu_opt is not set if only -mcpu or .cpu is used; |
|
|
+ - mcpu_cpu_opt is set to arm_arch_any for autodetection. |
|
|
+ Therefore, if not in -march=all case we first try an exact match and fall |
|
|
+ back to autodetection. */ |
|
|
+ if (!skip_exact_match) |
|
|
+ arch = get_aeabi_cpu_arch_from_fset (&flags_arch, &flags_ext, &profile, 1); |
|
|
+ if (arch == -1) |
|
|
+ arch = get_aeabi_cpu_arch_from_fset (&flags_arch, &flags_ext, &profile, 0); |
|
|
+ if (arch == -1) |
|
|
+ as_bad (_("no architecture contains all the instructions used\n")); |
|
|
|
|
|
/* Tag_CPU_name. */ |
|
|
if (selected_cpu_name[0]) |
|
|
@@ -26233,40 +26968,22 @@ aeabi_set_public_attributes (void) |
|
|
aeabi_set_attribute_int (Tag_CPU_arch, arch); |
|
|
|
|
|
/* Tag_CPU_arch_profile. */ |
|
|
- if (ARM_CPU_HAS_FEATURE (flags, arm_ext_v7a) |
|
|
- || ARM_CPU_HAS_FEATURE (flags, arm_ext_v8) |
|
|
- || (ARM_CPU_HAS_FEATURE (flags, arm_ext_atomics) |
|
|
- && !ARM_CPU_HAS_FEATURE (flags, arm_ext_v8m_m_only))) |
|
|
- profile = 'A'; |
|
|
- else if (ARM_CPU_HAS_FEATURE (flags, arm_ext_v7r)) |
|
|
- profile = 'R'; |
|
|
- else if (ARM_CPU_HAS_FEATURE (flags, arm_ext_m)) |
|
|
- profile = 'M'; |
|
|
- else |
|
|
- profile = '\0'; |
|
|
- |
|
|
if (profile != '\0') |
|
|
aeabi_set_attribute_int (Tag_CPU_arch_profile, profile); |
|
|
|
|
|
/* Tag_DSP_extension. */ |
|
|
- if (ARM_CPU_HAS_FEATURE (flags, arm_ext_dsp)) |
|
|
- { |
|
|
- arm_feature_set ext; |
|
|
- |
|
|
- /* DSP instructions not in architecture. */ |
|
|
- ARM_CLEAR_FEATURE (ext, flags, arm_arch); |
|
|
- if (ARM_CPU_HAS_FEATURE (ext, arm_ext_dsp)) |
|
|
- aeabi_set_attribute_int (Tag_DSP_extension, 1); |
|
|
- } |
|
|
+ if (dyn_mcpu_ext_opt && ARM_CPU_HAS_FEATURE (*dyn_mcpu_ext_opt, arm_ext_dsp)) |
|
|
+ aeabi_set_attribute_int (Tag_DSP_extension, 1); |
|
|
|
|
|
+ ARM_CLEAR_FEATURE (flags_arch, flags, fpu_any); |
|
|
/* Tag_ARM_ISA_use. */ |
|
|
if (ARM_CPU_HAS_FEATURE (flags, arm_ext_v1) |
|
|
- || arch == 0) |
|
|
+ || ARM_FEATURE_ZERO (flags_arch)) |
|
|
aeabi_set_attribute_int (Tag_ARM_ISA_use, 1); |
|
|
|
|
|
/* Tag_THUMB_ISA_use. */ |
|
|
if (ARM_CPU_HAS_FEATURE (flags, arm_ext_v4t) |
|
|
- || arch == 0) |
|
|
+ || ARM_FEATURE_ZERO (flags_arch)) |
|
|
{ |
|
|
int thumb_isa_use; |
|
|
|
|
|
@@ -26348,9 +27065,7 @@ aeabi_set_public_attributes (void) |
|
|
by the base architecture. |
|
|
|
|
|
For new architectures we will have to check these tests. */ |
|
|
- gas_assert (arch <= TAG_CPU_ARCH_V8 |
|
|
- || (arch >= TAG_CPU_ARCH_V8M_BASE |
|
|
- && arch <= TAG_CPU_ARCH_V8M_MAIN)); |
|
|
+ gas_assert (arch <= TAG_CPU_ARCH_V8M_MAIN); |
|
|
if (ARM_CPU_HAS_FEATURE (flags, arm_ext_v8) |
|
|
|| ARM_CPU_HAS_FEATURE (flags, arm_ext_v8m)) |
|
|
aeabi_set_attribute_int (Tag_DIV_use, 0); |
|
|
@@ -26373,6 +27088,18 @@ aeabi_set_public_attributes (void) |
|
|
aeabi_set_attribute_int (Tag_Virtualization_use, virt_sec); |
|
|
} |
|
|
|
|
|
+/* Post relaxation hook. Recompute ARM attributes now that relaxation is |
|
|
+ finished and free extension feature bits which will not be used anymore. */ |
|
|
+void |
|
|
+arm_md_post_relax (void) |
|
|
+{ |
|
|
+ aeabi_set_public_attributes (); |
|
|
+ XDELETE (dyn_mcpu_ext_opt); |
|
|
+ dyn_mcpu_ext_opt = NULL; |
|
|
+ XDELETE (dyn_march_ext_opt); |
|
|
+ dyn_march_ext_opt = NULL; |
|
|
+} |
|
|
+ |
|
|
/* Add the default contents for the .ARM.attributes section. */ |
|
|
void |
|
|
arm_md_end (void) |
|
|
@@ -26405,7 +27132,10 @@ s_arm_cpu (int ignored ATTRIBUTE_UNUSED) |
|
|
if (streq (opt->name, name)) |
|
|
{ |
|
|
mcpu_cpu_opt = &opt->value; |
|
|
- selected_cpu = opt->value; |
|
|
+ if (!dyn_mcpu_ext_opt) |
|
|
+ dyn_mcpu_ext_opt = XNEW (arm_feature_set); |
|
|
+ *dyn_mcpu_ext_opt = opt->ext; |
|
|
+ ARM_MERGE_FEATURE_SETS (selected_cpu, *mcpu_cpu_opt, *dyn_mcpu_ext_opt); |
|
|
if (opt->canonical_name) |
|
|
strcpy (selected_cpu_name, opt->canonical_name); |
|
|
else |
|
|
@@ -26417,6 +27147,8 @@ s_arm_cpu (int ignored ATTRIBUTE_UNUSED) |
|
|
selected_cpu_name[i] = 0; |
|
|
} |
|
|
ARM_MERGE_FEATURE_SETS (cpu_variant, *mcpu_cpu_opt, *mfpu_opt); |
|
|
+ if (dyn_mcpu_ext_opt) |
|
|
+ ARM_MERGE_FEATURE_SETS (cpu_variant, cpu_variant, *dyn_mcpu_ext_opt); |
|
|
*input_line_pointer = saved_char; |
|
|
demand_empty_rest_of_line (); |
|
|
return; |
|
|
@@ -26447,9 +27179,11 @@ s_arm_arch (int ignored ATTRIBUTE_UNUSED |
|
|
if (streq (opt->name, name)) |
|
|
{ |
|
|
mcpu_cpu_opt = &opt->value; |
|
|
- selected_cpu = opt->value; |
|
|
+ XDELETE (dyn_mcpu_ext_opt); |
|
|
+ dyn_mcpu_ext_opt = NULL; |
|
|
+ selected_cpu = *mcpu_cpu_opt; |
|
|
strcpy (selected_cpu_name, opt->name); |
|
|
- ARM_MERGE_FEATURE_SETS (cpu_variant, *mcpu_cpu_opt, *mfpu_opt); |
|
|
+ ARM_MERGE_FEATURE_SETS (cpu_variant, selected_cpu, *mfpu_opt); |
|
|
*input_line_pointer = saved_char; |
|
|
demand_empty_rest_of_line (); |
|
|
return; |
|
|
@@ -26536,16 +27270,26 @@ s_arm_arch_extension (int ignored ATTRIB |
|
|
break; |
|
|
} |
|
|
|
|
|
+ if (!dyn_mcpu_ext_opt) |
|
|
+ { |
|
|
+ dyn_mcpu_ext_opt = XNEW (arm_feature_set); |
|
|
+ *dyn_mcpu_ext_opt = arm_arch_none; |
|
|
+ } |
|
|
if (adding_value) |
|
|
- ARM_MERGE_FEATURE_SETS (selected_cpu, selected_cpu, |
|
|
+ ARM_MERGE_FEATURE_SETS (*dyn_mcpu_ext_opt, *dyn_mcpu_ext_opt, |
|
|
opt->merge_value); |
|
|
else |
|
|
- ARM_CLEAR_FEATURE (selected_cpu, selected_cpu, opt->clear_value); |
|
|
+ ARM_CLEAR_FEATURE (*dyn_mcpu_ext_opt, *dyn_mcpu_ext_opt, |
|
|
+ opt->clear_value); |
|
|
|
|
|
- mcpu_cpu_opt = &selected_cpu; |
|
|
- ARM_MERGE_FEATURE_SETS (cpu_variant, *mcpu_cpu_opt, *mfpu_opt); |
|
|
+ ARM_MERGE_FEATURE_SETS (selected_cpu, *mcpu_cpu_opt, *dyn_mcpu_ext_opt); |
|
|
+ ARM_MERGE_FEATURE_SETS (cpu_variant, selected_cpu, *mfpu_opt); |
|
|
*input_line_pointer = saved_char; |
|
|
demand_empty_rest_of_line (); |
|
|
+ /* Allowing Thumb division instructions for ARMv7 in autodetection rely |
|
|
+ on this return so that duplicate extensions (extensions with the |
|
|
+ same name as a previous extension in the list) are not considered |
|
|
+ for command-line parsing. */ |
|
|
return; |
|
|
} |
|
|
|
|
|
@@ -26576,6 +27320,8 @@ s_arm_fpu (int ignored ATTRIBUTE_UNUSED) |
|
|
{ |
|
|
mfpu_opt = &opt->value; |
|
|
ARM_MERGE_FEATURE_SETS (cpu_variant, *mcpu_cpu_opt, *mfpu_opt); |
|
|
+ if (dyn_mcpu_ext_opt) |
|
|
+ ARM_MERGE_FEATURE_SETS (cpu_variant, cpu_variant, *dyn_mcpu_ext_opt); |
|
|
*input_line_pointer = saved_char; |
|
|
demand_empty_rest_of_line (); |
|
|
return; |
|
|
diff -rup binutils.orig/gas/config/tc-arm.h binutils-2.27/gas/config/tc-arm.h |
|
|
--- binutils.orig/gas/config/tc-arm.h 2017-08-09 10:26:30.032741952 +0100 |
|
|
+++ binutils-2.27/gas/config/tc-arm.h 2017-08-09 11:17:35.442400257 +0100 |
|
|
@@ -118,8 +118,8 @@ extern bfd_boolean tc_start_label_withou |
|
|
extern void arm_md_end (void); |
|
|
bfd_boolean arm_is_eabi (void); |
|
|
|
|
|
-#define md_post_relax_hook aeabi_set_public_attributes () |
|
|
-extern void aeabi_set_public_attributes (void); |
|
|
+#define md_post_relax_hook arm_md_post_relax () |
|
|
+extern void arm_md_post_relax (void); |
|
|
#endif |
|
|
|
|
|
/* NOTE: The fake label creation in stabs.c:s_stab_generic() has |
|
|
diff -rup binutils.orig/gas/doc/c-arm.texi binutils-2.27/gas/doc/c-arm.texi |
|
|
--- binutils.orig/gas/doc/c-arm.texi 2017-08-09 10:26:30.039741874 +0100 |
|
|
+++ binutils-2.27/gas/doc/c-arm.texi 2017-08-09 10:28:00.216732329 +0100 |
|
|
@@ -172,6 +172,7 @@ been added, again in ascending alphabeti |
|
|
The following extensions are currently supported: |
|
|
@code{crc} |
|
|
@code{crypto} (Cryptography Extensions for v8-A architecture, implies @code{fp+simd}), |
|
|
+@code{dotprod} (Dot Product Extensions for v8.2-A architecture, implies @code{fp+simd}), |
|
|
@code{fp} (Floating Point Extensions for v8-A architecture), |
|
|
@code{idiv} (Integer Divide Extensions for v7-A and v7-R architectures), |
|
|
@code{iwmmxt}, |
|
|
@@ -185,7 +186,7 @@ architectures), |
|
|
@code{simd} (Advanced SIMD Extensions for v8-A architecture, implies @code{fp}), |
|
|
@code{virt} (Virtualization Extensions for v7-A architecture, implies |
|
|
@code{idiv}), |
|
|
-@code{pan} (Priviliged Access Never Extensions for v8-A architecture), |
|
|
+@code{pan} (Privileged Access Never Extensions for v8-A architecture), |
|
|
@code{ras} (Reliability, Availability and Serviceability extensions |
|
|
for v8-A architecture), |
|
|
@code{rdma} (ARMv8.1 Advanced SIMD extensions for v8-A architecture, implies |
|
|
@@ -230,6 +231,8 @@ names are recognized: |
|
|
@code{armv8-a}, |
|
|
@code{armv8.1-a}, |
|
|
@code{armv8.2-a}, |
|
|
+@code{armv8.3-a}, |
|
|
+@code{armv8-r}, |
|
|
@code{iwmmxt} |
|
|
@code{iwmmxt2} |
|
|
and |
|
|
@@ -281,7 +284,7 @@ The following format options are recogni |
|
|
@code{arm1136jf-s}, |
|
|
@code{maverick}, |
|
|
@code{neon}, |
|
|
-@code{neon-vfpv4}, |
|
|
+@code{neon-vfpv3}, |
|
|
@code{neon-fp-armv8}, |
|
|
@code{crypto-neon-fp-armv8}, |
|
|
@code{neon-fp-armv8.1} |
|
|
@@ -293,7 +296,7 @@ also affects the way in which the @code{ |
|
|
when assembling little-endian code. |
|
|
|
|
|
The default is dependent on the processor selected. For Architecture 5 or |
|
|
-later, the default is to assembler for VFP instructions; for earlier |
|
|
+later, the default is to assemble for VFP instructions; for earlier |
|
|
architectures the default is to assemble for FPA instructions. |
|
|
|
|
|
@cindex @code{-mthumb} command line option, ARM |
|
|
@@ -931,7 +934,7 @@ between Arm and Thumb instructions and s |
|
|
interworking is not going to be performed. The presence of this |
|
|
directive also implies @code{.thumb} |
|
|
|
|
|
-This directive is not neccessary when generating EABI objects. On these |
|
|
+This directive is not necessary when generating EABI objects. On these |
|
|
targets the encoding is implicit when generating Thumb code. |
|
|
|
|
|
@cindex @code{.thumb_set} directive, ARM |
|
|
@@ -966,7 +969,7 @@ should only be done if it is really nece |
|
|
|
|
|
@cindex @code{.unwind_raw} directive, ARM |
|
|
@item .unwind_raw @var{offset}, @var{byte1}, @dots{} |
|
|
-Insert one of more arbitary unwind opcode bytes, which are known to adjust |
|
|
+Insert one of more arbitrary unwind opcode bytes, which are known to adjust |
|
|
the stack pointer by @var{offset} bytes. |
|
|
|
|
|
For example @code{.unwind_raw 4, 0xb1, 0x01} is equivalent to |
|
|
diff -rup binutils.orig/gas/testsuite/gas/arm/archv8m-cmse-msr-base.d binutils-2.27/gas/testsuite/gas/arm/archv8m-cmse-msr-base.d |
|
|
--- binutils.orig/gas/testsuite/gas/arm/archv8m-cmse-msr-base.d 2017-08-09 10:26:30.056741684 +0100 |
|
|
+++ binutils-2.27/gas/testsuite/gas/arm/archv8m-cmse-msr-base.d 2017-08-09 11:51:59.357287965 +0100 |
|
|
@@ -6,27 +6,71 @@ |
|
|
.*: +file format .*arm.* |
|
|
|
|
|
Disassembly of section .text: |
|
|
-0+.* <[^>]*> f380 8808 msr MSP, r0 |
|
|
-0+.* <[^>]*> f380 8808 msr MSP, r0 |
|
|
-0+.* <[^>]*> f380 8888 msr MSP_NS, r0 |
|
|
-0+.* <[^>]*> f380 8809 msr PSP, r0 |
|
|
-0+.* <[^>]*> f380 8809 msr PSP, r0 |
|
|
-0+.* <[^>]*> f380 8889 msr PSP_NS, r0 |
|
|
-0+.* <[^>]*> f380 8808 msr MSP, r0 |
|
|
-0+.* <[^>]*> f380 8808 msr MSP, r0 |
|
|
-0+.* <[^>]*> f380 8888 msr MSP_NS, r0 |
|
|
-0+.* <[^>]*> f380 8809 msr PSP, r0 |
|
|
-0+.* <[^>]*> f380 8809 msr PSP, r0 |
|
|
-0+.* <[^>]*> f380 8889 msr PSP_NS, r0 |
|
|
-0+.* <[^>]*> f3ef 8008 mrs r0, MSP |
|
|
0+.* <[^>]*> f3ef 8008 mrs r0, MSP |
|
|
0+.* <[^>]*> f3ef 8088 mrs r0, MSP_NS |
|
|
-0+.* <[^>]*> f3ef 8009 mrs r0, PSP |
|
|
-0+.* <[^>]*> f3ef 8009 mrs r0, PSP |
|
|
-0+.* <[^>]*> f3ef 8089 mrs r0, PSP_NS |
|
|
-0+.* <[^>]*> f3ef 8008 mrs r0, MSP |
|
|
0+.* <[^>]*> f3ef 8008 mrs r0, MSP |
|
|
0+.* <[^>]*> f3ef 8088 mrs r0, MSP_NS |
|
|
-0+.* <[^>]*> f3ef 8009 mrs r0, PSP |
|
|
-0+.* <[^>]*> f3ef 8009 mrs r0, PSP |
|
|
-0+.* <[^>]*> f3ef 8089 mrs r0, PSP_NS |
|
|
+0+.* <[^>]*> f3ef 8109 mrs r1, PSP |
|
|
+0+.* <[^>]*> f3ef 8189 mrs r1, PSP_NS |
|
|
+0+.* <[^>]*> f3ef 8109 mrs r1, PSP |
|
|
+0+.* <[^>]*> f3ef 8189 mrs r1, PSP_NS |
|
|
+0+.* <[^>]*> f3ef 820a mrs r2, MSPLIM |
|
|
+0+.* <[^>]*> f3ef 828a mrs r2, MSPLIM_NS |
|
|
+0+.* <[^>]*> f3ef 820a mrs r2, MSPLIM |
|
|
+0+.* <[^>]*> f3ef 828a mrs r2, MSPLIM_NS |
|
|
+0+.* <[^>]*> f3ef 830b mrs r3, PSPLIM |
|
|
+0+.* <[^>]*> f3ef 838b mrs r3, PSPLIM_NS |
|
|
+0+.* <[^>]*> f3ef 830b mrs r3, PSPLIM |
|
|
+0+.* <[^>]*> f3ef 838b mrs r3, PSPLIM_NS |
|
|
+0+.* <[^>]*> f3ef 8410 mrs r4, PRIMASK |
|
|
+0+.* <[^>]*> f3ef 8490 mrs r4, PRIMASK_NS |
|
|
+0+.* <[^>]*> f3ef 8410 mrs r4, PRIMASK |
|
|
+0+.* <[^>]*> f3ef 8490 mrs r4, PRIMASK_NS |
|
|
+0+.* <[^>]*> f3ef 8511 mrs r5, BASEPRI |
|
|
+0+.* <[^>]*> f3ef 8591 mrs r5, BASEPRI_NS |
|
|
+0+.* <[^>]*> f3ef 8511 mrs r5, BASEPRI |
|
|
+0+.* <[^>]*> f3ef 8591 mrs r5, BASEPRI_NS |
|
|
+0+.* <[^>]*> f3ef 8613 mrs r6, FAULTMASK |
|
|
+0+.* <[^>]*> f3ef 8693 mrs r6, FAULTMASK_NS |
|
|
+0+.* <[^>]*> f3ef 8613 mrs r6, FAULTMASK |
|
|
+0+.* <[^>]*> f3ef 8693 mrs r6, FAULTMASK_NS |
|
|
+0+.* <[^>]*> f3ef 8714 mrs r7, CONTROL |
|
|
+0+.* <[^>]*> f3ef 8794 mrs r7, CONTROL_NS |
|
|
+0+.* <[^>]*> f3ef 8714 mrs r7, CONTROL |
|
|
+0+.* <[^>]*> f3ef 8794 mrs r7, CONTROL_NS |
|
|
+0+.* <[^>]*> f3ef 8898 mrs r8, SP_NS |
|
|
+0+.* <[^>]*> f3ef 8898 mrs r8, SP_NS |
|
|
+0+.* <[^>]*> f380 8808 msr MSP, r0 |
|
|
+0+.* <[^>]*> f380 8888 msr MSP_NS, r0 |
|
|
+0+.* <[^>]*> f380 8808 msr MSP, r0 |
|
|
+0+.* <[^>]*> f380 8888 msr MSP_NS, r0 |
|
|
+0+.* <[^>]*> f381 8809 msr PSP, r1 |
|
|
+0+.* <[^>]*> f381 8889 msr PSP_NS, r1 |
|
|
+0+.* <[^>]*> f381 8809 msr PSP, r1 |
|
|
+0+.* <[^>]*> f381 8889 msr PSP_NS, r1 |
|
|
+0+.* <[^>]*> f382 880a msr MSPLIM, r2 |
|
|
+0+.* <[^>]*> f382 888a msr MSPLIM_NS, r2 |
|
|
+0+.* <[^>]*> f382 880a msr MSPLIM, r2 |
|
|
+0+.* <[^>]*> f382 888a msr MSPLIM_NS, r2 |
|
|
+0+.* <[^>]*> f383 880b msr PSPLIM, r3 |
|
|
+0+.* <[^>]*> f383 888b msr PSPLIM_NS, r3 |
|
|
+0+.* <[^>]*> f383 880b msr PSPLIM, r3 |
|
|
+0+.* <[^>]*> f383 888b msr PSPLIM_NS, r3 |
|
|
+0+.* <[^>]*> f384 8810 msr PRIMASK, r4 |
|
|
+0+.* <[^>]*> f384 8890 msr PRIMASK_NS, r4 |
|
|
+0+.* <[^>]*> f384 8810 msr PRIMASK, r4 |
|
|
+0+.* <[^>]*> f384 8890 msr PRIMASK_NS, r4 |
|
|
+0+.* <[^>]*> f385 8811 msr BASEPRI, r5 |
|
|
+0+.* <[^>]*> f385 8891 msr BASEPRI_NS, r5 |
|
|
+0+.* <[^>]*> f385 8811 msr BASEPRI, r5 |
|
|
+0+.* <[^>]*> f385 8891 msr BASEPRI_NS, r5 |
|
|
+0+.* <[^>]*> f386 8813 msr FAULTMASK, r6 |
|
|
+0+.* <[^>]*> f386 8893 msr FAULTMASK_NS, r6 |
|
|
+0+.* <[^>]*> f386 8813 msr FAULTMASK, r6 |
|
|
+0+.* <[^>]*> f386 8893 msr FAULTMASK_NS, r6 |
|
|
+0+.* <[^>]*> f387 8814 msr CONTROL, r7 |
|
|
+0+.* <[^>]*> f387 8894 msr CONTROL_NS, r7 |
|
|
+0+.* <[^>]*> f387 8814 msr CONTROL, r7 |
|
|
+0+.* <[^>]*> f387 8894 msr CONTROL_NS, r7 |
|
|
+0+.* <[^>]*> f388 8898 msr SP_NS, r8 |
|
|
+0+.* <[^>]*> f388 8898 msr SP_NS, r8 |
|
|
diff -rup binutils.orig/gas/testsuite/gas/arm/archv8m-cmse-msr-main.d binutils-2.27/gas/testsuite/gas/arm/archv8m-cmse-msr-main.d |
|
|
--- binutils.orig/gas/testsuite/gas/arm/archv8m-cmse-msr-main.d 2017-08-09 10:26:30.056741684 +0100 |
|
|
+++ binutils-2.27/gas/testsuite/gas/arm/archv8m-cmse-msr-main.d 2017-08-09 11:52:33.776902849 +0100 |
|
|
@@ -6,27 +6,71 @@ |
|
|
.*: +file format .*arm.* |
|
|
|
|
|
Disassembly of section .text: |
|
|
-0+.* <[^>]*> f380 8808 msr MSP, r0 |
|
|
-0+.* <[^>]*> f380 8808 msr MSP, r0 |
|
|
-0+.* <[^>]*> f380 8888 msr MSP_NS, r0 |
|
|
-0+.* <[^>]*> f380 8809 msr PSP, r0 |
|
|
-0+.* <[^>]*> f380 8809 msr PSP, r0 |
|
|
-0+.* <[^>]*> f380 8889 msr PSP_NS, r0 |
|
|
-0+.* <[^>]*> f380 8808 msr MSP, r0 |
|
|
-0+.* <[^>]*> f380 8808 msr MSP, r0 |
|
|
-0+.* <[^>]*> f380 8888 msr MSP_NS, r0 |
|
|
-0+.* <[^>]*> f380 8809 msr PSP, r0 |
|
|
-0+.* <[^>]*> f380 8809 msr PSP, r0 |
|
|
-0+.* <[^>]*> f380 8889 msr PSP_NS, r0 |
|
|
-0+.* <[^>]*> f3ef 8008 mrs r0, MSP |
|
|
0+.* <[^>]*> f3ef 8008 mrs r0, MSP |
|
|
0+.* <[^>]*> f3ef 8088 mrs r0, MSP_NS |
|
|
-0+.* <[^>]*> f3ef 8009 mrs r0, PSP |
|
|
-0+.* <[^>]*> f3ef 8009 mrs r0, PSP |
|
|
-0+.* <[^>]*> f3ef 8089 mrs r0, PSP_NS |
|
|
-0+.* <[^>]*> f3ef 8008 mrs r0, MSP |
|
|
0+.* <[^>]*> f3ef 8008 mrs r0, MSP |
|
|
0+.* <[^>]*> f3ef 8088 mrs r0, MSP_NS |
|
|
-0+.* <[^>]*> f3ef 8009 mrs r0, PSP |
|
|
-0+.* <[^>]*> f3ef 8009 mrs r0, PSP |
|
|
-0+.* <[^>]*> f3ef 8089 mrs r0, PSP_NS |
|
|
+0+.* <[^>]*> f3ef 8109 mrs r1, PSP |
|
|
+0+.* <[^>]*> f3ef 8189 mrs r1, PSP_NS |
|
|
+0+.* <[^>]*> f3ef 8109 mrs r1, PSP |
|
|
+0+.* <[^>]*> f3ef 8189 mrs r1, PSP_NS |
|
|
+0+.* <[^>]*> f3ef 820a mrs r2, MSPLIM |
|
|
+0+.* <[^>]*> f3ef 828a mrs r2, MSPLIM_NS |
|
|
+0+.* <[^>]*> f3ef 820a mrs r2, MSPLIM |
|
|
+0+.* <[^>]*> f3ef 828a mrs r2, MSPLIM_NS |
|
|
+0+.* <[^>]*> f3ef 830b mrs r3, PSPLIM |
|
|
+0+.* <[^>]*> f3ef 838b mrs r3, PSPLIM_NS |
|
|
+0+.* <[^>]*> f3ef 830b mrs r3, PSPLIM |
|
|
+0+.* <[^>]*> f3ef 838b mrs r3, PSPLIM_NS |
|
|
+0+.* <[^>]*> f3ef 8410 mrs r4, PRIMASK |
|
|
+0+.* <[^>]*> f3ef 8490 mrs r4, PRIMASK_NS |
|
|
+0+.* <[^>]*> f3ef 8410 mrs r4, PRIMASK |
|
|
+0+.* <[^>]*> f3ef 8490 mrs r4, PRIMASK_NS |
|
|
+0+.* <[^>]*> f3ef 8511 mrs r5, BASEPRI |
|
|
+0+.* <[^>]*> f3ef 8591 mrs r5, BASEPRI_NS |
|
|
+0+.* <[^>]*> f3ef 8511 mrs r5, BASEPRI |
|
|
+0+.* <[^>]*> f3ef 8591 mrs r5, BASEPRI_NS |
|
|
+0+.* <[^>]*> f3ef 8613 mrs r6, FAULTMASK |
|
|
+0+.* <[^>]*> f3ef 8693 mrs r6, FAULTMASK_NS |
|
|
+0+.* <[^>]*> f3ef 8613 mrs r6, FAULTMASK |
|
|
+0+.* <[^>]*> f3ef 8693 mrs r6, FAULTMASK_NS |
|
|
+0+.* <[^>]*> f3ef 8714 mrs r7, CONTROL |
|
|
+0+.* <[^>]*> f3ef 8794 mrs r7, CONTROL_NS |
|
|
+0+.* <[^>]*> f3ef 8714 mrs r7, CONTROL |
|
|
+0+.* <[^>]*> f3ef 8794 mrs r7, CONTROL_NS |
|
|
+0+.* <[^>]*> f3ef 8898 mrs r8, SP_NS |
|
|
+0+.* <[^>]*> f3ef 8898 mrs r8, SP_NS |
|
|
+0+.* <[^>]*> f380 8808 msr MSP, r0 |
|
|
+0+.* <[^>]*> f380 8888 msr MSP_NS, r0 |
|
|
+0+.* <[^>]*> f380 8808 msr MSP, r0 |
|
|
+0+.* <[^>]*> f380 8888 msr MSP_NS, r0 |
|
|
+0+.* <[^>]*> f381 8809 msr PSP, r1 |
|
|
+0+.* <[^>]*> f381 8889 msr PSP_NS, r1 |
|
|
+0+.* <[^>]*> f381 8809 msr PSP, r1 |
|
|
+0+.* <[^>]*> f381 8889 msr PSP_NS, r1 |
|
|
+0+.* <[^>]*> f382 880a msr MSPLIM, r2 |
|
|
+0+.* <[^>]*> f382 888a msr MSPLIM_NS, r2 |
|
|
+0+.* <[^>]*> f382 880a msr MSPLIM, r2 |
|
|
+0+.* <[^>]*> f382 888a msr MSPLIM_NS, r2 |
|
|
+0+.* <[^>]*> f383 880b msr PSPLIM, r3 |
|
|
+0+.* <[^>]*> f383 888b msr PSPLIM_NS, r3 |
|
|
+0+.* <[^>]*> f383 880b msr PSPLIM, r3 |
|
|
+0+.* <[^>]*> f383 888b msr PSPLIM_NS, r3 |
|
|
+0+.* <[^>]*> f384 8810 msr PRIMASK, r4 |
|
|
+0+.* <[^>]*> f384 8890 msr PRIMASK_NS, r4 |
|
|
+0+.* <[^>]*> f384 8810 msr PRIMASK, r4 |
|
|
+0+.* <[^>]*> f384 8890 msr PRIMASK_NS, r4 |
|
|
+0+.* <[^>]*> f385 8811 msr BASEPRI, r5 |
|
|
+0+.* <[^>]*> f385 8891 msr BASEPRI_NS, r5 |
|
|
+0+.* <[^>]*> f385 8811 msr BASEPRI, r5 |
|
|
+0+.* <[^>]*> f385 8891 msr BASEPRI_NS, r5 |
|
|
+0+.* <[^>]*> f386 8813 msr FAULTMASK, r6 |
|
|
+0+.* <[^>]*> f386 8893 msr FAULTMASK_NS, r6 |
|
|
+0+.* <[^>]*> f386 8813 msr FAULTMASK, r6 |
|
|
+0+.* <[^>]*> f386 8893 msr FAULTMASK_NS, r6 |
|
|
+0+.* <[^>]*> f387 8814 msr CONTROL, r7 |
|
|
+0+.* <[^>]*> f387 8894 msr CONTROL_NS, r7 |
|
|
+0+.* <[^>]*> f387 8814 msr CONTROL, r7 |
|
|
+0+.* <[^>]*> f387 8894 msr CONTROL_NS, r7 |
|
|
+0+.* <[^>]*> f388 8898 msr SP_NS, r8 |
|
|
+0+.* <[^>]*> f388 8898 msr SP_NS, r8 |
|
|
diff -rup binutils.orig/gas/testsuite/gas/arm/archv8m-cmse-msr.s binutils-2.27/gas/testsuite/gas/arm/archv8m-cmse-msr.s |
|
|
--- binutils.orig/gas/testsuite/gas/arm/archv8m-cmse-msr.s 2017-08-09 10:26:30.056741684 +0100 |
|
|
+++ binutils-2.27/gas/testsuite/gas/arm/archv8m-cmse-msr.s 2017-08-09 11:50:44.728124484 +0100 |
|
|
@@ -1,25 +1,109 @@ |
|
|
T: |
|
|
-msr MSP, r0 |
|
|
-msr MSP_S, r0 |
|
|
-msr MSP_NS, r0 |
|
|
-msr PSP, r0 |
|
|
-msr PSP_S, r0 |
|
|
-msr PSP_NS, r0 |
|
|
-msr msp, r0 |
|
|
-msr msp_s, r0 |
|
|
-msr msp_ns, r0 |
|
|
-msr psp, r0 |
|
|
-msr psp_s, r0 |
|
|
-msr psp_ns, r0 |
|
|
+## MRS ## |
|
|
+ |
|
|
+# MSP |
|
|
mrs r0, MSP |
|
|
-mrs r0, MSP_S |
|
|
mrs r0, MSP_NS |
|
|
-mrs r0, PSP |
|
|
-mrs r0, PSP_S |
|
|
-mrs r0, PSP_NS |
|
|
mrs r0, msp |
|
|
-mrs r0, msp_s |
|
|
mrs r0, msp_ns |
|
|
-mrs r0, psp |
|
|
-mrs r0, psp_s |
|
|
-mrs r0, psp_ns |
|
|
+ |
|
|
+# PSP |
|
|
+mrs r1, PSP |
|
|
+mrs r1, PSP_NS |
|
|
+mrs r1, psp |
|
|
+mrs r1, psp_ns |
|
|
+ |
|
|
+# MSPLIM |
|
|
+mrs r2, MSPLIM |
|
|
+mrs r2, MSPLIM_NS |
|
|
+mrs r2, msplim |
|
|
+mrs r2, msplim_ns |
|
|
+ |
|
|
+# PSPLIM |
|
|
+mrs r3, PSPLIM |
|
|
+mrs r3, PSPLIM_NS |
|
|
+mrs r3, psplim |
|
|
+mrs r3, psplim_ns |
|
|
+ |
|
|
+# PRIMASK |
|
|
+mrs r4, PRIMASK |
|
|
+mrs r4, PRIMASK_NS |
|
|
+mrs r4, primask |
|
|
+mrs r4, primask_ns |
|
|
+ |
|
|
+# BASEPRI |
|
|
+mrs r5, BASEPRI |
|
|
+mrs r5, BASEPRI_NS |
|
|
+mrs r5, basepri |
|
|
+mrs r5, basepri_ns |
|
|
+ |
|
|
+# FAULTMASK |
|
|
+mrs r6, FAULTMASK |
|
|
+mrs r6, FAULTMASK_NS |
|
|
+mrs r6, faultmask |
|
|
+mrs r6, faultmask_ns |
|
|
+ |
|
|
+# CONTROL |
|
|
+mrs r7, CONTROL |
|
|
+mrs r7, CONTROL_NS |
|
|
+mrs r7, control |
|
|
+mrs r7, control_ns |
|
|
+ |
|
|
+# SP_NS |
|
|
+mrs r8, SP_NS |
|
|
+mrs r8, sp_ns |
|
|
+ |
|
|
+ |
|
|
+## MSR ## |
|
|
+ |
|
|
+# MSP |
|
|
+msr MSP, r0 |
|
|
+msr MSP_NS, r0 |
|
|
+msr msp, r0 |
|
|
+msr msp_ns, r0 |
|
|
+ |
|
|
+# PSP |
|
|
+msr PSP, r1 |
|
|
+msr PSP_NS, r1 |
|
|
+msr psp, r1 |
|
|
+msr psp_ns, r1 |
|
|
+ |
|
|
+# MSPLIM |
|
|
+msr MSPLIM, r2 |
|
|
+msr MSPLIM_NS, r2 |
|
|
+msr msplim, r2 |
|
|
+msr msplim_ns, r2 |
|
|
+ |
|
|
+# PSPLIM |
|
|
+msr PSPLIM, r3 |
|
|
+msr PSPLIM_NS, r3 |
|
|
+msr psplim, r3 |
|
|
+msr psplim_ns, r3 |
|
|
+ |
|
|
+# PRIMASK |
|
|
+msr PRIMASK, r4 |
|
|
+msr PRIMASK_NS, r4 |
|
|
+msr primask, r4 |
|
|
+msr primask_ns, r4 |
|
|
+ |
|
|
+# BASEPRI |
|
|
+msr BASEPRI, r5 |
|
|
+msr BASEPRI_NS, r5 |
|
|
+msr basepri, r5 |
|
|
+msr basepri_ns, r5 |
|
|
+ |
|
|
+# FAULTMASK |
|
|
+msr FAULTMASK, r6 |
|
|
+msr FAULTMASK_NS, r6 |
|
|
+msr faultmask, r6 |
|
|
+msr faultmask_ns, r6 |
|
|
+ |
|
|
+# CONTROL |
|
|
+msr CONTROL, r7 |
|
|
+msr CONTROL_NS, r7 |
|
|
+msr control, r7 |
|
|
+msr control_ns, r7 |
|
|
+ |
|
|
+# SP_NS |
|
|
+msr SP_NS, r8 |
|
|
+msr sp_ns, r8 |
|
|
diff -rup binutils.orig/gas/testsuite/gas/arm/archv8m-main-dsp-4.d binutils-2.27/gas/testsuite/gas/arm/archv8m-main-dsp-4.d |
|
|
--- binutils.orig/gas/testsuite/gas/arm/archv8m-main-dsp-4.d 2017-08-09 10:26:30.056741684 +0100 |
|
|
+++ binutils-2.27/gas/testsuite/gas/arm/archv8m-main-dsp-4.d 2017-08-09 11:54:37.162524973 +0100 |
|
|
@@ -6,27 +6,71 @@ |
|
|
.*: +file format .*arm.* |
|
|
|
|
|
Disassembly of section .text: |
|
|
-0+.* <[^>]*> f380 8808 msr MSP, r0 |
|
|
-0+.* <[^>]*> f380 8808 msr MSP, r0 |
|
|
-0+.* <[^>]*> f380 8888 msr MSP_NS, r0 |
|
|
-0+.* <[^>]*> f380 8809 msr PSP, r0 |
|
|
-0+.* <[^>]*> f380 8809 msr PSP, r0 |
|
|
-0+.* <[^>]*> f380 8889 msr PSP_NS, r0 |
|
|
-0+.* <[^>]*> f380 8808 msr MSP, r0 |
|
|
-0+.* <[^>]*> f380 8808 msr MSP, r0 |
|
|
-0+.* <[^>]*> f380 8888 msr MSP_NS, r0 |
|
|
-0+.* <[^>]*> f380 8809 msr PSP, r0 |
|
|
-0+.* <[^>]*> f380 8809 msr PSP, r0 |
|
|
-0+.* <[^>]*> f380 8889 msr PSP_NS, r0 |
|
|
-0+.* <[^>]*> f3ef 8008 mrs r0, MSP |
|
|
0+.* <[^>]*> f3ef 8008 mrs r0, MSP |
|
|
0+.* <[^>]*> f3ef 8088 mrs r0, MSP_NS |
|
|
-0+.* <[^>]*> f3ef 8009 mrs r0, PSP |
|
|
-0+.* <[^>]*> f3ef 8009 mrs r0, PSP |
|
|
-0+.* <[^>]*> f3ef 8089 mrs r0, PSP_NS |
|
|
-0+.* <[^>]*> f3ef 8008 mrs r0, MSP |
|
|
0+.* <[^>]*> f3ef 8008 mrs r0, MSP |
|
|
0+.* <[^>]*> f3ef 8088 mrs r0, MSP_NS |
|
|
-0+.* <[^>]*> f3ef 8009 mrs r0, PSP |
|
|
-0+.* <[^>]*> f3ef 8009 mrs r0, PSP |
|
|
-0+.* <[^>]*> f3ef 8089 mrs r0, PSP_NS |
|
|
+0+.* <[^>]*> f3ef 8109 mrs r1, PSP |
|
|
+0+.* <[^>]*> f3ef 8189 mrs r1, PSP_NS |
|
|
+0+.* <[^>]*> f3ef 8109 mrs r1, PSP |
|
|
+0+.* <[^>]*> f3ef 8189 mrs r1, PSP_NS |
|
|
+0+.* <[^>]*> f3ef 820a mrs r2, MSPLIM |
|
|
+0+.* <[^>]*> f3ef 828a mrs r2, MSPLIM_NS |
|
|
+0+.* <[^>]*> f3ef 820a mrs r2, MSPLIM |
|
|
+0+.* <[^>]*> f3ef 828a mrs r2, MSPLIM_NS |
|
|
+0+.* <[^>]*> f3ef 830b mrs r3, PSPLIM |
|
|
+0+.* <[^>]*> f3ef 838b mrs r3, PSPLIM_NS |
|
|
+0+.* <[^>]*> f3ef 830b mrs r3, PSPLIM |
|
|
+0+.* <[^>]*> f3ef 838b mrs r3, PSPLIM_NS |
|
|
+0+.* <[^>]*> f3ef 8410 mrs r4, PRIMASK |
|
|
+0+.* <[^>]*> f3ef 8490 mrs r4, PRIMASK_NS |
|
|
+0+.* <[^>]*> f3ef 8410 mrs r4, PRIMASK |
|
|
+0+.* <[^>]*> f3ef 8490 mrs r4, PRIMASK_NS |
|
|
+0+.* <[^>]*> f3ef 8511 mrs r5, BASEPRI |
|
|
+0+.* <[^>]*> f3ef 8591 mrs r5, BASEPRI_NS |
|
|
+0+.* <[^>]*> f3ef 8511 mrs r5, BASEPRI |
|
|
+0+.* <[^>]*> f3ef 8591 mrs r5, BASEPRI_NS |
|
|
+0+.* <[^>]*> f3ef 8613 mrs r6, FAULTMASK |
|
|
+0+.* <[^>]*> f3ef 8693 mrs r6, FAULTMASK_NS |
|
|
+0+.* <[^>]*> f3ef 8613 mrs r6, FAULTMASK |
|
|
+0+.* <[^>]*> f3ef 8693 mrs r6, FAULTMASK_NS |
|
|
+0+.* <[^>]*> f3ef 8714 mrs r7, CONTROL |
|
|
+0+.* <[^>]*> f3ef 8794 mrs r7, CONTROL_NS |
|
|
+0+.* <[^>]*> f3ef 8714 mrs r7, CONTROL |
|
|
+0+.* <[^>]*> f3ef 8794 mrs r7, CONTROL_NS |
|
|
+0+.* <[^>]*> f3ef 8898 mrs r8, SP_NS |
|
|
+0+.* <[^>]*> f3ef 8898 mrs r8, SP_NS |
|
|
+0+.* <[^>]*> f380 8808 msr MSP, r0 |
|
|
+0+.* <[^>]*> f380 8888 msr MSP_NS, r0 |
|
|
+0+.* <[^>]*> f380 8808 msr MSP, r0 |
|
|
+0+.* <[^>]*> f380 8888 msr MSP_NS, r0 |
|
|
+0+.* <[^>]*> f381 8809 msr PSP, r1 |
|
|
+0+.* <[^>]*> f381 8889 msr PSP_NS, r1 |
|
|
+0+.* <[^>]*> f381 8809 msr PSP, r1 |
|
|
+0+.* <[^>]*> f381 8889 msr PSP_NS, r1 |
|
|
+0+.* <[^>]*> f382 880a msr MSPLIM, r2 |
|
|
+0+.* <[^>]*> f382 888a msr MSPLIM_NS, r2 |
|
|
+0+.* <[^>]*> f382 880a msr MSPLIM, r2 |
|
|
+0+.* <[^>]*> f382 888a msr MSPLIM_NS, r2 |
|
|
+0+.* <[^>]*> f383 880b msr PSPLIM, r3 |
|
|
+0+.* <[^>]*> f383 888b msr PSPLIM_NS, r3 |
|
|
+0+.* <[^>]*> f383 880b msr PSPLIM, r3 |
|
|
+0+.* <[^>]*> f383 888b msr PSPLIM_NS, r3 |
|
|
+0+.* <[^>]*> f384 8810 msr PRIMASK, r4 |
|
|
+0+.* <[^>]*> f384 8890 msr PRIMASK_NS, r4 |
|
|
+0+.* <[^>]*> f384 8810 msr PRIMASK, r4 |
|
|
+0+.* <[^>]*> f384 8890 msr PRIMASK_NS, r4 |
|
|
+0+.* <[^>]*> f385 8811 msr BASEPRI, r5 |
|
|
+0+.* <[^>]*> f385 8891 msr BASEPRI_NS, r5 |
|
|
+0+.* <[^>]*> f385 8811 msr BASEPRI, r5 |
|
|
+0+.* <[^>]*> f385 8891 msr BASEPRI_NS, r5 |
|
|
+0+.* <[^>]*> f386 8813 msr FAULTMASK, r6 |
|
|
+0+.* <[^>]*> f386 8893 msr FAULTMASK_NS, r6 |
|
|
+0+.* <[^>]*> f386 8813 msr FAULTMASK, r6 |
|
|
+0+.* <[^>]*> f386 8893 msr FAULTMASK_NS, r6 |
|
|
+0+.* <[^>]*> f387 8814 msr CONTROL, r7 |
|
|
+0+.* <[^>]*> f387 8894 msr CONTROL_NS, r7 |
|
|
+0+.* <[^>]*> f387 8814 msr CONTROL, r7 |
|
|
+0+.* <[^>]*> f387 8894 msr CONTROL_NS, r7 |
|
|
+0+.* <[^>]*> f388 8898 msr SP_NS, r8 |
|
|
+0+.* <[^>]*> f388 8898 msr SP_NS, r8 |
|
|
diff -rup binutils.orig/gas/testsuite/gas/arm/attr-march-armv1.d binutils-2.27/gas/testsuite/gas/arm/attr-march-armv1.d |
|
|
--- binutils.orig/gas/testsuite/gas/arm/attr-march-armv1.d 2017-08-09 10:26:30.058741661 +0100 |
|
|
+++ binutils-2.27/gas/testsuite/gas/arm/attr-march-armv1.d 2017-08-09 11:56:00.992588823 +0100 |
|
|
@@ -8,5 +8,4 @@ |
|
|
Attribute Section: aeabi |
|
|
File Attributes |
|
|
Tag_CPU_name: "1" |
|
|
- Tag_CPU_arch: v4 |
|
|
Tag_ARM_ISA_use: Yes |
|
|
diff -rup binutils.orig/gas/testsuite/gas/arm/attr-march-armv2a.d binutils-2.27/gas/testsuite/gas/arm/attr-march-armv2a.d |
|
|
--- binutils.orig/gas/testsuite/gas/arm/attr-march-armv2a.d 2017-08-09 10:26:30.058741661 +0100 |
|
|
+++ binutils-2.27/gas/testsuite/gas/arm/attr-march-armv2a.d 2017-08-09 11:56:27.548292268 +0100 |
|
|
@@ -8,5 +8,4 @@ |
|
|
Attribute Section: aeabi |
|
|
File Attributes |
|
|
Tag_CPU_name: "2A" |
|
|
- Tag_CPU_arch: v4 |
|
|
Tag_ARM_ISA_use: Yes |
|
|
diff -rup binutils.orig/gas/testsuite/gas/arm/attr-march-armv2.d binutils-2.27/gas/testsuite/gas/arm/attr-march-armv2.d |
|
|
--- binutils.orig/gas/testsuite/gas/arm/attr-march-armv2.d 2017-08-09 10:26:30.058741661 +0100 |
|
|
+++ binutils-2.27/gas/testsuite/gas/arm/attr-march-armv2.d 2017-08-09 11:56:09.713491434 +0100 |
|
|
@@ -8,5 +8,4 @@ |
|
|
Attribute Section: aeabi |
|
|
File Attributes |
|
|
Tag_CPU_name: "2" |
|
|
- Tag_CPU_arch: v4 |
|
|
Tag_ARM_ISA_use: Yes |
|
|
diff -rup binutils.orig/gas/testsuite/gas/arm/attr-march-armv2s.d binutils-2.27/gas/testsuite/gas/arm/attr-march-armv2s.d |
|
|
--- binutils.orig/gas/testsuite/gas/arm/attr-march-armv2s.d 2017-08-09 10:26:30.058741661 +0100 |
|
|
+++ binutils-2.27/gas/testsuite/gas/arm/attr-march-armv2s.d 2017-08-09 11:56:35.794200184 +0100 |
|
|
@@ -8,5 +8,4 @@ |
|
|
Attribute Section: aeabi |
|
|
File Attributes |
|
|
Tag_CPU_name: "2S" |
|
|
- Tag_CPU_arch: v4 |
|
|
Tag_ARM_ISA_use: Yes |
|
|
diff -rup binutils.orig/gas/testsuite/gas/arm/attr-march-armv3.d binutils-2.27/gas/testsuite/gas/arm/attr-march-armv3.d |
|
|
--- binutils.orig/gas/testsuite/gas/arm/attr-march-armv3.d 2017-08-09 10:26:30.058741661 +0100 |
|
|
+++ binutils-2.27/gas/testsuite/gas/arm/attr-march-armv3.d 2017-08-09 11:56:52.435014353 +0100 |
|
|
@@ -8,5 +8,4 @@ |
|
|
Attribute Section: aeabi |
|
|
File Attributes |
|
|
Tag_CPU_name: "3" |
|
|
- Tag_CPU_arch: v4 |
|
|
Tag_ARM_ISA_use: Yes |
|
|
diff -rup binutils.orig/gas/testsuite/gas/arm/attr-march-armv3m.d binutils-2.27/gas/testsuite/gas/arm/attr-march-armv3m.d |
|
|
--- binutils.orig/gas/testsuite/gas/arm/attr-march-armv3m.d 2017-08-09 10:26:30.058741661 +0100 |
|
|
+++ binutils-2.27/gas/testsuite/gas/arm/attr-march-armv3m.d 2017-08-09 11:56:57.715955379 +0100 |
|
|
@@ -8,5 +8,4 @@ |
|
|
Attribute Section: aeabi |
|
|
File Attributes |
|
|
Tag_CPU_name: "3M" |
|
|
- Tag_CPU_arch: v4 |
|
|
Tag_ARM_ISA_use: Yes |
|
|
diff -rup binutils.orig/gas/testsuite/gas/arm/ldr-bad.l binutils-2.27/gas/testsuite/gas/arm/ldr-bad.l |
|
|
--- binutils.orig/gas/testsuite/gas/arm/ldr-bad.l 2017-08-09 10:26:30.062741616 +0100 |
|
|
+++ binutils-2.27/gas/testsuite/gas/arm/ldr-bad.l 2017-08-09 11:59:45.777078600 +0100 |
|
|
@@ -1,7 +1,7 @@ |
|
|
[^:]*: Assembler messages: |
|
|
[^:]*:5: Warning: destination register same as write-back base |
|
|
-[^:]*:9: Error: ldr to register 15 must be 4-byte alligned -- `ldr r15,\[r15,#5\]' |
|
|
-[^:]*:12: Error: ldr to register 15 must be 4-byte alligned -- `ldr r15,.-0xab7' |
|
|
+[^:]*:9: Error: ldr to register 15 must be 4-byte aligned -- `ldr r15,\[r15,#5\]' |
|
|
+[^:]*:12: Error: ldr to register 15 must be 4-byte aligned -- `ldr r15,.-0xab7' |
|
|
[^:]*:15: Warning: destination register same as write-back base |
|
|
[^:]*:16: Error: cannot use register index with PC-relative addressing -- `ldr r2,\[r15,r2\]!' |
|
|
[^:]*:19: Error: cannot use register index with PC-relative addressing -- `ldr r1,\[r1,r15\]' |
|
|
diff -rup binutils.orig/gas/testsuite/gas/arm/ldr-t-bad.l binutils-2.27/gas/testsuite/gas/arm/ldr-t-bad.l |
|
|
--- binutils.orig/gas/testsuite/gas/arm/ldr-t-bad.l 2017-08-09 10:26:30.062741616 +0100 |
|
|
+++ binutils-2.27/gas/testsuite/gas/arm/ldr-t-bad.l 2017-08-09 12:00:06.268849764 +0100 |
|
|
@@ -1,9 +1,9 @@ |
|
|
[^:]*: Assembler messages: |
|
|
[^:]*:8: Error: registers may not be the same -- `ldr r1,\[r1,#5\]!' |
|
|
-[^:]*:12: Error: ldr to register 15 must be 4-byte alligned -- `ldr r15,\[r15,#5\]' |
|
|
+[^:]*:12: Error: ldr to register 15 must be 4-byte aligned -- `ldr r15,\[r15,#5\]' |
|
|
[^:]*:16: Error: branch must be last instruction in IT block -- `ldrge r15,\[r15,#4\]' |
|
|
[^:]*:25: Error: branch must be last instruction in IT block -- `ldrge r15,.0x4' |
|
|
-[^:]*:30: Error: ldr to register 15 must be 4-byte alligned -- `ldr r15,.-0xab7' |
|
|
+[^:]*:30: Error: ldr to register 15 must be 4-byte aligned -- `ldr r15,.-0xab7' |
|
|
[^:]*:36: Error: branch must be last instruction in IT block -- `ldrge r15,\[r15,r1\]' |
|
|
[^:]*:41: Error: r13 not allowed here -- `ldr r1,\[r2,r13\]' |
|
|
[^:]*:42: Error: r15 not allowed here -- `ldr r2,\[r2,r15\]' |
|
|
diff -rup binutils.orig/gas/testsuite/gas/arm/ld-sp-warn.l binutils-2.27/gas/testsuite/gas/arm/ld-sp-warn.l |
|
|
--- binutils.orig/gas/testsuite/gas/arm/ld-sp-warn.l 2017-08-09 10:26:30.062741616 +0100 |
|
|
+++ binutils-2.27/gas/testsuite/gas/arm/ld-sp-warn.l 2017-08-09 11:59:02.223564973 +0100 |
|
|
@@ -2,4 +2,3 @@ |
|
|
[^:]*:3: Warning: This instruction may be unpredictable if executed on M-profile cores with interrupts enabled. |
|
|
[^:]*:4: Warning: This instruction may be unpredictable if executed on M-profile cores with interrupts enabled. |
|
|
[^:]*:7: Error: Thumb does not support register indexing with writeback -- `ldr r1,\[r0,r1\]!' |
|
|
-[^:]*:8: Error: r13 not allowed here -- `ldrsb sp,\[r2,#16\]!' |
|
|
diff -rup binutils.orig/gas/testsuite/gas/arm/strex-bad-t.d binutils-2.27/gas/testsuite/gas/arm/strex-bad-t.d |
|
|
--- binutils.orig/gas/testsuite/gas/arm/strex-bad-t.d 2017-08-09 10:26:30.066741571 +0100 |
|
|
+++ binutils-2.27/gas/testsuite/gas/arm/strex-bad-t.d 2017-08-09 12:01:22.679996462 +0100 |
|
|
@@ -1,3 +1,4 @@ |
|
|
# name: Bad addressing modes STREXH/STREXB. - THUMB |
|
|
+# as: -march=armv7-a |
|
|
# error-output: strex-bad-t.l |
|
|
|
|
|
diff -rup binutils.orig/gas/testsuite/gas/arm/thumb2_ldr_immediate_highregs_armv6t2.d binutils-2.27/gas/testsuite/gas/arm/thumb2_ldr_immediate_highregs_armv6t2.d |
|
|
--- binutils.orig/gas/testsuite/gas/arm/thumb2_ldr_immediate_highregs_armv6t2.d 2017-08-09 10:26:30.067741560 +0100 |
|
|
+++ binutils-2.27/gas/testsuite/gas/arm/thumb2_ldr_immediate_highregs_armv6t2.d 2017-08-09 11:57:45.943416812 +0100 |
|
|
@@ -6,19 +6,23 @@ |
|
|
.*: +file format .*arm.* |
|
|
|
|
|
Disassembly of section \.text: |
|
|
-0[0-9a-f]+ <[^>]+> 2000[[:space:]]+movs[[:space:]]+r0, #0.* |
|
|
-0[0-9a-f]+ <[^>]+> 2108[[:space:]]+movs[[:space:]]+r1, #8.* |
|
|
-0[0-9a-f]+ <[^>]+> 2251[[:space:]]+movs[[:space:]]+r2, #81.* |
|
|
-0[0-9a-f]+ <[^>]+> 231f[[:space:]]+movs[[:space:]]+r3, #31.* |
|
|
-0[0-9a-f]+ <[^>]+> 242f[[:space:]]+movs[[:space:]]+r4, #47.* |
|
|
-0[0-9a-f]+ <[^>]+> 253f[[:space:]]+movs[[:space:]]+r5, #63.* |
|
|
-0[0-9a-f]+ <[^>]+> 2680[[:space:]]+movs[[:space:]]+r6, #128.* |
|
|
-0[0-9a-f]+ <[^>]+> 27ff[[:space:]]+movs[[:space:]]+r7, #255.* |
|
|
+0[0-9a-f]+ <[^>]+> f04f 0000[[:space:]]+mov\.w[[:space:]]+r0, #0.* |
|
|
+0[0-9a-f]+ <[^>]+> f04f 0108[[:space:]]+mov\.w[[:space:]]+r1, #8.* |
|
|
+0[0-9a-f]+ <[^>]+> f04f 0251[[:space:]]+mov\.w[[:space:]]+r2, #81.* |
|
|
+0[0-9a-f]+ <[^>]+> f04f 031f[[:space:]]+mov\.w[[:space:]]+r3, #31.* |
|
|
+0[0-9a-f]+ <[^>]+> f04f 042f[[:space:]]+mov\.w[[:space:]]+r4, #47.* |
|
|
+0[0-9a-f]+ <[^>]+> f04f 053f[[:space:]]+mov\.w[[:space:]]+r5, #63.* |
|
|
+0[0-9a-f]+ <[^>]+> f04f 0680[[:space:]]+mov\.w[[:space:]]+r6, #128.* |
|
|
+0[0-9a-f]+ <[^>]+> f04f 07ff[[:space:]]+mov\.w[[:space:]]+r7, #255.* |
|
|
0[0-9a-f]+ <[^>]+> f04f 0800[[:space:]]+mov\.w[[:space:]]+r8, #0.* |
|
|
0[0-9a-f]+ <[^>]+> f04f 0908[[:space:]]+mov\.w[[:space:]]+r9, #8.* |
|
|
0[0-9a-f]+ <[^>]+> f04f 0a51[[:space:]]+mov\.w[[:space:]]+sl, #81.* |
|
|
0[0-9a-f]+ <[^>]+> f04f 0b1f[[:space:]]+mov\.w[[:space:]]+fp, #31.* |
|
|
0[0-9a-f]+ <[^>]+> f04f 0c2f[[:space:]]+mov\.w[[:space:]]+ip, #47.* |
|
|
-0[0-9a-f]+ <[^>]+> f04f 0d3f[[:space:]]+mov\.w[[:space:]]+sp, #63.* |
|
|
0[0-9a-f]+ <[^>]+> f04f 0e80[[:space:]]+mov\.w[[:space:]]+lr, #128.* |
|
|
-0[0-9a-f]+ <[^>]+> f04f 0fff[[:space:]]+mov\.w[[:space:]]+pc, #255.* |
|
|
+0[0-9a-f]+ <[^>]+> f64f 78ff[[:space:]]+movw[[:space:]]+r8, #65535.* |
|
|
+0[0-9a-f]+ <[^>]+> f24f 09f0[[:space:]]+movw[[:space:]]+r9, #61680.* |
|
|
+0[0-9a-f]+ <[^>]+> f8df d004[[:space:]]+ldr\.w[[:space:]]+sp, \[pc, #4\].* |
|
|
+0[0-9a-f]+ <[^>]+> f8df f004[[:space:]]+ldr\.w[[:space:]]+pc, \[pc, #4\].* |
|
|
+0[0-9a-f]+ <[^>]+> 0000003f[[:space:]]+.word[[:space:]]+0x0000003f.* |
|
|
+0[0-9a-f]+ <[^>]+> 000000ff[[:space:]]+.word[[:space:]]+0x000000ff.* |
|
|
diff -rup binutils.orig/gas/testsuite/gas/arm/thumb2_ldr_immediate_highregs_armv6t2.s binutils-2.27/gas/testsuite/gas/arm/thumb2_ldr_immediate_highregs_armv6t2.s |
|
|
--- binutils.orig/gas/testsuite/gas/arm/thumb2_ldr_immediate_highregs_armv6t2.s 2017-08-09 10:26:30.067741560 +0100 |
|
|
+++ binutils-2.27/gas/testsuite/gas/arm/thumb2_ldr_immediate_highregs_armv6t2.s 2017-08-09 11:58:27.561952048 +0100 |
|
|
@@ -2,8 +2,8 @@ |
|
|
.syntax unified |
|
|
.thumb_func |
|
|
thumb2_ldr: |
|
|
- # These can be encoded into movs since constant is small |
|
|
- # And register can be encoded in 3 bits |
|
|
+ # These must be encoded into mov.w despite constant and register being |
|
|
+ # small enough as ldr should not generate a flag-setting instruction. |
|
|
ldr r0,=0x00 |
|
|
ldr r1,=0x08 |
|
|
ldr r2,=0x51 |
|
|
@@ -12,13 +12,19 @@ thumb2_ldr: |
|
|
ldr r5,=0x3F |
|
|
ldr r6,=0x80 |
|
|
ldr r7,=0xFF |
|
|
- # These shall be encoded into mov.w |
|
|
- # Since register cannot be encoded in 3 bits |
|
|
+ # These shall be encoded into mov.w since register cannot be encoded in |
|
|
+ # 3 bits |
|
|
ldr r8,=0x00 |
|
|
ldr r9,=0x08 |
|
|
ldr r10,=0x51 |
|
|
ldr r11,=0x1F |
|
|
ldr r12,=0x2F |
|
|
- ldr r13,=0x3F |
|
|
ldr r14,=0x80 |
|
|
+ # These shall be encoded into movw since immediate cannot be encoded |
|
|
+ # with mov.w |
|
|
+ ldr r8,=0xFFFF |
|
|
+ ldr r9,=0xF0F0 |
|
|
+ # These should be encoded as ldr since mov immediate is unpredictable |
|
|
+ # for sp and pc |
|
|
+ ldr r13,=0x3F |
|
|
ldr r15,=0xFF |
|
|
diff -rup binutils.orig/include/opcode/arm.h binutils-2.27/include/opcode/arm.h |
|
|
--- binutils.orig/include/opcode/arm.h 2017-08-09 10:26:30.209739969 +0100 |
|
|
+++ binutils-2.27/include/opcode/arm.h 2017-08-09 11:11:08.487736404 +0100 |
|
|
@@ -64,6 +64,8 @@ |
|
|
#define ARM_EXT2_FP16_INST 0x00000020 /* ARM V8.2A FP16 instructions. */ |
|
|
#define ARM_EXT2_V8M_MAIN 0x00000040 /* ARMv8-M Mainline. */ |
|
|
#define ARM_EXT2_RAS 0x00000080 /* RAS extension. */ |
|
|
+#define ARM_EXT2_V8_3A 0x00000100 /* ARM V8.3A. */ |
|
|
+#define ARM_EXT2_V8A 0x00000200 /* ARMv8-A. */ |
|
|
|
|
|
/* Co-processor space extensions. */ |
|
|
#define ARM_CEXT_XSCALE 0x00000001 /* Allow MIA etc. */ |
|
|
@@ -92,6 +94,7 @@ |
|
|
#define CRC_EXT_ARMV8 0x00004000 /* CRC32 for ARMv8. */ |
|
|
#define FPU_VFP_EXT_ARMV8xD 0x00002000 /* Single-precision FP for ARMv8. */ |
|
|
#define FPU_NEON_EXT_RDMA 0x00001000 /* v8.1 Adv.SIMD extensions. */ |
|
|
+#define FPU_NEON_EXT_DOTPROD 0x00000800 /* Dot Product extension. */ |
|
|
|
|
|
/* Architectures are the sum of the base and extensions. The ARM ARM (rev E) |
|
|
defines the following: ARMv3, ARMv3M, ARMv4xM, ARMv4, ARMv4TxM, ARMv4T, |
|
|
@@ -105,12 +108,14 @@ |
|
|
#define ARM_AEXT_V3M (ARM_AEXT_V3 | ARM_EXT_V3M) |
|
|
#define ARM_AEXT_V4xM (ARM_AEXT_V3 | ARM_EXT_V4) |
|
|
#define ARM_AEXT_V4 (ARM_AEXT_V3M | ARM_EXT_V4) |
|
|
-#define ARM_AEXT_V4TxM (ARM_AEXT_V4xM | ARM_EXT_V4T) |
|
|
-#define ARM_AEXT_V4T (ARM_AEXT_V4 | ARM_EXT_V4T) |
|
|
+#define ARM_AEXT_V4TxM (ARM_AEXT_V4xM | ARM_EXT_V4T | ARM_EXT_OS) |
|
|
+#define ARM_AEXT_V4T (ARM_AEXT_V4 | ARM_EXT_V4T | ARM_EXT_OS) |
|
|
#define ARM_AEXT_V5xM (ARM_AEXT_V4xM | ARM_EXT_V5) |
|
|
#define ARM_AEXT_V5 (ARM_AEXT_V4 | ARM_EXT_V5) |
|
|
-#define ARM_AEXT_V5TxM (ARM_AEXT_V5xM | ARM_EXT_V4T | ARM_EXT_V5T) |
|
|
-#define ARM_AEXT_V5T (ARM_AEXT_V5 | ARM_EXT_V4T | ARM_EXT_V5T) |
|
|
+#define ARM_AEXT_V5TxM (ARM_AEXT_V5xM | ARM_EXT_V4T | ARM_EXT_V5T \ |
|
|
+ | ARM_EXT_OS) |
|
|
+#define ARM_AEXT_V5T (ARM_AEXT_V5 | ARM_EXT_V4T | ARM_EXT_V5T \ |
|
|
+ | ARM_EXT_OS) |
|
|
#define ARM_AEXT_V5TExP (ARM_AEXT_V5T | ARM_EXT_V5ExP) |
|
|
#define ARM_AEXT_V5TE (ARM_AEXT_V5TExP | ARM_EXT_V5E) |
|
|
#define ARM_AEXT_V5TEJ (ARM_AEXT_V5TE | ARM_EXT_V5J) |
|
|
@@ -135,7 +140,7 @@ |
|
|
#define ARM_AEXT_V6M_ONLY \ |
|
|
((ARM_EXT_BARRIER | ARM_EXT_V6M | ARM_EXT_THUMB_MSR) & ~(ARM_AEXT_NOTM)) |
|
|
#define ARM_AEXT_V6M \ |
|
|
- ((ARM_AEXT_V6K | ARM_AEXT_V6M_ONLY) & ~(ARM_AEXT_NOTM)) |
|
|
+ ((ARM_AEXT_V6K | ARM_AEXT_V6M_ONLY) & ~(ARM_AEXT_NOTM | ARM_EXT_OS)) |
|
|
#define ARM_AEXT_V6SM (ARM_AEXT_V6M | ARM_EXT_OS) |
|
|
#define ARM_AEXT_V7M \ |
|
|
((ARM_AEXT_V7_ARM | ARM_EXT_V6M | ARM_EXT_V7M | ARM_EXT_DIV) \ |
|
|
@@ -146,13 +151,19 @@ |
|
|
#define ARM_AEXT_V8A \ |
|
|
(ARM_AEXT_V7A | ARM_EXT_MP | ARM_EXT_SEC | ARM_EXT_DIV | ARM_EXT_ADIV \ |
|
|
| ARM_EXT_VIRT | ARM_EXT_V8) |
|
|
-#define ARM_AEXT2_V8A (ARM_EXT2_V6T2_V8M | ARM_EXT2_ATOMICS) |
|
|
+#define ARM_AEXT2_V8AR (ARM_EXT2_V6T2_V8M | ARM_EXT2_ATOMICS) |
|
|
+#define ARM_AEXT2_V8A (ARM_AEXT2_V8AR | ARM_EXT2_V8A) |
|
|
#define ARM_AEXT2_V8_1A (ARM_AEXT2_V8A | ARM_EXT2_PAN) |
|
|
#define ARM_AEXT2_V8_2A (ARM_AEXT2_V8_1A | ARM_EXT2_V8_2A | ARM_EXT2_RAS) |
|
|
+#define ARM_AEXT2_V8_3A (ARM_AEXT2_V8_2A | ARM_EXT2_V8_3A) |
|
|
#define ARM_AEXT_V8M_BASE (ARM_AEXT_V6SM | ARM_EXT_DIV) |
|
|
#define ARM_AEXT_V8M_MAIN ARM_AEXT_V7M |
|
|
+#define ARM_AEXT_V8M_MAIN_DSP ARM_AEXT_V7EM |
|
|
#define ARM_AEXT2_V8M (ARM_EXT2_V8M | ARM_EXT2_ATOMICS | ARM_EXT2_V6T2_V8M) |
|
|
#define ARM_AEXT2_V8M_MAIN (ARM_AEXT2_V8M | ARM_EXT2_V8M_MAIN) |
|
|
+#define ARM_AEXT2_V8M_MAIN_DSP ARM_AEXT2_V8M_MAIN |
|
|
+#define ARM_AEXT_V8R ARM_AEXT_V8A |
|
|
+#define ARM_AEXT2_V8R ARM_AEXT2_V8AR |
|
|
|
|
|
/* Processors with specific extensions in the co-processor space. */ |
|
|
#define ARM_ARCH_XSCALE ARM_FEATURE_LOW (ARM_AEXT_V5TE, ARM_CEXT_XSCALE) |
|
|
@@ -224,6 +235,8 @@ |
|
|
#define FPU_ARCH_CRYPTO_NEON_VFP_ARMV8_1 \ |
|
|
ARM_FEATURE_COPROC (FPU_CRYPTO_ARMV8 | FPU_NEON_ARMV8 | FPU_VFP_ARMV8 \ |
|
|
| FPU_NEON_EXT_RDMA) |
|
|
+#define FPU_ARCH_DOTPROD_NEON_VFP_ARMV8 \ |
|
|
+ ARM_FEATURE_COPROC (FPU_NEON_EXT_DOTPROD | FPU_NEON_ARMV8 | FPU_VFP_ARMV8) |
|
|
|
|
|
|
|
|
#define FPU_ARCH_ENDIAN_PURE ARM_FEATURE_COPROC (FPU_ENDIAN_PURE) |
|
|
@@ -263,18 +276,26 @@ |
|
|
#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, \ |
|
|
+ CRC_EXT_ARMV8) |
|
|
#define ARM_ARCH_V8_1A ARM_FEATURE (ARM_AEXT_V8A, ARM_AEXT2_V8_1A, \ |
|
|
CRC_EXT_ARMV8 | FPU_NEON_EXT_RDMA) |
|
|
#define ARM_ARCH_V8_2A ARM_FEATURE (ARM_AEXT_V8A, ARM_AEXT2_V8_2A, \ |
|
|
CRC_EXT_ARMV8 | FPU_NEON_EXT_RDMA) |
|
|
+#define ARM_ARCH_V8_3A ARM_FEATURE (ARM_AEXT_V8A, ARM_AEXT2_V8_3A, \ |
|
|
+ CRC_EXT_ARMV8 | FPU_NEON_EXT_RDMA) |
|
|
#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) |
|
|
+#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) |
|
|
|
|
|
/* Some useful combinations: */ |
|
|
#define ARM_ARCH_NONE ARM_FEATURE_LOW (0, 0) |
|
|
#define FPU_NONE ARM_FEATURE_LOW (0, 0) |
|
|
#define ARM_ANY ARM_FEATURE (-1, -1, 0) /* Any basic core. */ |
|
|
+#define FPU_ANY ARM_FEATURE_COPROC (-1) /* Any FPU. */ |
|
|
#define ARM_FEATURE_ALL ARM_FEATURE (-1, -1, -1)/* All CPU and FPU features. */ |
|
|
#define FPU_ANY_HARD ARM_FEATURE_COPROC (FPU_FPA | FPU_VFP_HARD | FPU_MAVERICK) |
|
|
/* Extensions containing some Thumb-2 instructions. If any is present, Thumb |
|
|
diff -rup binutils.orig/opcodes/arm-dis.c binutils-2.27/opcodes/arm-dis.c |
|
|
--- binutils.orig/opcodes/arm-dis.c 2017-08-09 10:26:30.352738367 +0100 |
|
|
+++ binutils-2.27/opcodes/arm-dis.c 2017-08-09 11:44:50.913090391 +0100 |
|
|
@@ -26,6 +26,7 @@ |
|
|
#include "opcode/arm.h" |
|
|
#include "opintl.h" |
|
|
#include "safe-ctype.h" |
|
|
+#include "libiberty.h" |
|
|
#include "floatformat.h" |
|
|
|
|
|
/* FIXME: This shouldn't be done here. */ |
|
|
@@ -41,10 +42,6 @@ |
|
|
#define strneq(a,b,n) (strncmp ((a), (b), (n)) == 0) |
|
|
#endif |
|
|
|
|
|
-#ifndef NUM_ELEM |
|
|
-#define NUM_ELEM(a) (sizeof (a) / sizeof (a)[0]) |
|
|
-#endif |
|
|
- |
|
|
/* Cached mapping symbol state. */ |
|
|
enum map_type |
|
|
{ |
|
|
@@ -116,6 +113,7 @@ struct opcode16 |
|
|
%<bitfield>G print as an iWMMXt general purpose or control register |
|
|
%<bitfield>D print as a NEON D register |
|
|
%<bitfield>Q print as a NEON Q register |
|
|
+ %<bitfield>V print as a NEON D or Q register |
|
|
%<bitfield>E print a quarter-float immediate value |
|
|
|
|
|
%y<code> print a single precision VFP reg. |
|
|
@@ -505,6 +503,8 @@ static const struct opcode32 coprocessor |
|
|
0x0ee60a10, 0x0fff0fff, "vmsr%c\tmvfr1, %12-15r"}, |
|
|
{ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD), |
|
|
0x0ee70a10, 0x0fff0fff, "vmsr%c\tmvfr0, %12-15r"}, |
|
|
+ {ARM_FEATURE_COPROC (FPU_VFP_EXT_ARMV8), |
|
|
+ 0x0ee50a10, 0x0fff0fff, "vmsr%c\tmvfr2, %12-15r"}, |
|
|
{ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD), |
|
|
0x0ee80a10, 0x0fff0fff, "vmsr%c\tfpexc, %12-15r"}, |
|
|
{ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD), |
|
|
@@ -517,6 +517,8 @@ static const struct opcode32 coprocessor |
|
|
0x0ef1fa10, 0x0fffffff, "vmrs%c\tAPSR_nzcv, fpscr"}, |
|
|
{ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD), |
|
|
0x0ef10a10, 0x0fff0fff, "vmrs%c\t%12-15r, fpscr"}, |
|
|
+ {ARM_FEATURE_COPROC (FPU_VFP_EXT_ARMV8), |
|
|
+ 0x0ef50a10, 0x0fff0fff, "vmrs%c\t%12-15r, mvfr2"}, |
|
|
{ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD), |
|
|
0x0ef60a10, 0x0fff0fff, "vmrs%c\t%12-15r, mvfr1"}, |
|
|
{ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD), |
|
|
@@ -882,6 +884,34 @@ static const struct opcode32 coprocessor |
|
|
0xfc400000, 0xfff00000, |
|
|
"mcrr2%c\t%8-11d, %4-7d, %12-15R, %16-19R, cr%0-3d"}, |
|
|
|
|
|
+ /* ARMv8.3 AdvSIMD instructions in the space of coprocessor 8. */ |
|
|
+ {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_3A), |
|
|
+ 0xfc800800, 0xfeb00f10, "vcadd%c.f16\t%12-15,22V, %16-19,7V, %0-3,5V, #%24?29%24'70"}, |
|
|
+ {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_3A), |
|
|
+ 0xfc900800, 0xfeb00f10, "vcadd%c.f32\t%12-15,22V, %16-19,7V, %0-3,5V, #%24?29%24'70"}, |
|
|
+ {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_3A), |
|
|
+ 0xfc200800, 0xff300f10, "vcmla%c.f16\t%12-15,22V, %16-19,7V, %0-3,5V, #%23'90"}, |
|
|
+ {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_3A), |
|
|
+ 0xfd200800, 0xff300f10, "vcmla%c.f16\t%12-15,22V, %16-19,7V, %0-3,5V, #%23?21%23?780"}, |
|
|
+ {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_3A), |
|
|
+ 0xfc300800, 0xff300f10, "vcmla%c.f32\t%12-15,22V, %16-19,7V, %0-3,5V, #%23'90"}, |
|
|
+ {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_3A), |
|
|
+ 0xfd300800, 0xff300f10, "vcmla%c.f32\t%12-15,22V, %16-19,7V, %0-3,5V, #%23?21%23?780"}, |
|
|
+ {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_3A), |
|
|
+ 0xfe000800, 0xffa00f10, "vcmla%c.f16\t%12-15,22V, %16-19,7V, %0-3D[%5?10], #%20'90"}, |
|
|
+ {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_3A), |
|
|
+ 0xfe200800, 0xffa00f10, "vcmla%c.f16\t%12-15,22V, %16-19,7V, %0-3D[%5?10], #%20?21%20?780"}, |
|
|
+ {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_3A), |
|
|
+ 0xfe800800, 0xffa00f10, "vcmla%c.f32\t%12-15,22V, %16-19,7V, %0-3,5D[0], #%20'90"}, |
|
|
+ {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_3A), |
|
|
+ 0xfea00800, 0xffa00f10, "vcmla%c.f32\t%12-15,22V, %16-19,7V, %0-3,5D[0], #%20?21%20?780"}, |
|
|
+ |
|
|
+ /* Dot Product instructions in the space of coprocessor 13. */ |
|
|
+ {ARM_FEATURE_COPROC (FPU_NEON_EXT_DOTPROD), |
|
|
+ 0xfc200d00, 0xffb00f00, "v%4?usdot.%4?us8\t%12-15,22V, %16-19,7V, %0-3,5V"}, |
|
|
+ {ARM_FEATURE_COPROC (FPU_NEON_EXT_DOTPROD), |
|
|
+ 0xfe000d00, 0xff000f00, "v%4?usdot.%4?us8\t%12-15,22V, %16-19,7V, %0-3D[%5?10]"}, |
|
|
+ |
|
|
/* V5 coprocessor instructions. */ |
|
|
{ARM_FEATURE_CORE_LOW (ARM_EXT_V5), |
|
|
0xfc100000, 0xfe100000, "ldc2%22'l%c\t%8-11d, cr%12-15d, %A"}, |
|
|
@@ -971,6 +1001,10 @@ static const struct opcode32 coprocessor |
|
|
{ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST), |
|
|
0x0e300940, 0x0fb00f50, "vsub%c.f16\t%y1, %y2, %y0"}, |
|
|
|
|
|
+ /* ARMv8.3 javascript conversion instruction. */ |
|
|
+ {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_3A), |
|
|
+ 0x0eb90bc0, 0x0fbf0fd0, "vjcvt%c.s32.f64\t%y1, %z0"}, |
|
|
+ |
|
|
{ARM_FEATURE_CORE_LOW (0), 0, 0, 0} |
|
|
}; |
|
|
|
|
|
@@ -2286,8 +2320,6 @@ static const struct opcode32 arm_opcodes |
|
|
0x01300000, 0x0ff00010, "teq%p%c\t%16-19r, %o"}, |
|
|
{ARM_FEATURE_CORE_LOW (ARM_EXT_V1), |
|
|
0x01300010, 0x0ff00010, "teq%p%c\t%16-19R, %o"}, |
|
|
- {ARM_FEATURE_CORE_LOW (ARM_EXT_V5), |
|
|
- 0x0130f000, 0x0ff0f010, "bx%c\t%0-3r"}, |
|
|
|
|
|
{ARM_FEATURE_CORE_LOW (ARM_EXT_V1), |
|
|
0x03400000, 0x0fe00000, "cmp%p%c\t%16-19r, %o"}, |
|
|
@@ -3171,18 +3203,20 @@ arm_regname; |
|
|
|
|
|
static const arm_regname regnames[] = |
|
|
{ |
|
|
- { "raw" , "Select raw register names", |
|
|
+ { "reg-names-raw", N_("Select raw register names"), |
|
|
{ "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7", "r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15"}}, |
|
|
- { "gcc", "Select register names used by GCC", |
|
|
+ { "reg-names-gcc", N_("Select register names used by GCC"), |
|
|
{ "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7", "r8", "r9", "sl", "fp", "ip", "sp", "lr", "pc" }}, |
|
|
- { "std", "Select register names used in ARM's ISA documentation", |
|
|
+ { "reg-names-std", N_("Select register names used in ARM's ISA documentation"), |
|
|
{ "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7", "r8", "r9", "r10", "r11", "r12", "sp", "lr", "pc" }}, |
|
|
- { "apcs", "Select register names used in the APCS", |
|
|
+ { "force-thumb", N_("Assume all insns are Thumb insns"), {NULL} }, |
|
|
+ { "no-force-thumb", N_("Examine preceding label to determine an insn's type"), {NULL} }, |
|
|
+ { "reg-names-apcs", N_("Select register names used in the APCS"), |
|
|
{ "a1", "a2", "a3", "a4", "v1", "v2", "v3", "v4", "v5", "v6", "sl", "fp", "ip", "sp", "lr", "pc" }}, |
|
|
- { "atpcs", "Select register names used in the ATPCS", |
|
|
+ { "reg-names-atpcs", N_("Select register names used in the ATPCS"), |
|
|
{ "a1", "a2", "a3", "a4", "v1", "v2", "v3", "v4", "v5", "v6", "v7", "v8", "IP", "SP", "LR", "PC" }}, |
|
|
- { "special-atpcs", "Select special register names used in the ATPCS", |
|
|
- { "a1", "a2", "a3", "a4", "v1", "v2", "v3", "WR", "v5", "SB", "SL", "FP", "IP", "SP", "LR", "PC" }}, |
|
|
+ { "reg-names-special-atpcs", N_("Select special register names used in the ATPCS"), |
|
|
+ { "a1", "a2", "a3", "a4", "v1", "v2", "v3", "WR", "v5", "SB", "SL", "FP", "IP", "SP", "LR", "PC" }} |
|
|
}; |
|
|
|
|
|
static const char *const iwmmxt_wwnames[] = |
|
|
@@ -3208,7 +3242,7 @@ static const char *const iwmmxt_cregname |
|
|
/* Default to GCC register name set. */ |
|
|
static unsigned int regname_selected = 1; |
|
|
|
|
|
-#define NUM_ARM_REGNAMES NUM_ELEM (regnames) |
|
|
+#define NUM_ARM_REGNAMES ARRAY_SIZE (regnames) |
|
|
#define arm_regnames regnames[regname_selected].reg_names |
|
|
|
|
|
static bfd_boolean force_thumb = FALSE; |
|
|
@@ -3227,31 +3261,6 @@ static bfd_vma ifthen_address; |
|
|
|
|
|
|
|
|
/* Functions. */ |
|
|
-int |
|
|
-get_arm_regname_num_options (void) |
|
|
-{ |
|
|
- return NUM_ARM_REGNAMES; |
|
|
-} |
|
|
- |
|
|
-int |
|
|
-set_arm_regname_option (int option) |
|
|
-{ |
|
|
- int old = regname_selected; |
|
|
- regname_selected = option; |
|
|
- return old; |
|
|
-} |
|
|
- |
|
|
-int |
|
|
-get_arm_regnames (int option, |
|
|
- const char **setname, |
|
|
- const char **setdescription, |
|
|
- const char *const **register_names) |
|
|
-{ |
|
|
- *setname = regnames[option].name; |
|
|
- *setdescription = regnames[option].description; |
|
|
- *register_names = regnames[option].reg_names; |
|
|
- return 16; |
|
|
-} |
|
|
|
|
|
/* Decode a bitfield of the form matching regexp (N(-N)?,)*N(-N)?. |
|
|
Returns pointer to following character of the format string and |
|
|
@@ -3669,10 +3678,15 @@ print_insn_coprocessor (bfd_vma pc, |
|
|
} |
|
|
func (stream, "%s", arm_regnames[value]); |
|
|
break; |
|
|
+ case 'V': |
|
|
+ if (given & (1 << 6)) |
|
|
+ goto Q; |
|
|
+ /* FALLTHROUGH */ |
|
|
case 'D': |
|
|
func (stream, "d%ld", value); |
|
|
break; |
|
|
case 'Q': |
|
|
+ Q: |
|
|
if (value & 1) |
|
|
func (stream, "<illegal reg q%ld.5>", value >> 1); |
|
|
else |
|
|
@@ -4686,6 +4700,7 @@ print_insn_arm (bfd_vma pc, struct disas |
|
|
|
|
|
case 'S': |
|
|
allow_unpredictable = TRUE; |
|
|
+ /* Fall through. */ |
|
|
case 's': |
|
|
if ((given & 0x004f0000) == 0x004f0000) |
|
|
{ |
|
|
@@ -5427,22 +5442,31 @@ psr_name (int regno) |
|
|
{ |
|
|
switch (regno) |
|
|
{ |
|
|
- case 0: return "APSR"; |
|
|
- case 1: return "IAPSR"; |
|
|
- case 2: return "EAPSR"; |
|
|
- case 3: return "PSR"; |
|
|
- case 5: return "IPSR"; |
|
|
- case 6: return "EPSR"; |
|
|
- case 7: return "IEPSR"; |
|
|
- case 8: return "MSP"; |
|
|
- case 9: return "PSP"; |
|
|
- case 16: return "PRIMASK"; |
|
|
- case 17: return "BASEPRI"; |
|
|
- case 18: return "BASEPRI_MAX"; |
|
|
- case 19: return "FAULTMASK"; |
|
|
- case 20: return "CONTROL"; |
|
|
+ case 0x0: return "APSR"; |
|
|
+ case 0x1: return "IAPSR"; |
|
|
+ case 0x2: return "EAPSR"; |
|
|
+ case 0x3: return "PSR"; |
|
|
+ case 0x5: return "IPSR"; |
|
|
+ case 0x6: return "EPSR"; |
|
|
+ case 0x7: return "IEPSR"; |
|
|
+ case 0x8: return "MSP"; |
|
|
+ case 0x9: return "PSP"; |
|
|
+ case 0xa: return "MSPLIM"; |
|
|
+ case 0xb: return "PSPLIM"; |
|
|
+ case 0x10: return "PRIMASK"; |
|
|
+ case 0x11: return "BASEPRI"; |
|
|
+ case 0x12: return "BASEPRI_MAX"; |
|
|
+ case 0x13: return "FAULTMASK"; |
|
|
+ case 0x14: return "CONTROL"; |
|
|
case 0x88: return "MSP_NS"; |
|
|
case 0x89: return "PSP_NS"; |
|
|
+ case 0x8a: return "MSPLIM_NS"; |
|
|
+ case 0x8b: return "PSPLIM_NS"; |
|
|
+ case 0x90: return "PRIMASK_NS"; |
|
|
+ case 0x91: return "BASEPRI_NS"; |
|
|
+ case 0x93: return "FAULTMASK_NS"; |
|
|
+ case 0x94: return "CONTROL_NS"; |
|
|
+ case 0x98: return "SP_NS"; |
|
|
default: return "<unknown>"; |
|
|
} |
|
|
} |
|
|
@@ -5717,7 +5741,7 @@ print_insn_thumb32 (bfd_vma pc, struct d |
|
|
if (off || !U) |
|
|
{ |
|
|
func (stream, ", #%c%u", U ? '+' : '-', off * 4); |
|
|
- value_in_comment = off * 4 * U ? 1 : -1; |
|
|
+ value_in_comment = off * 4 * (U ? 1 : -1); |
|
|
} |
|
|
func (stream, "]"); |
|
|
if (W) |
|
|
@@ -5729,7 +5753,7 @@ print_insn_thumb32 (bfd_vma pc, struct d |
|
|
if (W) |
|
|
{ |
|
|
func (stream, "#%c%u", U ? '+' : '-', off * 4); |
|
|
- value_in_comment = off * 4 * U ? 1 : -1; |
|
|
+ value_in_comment = off * 4 * (U ? 1 : -1); |
|
|
} |
|
|
else |
|
|
{ |
|
|
diff -rupN binutils.orig/gas/testsuite/gas/arm/armv8_3-a-fp-bad.d binutils-2.27/gas/testsuite/gas/arm/armv8_3-a-fp-bad.d |
|
|
--- binutils.orig/gas/testsuite/gas/arm/armv8_3-a-fp-bad.d 1970-01-01 01:00:00.000000000 +0100 |
|
|
+++ binutils-2.27/gas/testsuite/gas/arm/armv8_3-a-fp-bad.d 2017-08-09 12:10:22.428965485 +0100 |
|
|
@@ -0,0 +1,2 @@ |
|
|
+#as: -march=armv8.3-a+fp |
|
|
+#error-output: armv8_3-a-fp-bad.l |
|
|
diff -rupN binutils.orig/gas/testsuite/gas/arm/armv8_3-a-fp-bad.l binutils-2.27/gas/testsuite/gas/arm/armv8_3-a-fp-bad.l |
|
|
--- binutils.orig/gas/testsuite/gas/arm/armv8_3-a-fp-bad.l 1970-01-01 01:00:00.000000000 +0100 |
|
|
+++ binutils-2.27/gas/testsuite/gas/arm/armv8_3-a-fp-bad.l 2017-08-09 12:10:22.428965485 +0100 |
|
|
@@ -0,0 +1,7 @@ |
|
|
+[^:]+: Assembler messages: |
|
|
+[^:]+:3: Error: operand types can't be inferred -- `vjcvt s0,d1' |
|
|
+[^:]+:4: Error: VFP single precision register expected -- `vjcvt\.s32\.f64 r0,d1' |
|
|
+[^:]+:5: Error: VFP/Neon double precision register expected -- `vjcvt\.s32\.f64 s0,s1' |
|
|
+[^:]+:6: Error: VFP/Neon double precision register expected -- `vjcvt\.s32\.f32 s0,s1' |
|
|
+[^:]+:7: Error: bad type in Neon instruction -- `vjcvt\.s32\.f32 s0,d1' |
|
|
+[^:]+:8: Error: bad type in Neon instruction -- `vjcvt\.f32\.f64 s0,d1' |
|
|
diff -rupN binutils.orig/gas/testsuite/gas/arm/armv8_3-a-fp-bad.s binutils-2.27/gas/testsuite/gas/arm/armv8_3-a-fp-bad.s |
|
|
--- binutils.orig/gas/testsuite/gas/arm/armv8_3-a-fp-bad.s 1970-01-01 01:00:00.000000000 +0100 |
|
|
+++ binutils-2.27/gas/testsuite/gas/arm/armv8_3-a-fp-bad.s 2017-08-09 12:10:22.428965485 +0100 |
|
|
@@ -0,0 +1,8 @@ |
|
|
+ .text |
|
|
+ .arm |
|
|
+ vjcvt s0, d1 |
|
|
+ vjcvt.s32.f64 r0, d1 |
|
|
+ vjcvt.s32.f64 s0, s1 |
|
|
+ vjcvt.s32.f32 s0, s1 |
|
|
+ vjcvt.s32.f32 s0, d1 |
|
|
+ vjcvt.f32.f64 s0, d1 |
|
|
diff -rupN binutils.orig/gas/testsuite/gas/arm/armv8_3-a-fp.d binutils-2.27/gas/testsuite/gas/arm/armv8_3-a-fp.d |
|
|
--- binutils.orig/gas/testsuite/gas/arm/armv8_3-a-fp.d 1970-01-01 01:00:00.000000000 +0100 |
|
|
+++ binutils-2.27/gas/testsuite/gas/arm/armv8_3-a-fp.d 2017-08-09 12:10:22.428965485 +0100 |
|
|
@@ -0,0 +1,15 @@ |
|
|
+#as: -march=armv8.3-a+fp |
|
|
+#objdump: -dr |
|
|
+#skip: *-*-pe *-wince-* *-*-coff |
|
|
+ |
|
|
+.*: +file format .*arm.* |
|
|
+ |
|
|
+Disassembly of section .text: |
|
|
+ |
|
|
+[0-9a-f]+ <.*>: |
|
|
+ [0-9a-f]+: eef90bc7 vjcvt.s32.f64 s1, d7 |
|
|
+ [0-9a-f]+: eef90bc7 vjcvt.s32.f64 s1, d7 |
|
|
+ |
|
|
+[0-9a-f]+ <.*>: |
|
|
+ [0-9a-f]+: eef9 0bc7 vjcvt.s32.f64 s1, d7 |
|
|
+ |
|
|
diff -rupN binutils.orig/gas/testsuite/gas/arm/armv8_3-a-fp.s binutils-2.27/gas/testsuite/gas/arm/armv8_3-a-fp.s |
|
|
--- binutils.orig/gas/testsuite/gas/arm/armv8_3-a-fp.s 1970-01-01 01:00:00.000000000 +0100 |
|
|
+++ binutils-2.27/gas/testsuite/gas/arm/armv8_3-a-fp.s 2017-08-09 12:10:22.428965485 +0100 |
|
|
@@ -0,0 +1,8 @@ |
|
|
+ .text |
|
|
+A1: |
|
|
+ .arm |
|
|
+ vjcvt.s32.f64 s1, d7 |
|
|
+ vjcvtal.s32.f64 s1, d7 |
|
|
+T1: |
|
|
+ .thumb |
|
|
+ vjcvt.s32.f64 s1, d7 |
|
|
diff -rupN binutils.orig/gas/testsuite/gas/arm/armv8_3-a-simd-bad.d binutils-2.27/gas/testsuite/gas/arm/armv8_3-a-simd-bad.d |
|
|
--- binutils.orig/gas/testsuite/gas/arm/armv8_3-a-simd-bad.d 1970-01-01 01:00:00.000000000 +0100 |
|
|
+++ binutils-2.27/gas/testsuite/gas/arm/armv8_3-a-simd-bad.d 2017-08-09 12:10:22.428965485 +0100 |
|
|
@@ -0,0 +1,2 @@ |
|
|
+#as: -march=armv8.3-a+fp16+simd |
|
|
+#error-output: armv8_3-a-simd-bad.l |
|
|
diff -rupN binutils.orig/gas/testsuite/gas/arm/armv8_3-a-simd-bad.l binutils-2.27/gas/testsuite/gas/arm/armv8_3-a-simd-bad.l |
|
|
--- binutils.orig/gas/testsuite/gas/arm/armv8_3-a-simd-bad.l 1970-01-01 01:00:00.000000000 +0100 |
|
|
+++ binutils-2.27/gas/testsuite/gas/arm/armv8_3-a-simd-bad.l 2017-08-09 12:10:22.428965485 +0100 |
|
|
@@ -0,0 +1,39 @@ |
|
|
+[^:]+: Assembler messages: |
|
|
+[^:]+:6: Error: operand types can't be inferred -- `vcadd d0,d1,d2,#90' |
|
|
+[^:]+:7: Error: immediate out of range -- `vcadd\.f32 q0,q1,q2,#0' |
|
|
+[^:]+:8: Error: immediate out of range -- `vcadd\.f32 q0,q1,q2,#180' |
|
|
+[^:]+:9: Error: Neon double or quad precision register expected -- `vcadd\.f16 s0,s1,s2,#90' |
|
|
+[^:]+:10: Error: bad type in Neon instruction -- `vcadd\.f64 d0,d1,d2,#90' |
|
|
+[^:]+:11: Error: bad type in Neon instruction -- `vcadd\.f64 q0,q1,q2,#90' |
|
|
+[^:]+:13: Error: operand types can't be inferred -- `vcmla d0,d1,d2,#90' |
|
|
+[^:]+:14: Error: immediate out of range -- `vcmla\.f32 q0,q1,q2,#-90' |
|
|
+[^:]+:15: Error: immediate out of range -- `vcmla\.f32 q0,q1,q2,#120' |
|
|
+[^:]+:16: Error: immediate out of range -- `vcmla\.f32 q0,q1,q2,#360' |
|
|
+[^:]+:17: Error: Neon double or quad precision register expected -- `vcmla\.f16 s0,s1,s2,#90' |
|
|
+[^:]+:18: Error: bad type in Neon instruction -- `vcmla\.f64 d0,d1,d2,#90' |
|
|
+[^:]+:19: Error: bad type in Neon instruction -- `vcmla\.f64 q0,q1,q2,#90' |
|
|
+[^:]+:21: Error: only D registers may be indexed -- `vcmla\.f16 q0,q1,q2\[0\],#90' |
|
|
+[^:]+:22: Error: only D registers may be indexed -- `vcmla\.f32 q0,q1,q2\[0\],#90' |
|
|
+[^:]+:23: Error: scalar out of range -- `vcmla\.f16 d0,d1,d2\[2\],#90' |
|
|
+[^:]+:24: Error: scalar out of range -- `vcmla\.f16 q0,q1,d2\[2\],#90' |
|
|
+[^:]+:25: Error: scalar out of range -- `vcmla\.f16 q0,q1,d16\[1\],#90' |
|
|
+[^:]+:26: Error: scalar out of range -- `vcmla\.f32 q0,q1,d2\[1\],#90' |
|
|
+[^:]+:31: Error: operand types can't be inferred -- `vcadd d0,d1,d2,#90' |
|
|
+[^:]+:32: Error: immediate out of range -- `vcadd\.f32 q0,q1,q2,#0' |
|
|
+[^:]+:33: Error: immediate out of range -- `vcadd\.f32 q0,q1,q2,#180' |
|
|
+[^:]+:34: Error: Neon double or quad precision register expected -- `vcadd\.f16 s0,s1,s2,#90' |
|
|
+[^:]+:35: Error: bad type in Neon instruction -- `vcadd\.f64 d0,d1,d2,#90' |
|
|
+[^:]+:36: Error: bad type in Neon instruction -- `vcadd\.f64 q0,q1,q2,#90' |
|
|
+[^:]+:38: Error: operand types can't be inferred -- `vcmla d0,d1,d2,#90' |
|
|
+[^:]+:39: Error: immediate out of range -- `vcmla\.f32 q0,q1,q2,#-90' |
|
|
+[^:]+:40: Error: immediate out of range -- `vcmla\.f32 q0,q1,q2,#120' |
|
|
+[^:]+:41: Error: immediate out of range -- `vcmla\.f32 q0,q1,q2,#360' |
|
|
+[^:]+:42: Error: Neon double or quad precision register expected -- `vcmla\.f16 s0,s1,s2,#90' |
|
|
+[^:]+:43: Error: bad type in Neon instruction -- `vcmla\.f64 d0,d1,d2,#90' |
|
|
+[^:]+:44: Error: bad type in Neon instruction -- `vcmla\.f64 q0,q1,q2,#90' |
|
|
+[^:]+:46: Error: only D registers may be indexed -- `vcmla\.f16 q0,q1,q2\[0\],#90' |
|
|
+[^:]+:47: Error: only D registers may be indexed -- `vcmla\.f32 q0,q1,q2\[0\],#90' |
|
|
+[^:]+:48: Error: scalar out of range -- `vcmla\.f16 d0,d1,d2\[2\],#90' |
|
|
+[^:]+:49: Error: scalar out of range -- `vcmla\.f16 q0,q1,d2\[2\],#90' |
|
|
+[^:]+:50: Error: scalar out of range -- `vcmla\.f16 q0,q1,d16\[1\],#90' |
|
|
+[^:]+:51: Error: scalar out of range -- `vcmla\.f32 q0,q1,d2\[1\],#90' |
|
|
diff -rupN binutils.orig/gas/testsuite/gas/arm/armv8_3-a-simd-bad.s binutils-2.27/gas/testsuite/gas/arm/armv8_3-a-simd-bad.s |
|
|
--- binutils.orig/gas/testsuite/gas/arm/armv8_3-a-simd-bad.s 1970-01-01 01:00:00.000000000 +0100 |
|
|
+++ binutils-2.27/gas/testsuite/gas/arm/armv8_3-a-simd-bad.s 2017-08-09 12:10:22.428965485 +0100 |
|
|
@@ -0,0 +1,51 @@ |
|
|
+ .text |
|
|
+ |
|
|
+A1: |
|
|
+ .arm |
|
|
+ |
|
|
+ vcadd d0,d1,d2,#90 |
|
|
+ vcadd.f32 q0,q1,q2,#0 |
|
|
+ vcadd.f32 q0,q1,q2,#180 |
|
|
+ vcadd.f16 s0,s1,s2,#90 |
|
|
+ vcadd.f64 d0,d1,d2,#90 |
|
|
+ vcadd.f64 q0,q1,q2,#90 |
|
|
+ |
|
|
+ vcmla d0,d1,d2,#90 |
|
|
+ vcmla.f32 q0,q1,q2,#-90 |
|
|
+ vcmla.f32 q0,q1,q2,#120 |
|
|
+ vcmla.f32 q0,q1,q2,#360 |
|
|
+ vcmla.f16 s0,s1,s2,#90 |
|
|
+ vcmla.f64 d0,d1,d2,#90 |
|
|
+ vcmla.f64 q0,q1,q2,#90 |
|
|
+ |
|
|
+ vcmla.f16 q0,q1,q2[0],#90 |
|
|
+ vcmla.f32 q0,q1,q2[0],#90 |
|
|
+ vcmla.f16 d0,d1,d2[2],#90 |
|
|
+ vcmla.f16 q0,q1,d2[2],#90 |
|
|
+ vcmla.f16 q0,q1,d16[1],#90 |
|
|
+ vcmla.f32 q0,q1,d2[1],#90 |
|
|
+ |
|
|
+T1: |
|
|
+ .thumb |
|
|
+ |
|
|
+ vcadd d0,d1,d2,#90 |
|
|
+ vcadd.f32 q0,q1,q2,#0 |
|
|
+ vcadd.f32 q0,q1,q2,#180 |
|
|
+ vcadd.f16 s0,s1,s2,#90 |
|
|
+ vcadd.f64 d0,d1,d2,#90 |
|
|
+ vcadd.f64 q0,q1,q2,#90 |
|
|
+ |
|
|
+ vcmla d0,d1,d2,#90 |
|
|
+ vcmla.f32 q0,q1,q2,#-90 |
|
|
+ vcmla.f32 q0,q1,q2,#120 |
|
|
+ vcmla.f32 q0,q1,q2,#360 |
|
|
+ vcmla.f16 s0,s1,s2,#90 |
|
|
+ vcmla.f64 d0,d1,d2,#90 |
|
|
+ vcmla.f64 q0,q1,q2,#90 |
|
|
+ |
|
|
+ vcmla.f16 q0,q1,q2[0],#90 |
|
|
+ vcmla.f32 q0,q1,q2[0],#90 |
|
|
+ vcmla.f16 d0,d1,d2[2],#90 |
|
|
+ vcmla.f16 q0,q1,d2[2],#90 |
|
|
+ vcmla.f16 q0,q1,d16[1],#90 |
|
|
+ vcmla.f32 q0,q1,d2[1],#90 |
|
|
diff -rupN binutils.orig/gas/testsuite/gas/arm/armv8_3-a-simd.d binutils-2.27/gas/testsuite/gas/arm/armv8_3-a-simd.d |
|
|
--- binutils.orig/gas/testsuite/gas/arm/armv8_3-a-simd.d 1970-01-01 01:00:00.000000000 +0100 |
|
|
+++ binutils-2.27/gas/testsuite/gas/arm/armv8_3-a-simd.d 2017-08-09 12:10:22.428965485 +0100 |
|
|
@@ -0,0 +1,59 @@ |
|
|
+#as: -march=armv8.3-a+fp16+simd |
|
|
+#objdump: -dr |
|
|
+#skip: *-*-pe *-wince-* *-*-coff |
|
|
+ |
|
|
+.*: +file format .*arm.* |
|
|
+ |
|
|
+Disassembly of section .text: |
|
|
+ |
|
|
+[0-9a-f]+ <.*>: |
|
|
+ +[0-9a-f]+: fc942846 vcadd.f32 q1, q2, q3, #90 |
|
|
+ +[0-9a-f]+: fd942846 vcadd.f32 q1, q2, q3, #270 |
|
|
+ +[0-9a-f]+: fcc658a7 vcadd.f16 d21, d22, d23, #90 |
|
|
+ +[0-9a-f]+: fc842846 vcadd.f16 q1, q2, q3, #90 |
|
|
+ +[0-9a-f]+: fcd658a7 vcadd.f32 d21, d22, d23, #90 |
|
|
+ +[0-9a-f]+: fc342846 vcmla.f32 q1, q2, q3, #0 |
|
|
+ +[0-9a-f]+: fcb42846 vcmla.f32 q1, q2, q3, #90 |
|
|
+ +[0-9a-f]+: fd342846 vcmla.f32 q1, q2, q3, #180 |
|
|
+ +[0-9a-f]+: fdb42846 vcmla.f32 q1, q2, q3, #270 |
|
|
+ +[0-9a-f]+: fce658a7 vcmla.f16 d21, d22, d23, #90 |
|
|
+ +[0-9a-f]+: fca42846 vcmla.f16 q1, q2, q3, #90 |
|
|
+ +[0-9a-f]+: fcf658a7 vcmla.f32 d21, d22, d23, #90 |
|
|
+ +[0-9a-f]+: fe565883 vcmla.f16 d21, d22, d3\[0\], #90 |
|
|
+ +[0-9a-f]+: fe5658a3 vcmla.f16 d21, d22, d3\[1\], #90 |
|
|
+ +[0-9a-f]+: fe142843 vcmla.f16 q1, q2, d3\[0\], #90 |
|
|
+ +[0-9a-f]+: fe142863 vcmla.f16 q1, q2, d3\[1\], #90 |
|
|
+ +[0-9a-f]+: fed658a7 vcmla.f32 d21, d22, d23\[0\], #90 |
|
|
+ +[0-9a-f]+: fe942867 vcmla.f32 q1, q2, d23\[0\], #90 |
|
|
+ +[0-9a-f]+: fe042863 vcmla.f16 q1, q2, d3\[1\], #0 |
|
|
+ +[0-9a-f]+: fe242863 vcmla.f16 q1, q2, d3\[1\], #180 |
|
|
+ +[0-9a-f]+: fe342863 vcmla.f16 q1, q2, d3\[1\], #270 |
|
|
+ +[0-9a-f]+: fe842843 vcmla.f32 q1, q2, d3\[0\], #0 |
|
|
+ +[0-9a-f]+: fea42843 vcmla.f32 q1, q2, d3\[0\], #180 |
|
|
+ +[0-9a-f]+: feb42843 vcmla.f32 q1, q2, d3\[0\], #270 |
|
|
+ |
|
|
+[0-9a-f]+ <.*>: |
|
|
+ +[0-9a-f]+: fc94 2846 vcadd.f32 q1, q2, q3, #90 |
|
|
+ +[0-9a-f]+: fd94 2846 vcadd.f32 q1, q2, q3, #270 |
|
|
+ +[0-9a-f]+: fcc6 58a7 vcadd.f16 d21, d22, d23, #90 |
|
|
+ +[0-9a-f]+: fc84 2846 vcadd.f16 q1, q2, q3, #90 |
|
|
+ +[0-9a-f]+: fcd6 58a7 vcadd.f32 d21, d22, d23, #90 |
|
|
+ +[0-9a-f]+: fc34 2846 vcmla.f32 q1, q2, q3, #0 |
|
|
+ +[0-9a-f]+: fcb4 2846 vcmla.f32 q1, q2, q3, #90 |
|
|
+ +[0-9a-f]+: fd34 2846 vcmla.f32 q1, q2, q3, #180 |
|
|
+ +[0-9a-f]+: fdb4 2846 vcmla.f32 q1, q2, q3, #270 |
|
|
+ +[0-9a-f]+: fce6 58a7 vcmla.f16 d21, d22, d23, #90 |
|
|
+ +[0-9a-f]+: fca4 2846 vcmla.f16 q1, q2, q3, #90 |
|
|
+ +[0-9a-f]+: fcf6 58a7 vcmla.f32 d21, d22, d23, #90 |
|
|
+ +[0-9a-f]+: fe56 5883 vcmla.f16 d21, d22, d3\[0\], #90 |
|
|
+ +[0-9a-f]+: fe56 58a3 vcmla.f16 d21, d22, d3\[1\], #90 |
|
|
+ +[0-9a-f]+: fe14 2843 vcmla.f16 q1, q2, d3\[0\], #90 |
|
|
+ +[0-9a-f]+: fe14 2863 vcmla.f16 q1, q2, d3\[1\], #90 |
|
|
+ +[0-9a-f]+: fed6 58a7 vcmla.f32 d21, d22, d23\[0\], #90 |
|
|
+ +[0-9a-f]+: fe94 2867 vcmla.f32 q1, q2, d23\[0\], #90 |
|
|
+ +[0-9a-f]+: fe04 2863 vcmla.f16 q1, q2, d3\[1\], #0 |
|
|
+ +[0-9a-f]+: fe24 2863 vcmla.f16 q1, q2, d3\[1\], #180 |
|
|
+ +[0-9a-f]+: fe34 2863 vcmla.f16 q1, q2, d3\[1\], #270 |
|
|
+ +[0-9a-f]+: fe84 2843 vcmla.f32 q1, q2, d3\[0\], #0 |
|
|
+ +[0-9a-f]+: fea4 2843 vcmla.f32 q1, q2, d3\[0\], #180 |
|
|
+ +[0-9a-f]+: feb4 2843 vcmla.f32 q1, q2, d3\[0\], #270 |
|
|
diff -rupN binutils.orig/gas/testsuite/gas/arm/armv8_3-a-simd.s binutils-2.27/gas/testsuite/gas/arm/armv8_3-a-simd.s |
|
|
--- binutils.orig/gas/testsuite/gas/arm/armv8_3-a-simd.s 1970-01-01 01:00:00.000000000 +0100 |
|
|
+++ binutils-2.27/gas/testsuite/gas/arm/armv8_3-a-simd.s 2017-08-09 12:10:22.428965485 +0100 |
|
|
@@ -0,0 +1,63 @@ |
|
|
+ .text |
|
|
+ |
|
|
+A1: |
|
|
+ .arm |
|
|
+ |
|
|
+ vcadd.f32 q1,q2,q3,#90 |
|
|
+ vcadd.f32 q1,q2,q3,#270 |
|
|
+ vcadd.f16 d21,d22,d23,#90 |
|
|
+ vcadd.f16 q1,q2,q3,#90 |
|
|
+ vcadd.f32 d21,d22,d23,#90 |
|
|
+ |
|
|
+ vcmla.f32 q1,q2,q3,#0 |
|
|
+ vcmla.f32 q1,q2,q3,#90 |
|
|
+ vcmla.f32 q1,q2,q3,#180 |
|
|
+ vcmla.f32 q1,q2,q3,#270 |
|
|
+ vcmla.f16 d21,d22,d23,#90 |
|
|
+ vcmla.f16 q1,q2,q3,#90 |
|
|
+ vcmla.f32 d21,d22,d23,#90 |
|
|
+ |
|
|
+ vcmla.f16 d21,d22,d3[0],#90 |
|
|
+ vcmla.f16 d21,d22,d3[1],#90 |
|
|
+ vcmla.f16 q1,q2,d3[0],#90 |
|
|
+ vcmla.f16 q1,q2,d3[1],#90 |
|
|
+ vcmla.f32 d21,d22,d23[0],#90 |
|
|
+ vcmla.f32 q1,q2,d23[0],#90 |
|
|
+ |
|
|
+ vcmla.f16 q1,q2,d3[1],#0 |
|
|
+ vcmla.f16 q1,q2,d3[1],#180 |
|
|
+ vcmla.f16 q1,q2,d3[1],#270 |
|
|
+ vcmla.f32 q1,q2,d3[0],#0 |
|
|
+ vcmla.f32 q1,q2,d3[0],#180 |
|
|
+ vcmla.f32 q1,q2,d3[0],#270 |
|
|
+ |
|
|
+T1: |
|
|
+ .thumb |
|
|
+ |
|
|
+ vcadd.f32 q1,q2,q3,#90 |
|
|
+ vcadd.f32 q1,q2,q3,#270 |
|
|
+ vcadd.f16 d21,d22,d23,#90 |
|
|
+ vcadd.f16 q1,q2,q3,#90 |
|
|
+ vcadd.f32 d21,d22,d23,#90 |
|
|
+ |
|
|
+ vcmla.f32 q1,q2,q3,#0 |
|
|
+ vcmla.f32 q1,q2,q3,#90 |
|
|
+ vcmla.f32 q1,q2,q3,#180 |
|
|
+ vcmla.f32 q1,q2,q3,#270 |
|
|
+ vcmla.f16 d21,d22,d23,#90 |
|
|
+ vcmla.f16 q1,q2,q3,#90 |
|
|
+ vcmla.f32 d21,d22,d23,#90 |
|
|
+ |
|
|
+ vcmla.f16 d21,d22,d3[0],#90 |
|
|
+ vcmla.f16 d21,d22,d3[1],#90 |
|
|
+ vcmla.f16 q1,q2,d3[0],#90 |
|
|
+ vcmla.f16 q1,q2,d3[1],#90 |
|
|
+ vcmla.f32 d21,d22,d23[0],#90 |
|
|
+ vcmla.f32 q1,q2,d23[0],#90 |
|
|
+ |
|
|
+ vcmla.f16 q1,q2,d3[1],#0 |
|
|
+ vcmla.f16 q1,q2,d3[1],#180 |
|
|
+ vcmla.f16 q1,q2,d3[1],#270 |
|
|
+ vcmla.f32 q1,q2,d3[0],#0 |
|
|
+ vcmla.f32 q1,q2,d3[0],#180 |
|
|
+ vcmla.f32 q1,q2,d3[0],#270
|
|
|
|