[AArch64][SVE 25/32] Add support for SVE addressing modes
[deliverable/binutils-gdb.git] / gas / config / tc-aarch64.c
CommitLineData
a06ea964
NC
1/* tc-aarch64.c -- Assemble for the AArch64 ISA
2
6f2750fe 3 Copyright (C) 2009-2016 Free Software Foundation, Inc.
a06ea964
NC
4 Contributed by ARM Ltd.
5
6 This file is part of GAS.
7
8 GAS is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 3 of the license, or
11 (at your option) any later version.
12
13 GAS is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
17
18 You should have received a copy of the GNU General Public License
19 along with this program; see the file COPYING3. If not,
20 see <http://www.gnu.org/licenses/>. */
21
22#include "as.h"
23#include <limits.h>
24#include <stdarg.h>
25#include "bfd_stdint.h"
26#define NO_RELOC 0
27#include "safe-ctype.h"
28#include "subsegs.h"
29#include "obstack.h"
30
31#ifdef OBJ_ELF
32#include "elf/aarch64.h"
33#include "dw2gencfi.h"
34#endif
35
36#include "dwarf2dbg.h"
37
38/* Types of processor to assemble for. */
39#ifndef CPU_DEFAULT
40#define CPU_DEFAULT AARCH64_ARCH_V8
41#endif
42
43#define streq(a, b) (strcmp (a, b) == 0)
44
f4c51f60
JW
45#define END_OF_INSN '\0'
46
a06ea964
NC
47static aarch64_feature_set cpu_variant;
48
49/* Variables that we set while parsing command-line options. Once all
50 options have been read we re-process these values to set the real
51 assembly flags. */
52static const aarch64_feature_set *mcpu_cpu_opt = NULL;
53static const aarch64_feature_set *march_cpu_opt = NULL;
54
55/* Constants for known architecture features. */
56static const aarch64_feature_set cpu_default = CPU_DEFAULT;
57
a06ea964
NC
58#ifdef OBJ_ELF
59/* Pre-defined "_GLOBAL_OFFSET_TABLE_" */
60static symbolS *GOT_symbol;
cec5225b 61
69091a2c
YZ
62/* Which ABI to use. */
63enum aarch64_abi_type
64{
65 AARCH64_ABI_LP64 = 0,
66 AARCH64_ABI_ILP32 = 1
67};
68
69/* AArch64 ABI for the output file. */
70static enum aarch64_abi_type aarch64_abi = AARCH64_ABI_LP64;
71
cec5225b
YZ
72/* When non-zero, program to a 32-bit model, in which the C data types
73 int, long and all pointer types are 32-bit objects (ILP32); or to a
74 64-bit model, in which the C int type is 32-bits but the C long type
75 and all pointer types are 64-bit objects (LP64). */
69091a2c 76#define ilp32_p (aarch64_abi == AARCH64_ABI_ILP32)
a06ea964
NC
77#endif
78
f06935a5 79enum vector_el_type
a06ea964
NC
80{
81 NT_invtype = -1,
82 NT_b,
83 NT_h,
84 NT_s,
85 NT_d,
d50c751e
RS
86 NT_q,
87 NT_zero,
88 NT_merge
a06ea964
NC
89};
90
8f9a77af 91/* Bits for DEFINED field in vector_type_el. */
f11ad6bc
RS
92#define NTA_HASTYPE 1
93#define NTA_HASINDEX 2
94#define NTA_HASVARWIDTH 4
a06ea964 95
8f9a77af 96struct vector_type_el
a06ea964 97{
f06935a5 98 enum vector_el_type type;
a06ea964
NC
99 unsigned char defined;
100 unsigned width;
101 int64_t index;
102};
103
104#define FIXUP_F_HAS_EXPLICIT_SHIFT 0x00000001
105
106struct reloc
107{
108 bfd_reloc_code_real_type type;
109 expressionS exp;
110 int pc_rel;
111 enum aarch64_opnd opnd;
112 uint32_t flags;
113 unsigned need_libopcodes_p : 1;
114};
115
116struct aarch64_instruction
117{
118 /* libopcodes structure for instruction intermediate representation. */
119 aarch64_inst base;
120 /* Record assembly errors found during the parsing. */
121 struct
122 {
123 enum aarch64_operand_error_kind kind;
124 const char *error;
125 } parsing_error;
126 /* The condition that appears in the assembly line. */
127 int cond;
128 /* Relocation information (including the GAS internal fixup). */
129 struct reloc reloc;
130 /* Need to generate an immediate in the literal pool. */
131 unsigned gen_lit_pool : 1;
132};
133
134typedef struct aarch64_instruction aarch64_instruction;
135
136static aarch64_instruction inst;
137
138static bfd_boolean parse_operands (char *, const aarch64_opcode *);
139static bfd_boolean programmer_friendly_fixup (aarch64_instruction *);
140
141/* Diagnostics inline function utilites.
142
143 These are lightweight utlities which should only be called by parse_operands
144 and other parsers. GAS processes each assembly line by parsing it against
145 instruction template(s), in the case of multiple templates (for the same
146 mnemonic name), those templates are tried one by one until one succeeds or
147 all fail. An assembly line may fail a few templates before being
148 successfully parsed; an error saved here in most cases is not a user error
149 but an error indicating the current template is not the right template.
150 Therefore it is very important that errors can be saved at a low cost during
151 the parsing; we don't want to slow down the whole parsing by recording
152 non-user errors in detail.
153
154 Remember that the objective is to help GAS pick up the most approapriate
155 error message in the case of multiple templates, e.g. FMOV which has 8
156 templates. */
157
158static inline void
159clear_error (void)
160{
161 inst.parsing_error.kind = AARCH64_OPDE_NIL;
162 inst.parsing_error.error = NULL;
163}
164
165static inline bfd_boolean
166error_p (void)
167{
168 return inst.parsing_error.kind != AARCH64_OPDE_NIL;
169}
170
171static inline const char *
172get_error_message (void)
173{
174 return inst.parsing_error.error;
175}
176
a06ea964
NC
177static inline enum aarch64_operand_error_kind
178get_error_kind (void)
179{
180 return inst.parsing_error.kind;
181}
182
a06ea964
NC
183static inline void
184set_error (enum aarch64_operand_error_kind kind, const char *error)
185{
186 inst.parsing_error.kind = kind;
187 inst.parsing_error.error = error;
188}
189
190static inline void
191set_recoverable_error (const char *error)
192{
193 set_error (AARCH64_OPDE_RECOVERABLE, error);
194}
195
196/* Use the DESC field of the corresponding aarch64_operand entry to compose
197 the error message. */
198static inline void
199set_default_error (void)
200{
201 set_error (AARCH64_OPDE_SYNTAX_ERROR, NULL);
202}
203
204static inline void
205set_syntax_error (const char *error)
206{
207 set_error (AARCH64_OPDE_SYNTAX_ERROR, error);
208}
209
210static inline void
211set_first_syntax_error (const char *error)
212{
213 if (! error_p ())
214 set_error (AARCH64_OPDE_SYNTAX_ERROR, error);
215}
216
217static inline void
218set_fatal_syntax_error (const char *error)
219{
220 set_error (AARCH64_OPDE_FATAL_SYNTAX_ERROR, error);
221}
222\f
223/* Number of littlenums required to hold an extended precision number. */
224#define MAX_LITTLENUMS 6
225
226/* Return value for certain parsers when the parsing fails; those parsers
227 return the information of the parsed result, e.g. register number, on
228 success. */
229#define PARSE_FAIL -1
230
231/* This is an invalid condition code that means no conditional field is
232 present. */
233#define COND_ALWAYS 0x10
234
235typedef struct
236{
237 const char *template;
238 unsigned long value;
239} asm_barrier_opt;
240
241typedef struct
242{
243 const char *template;
244 uint32_t value;
245} asm_nzcv;
246
247struct reloc_entry
248{
249 char *name;
250 bfd_reloc_code_real_type reloc;
251};
252
a06ea964
NC
253/* Macros to define the register types and masks for the purpose
254 of parsing. */
255
256#undef AARCH64_REG_TYPES
257#define AARCH64_REG_TYPES \
258 BASIC_REG_TYPE(R_32) /* w[0-30] */ \
259 BASIC_REG_TYPE(R_64) /* x[0-30] */ \
260 BASIC_REG_TYPE(SP_32) /* wsp */ \
261 BASIC_REG_TYPE(SP_64) /* sp */ \
262 BASIC_REG_TYPE(Z_32) /* wzr */ \
263 BASIC_REG_TYPE(Z_64) /* xzr */ \
264 BASIC_REG_TYPE(FP_B) /* b[0-31] *//* NOTE: keep FP_[BHSDQ] consecutive! */\
265 BASIC_REG_TYPE(FP_H) /* h[0-31] */ \
266 BASIC_REG_TYPE(FP_S) /* s[0-31] */ \
267 BASIC_REG_TYPE(FP_D) /* d[0-31] */ \
268 BASIC_REG_TYPE(FP_Q) /* q[0-31] */ \
269 BASIC_REG_TYPE(CN) /* c[0-7] */ \
270 BASIC_REG_TYPE(VN) /* v[0-31] */ \
f11ad6bc
RS
271 BASIC_REG_TYPE(ZN) /* z[0-31] */ \
272 BASIC_REG_TYPE(PN) /* p[0-15] */ \
e1b988bb 273 /* Typecheck: any 64-bit int reg (inc SP exc XZR). */ \
a06ea964 274 MULTI_REG_TYPE(R64_SP, REG_TYPE(R_64) | REG_TYPE(SP_64)) \
4df068de
RS
275 /* Typecheck: same, plus SVE registers. */ \
276 MULTI_REG_TYPE(SVE_BASE, REG_TYPE(R_64) | REG_TYPE(SP_64) \
277 | REG_TYPE(ZN)) \
e1b988bb
RS
278 /* Typecheck: x[0-30], w[0-30] or [xw]zr. */ \
279 MULTI_REG_TYPE(R_Z, REG_TYPE(R_32) | REG_TYPE(R_64) \
280 | REG_TYPE(Z_32) | REG_TYPE(Z_64)) \
4df068de
RS
281 /* Typecheck: same, plus SVE registers. */ \
282 MULTI_REG_TYPE(SVE_OFFSET, REG_TYPE(R_32) | REG_TYPE(R_64) \
283 | REG_TYPE(Z_32) | REG_TYPE(Z_64) \
284 | REG_TYPE(ZN)) \
e1b988bb
RS
285 /* Typecheck: x[0-30], w[0-30] or {w}sp. */ \
286 MULTI_REG_TYPE(R_SP, REG_TYPE(R_32) | REG_TYPE(R_64) \
287 | REG_TYPE(SP_32) | REG_TYPE(SP_64)) \
288 /* Typecheck: any int (inc {W}SP inc [WX]ZR). */ \
a06ea964
NC
289 MULTI_REG_TYPE(R_Z_SP, REG_TYPE(R_32) | REG_TYPE(R_64) \
290 | REG_TYPE(SP_32) | REG_TYPE(SP_64) \
291 | REG_TYPE(Z_32) | REG_TYPE(Z_64)) \
292 /* Typecheck: any [BHSDQ]P FP. */ \
293 MULTI_REG_TYPE(BHSDQ, REG_TYPE(FP_B) | REG_TYPE(FP_H) \
294 | REG_TYPE(FP_S) | REG_TYPE(FP_D) | REG_TYPE(FP_Q)) \
e1b988bb 295 /* Typecheck: any int or [BHSDQ]P FP or V reg (exc SP inc [WX]ZR). */ \
a06ea964
NC
296 MULTI_REG_TYPE(R_Z_BHSDQ_V, REG_TYPE(R_32) | REG_TYPE(R_64) \
297 | REG_TYPE(Z_32) | REG_TYPE(Z_64) | REG_TYPE(VN) \
298 | REG_TYPE(FP_B) | REG_TYPE(FP_H) \
299 | REG_TYPE(FP_S) | REG_TYPE(FP_D) | REG_TYPE(FP_Q)) \
300 /* Any integer register; used for error messages only. */ \
301 MULTI_REG_TYPE(R_N, REG_TYPE(R_32) | REG_TYPE(R_64) \
302 | REG_TYPE(SP_32) | REG_TYPE(SP_64) \
303 | REG_TYPE(Z_32) | REG_TYPE(Z_64)) \
304 /* Pseudo type to mark the end of the enumerator sequence. */ \
305 BASIC_REG_TYPE(MAX)
306
307#undef BASIC_REG_TYPE
308#define BASIC_REG_TYPE(T) REG_TYPE_##T,
309#undef MULTI_REG_TYPE
310#define MULTI_REG_TYPE(T,V) BASIC_REG_TYPE(T)
311
312/* Register type enumerators. */
8a0b252a 313typedef enum aarch64_reg_type_
a06ea964
NC
314{
315 /* A list of REG_TYPE_*. */
316 AARCH64_REG_TYPES
317} aarch64_reg_type;
318
319#undef BASIC_REG_TYPE
320#define BASIC_REG_TYPE(T) 1 << REG_TYPE_##T,
321#undef REG_TYPE
322#define REG_TYPE(T) (1 << REG_TYPE_##T)
323#undef MULTI_REG_TYPE
324#define MULTI_REG_TYPE(T,V) V,
325
8a0b252a
TS
326/* Structure for a hash table entry for a register. */
327typedef struct
328{
329 const char *name;
330 unsigned char number;
331 ENUM_BITFIELD (aarch64_reg_type_) type : 8;
332 unsigned char builtin;
333} reg_entry;
334
a06ea964
NC
335/* Values indexed by aarch64_reg_type to assist the type checking. */
336static const unsigned reg_type_masks[] =
337{
338 AARCH64_REG_TYPES
339};
340
341#undef BASIC_REG_TYPE
342#undef REG_TYPE
343#undef MULTI_REG_TYPE
344#undef AARCH64_REG_TYPES
345
346/* Diagnostics used when we don't get a register of the expected type.
347 Note: this has to synchronized with aarch64_reg_type definitions
348 above. */
349static const char *
350get_reg_expected_msg (aarch64_reg_type reg_type)
351{
352 const char *msg;
353
354 switch (reg_type)
355 {
356 case REG_TYPE_R_32:
357 msg = N_("integer 32-bit register expected");
358 break;
359 case REG_TYPE_R_64:
360 msg = N_("integer 64-bit register expected");
361 break;
362 case REG_TYPE_R_N:
363 msg = N_("integer register expected");
364 break;
e1b988bb
RS
365 case REG_TYPE_R64_SP:
366 msg = N_("64-bit integer or SP register expected");
367 break;
4df068de
RS
368 case REG_TYPE_SVE_BASE:
369 msg = N_("base register expected");
370 break;
e1b988bb
RS
371 case REG_TYPE_R_Z:
372 msg = N_("integer or zero register expected");
373 break;
4df068de
RS
374 case REG_TYPE_SVE_OFFSET:
375 msg = N_("offset register expected");
376 break;
e1b988bb
RS
377 case REG_TYPE_R_SP:
378 msg = N_("integer or SP register expected");
379 break;
a06ea964
NC
380 case REG_TYPE_R_Z_SP:
381 msg = N_("integer, zero or SP register expected");
382 break;
383 case REG_TYPE_FP_B:
384 msg = N_("8-bit SIMD scalar register expected");
385 break;
386 case REG_TYPE_FP_H:
387 msg = N_("16-bit SIMD scalar or floating-point half precision "
388 "register expected");
389 break;
390 case REG_TYPE_FP_S:
391 msg = N_("32-bit SIMD scalar or floating-point single precision "
392 "register expected");
393 break;
394 case REG_TYPE_FP_D:
395 msg = N_("64-bit SIMD scalar or floating-point double precision "
396 "register expected");
397 break;
398 case REG_TYPE_FP_Q:
399 msg = N_("128-bit SIMD scalar or floating-point quad precision "
400 "register expected");
401 break;
402 case REG_TYPE_CN:
403 msg = N_("C0 - C15 expected");
404 break;
405 case REG_TYPE_R_Z_BHSDQ_V:
406 msg = N_("register expected");
407 break;
408 case REG_TYPE_BHSDQ: /* any [BHSDQ]P FP */
409 msg = N_("SIMD scalar or floating-point register expected");
410 break;
411 case REG_TYPE_VN: /* any V reg */
412 msg = N_("vector register expected");
413 break;
f11ad6bc
RS
414 case REG_TYPE_ZN:
415 msg = N_("SVE vector register expected");
416 break;
417 case REG_TYPE_PN:
418 msg = N_("SVE predicate register expected");
419 break;
a06ea964
NC
420 default:
421 as_fatal (_("invalid register type %d"), reg_type);
422 }
423 return msg;
424}
425
426/* Some well known registers that we refer to directly elsewhere. */
427#define REG_SP 31
428
429/* Instructions take 4 bytes in the object file. */
430#define INSN_SIZE 4
431
a06ea964
NC
432static struct hash_control *aarch64_ops_hsh;
433static struct hash_control *aarch64_cond_hsh;
434static struct hash_control *aarch64_shift_hsh;
435static struct hash_control *aarch64_sys_regs_hsh;
436static struct hash_control *aarch64_pstatefield_hsh;
437static struct hash_control *aarch64_sys_regs_ic_hsh;
438static struct hash_control *aarch64_sys_regs_dc_hsh;
439static struct hash_control *aarch64_sys_regs_at_hsh;
440static struct hash_control *aarch64_sys_regs_tlbi_hsh;
441static struct hash_control *aarch64_reg_hsh;
442static struct hash_control *aarch64_barrier_opt_hsh;
443static struct hash_control *aarch64_nzcv_hsh;
444static struct hash_control *aarch64_pldop_hsh;
1e6f4800 445static struct hash_control *aarch64_hint_opt_hsh;
a06ea964
NC
446
447/* Stuff needed to resolve the label ambiguity
448 As:
449 ...
450 label: <insn>
451 may differ from:
452 ...
453 label:
454 <insn> */
455
456static symbolS *last_label_seen;
457
458/* Literal pool structure. Held on a per-section
459 and per-sub-section basis. */
460
461#define MAX_LITERAL_POOL_SIZE 1024
55d9b4c1
NC
462typedef struct literal_expression
463{
464 expressionS exp;
465 /* If exp.op == O_big then this bignum holds a copy of the global bignum value. */
466 LITTLENUM_TYPE * bignum;
467} literal_expression;
468
a06ea964
NC
469typedef struct literal_pool
470{
55d9b4c1 471 literal_expression literals[MAX_LITERAL_POOL_SIZE];
a06ea964
NC
472 unsigned int next_free_entry;
473 unsigned int id;
474 symbolS *symbol;
475 segT section;
476 subsegT sub_section;
477 int size;
478 struct literal_pool *next;
479} literal_pool;
480
481/* Pointer to a linked list of literal pools. */
482static literal_pool *list_of_pools = NULL;
483\f
484/* Pure syntax. */
485
486/* This array holds the chars that always start a comment. If the
487 pre-processor is disabled, these aren't very useful. */
488const char comment_chars[] = "";
489
490/* This array holds the chars that only start a comment at the beginning of
491 a line. If the line seems to have the form '# 123 filename'
492 .line and .file directives will appear in the pre-processed output. */
493/* Note that input_file.c hand checks for '#' at the beginning of the
494 first line of the input file. This is because the compiler outputs
495 #NO_APP at the beginning of its output. */
496/* Also note that comments like this one will always work. */
497const char line_comment_chars[] = "#";
498
499const char line_separator_chars[] = ";";
500
501/* Chars that can be used to separate mant
502 from exp in floating point numbers. */
503const char EXP_CHARS[] = "eE";
504
505/* Chars that mean this number is a floating point constant. */
506/* As in 0f12.456 */
507/* or 0d1.2345e12 */
508
509const char FLT_CHARS[] = "rRsSfFdDxXeEpP";
510
511/* Prefix character that indicates the start of an immediate value. */
512#define is_immediate_prefix(C) ((C) == '#')
513
514/* Separator character handling. */
515
516#define skip_whitespace(str) do { if (*(str) == ' ') ++(str); } while (0)
517
518static inline bfd_boolean
519skip_past_char (char **str, char c)
520{
521 if (**str == c)
522 {
523 (*str)++;
524 return TRUE;
525 }
526 else
527 return FALSE;
528}
529
530#define skip_past_comma(str) skip_past_char (str, ',')
531
532/* Arithmetic expressions (possibly involving symbols). */
533
a06ea964
NC
534static bfd_boolean in_my_get_expression_p = FALSE;
535
536/* Third argument to my_get_expression. */
537#define GE_NO_PREFIX 0
538#define GE_OPT_PREFIX 1
539
540/* Return TRUE if the string pointed by *STR is successfully parsed
541 as an valid expression; *EP will be filled with the information of
542 such an expression. Otherwise return FALSE. */
543
544static bfd_boolean
545my_get_expression (expressionS * ep, char **str, int prefix_mode,
546 int reject_absent)
547{
548 char *save_in;
549 segT seg;
550 int prefix_present_p = 0;
551
552 switch (prefix_mode)
553 {
554 case GE_NO_PREFIX:
555 break;
556 case GE_OPT_PREFIX:
557 if (is_immediate_prefix (**str))
558 {
559 (*str)++;
560 prefix_present_p = 1;
561 }
562 break;
563 default:
564 abort ();
565 }
566
567 memset (ep, 0, sizeof (expressionS));
568
569 save_in = input_line_pointer;
570 input_line_pointer = *str;
571 in_my_get_expression_p = TRUE;
572 seg = expression (ep);
573 in_my_get_expression_p = FALSE;
574
575 if (ep->X_op == O_illegal || (reject_absent && ep->X_op == O_absent))
576 {
577 /* We found a bad expression in md_operand(). */
578 *str = input_line_pointer;
579 input_line_pointer = save_in;
580 if (prefix_present_p && ! error_p ())
581 set_fatal_syntax_error (_("bad expression"));
582 else
583 set_first_syntax_error (_("bad expression"));
584 return FALSE;
585 }
586
587#ifdef OBJ_AOUT
588 if (seg != absolute_section
589 && seg != text_section
590 && seg != data_section
591 && seg != bss_section && seg != undefined_section)
592 {
593 set_syntax_error (_("bad segment"));
594 *str = input_line_pointer;
595 input_line_pointer = save_in;
596 return FALSE;
597 }
598#else
599 (void) seg;
600#endif
601
a06ea964
NC
602 *str = input_line_pointer;
603 input_line_pointer = save_in;
604 return TRUE;
605}
606
607/* Turn a string in input_line_pointer into a floating point constant
608 of type TYPE, and store the appropriate bytes in *LITP. The number
609 of LITTLENUMS emitted is stored in *SIZEP. An error message is
610 returned, or NULL on OK. */
611
6d4af3c2 612const char *
a06ea964
NC
613md_atof (int type, char *litP, int *sizeP)
614{
615 return ieee_md_atof (type, litP, sizeP, target_big_endian);
616}
617
618/* We handle all bad expressions here, so that we can report the faulty
619 instruction in the error message. */
620void
621md_operand (expressionS * exp)
622{
623 if (in_my_get_expression_p)
624 exp->X_op = O_illegal;
625}
626
627/* Immediate values. */
628
629/* Errors may be set multiple times during parsing or bit encoding
630 (particularly in the Neon bits), but usually the earliest error which is set
631 will be the most meaningful. Avoid overwriting it with later (cascading)
632 errors by calling this function. */
633
634static void
635first_error (const char *error)
636{
637 if (! error_p ())
638 set_syntax_error (error);
639}
640
641/* Similiar to first_error, but this function accepts formatted error
642 message. */
643static void
644first_error_fmt (const char *format, ...)
645{
646 va_list args;
647 enum
648 { size = 100 };
649 /* N.B. this single buffer will not cause error messages for different
650 instructions to pollute each other; this is because at the end of
651 processing of each assembly line, error message if any will be
652 collected by as_bad. */
653 static char buffer[size];
654
655 if (! error_p ())
656 {
3e0baa28 657 int ret ATTRIBUTE_UNUSED;
a06ea964
NC
658 va_start (args, format);
659 ret = vsnprintf (buffer, size, format, args);
660 know (ret <= size - 1 && ret >= 0);
661 va_end (args);
662 set_syntax_error (buffer);
663 }
664}
665
666/* Register parsing. */
667
668/* Generic register parser which is called by other specialized
669 register parsers.
670 CCP points to what should be the beginning of a register name.
671 If it is indeed a valid register name, advance CCP over it and
672 return the reg_entry structure; otherwise return NULL.
673 It does not issue diagnostics. */
674
675static reg_entry *
676parse_reg (char **ccp)
677{
678 char *start = *ccp;
679 char *p;
680 reg_entry *reg;
681
682#ifdef REGISTER_PREFIX
683 if (*start != REGISTER_PREFIX)
684 return NULL;
685 start++;
686#endif
687
688 p = start;
689 if (!ISALPHA (*p) || !is_name_beginner (*p))
690 return NULL;
691
692 do
693 p++;
694 while (ISALPHA (*p) || ISDIGIT (*p) || *p == '_');
695
696 reg = (reg_entry *) hash_find_n (aarch64_reg_hsh, start, p - start);
697
698 if (!reg)
699 return NULL;
700
701 *ccp = p;
702 return reg;
703}
704
705/* Return TRUE if REG->TYPE is a valid type of TYPE; otherwise
706 return FALSE. */
707static bfd_boolean
708aarch64_check_reg_type (const reg_entry *reg, aarch64_reg_type type)
709{
e1b988bb 710 return (reg_type_masks[type] & (1 << reg->type)) != 0;
a06ea964
NC
711}
712
4df068de
RS
713/* Try to parse a base or offset register. Allow SVE base and offset
714 registers if REG_TYPE includes SVE registers. Return the register
715 entry on success, setting *QUALIFIER to the register qualifier.
716 Return null otherwise.
e1b988bb 717
a06ea964
NC
718 Note that this function does not issue any diagnostics. */
719
e1b988bb 720static const reg_entry *
4df068de
RS
721aarch64_addr_reg_parse (char **ccp, aarch64_reg_type reg_type,
722 aarch64_opnd_qualifier_t *qualifier)
a06ea964
NC
723{
724 char *str = *ccp;
725 const reg_entry *reg = parse_reg (&str);
726
727 if (reg == NULL)
e1b988bb 728 return NULL;
a06ea964
NC
729
730 switch (reg->type)
731 {
e1b988bb 732 case REG_TYPE_R_32:
a06ea964 733 case REG_TYPE_SP_32:
e1b988bb
RS
734 case REG_TYPE_Z_32:
735 *qualifier = AARCH64_OPND_QLF_W;
a06ea964 736 break;
e1b988bb 737
a06ea964 738 case REG_TYPE_R_64:
e1b988bb 739 case REG_TYPE_SP_64:
a06ea964 740 case REG_TYPE_Z_64:
e1b988bb 741 *qualifier = AARCH64_OPND_QLF_X;
a06ea964 742 break;
e1b988bb 743
4df068de
RS
744 case REG_TYPE_ZN:
745 if ((reg_type_masks[reg_type] & (1 << REG_TYPE_ZN)) == 0
746 || str[0] != '.')
747 return NULL;
748 switch (TOLOWER (str[1]))
749 {
750 case 's':
751 *qualifier = AARCH64_OPND_QLF_S_S;
752 break;
753 case 'd':
754 *qualifier = AARCH64_OPND_QLF_S_D;
755 break;
756 default:
757 return NULL;
758 }
759 str += 2;
760 break;
761
a06ea964 762 default:
e1b988bb 763 return NULL;
a06ea964
NC
764 }
765
766 *ccp = str;
767
e1b988bb 768 return reg;
a06ea964
NC
769}
770
4df068de
RS
771/* Try to parse a base or offset register. Return the register entry
772 on success, setting *QUALIFIER to the register qualifier. Return null
773 otherwise.
774
775 Note that this function does not issue any diagnostics. */
776
777static const reg_entry *
778aarch64_reg_parse_32_64 (char **ccp, aarch64_opnd_qualifier_t *qualifier)
779{
780 return aarch64_addr_reg_parse (ccp, REG_TYPE_R_Z_SP, qualifier);
781}
782
f11ad6bc
RS
783/* Parse the qualifier of a vector register or vector element of type
784 REG_TYPE. Fill in *PARSED_TYPE and return TRUE if the parsing
785 succeeds; otherwise return FALSE.
a06ea964
NC
786
787 Accept only one occurrence of:
3067d3b9 788 8b 16b 2h 4h 8h 2s 4s 1d 2d
a06ea964
NC
789 b h s d q */
790static bfd_boolean
f11ad6bc
RS
791parse_vector_type_for_operand (aarch64_reg_type reg_type,
792 struct vector_type_el *parsed_type, char **str)
a06ea964
NC
793{
794 char *ptr = *str;
795 unsigned width;
796 unsigned element_size;
f06935a5 797 enum vector_el_type type;
a06ea964
NC
798
799 /* skip '.' */
d50c751e 800 gas_assert (*ptr == '.');
a06ea964
NC
801 ptr++;
802
f11ad6bc 803 if (reg_type == REG_TYPE_ZN || reg_type == REG_TYPE_PN || !ISDIGIT (*ptr))
a06ea964
NC
804 {
805 width = 0;
806 goto elt_size;
807 }
808 width = strtoul (ptr, &ptr, 10);
809 if (width != 1 && width != 2 && width != 4 && width != 8 && width != 16)
810 {
811 first_error_fmt (_("bad size %d in vector width specifier"), width);
812 return FALSE;
813 }
814
815elt_size:
816 switch (TOLOWER (*ptr))
817 {
818 case 'b':
819 type = NT_b;
820 element_size = 8;
821 break;
822 case 'h':
823 type = NT_h;
824 element_size = 16;
825 break;
826 case 's':
827 type = NT_s;
828 element_size = 32;
829 break;
830 case 'd':
831 type = NT_d;
832 element_size = 64;
833 break;
834 case 'q':
835 if (width == 1)
836 {
837 type = NT_q;
838 element_size = 128;
839 break;
840 }
841 /* fall through. */
842 default:
843 if (*ptr != '\0')
844 first_error_fmt (_("unexpected character `%c' in element size"), *ptr);
845 else
846 first_error (_("missing element size"));
847 return FALSE;
848 }
3067d3b9
MW
849 if (width != 0 && width * element_size != 64 && width * element_size != 128
850 && !(width == 2 && element_size == 16))
a06ea964
NC
851 {
852 first_error_fmt (_
853 ("invalid element size %d and vector size combination %c"),
854 width, *ptr);
855 return FALSE;
856 }
857 ptr++;
858
859 parsed_type->type = type;
860 parsed_type->width = width;
861
862 *str = ptr;
863
864 return TRUE;
865}
866
d50c751e
RS
867/* *STR contains an SVE zero/merge predication suffix. Parse it into
868 *PARSED_TYPE and point *STR at the end of the suffix. */
869
870static bfd_boolean
871parse_predication_for_operand (struct vector_type_el *parsed_type, char **str)
872{
873 char *ptr = *str;
874
875 /* Skip '/'. */
876 gas_assert (*ptr == '/');
877 ptr++;
878 switch (TOLOWER (*ptr))
879 {
880 case 'z':
881 parsed_type->type = NT_zero;
882 break;
883 case 'm':
884 parsed_type->type = NT_merge;
885 break;
886 default:
887 if (*ptr != '\0' && *ptr != ',')
888 first_error_fmt (_("unexpected character `%c' in predication type"),
889 *ptr);
890 else
891 first_error (_("missing predication type"));
892 return FALSE;
893 }
894 parsed_type->width = 0;
895 *str = ptr + 1;
896 return TRUE;
897}
898
a06ea964
NC
899/* Parse a register of the type TYPE.
900
901 Return PARSE_FAIL if the string pointed by *CCP is not a valid register
902 name or the parsed register is not of TYPE.
903
904 Otherwise return the register number, and optionally fill in the actual
905 type of the register in *RTYPE when multiple alternatives were given, and
906 return the register shape and element index information in *TYPEINFO.
907
908 IN_REG_LIST should be set with TRUE if the caller is parsing a register
909 list. */
910
911static int
912parse_typed_reg (char **ccp, aarch64_reg_type type, aarch64_reg_type *rtype,
8f9a77af 913 struct vector_type_el *typeinfo, bfd_boolean in_reg_list)
a06ea964
NC
914{
915 char *str = *ccp;
916 const reg_entry *reg = parse_reg (&str);
8f9a77af
RS
917 struct vector_type_el atype;
918 struct vector_type_el parsetype;
a06ea964
NC
919 bfd_boolean is_typed_vecreg = FALSE;
920
921 atype.defined = 0;
922 atype.type = NT_invtype;
923 atype.width = -1;
924 atype.index = 0;
925
926 if (reg == NULL)
927 {
928 if (typeinfo)
929 *typeinfo = atype;
930 set_default_error ();
931 return PARSE_FAIL;
932 }
933
934 if (! aarch64_check_reg_type (reg, type))
935 {
936 DEBUG_TRACE ("reg type check failed");
937 set_default_error ();
938 return PARSE_FAIL;
939 }
940 type = reg->type;
941
f11ad6bc 942 if ((type == REG_TYPE_VN || type == REG_TYPE_ZN || type == REG_TYPE_PN)
d50c751e 943 && (*str == '.' || (type == REG_TYPE_PN && *str == '/')))
a06ea964 944 {
d50c751e
RS
945 if (*str == '.')
946 {
947 if (!parse_vector_type_for_operand (type, &parsetype, &str))
948 return PARSE_FAIL;
949 }
950 else
951 {
952 if (!parse_predication_for_operand (&parsetype, &str))
953 return PARSE_FAIL;
954 }
a235d3ae 955
a06ea964
NC
956 /* Register if of the form Vn.[bhsdq]. */
957 is_typed_vecreg = TRUE;
958
f11ad6bc
RS
959 if (type == REG_TYPE_ZN || type == REG_TYPE_PN)
960 {
961 /* The width is always variable; we don't allow an integer width
962 to be specified. */
963 gas_assert (parsetype.width == 0);
964 atype.defined |= NTA_HASVARWIDTH | NTA_HASTYPE;
965 }
966 else if (parsetype.width == 0)
a06ea964
NC
967 /* Expect index. In the new scheme we cannot have
968 Vn.[bhsdq] represent a scalar. Therefore any
969 Vn.[bhsdq] should have an index following it.
970 Except in reglists ofcourse. */
971 atype.defined |= NTA_HASINDEX;
972 else
973 atype.defined |= NTA_HASTYPE;
974
975 atype.type = parsetype.type;
976 atype.width = parsetype.width;
977 }
978
979 if (skip_past_char (&str, '['))
980 {
981 expressionS exp;
982
983 /* Reject Sn[index] syntax. */
984 if (!is_typed_vecreg)
985 {
986 first_error (_("this type of register can't be indexed"));
987 return PARSE_FAIL;
988 }
989
990 if (in_reg_list == TRUE)
991 {
992 first_error (_("index not allowed inside register list"));
993 return PARSE_FAIL;
994 }
995
996 atype.defined |= NTA_HASINDEX;
997
998 my_get_expression (&exp, &str, GE_NO_PREFIX, 1);
999
1000 if (exp.X_op != O_constant)
1001 {
1002 first_error (_("constant expression required"));
1003 return PARSE_FAIL;
1004 }
1005
1006 if (! skip_past_char (&str, ']'))
1007 return PARSE_FAIL;
1008
1009 atype.index = exp.X_add_number;
1010 }
1011 else if (!in_reg_list && (atype.defined & NTA_HASINDEX) != 0)
1012 {
1013 /* Indexed vector register expected. */
1014 first_error (_("indexed vector register expected"));
1015 return PARSE_FAIL;
1016 }
1017
1018 /* A vector reg Vn should be typed or indexed. */
1019 if (type == REG_TYPE_VN && atype.defined == 0)
1020 {
1021 first_error (_("invalid use of vector register"));
1022 }
1023
1024 if (typeinfo)
1025 *typeinfo = atype;
1026
1027 if (rtype)
1028 *rtype = type;
1029
1030 *ccp = str;
1031
1032 return reg->number;
1033}
1034
1035/* Parse register.
1036
1037 Return the register number on success; return PARSE_FAIL otherwise.
1038
1039 If RTYPE is not NULL, return in *RTYPE the (possibly restricted) type of
1040 the register (e.g. NEON double or quad reg when either has been requested).
1041
1042 If this is a NEON vector register with additional type information, fill
1043 in the struct pointed to by VECTYPE (if non-NULL).
1044
1045 This parser does not handle register list. */
1046
1047static int
1048aarch64_reg_parse (char **ccp, aarch64_reg_type type,
8f9a77af 1049 aarch64_reg_type *rtype, struct vector_type_el *vectype)
a06ea964 1050{
8f9a77af 1051 struct vector_type_el atype;
a06ea964
NC
1052 char *str = *ccp;
1053 int reg = parse_typed_reg (&str, type, rtype, &atype,
1054 /*in_reg_list= */ FALSE);
1055
1056 if (reg == PARSE_FAIL)
1057 return PARSE_FAIL;
1058
1059 if (vectype)
1060 *vectype = atype;
1061
1062 *ccp = str;
1063
1064 return reg;
1065}
1066
1067static inline bfd_boolean
8f9a77af 1068eq_vector_type_el (struct vector_type_el e1, struct vector_type_el e2)
a06ea964
NC
1069{
1070 return
1071 e1.type == e2.type
1072 && e1.defined == e2.defined
1073 && e1.width == e2.width && e1.index == e2.index;
1074}
1075
10d76650
RS
1076/* This function parses a list of vector registers of type TYPE.
1077 On success, it returns the parsed register list information in the
1078 following encoded format:
a06ea964
NC
1079
1080 bit 18-22 | 13-17 | 7-11 | 2-6 | 0-1
1081 4th regno | 3rd regno | 2nd regno | 1st regno | num_of_reg
1082
1083 The information of the register shape and/or index is returned in
1084 *VECTYPE.
1085
1086 It returns PARSE_FAIL if the register list is invalid.
1087
1088 The list contains one to four registers.
1089 Each register can be one of:
1090 <Vt>.<T>[<index>]
1091 <Vt>.<T>
1092 All <T> should be identical.
1093 All <index> should be identical.
1094 There are restrictions on <Vt> numbers which are checked later
1095 (by reg_list_valid_p). */
1096
1097static int
10d76650
RS
1098parse_vector_reg_list (char **ccp, aarch64_reg_type type,
1099 struct vector_type_el *vectype)
a06ea964
NC
1100{
1101 char *str = *ccp;
1102 int nb_regs;
8f9a77af 1103 struct vector_type_el typeinfo, typeinfo_first;
a06ea964
NC
1104 int val, val_range;
1105 int in_range;
1106 int ret_val;
1107 int i;
1108 bfd_boolean error = FALSE;
1109 bfd_boolean expect_index = FALSE;
1110
1111 if (*str != '{')
1112 {
1113 set_syntax_error (_("expecting {"));
1114 return PARSE_FAIL;
1115 }
1116 str++;
1117
1118 nb_regs = 0;
1119 typeinfo_first.defined = 0;
1120 typeinfo_first.type = NT_invtype;
1121 typeinfo_first.width = -1;
1122 typeinfo_first.index = 0;
1123 ret_val = 0;
1124 val = -1;
1125 val_range = -1;
1126 in_range = 0;
1127 do
1128 {
1129 if (in_range)
1130 {
1131 str++; /* skip over '-' */
1132 val_range = val;
1133 }
10d76650 1134 val = parse_typed_reg (&str, type, NULL, &typeinfo,
a06ea964
NC
1135 /*in_reg_list= */ TRUE);
1136 if (val == PARSE_FAIL)
1137 {
1138 set_first_syntax_error (_("invalid vector register in list"));
1139 error = TRUE;
1140 continue;
1141 }
1142 /* reject [bhsd]n */
f11ad6bc 1143 if (type == REG_TYPE_VN && typeinfo.defined == 0)
a06ea964
NC
1144 {
1145 set_first_syntax_error (_("invalid scalar register in list"));
1146 error = TRUE;
1147 continue;
1148 }
1149
1150 if (typeinfo.defined & NTA_HASINDEX)
1151 expect_index = TRUE;
1152
1153 if (in_range)
1154 {
1155 if (val < val_range)
1156 {
1157 set_first_syntax_error
1158 (_("invalid range in vector register list"));
1159 error = TRUE;
1160 }
1161 val_range++;
1162 }
1163 else
1164 {
1165 val_range = val;
1166 if (nb_regs == 0)
1167 typeinfo_first = typeinfo;
8f9a77af 1168 else if (! eq_vector_type_el (typeinfo_first, typeinfo))
a06ea964
NC
1169 {
1170 set_first_syntax_error
1171 (_("type mismatch in vector register list"));
1172 error = TRUE;
1173 }
1174 }
1175 if (! error)
1176 for (i = val_range; i <= val; i++)
1177 {
1178 ret_val |= i << (5 * nb_regs);
1179 nb_regs++;
1180 }
1181 in_range = 0;
1182 }
1183 while (skip_past_comma (&str) || (in_range = 1, *str == '-'));
1184
1185 skip_whitespace (str);
1186 if (*str != '}')
1187 {
1188 set_first_syntax_error (_("end of vector register list not found"));
1189 error = TRUE;
1190 }
1191 str++;
1192
1193 skip_whitespace (str);
1194
1195 if (expect_index)
1196 {
1197 if (skip_past_char (&str, '['))
1198 {
1199 expressionS exp;
1200
1201 my_get_expression (&exp, &str, GE_NO_PREFIX, 1);
1202 if (exp.X_op != O_constant)
1203 {
1204 set_first_syntax_error (_("constant expression required."));
1205 error = TRUE;
1206 }
1207 if (! skip_past_char (&str, ']'))
1208 error = TRUE;
1209 else
1210 typeinfo_first.index = exp.X_add_number;
1211 }
1212 else
1213 {
1214 set_first_syntax_error (_("expected index"));
1215 error = TRUE;
1216 }
1217 }
1218
1219 if (nb_regs > 4)
1220 {
1221 set_first_syntax_error (_("too many registers in vector register list"));
1222 error = TRUE;
1223 }
1224 else if (nb_regs == 0)
1225 {
1226 set_first_syntax_error (_("empty vector register list"));
1227 error = TRUE;
1228 }
1229
1230 *ccp = str;
1231 if (! error)
1232 *vectype = typeinfo_first;
1233
1234 return error ? PARSE_FAIL : (ret_val << 2) | (nb_regs - 1);
1235}
1236
1237/* Directives: register aliases. */
1238
1239static reg_entry *
1240insert_reg_alias (char *str, int number, aarch64_reg_type type)
1241{
1242 reg_entry *new;
1243 const char *name;
1244
1245 if ((new = hash_find (aarch64_reg_hsh, str)) != 0)
1246 {
1247 if (new->builtin)
1248 as_warn (_("ignoring attempt to redefine built-in register '%s'"),
1249 str);
1250
1251 /* Only warn about a redefinition if it's not defined as the
1252 same register. */
1253 else if (new->number != number || new->type != type)
1254 as_warn (_("ignoring redefinition of register alias '%s'"), str);
1255
1256 return NULL;
1257 }
1258
1259 name = xstrdup (str);
add39d23 1260 new = XNEW (reg_entry);
a06ea964
NC
1261
1262 new->name = name;
1263 new->number = number;
1264 new->type = type;
1265 new->builtin = FALSE;
1266
1267 if (hash_insert (aarch64_reg_hsh, name, (void *) new))
1268 abort ();
1269
1270 return new;
1271}
1272
1273/* Look for the .req directive. This is of the form:
1274
1275 new_register_name .req existing_register_name
1276
1277 If we find one, or if it looks sufficiently like one that we want to
1278 handle any error here, return TRUE. Otherwise return FALSE. */
1279
1280static bfd_boolean
1281create_register_alias (char *newname, char *p)
1282{
1283 const reg_entry *old;
1284 char *oldname, *nbuf;
1285 size_t nlen;
1286
1287 /* The input scrubber ensures that whitespace after the mnemonic is
1288 collapsed to single spaces. */
1289 oldname = p;
1290 if (strncmp (oldname, " .req ", 6) != 0)
1291 return FALSE;
1292
1293 oldname += 6;
1294 if (*oldname == '\0')
1295 return FALSE;
1296
1297 old = hash_find (aarch64_reg_hsh, oldname);
1298 if (!old)
1299 {
1300 as_warn (_("unknown register '%s' -- .req ignored"), oldname);
1301 return TRUE;
1302 }
1303
1304 /* If TC_CASE_SENSITIVE is defined, then newname already points to
1305 the desired alias name, and p points to its end. If not, then
1306 the desired alias name is in the global original_case_string. */
1307#ifdef TC_CASE_SENSITIVE
1308 nlen = p - newname;
1309#else
1310 newname = original_case_string;
1311 nlen = strlen (newname);
1312#endif
1313
29a2809e 1314 nbuf = xmemdup0 (newname, nlen);
a06ea964
NC
1315
1316 /* Create aliases under the new name as stated; an all-lowercase
1317 version of the new name; and an all-uppercase version of the new
1318 name. */
1319 if (insert_reg_alias (nbuf, old->number, old->type) != NULL)
1320 {
1321 for (p = nbuf; *p; p++)
1322 *p = TOUPPER (*p);
1323
1324 if (strncmp (nbuf, newname, nlen))
1325 {
1326 /* If this attempt to create an additional alias fails, do not bother
1327 trying to create the all-lower case alias. We will fail and issue
1328 a second, duplicate error message. This situation arises when the
1329 programmer does something like:
1330 foo .req r0
1331 Foo .req r1
1332 The second .req creates the "Foo" alias but then fails to create
1333 the artificial FOO alias because it has already been created by the
1334 first .req. */
1335 if (insert_reg_alias (nbuf, old->number, old->type) == NULL)
e1fa0163
NC
1336 {
1337 free (nbuf);
1338 return TRUE;
1339 }
a06ea964
NC
1340 }
1341
1342 for (p = nbuf; *p; p++)
1343 *p = TOLOWER (*p);
1344
1345 if (strncmp (nbuf, newname, nlen))
1346 insert_reg_alias (nbuf, old->number, old->type);
1347 }
1348
e1fa0163 1349 free (nbuf);
a06ea964
NC
1350 return TRUE;
1351}
1352
1353/* Should never be called, as .req goes between the alias and the
1354 register name, not at the beginning of the line. */
1355static void
1356s_req (int a ATTRIBUTE_UNUSED)
1357{
1358 as_bad (_("invalid syntax for .req directive"));
1359}
1360
1361/* The .unreq directive deletes an alias which was previously defined
1362 by .req. For example:
1363
1364 my_alias .req r11
1365 .unreq my_alias */
1366
1367static void
1368s_unreq (int a ATTRIBUTE_UNUSED)
1369{
1370 char *name;
1371 char saved_char;
1372
1373 name = input_line_pointer;
1374
1375 while (*input_line_pointer != 0
1376 && *input_line_pointer != ' ' && *input_line_pointer != '\n')
1377 ++input_line_pointer;
1378
1379 saved_char = *input_line_pointer;
1380 *input_line_pointer = 0;
1381
1382 if (!*name)
1383 as_bad (_("invalid syntax for .unreq directive"));
1384 else
1385 {
1386 reg_entry *reg = hash_find (aarch64_reg_hsh, name);
1387
1388 if (!reg)
1389 as_bad (_("unknown register alias '%s'"), name);
1390 else if (reg->builtin)
1391 as_warn (_("ignoring attempt to undefine built-in register '%s'"),
1392 name);
1393 else
1394 {
1395 char *p;
1396 char *nbuf;
1397
1398 hash_delete (aarch64_reg_hsh, name, FALSE);
1399 free ((char *) reg->name);
1400 free (reg);
1401
1402 /* Also locate the all upper case and all lower case versions.
1403 Do not complain if we cannot find one or the other as it
1404 was probably deleted above. */
1405
1406 nbuf = strdup (name);
1407 for (p = nbuf; *p; p++)
1408 *p = TOUPPER (*p);
1409 reg = hash_find (aarch64_reg_hsh, nbuf);
1410 if (reg)
1411 {
1412 hash_delete (aarch64_reg_hsh, nbuf, FALSE);
1413 free ((char *) reg->name);
1414 free (reg);
1415 }
1416
1417 for (p = nbuf; *p; p++)
1418 *p = TOLOWER (*p);
1419 reg = hash_find (aarch64_reg_hsh, nbuf);
1420 if (reg)
1421 {
1422 hash_delete (aarch64_reg_hsh, nbuf, FALSE);
1423 free ((char *) reg->name);
1424 free (reg);
1425 }
1426
1427 free (nbuf);
1428 }
1429 }
1430
1431 *input_line_pointer = saved_char;
1432 demand_empty_rest_of_line ();
1433}
1434
1435/* Directives: Instruction set selection. */
1436
1437#ifdef OBJ_ELF
1438/* This code is to handle mapping symbols as defined in the ARM AArch64 ELF
1439 spec. (See "Mapping symbols", section 4.5.4, ARM AAELF64 version 0.05).
1440 Note that previously, $a and $t has type STT_FUNC (BSF_OBJECT flag),
1441 and $d has type STT_OBJECT (BSF_OBJECT flag). Now all three are untyped. */
1442
1443/* Create a new mapping symbol for the transition to STATE. */
1444
1445static void
1446make_mapping_symbol (enum mstate state, valueT value, fragS * frag)
1447{
1448 symbolS *symbolP;
1449 const char *symname;
1450 int type;
1451
1452 switch (state)
1453 {
1454 case MAP_DATA:
1455 symname = "$d";
1456 type = BSF_NO_FLAGS;
1457 break;
1458 case MAP_INSN:
1459 symname = "$x";
1460 type = BSF_NO_FLAGS;
1461 break;
1462 default:
1463 abort ();
1464 }
1465
1466 symbolP = symbol_new (symname, now_seg, value, frag);
1467 symbol_get_bfdsym (symbolP)->flags |= type | BSF_LOCAL;
1468
1469 /* Save the mapping symbols for future reference. Also check that
1470 we do not place two mapping symbols at the same offset within a
1471 frag. We'll handle overlap between frags in
1472 check_mapping_symbols.
1473
1474 If .fill or other data filling directive generates zero sized data,
1475 the mapping symbol for the following code will have the same value
1476 as the one generated for the data filling directive. In this case,
1477 we replace the old symbol with the new one at the same address. */
1478 if (value == 0)
1479 {
1480 if (frag->tc_frag_data.first_map != NULL)
1481 {
1482 know (S_GET_VALUE (frag->tc_frag_data.first_map) == 0);
1483 symbol_remove (frag->tc_frag_data.first_map, &symbol_rootP,
1484 &symbol_lastP);
1485 }
1486 frag->tc_frag_data.first_map = symbolP;
1487 }
1488 if (frag->tc_frag_data.last_map != NULL)
1489 {
1490 know (S_GET_VALUE (frag->tc_frag_data.last_map) <=
1491 S_GET_VALUE (symbolP));
1492 if (S_GET_VALUE (frag->tc_frag_data.last_map) == S_GET_VALUE (symbolP))
1493 symbol_remove (frag->tc_frag_data.last_map, &symbol_rootP,
1494 &symbol_lastP);
1495 }
1496 frag->tc_frag_data.last_map = symbolP;
1497}
1498
1499/* We must sometimes convert a region marked as code to data during
1500 code alignment, if an odd number of bytes have to be padded. The
1501 code mapping symbol is pushed to an aligned address. */
1502
1503static void
1504insert_data_mapping_symbol (enum mstate state,
1505 valueT value, fragS * frag, offsetT bytes)
1506{
1507 /* If there was already a mapping symbol, remove it. */
1508 if (frag->tc_frag_data.last_map != NULL
1509 && S_GET_VALUE (frag->tc_frag_data.last_map) ==
1510 frag->fr_address + value)
1511 {
1512 symbolS *symp = frag->tc_frag_data.last_map;
1513
1514 if (value == 0)
1515 {
1516 know (frag->tc_frag_data.first_map == symp);
1517 frag->tc_frag_data.first_map = NULL;
1518 }
1519 frag->tc_frag_data.last_map = NULL;
1520 symbol_remove (symp, &symbol_rootP, &symbol_lastP);
1521 }
1522
1523 make_mapping_symbol (MAP_DATA, value, frag);
1524 make_mapping_symbol (state, value + bytes, frag);
1525}
1526
1527static void mapping_state_2 (enum mstate state, int max_chars);
1528
1529/* Set the mapping state to STATE. Only call this when about to
1530 emit some STATE bytes to the file. */
1531
1532void
1533mapping_state (enum mstate state)
1534{
1535 enum mstate mapstate = seg_info (now_seg)->tc_segment_info_data.mapstate;
1536
a578ef7e
JW
1537 if (state == MAP_INSN)
1538 /* AArch64 instructions require 4-byte alignment. When emitting
1539 instructions into any section, record the appropriate section
1540 alignment. */
1541 record_alignment (now_seg, 2);
1542
448eb63d
RL
1543 if (mapstate == state)
1544 /* The mapping symbol has already been emitted.
1545 There is nothing else to do. */
1546 return;
1547
c1baaddf 1548#define TRANSITION(from, to) (mapstate == (from) && state == (to))
a97902de
RL
1549 if (TRANSITION (MAP_UNDEFINED, MAP_DATA) && !subseg_text_p (now_seg))
1550 /* Emit MAP_DATA within executable section in order. Otherwise, it will be
c1baaddf 1551 evaluated later in the next else. */
a06ea964 1552 return;
c1baaddf
RL
1553 else if (TRANSITION (MAP_UNDEFINED, MAP_INSN))
1554 {
1555 /* Only add the symbol if the offset is > 0:
1556 if we're at the first frag, check it's size > 0;
1557 if we're not at the first frag, then for sure
1558 the offset is > 0. */
1559 struct frag *const frag_first = seg_info (now_seg)->frchainP->frch_root;
1560 const int add_symbol = (frag_now != frag_first)
1561 || (frag_now_fix () > 0);
1562
1563 if (add_symbol)
1564 make_mapping_symbol (MAP_DATA, (valueT) 0, frag_first);
1565 }
1566#undef TRANSITION
a06ea964
NC
1567
1568 mapping_state_2 (state, 0);
a06ea964
NC
1569}
1570
1571/* Same as mapping_state, but MAX_CHARS bytes have already been
1572 allocated. Put the mapping symbol that far back. */
1573
1574static void
1575mapping_state_2 (enum mstate state, int max_chars)
1576{
1577 enum mstate mapstate = seg_info (now_seg)->tc_segment_info_data.mapstate;
1578
1579 if (!SEG_NORMAL (now_seg))
1580 return;
1581
1582 if (mapstate == state)
1583 /* The mapping symbol has already been emitted.
1584 There is nothing else to do. */
1585 return;
1586
1587 seg_info (now_seg)->tc_segment_info_data.mapstate = state;
1588 make_mapping_symbol (state, (valueT) frag_now_fix () - max_chars, frag_now);
1589}
1590#else
1591#define mapping_state(x) /* nothing */
1592#define mapping_state_2(x, y) /* nothing */
1593#endif
1594
1595/* Directives: sectioning and alignment. */
1596
1597static void
1598s_bss (int ignore ATTRIBUTE_UNUSED)
1599{
1600 /* We don't support putting frags in the BSS segment, we fake it by
1601 marking in_bss, then looking at s_skip for clues. */
1602 subseg_set (bss_section, 0);
1603 demand_empty_rest_of_line ();
1604 mapping_state (MAP_DATA);
1605}
1606
1607static void
1608s_even (int ignore ATTRIBUTE_UNUSED)
1609{
1610 /* Never make frag if expect extra pass. */
1611 if (!need_pass_2)
1612 frag_align (1, 0, 0);
1613
1614 record_alignment (now_seg, 1);
1615
1616 demand_empty_rest_of_line ();
1617}
1618
1619/* Directives: Literal pools. */
1620
1621static literal_pool *
1622find_literal_pool (int size)
1623{
1624 literal_pool *pool;
1625
1626 for (pool = list_of_pools; pool != NULL; pool = pool->next)
1627 {
1628 if (pool->section == now_seg
1629 && pool->sub_section == now_subseg && pool->size == size)
1630 break;
1631 }
1632
1633 return pool;
1634}
1635
1636static literal_pool *
1637find_or_make_literal_pool (int size)
1638{
1639 /* Next literal pool ID number. */
1640 static unsigned int latest_pool_num = 1;
1641 literal_pool *pool;
1642
1643 pool = find_literal_pool (size);
1644
1645 if (pool == NULL)
1646 {
1647 /* Create a new pool. */
add39d23 1648 pool = XNEW (literal_pool);
a06ea964
NC
1649 if (!pool)
1650 return NULL;
1651
1652 /* Currently we always put the literal pool in the current text
1653 section. If we were generating "small" model code where we
1654 knew that all code and initialised data was within 1MB then
1655 we could output literals to mergeable, read-only data
1656 sections. */
1657
1658 pool->next_free_entry = 0;
1659 pool->section = now_seg;
1660 pool->sub_section = now_subseg;
1661 pool->size = size;
1662 pool->next = list_of_pools;
1663 pool->symbol = NULL;
1664
1665 /* Add it to the list. */
1666 list_of_pools = pool;
1667 }
1668
1669 /* New pools, and emptied pools, will have a NULL symbol. */
1670 if (pool->symbol == NULL)
1671 {
1672 pool->symbol = symbol_create (FAKE_LABEL_NAME, undefined_section,
1673 (valueT) 0, &zero_address_frag);
1674 pool->id = latest_pool_num++;
1675 }
1676
1677 /* Done. */
1678 return pool;
1679}
1680
1681/* Add the literal of size SIZE in *EXP to the relevant literal pool.
1682 Return TRUE on success, otherwise return FALSE. */
1683static bfd_boolean
1684add_to_lit_pool (expressionS *exp, int size)
1685{
1686 literal_pool *pool;
1687 unsigned int entry;
1688
1689 pool = find_or_make_literal_pool (size);
1690
1691 /* Check if this literal value is already in the pool. */
1692 for (entry = 0; entry < pool->next_free_entry; entry++)
1693 {
55d9b4c1
NC
1694 expressionS * litexp = & pool->literals[entry].exp;
1695
1696 if ((litexp->X_op == exp->X_op)
a06ea964 1697 && (exp->X_op == O_constant)
55d9b4c1
NC
1698 && (litexp->X_add_number == exp->X_add_number)
1699 && (litexp->X_unsigned == exp->X_unsigned))
a06ea964
NC
1700 break;
1701
55d9b4c1 1702 if ((litexp->X_op == exp->X_op)
a06ea964 1703 && (exp->X_op == O_symbol)
55d9b4c1
NC
1704 && (litexp->X_add_number == exp->X_add_number)
1705 && (litexp->X_add_symbol == exp->X_add_symbol)
1706 && (litexp->X_op_symbol == exp->X_op_symbol))
a06ea964
NC
1707 break;
1708 }
1709
1710 /* Do we need to create a new entry? */
1711 if (entry == pool->next_free_entry)
1712 {
1713 if (entry >= MAX_LITERAL_POOL_SIZE)
1714 {
1715 set_syntax_error (_("literal pool overflow"));
1716 return FALSE;
1717 }
1718
55d9b4c1 1719 pool->literals[entry].exp = *exp;
a06ea964 1720 pool->next_free_entry += 1;
55d9b4c1
NC
1721 if (exp->X_op == O_big)
1722 {
1723 /* PR 16688: Bignums are held in a single global array. We must
1724 copy and preserve that value now, before it is overwritten. */
add39d23
TS
1725 pool->literals[entry].bignum = XNEWVEC (LITTLENUM_TYPE,
1726 exp->X_add_number);
55d9b4c1
NC
1727 memcpy (pool->literals[entry].bignum, generic_bignum,
1728 CHARS_PER_LITTLENUM * exp->X_add_number);
1729 }
1730 else
1731 pool->literals[entry].bignum = NULL;
a06ea964
NC
1732 }
1733
1734 exp->X_op = O_symbol;
1735 exp->X_add_number = ((int) entry) * size;
1736 exp->X_add_symbol = pool->symbol;
1737
1738 return TRUE;
1739}
1740
1741/* Can't use symbol_new here, so have to create a symbol and then at
1742 a later date assign it a value. Thats what these functions do. */
1743
1744static void
1745symbol_locate (symbolS * symbolP,
1746 const char *name,/* It is copied, the caller can modify. */
1747 segT segment, /* Segment identifier (SEG_<something>). */
1748 valueT valu, /* Symbol value. */
1749 fragS * frag) /* Associated fragment. */
1750{
e57e6ddc 1751 size_t name_length;
a06ea964
NC
1752 char *preserved_copy_of_name;
1753
1754 name_length = strlen (name) + 1; /* +1 for \0. */
1755 obstack_grow (&notes, name, name_length);
1756 preserved_copy_of_name = obstack_finish (&notes);
1757
1758#ifdef tc_canonicalize_symbol_name
1759 preserved_copy_of_name =
1760 tc_canonicalize_symbol_name (preserved_copy_of_name);
1761#endif
1762
1763 S_SET_NAME (symbolP, preserved_copy_of_name);
1764
1765 S_SET_SEGMENT (symbolP, segment);
1766 S_SET_VALUE (symbolP, valu);
1767 symbol_clear_list_pointers (symbolP);
1768
1769 symbol_set_frag (symbolP, frag);
1770
1771 /* Link to end of symbol chain. */
1772 {
1773 extern int symbol_table_frozen;
1774
1775 if (symbol_table_frozen)
1776 abort ();
1777 }
1778
1779 symbol_append (symbolP, symbol_lastP, &symbol_rootP, &symbol_lastP);
1780
1781 obj_symbol_new_hook (symbolP);
1782
1783#ifdef tc_symbol_new_hook
1784 tc_symbol_new_hook (symbolP);
1785#endif
1786
1787#ifdef DEBUG_SYMS
1788 verify_symbol_chain (symbol_rootP, symbol_lastP);
1789#endif /* DEBUG_SYMS */
1790}
1791
1792
1793static void
1794s_ltorg (int ignored ATTRIBUTE_UNUSED)
1795{
1796 unsigned int entry;
1797 literal_pool *pool;
1798 char sym_name[20];
1799 int align;
1800
67a32447 1801 for (align = 2; align <= 4; align++)
a06ea964
NC
1802 {
1803 int size = 1 << align;
1804
1805 pool = find_literal_pool (size);
1806 if (pool == NULL || pool->symbol == NULL || pool->next_free_entry == 0)
1807 continue;
1808
a06ea964
NC
1809 /* Align pool as you have word accesses.
1810 Only make a frag if we have to. */
1811 if (!need_pass_2)
1812 frag_align (align, 0, 0);
1813
7ea12e5c
NC
1814 mapping_state (MAP_DATA);
1815
a06ea964
NC
1816 record_alignment (now_seg, align);
1817
1818 sprintf (sym_name, "$$lit_\002%x", pool->id);
1819
1820 symbol_locate (pool->symbol, sym_name, now_seg,
1821 (valueT) frag_now_fix (), frag_now);
1822 symbol_table_insert (pool->symbol);
1823
1824 for (entry = 0; entry < pool->next_free_entry; entry++)
55d9b4c1
NC
1825 {
1826 expressionS * exp = & pool->literals[entry].exp;
1827
1828 if (exp->X_op == O_big)
1829 {
1830 /* PR 16688: Restore the global bignum value. */
1831 gas_assert (pool->literals[entry].bignum != NULL);
1832 memcpy (generic_bignum, pool->literals[entry].bignum,
1833 CHARS_PER_LITTLENUM * exp->X_add_number);
1834 }
1835
1836 /* First output the expression in the instruction to the pool. */
1837 emit_expr (exp, size); /* .word|.xword */
1838
1839 if (exp->X_op == O_big)
1840 {
1841 free (pool->literals[entry].bignum);
1842 pool->literals[entry].bignum = NULL;
1843 }
1844 }
a06ea964
NC
1845
1846 /* Mark the pool as empty. */
1847 pool->next_free_entry = 0;
1848 pool->symbol = NULL;
1849 }
1850}
1851
1852#ifdef OBJ_ELF
1853/* Forward declarations for functions below, in the MD interface
1854 section. */
1855static fixS *fix_new_aarch64 (fragS *, int, short, expressionS *, int, int);
1856static struct reloc_table_entry * find_reloc_table_entry (char **);
1857
1858/* Directives: Data. */
1859/* N.B. the support for relocation suffix in this directive needs to be
1860 implemented properly. */
1861
1862static void
1863s_aarch64_elf_cons (int nbytes)
1864{
1865 expressionS exp;
1866
1867#ifdef md_flush_pending_output
1868 md_flush_pending_output ();
1869#endif
1870
1871 if (is_it_end_of_statement ())
1872 {
1873 demand_empty_rest_of_line ();
1874 return;
1875 }
1876
1877#ifdef md_cons_align
1878 md_cons_align (nbytes);
1879#endif
1880
1881 mapping_state (MAP_DATA);
1882 do
1883 {
1884 struct reloc_table_entry *reloc;
1885
1886 expression (&exp);
1887
1888 if (exp.X_op != O_symbol)
1889 emit_expr (&exp, (unsigned int) nbytes);
1890 else
1891 {
1892 skip_past_char (&input_line_pointer, '#');
1893 if (skip_past_char (&input_line_pointer, ':'))
1894 {
1895 reloc = find_reloc_table_entry (&input_line_pointer);
1896 if (reloc == NULL)
1897 as_bad (_("unrecognized relocation suffix"));
1898 else
1899 as_bad (_("unimplemented relocation suffix"));
1900 ignore_rest_of_line ();
1901 return;
1902 }
1903 else
1904 emit_expr (&exp, (unsigned int) nbytes);
1905 }
1906 }
1907 while (*input_line_pointer++ == ',');
1908
1909 /* Put terminator back into stream. */
1910 input_line_pointer--;
1911 demand_empty_rest_of_line ();
1912}
1913
1914#endif /* OBJ_ELF */
1915
1916/* Output a 32-bit word, but mark as an instruction. */
1917
1918static void
1919s_aarch64_inst (int ignored ATTRIBUTE_UNUSED)
1920{
1921 expressionS exp;
1922
1923#ifdef md_flush_pending_output
1924 md_flush_pending_output ();
1925#endif
1926
1927 if (is_it_end_of_statement ())
1928 {
1929 demand_empty_rest_of_line ();
1930 return;
1931 }
1932
a97902de 1933 /* Sections are assumed to start aligned. In executable section, there is no
c1baaddf
RL
1934 MAP_DATA symbol pending. So we only align the address during
1935 MAP_DATA --> MAP_INSN transition.
eb9d6cc9 1936 For other sections, this is not guaranteed. */
c1baaddf 1937 enum mstate mapstate = seg_info (now_seg)->tc_segment_info_data.mapstate;
eb9d6cc9 1938 if (!need_pass_2 && subseg_text_p (now_seg) && mapstate == MAP_DATA)
a06ea964 1939 frag_align_code (2, 0);
c1baaddf 1940
a06ea964
NC
1941#ifdef OBJ_ELF
1942 mapping_state (MAP_INSN);
1943#endif
1944
1945 do
1946 {
1947 expression (&exp);
1948 if (exp.X_op != O_constant)
1949 {
1950 as_bad (_("constant expression required"));
1951 ignore_rest_of_line ();
1952 return;
1953 }
1954
1955 if (target_big_endian)
1956 {
1957 unsigned int val = exp.X_add_number;
1958 exp.X_add_number = SWAP_32 (val);
1959 }
1960 emit_expr (&exp, 4);
1961 }
1962 while (*input_line_pointer++ == ',');
1963
1964 /* Put terminator back into stream. */
1965 input_line_pointer--;
1966 demand_empty_rest_of_line ();
1967}
1968
1969#ifdef OBJ_ELF
43a357f9
RL
1970/* Emit BFD_RELOC_AARCH64_TLSDESC_ADD on the next ADD instruction. */
1971
1972static void
1973s_tlsdescadd (int ignored ATTRIBUTE_UNUSED)
1974{
1975 expressionS exp;
1976
1977 expression (&exp);
1978 frag_grow (4);
1979 fix_new_aarch64 (frag_now, frag_more (0) - frag_now->fr_literal, 4, &exp, 0,
1980 BFD_RELOC_AARCH64_TLSDESC_ADD);
1981
1982 demand_empty_rest_of_line ();
1983}
1984
a06ea964
NC
1985/* Emit BFD_RELOC_AARCH64_TLSDESC_CALL on the next BLR instruction. */
1986
1987static void
1988s_tlsdesccall (int ignored ATTRIBUTE_UNUSED)
1989{
1990 expressionS exp;
1991
1992 /* Since we're just labelling the code, there's no need to define a
1993 mapping symbol. */
1994 expression (&exp);
1995 /* Make sure there is enough room in this frag for the following
1996 blr. This trick only works if the blr follows immediately after
1997 the .tlsdesc directive. */
1998 frag_grow (4);
1999 fix_new_aarch64 (frag_now, frag_more (0) - frag_now->fr_literal, 4, &exp, 0,
2000 BFD_RELOC_AARCH64_TLSDESC_CALL);
2001
2002 demand_empty_rest_of_line ();
2003}
43a357f9
RL
2004
2005/* Emit BFD_RELOC_AARCH64_TLSDESC_LDR on the next LDR instruction. */
2006
2007static void
2008s_tlsdescldr (int ignored ATTRIBUTE_UNUSED)
2009{
2010 expressionS exp;
2011
2012 expression (&exp);
2013 frag_grow (4);
2014 fix_new_aarch64 (frag_now, frag_more (0) - frag_now->fr_literal, 4, &exp, 0,
2015 BFD_RELOC_AARCH64_TLSDESC_LDR);
2016
2017 demand_empty_rest_of_line ();
2018}
a06ea964
NC
2019#endif /* OBJ_ELF */
2020
2021static void s_aarch64_arch (int);
2022static void s_aarch64_cpu (int);
ae527cd8 2023static void s_aarch64_arch_extension (int);
a06ea964
NC
2024
2025/* This table describes all the machine specific pseudo-ops the assembler
2026 has to support. The fields are:
2027 pseudo-op name without dot
2028 function to call to execute this pseudo-op
2029 Integer arg to pass to the function. */
2030
2031const pseudo_typeS md_pseudo_table[] = {
2032 /* Never called because '.req' does not start a line. */
2033 {"req", s_req, 0},
2034 {"unreq", s_unreq, 0},
2035 {"bss", s_bss, 0},
2036 {"even", s_even, 0},
2037 {"ltorg", s_ltorg, 0},
2038 {"pool", s_ltorg, 0},
2039 {"cpu", s_aarch64_cpu, 0},
2040 {"arch", s_aarch64_arch, 0},
ae527cd8 2041 {"arch_extension", s_aarch64_arch_extension, 0},
a06ea964
NC
2042 {"inst", s_aarch64_inst, 0},
2043#ifdef OBJ_ELF
43a357f9 2044 {"tlsdescadd", s_tlsdescadd, 0},
a06ea964 2045 {"tlsdesccall", s_tlsdesccall, 0},
43a357f9 2046 {"tlsdescldr", s_tlsdescldr, 0},
a06ea964
NC
2047 {"word", s_aarch64_elf_cons, 4},
2048 {"long", s_aarch64_elf_cons, 4},
2049 {"xword", s_aarch64_elf_cons, 8},
2050 {"dword", s_aarch64_elf_cons, 8},
2051#endif
2052 {0, 0, 0}
2053};
2054\f
2055
2056/* Check whether STR points to a register name followed by a comma or the
2057 end of line; REG_TYPE indicates which register types are checked
2058 against. Return TRUE if STR is such a register name; otherwise return
2059 FALSE. The function does not intend to produce any diagnostics, but since
2060 the register parser aarch64_reg_parse, which is called by this function,
2061 does produce diagnostics, we call clear_error to clear any diagnostics
2062 that may be generated by aarch64_reg_parse.
2063 Also, the function returns FALSE directly if there is any user error
2064 present at the function entry. This prevents the existing diagnostics
2065 state from being spoiled.
2066 The function currently serves parse_constant_immediate and
2067 parse_big_immediate only. */
2068static bfd_boolean
2069reg_name_p (char *str, aarch64_reg_type reg_type)
2070{
2071 int reg;
2072
2073 /* Prevent the diagnostics state from being spoiled. */
2074 if (error_p ())
2075 return FALSE;
2076
2077 reg = aarch64_reg_parse (&str, reg_type, NULL, NULL);
2078
2079 /* Clear the parsing error that may be set by the reg parser. */
2080 clear_error ();
2081
2082 if (reg == PARSE_FAIL)
2083 return FALSE;
2084
2085 skip_whitespace (str);
2086 if (*str == ',' || is_end_of_line[(unsigned int) *str])
2087 return TRUE;
2088
2089 return FALSE;
2090}
2091
2092/* Parser functions used exclusively in instruction operands. */
2093
2094/* Parse an immediate expression which may not be constant.
2095
2096 To prevent the expression parser from pushing a register name
2097 into the symbol table as an undefined symbol, firstly a check is
1799c0d0
RS
2098 done to find out whether STR is a register of type REG_TYPE followed
2099 by a comma or the end of line. Return FALSE if STR is such a string. */
a06ea964
NC
2100
2101static bfd_boolean
1799c0d0
RS
2102parse_immediate_expression (char **str, expressionS *exp,
2103 aarch64_reg_type reg_type)
a06ea964 2104{
1799c0d0 2105 if (reg_name_p (*str, reg_type))
a06ea964
NC
2106 {
2107 set_recoverable_error (_("immediate operand required"));
2108 return FALSE;
2109 }
2110
2111 my_get_expression (exp, str, GE_OPT_PREFIX, 1);
2112
2113 if (exp->X_op == O_absent)
2114 {
2115 set_fatal_syntax_error (_("missing immediate expression"));
2116 return FALSE;
2117 }
2118
2119 return TRUE;
2120}
2121
2122/* Constant immediate-value read function for use in insn parsing.
2123 STR points to the beginning of the immediate (with the optional
1799c0d0
RS
2124 leading #); *VAL receives the value. REG_TYPE says which register
2125 names should be treated as registers rather than as symbolic immediates.
a06ea964
NC
2126
2127 Return TRUE on success; otherwise return FALSE. */
2128
2129static bfd_boolean
1799c0d0 2130parse_constant_immediate (char **str, int64_t *val, aarch64_reg_type reg_type)
a06ea964
NC
2131{
2132 expressionS exp;
2133
1799c0d0 2134 if (! parse_immediate_expression (str, &exp, reg_type))
a06ea964
NC
2135 return FALSE;
2136
2137 if (exp.X_op != O_constant)
2138 {
2139 set_syntax_error (_("constant expression required"));
2140 return FALSE;
2141 }
2142
2143 *val = exp.X_add_number;
2144 return TRUE;
2145}
2146
2147static uint32_t
2148encode_imm_float_bits (uint32_t imm)
2149{
2150 return ((imm >> 19) & 0x7f) /* b[25:19] -> b[6:0] */
2151 | ((imm >> (31 - 7)) & 0x80); /* b[31] -> b[7] */
2152}
2153
62b0d0d5
YZ
2154/* Return TRUE if the single-precision floating-point value encoded in IMM
2155 can be expressed in the AArch64 8-bit signed floating-point format with
2156 3-bit exponent and normalized 4 bits of precision; in other words, the
2157 floating-point value must be expressable as
2158 (+/-) n / 16 * power (2, r)
2159 where n and r are integers such that 16 <= n <=31 and -3 <= r <= 4. */
2160
a06ea964
NC
2161static bfd_boolean
2162aarch64_imm_float_p (uint32_t imm)
2163{
62b0d0d5
YZ
2164 /* If a single-precision floating-point value has the following bit
2165 pattern, it can be expressed in the AArch64 8-bit floating-point
2166 format:
2167
2168 3 32222222 2221111111111
a06ea964 2169 1 09876543 21098765432109876543210
62b0d0d5
YZ
2170 n Eeeeeexx xxxx0000000000000000000
2171
2172 where n, e and each x are either 0 or 1 independently, with
2173 E == ~ e. */
a06ea964 2174
62b0d0d5
YZ
2175 uint32_t pattern;
2176
2177 /* Prepare the pattern for 'Eeeeee'. */
2178 if (((imm >> 30) & 0x1) == 0)
2179 pattern = 0x3e000000;
a06ea964 2180 else
62b0d0d5
YZ
2181 pattern = 0x40000000;
2182
2183 return (imm & 0x7ffff) == 0 /* lower 19 bits are 0. */
2184 && ((imm & 0x7e000000) == pattern); /* bits 25 - 29 == ~ bit 30. */
a06ea964
NC
2185}
2186
04a3379a
RS
2187/* Return TRUE if the IEEE double value encoded in IMM can be expressed
2188 as an IEEE float without any loss of precision. Store the value in
2189 *FPWORD if so. */
62b0d0d5 2190
a06ea964 2191static bfd_boolean
04a3379a 2192can_convert_double_to_float (uint64_t imm, uint32_t *fpword)
62b0d0d5
YZ
2193{
2194 /* If a double-precision floating-point value has the following bit
04a3379a 2195 pattern, it can be expressed in a float:
62b0d0d5 2196
04a3379a
RS
2197 6 66655555555 5544 44444444 33333333 33222222 22221111 111111
2198 3 21098765432 1098 76543210 98765432 10987654 32109876 54321098 76543210
2199 n E~~~eeeeeee ssss ssssssss ssssssss SSS00000 00000000 00000000 00000000
62b0d0d5 2200
04a3379a
RS
2201 -----------------------------> nEeeeeee esssssss ssssssss sssssSSS
2202 if Eeee_eeee != 1111_1111
2203
2204 where n, e, s and S are either 0 or 1 independently and where ~ is the
2205 inverse of E. */
62b0d0d5
YZ
2206
2207 uint32_t pattern;
2208 uint32_t high32 = imm >> 32;
04a3379a 2209 uint32_t low32 = imm;
62b0d0d5 2210
04a3379a
RS
2211 /* Lower 29 bits need to be 0s. */
2212 if ((imm & 0x1fffffff) != 0)
62b0d0d5
YZ
2213 return FALSE;
2214
2215 /* Prepare the pattern for 'Eeeeeeeee'. */
2216 if (((high32 >> 30) & 0x1) == 0)
04a3379a 2217 pattern = 0x38000000;
62b0d0d5
YZ
2218 else
2219 pattern = 0x40000000;
2220
04a3379a
RS
2221 /* Check E~~~. */
2222 if ((high32 & 0x78000000) != pattern)
62b0d0d5 2223 return FALSE;
04a3379a
RS
2224
2225 /* Check Eeee_eeee != 1111_1111. */
2226 if ((high32 & 0x7ff00000) == 0x47f00000)
2227 return FALSE;
2228
2229 *fpword = ((high32 & 0xc0000000) /* 1 n bit and 1 E bit. */
2230 | ((high32 << 3) & 0x3ffffff8) /* 7 e and 20 s bits. */
2231 | (low32 >> 29)); /* 3 S bits. */
2232 return TRUE;
62b0d0d5
YZ
2233}
2234
2235/* Parse a floating-point immediate. Return TRUE on success and return the
2236 value in *IMMED in the format of IEEE754 single-precision encoding.
2237 *CCP points to the start of the string; DP_P is TRUE when the immediate
2238 is expected to be in double-precision (N.B. this only matters when
1799c0d0
RS
2239 hexadecimal representation is involved). REG_TYPE says which register
2240 names should be treated as registers rather than as symbolic immediates.
62b0d0d5 2241
874d7e6e
RS
2242 This routine accepts any IEEE float; it is up to the callers to reject
2243 invalid ones. */
62b0d0d5
YZ
2244
2245static bfd_boolean
1799c0d0
RS
2246parse_aarch64_imm_float (char **ccp, int *immed, bfd_boolean dp_p,
2247 aarch64_reg_type reg_type)
a06ea964
NC
2248{
2249 char *str = *ccp;
2250 char *fpnum;
2251 LITTLENUM_TYPE words[MAX_LITTLENUMS];
2252 int found_fpchar = 0;
62b0d0d5
YZ
2253 int64_t val = 0;
2254 unsigned fpword = 0;
2255 bfd_boolean hex_p = FALSE;
a06ea964
NC
2256
2257 skip_past_char (&str, '#');
2258
a06ea964
NC
2259 fpnum = str;
2260 skip_whitespace (fpnum);
2261
2262 if (strncmp (fpnum, "0x", 2) == 0)
62b0d0d5
YZ
2263 {
2264 /* Support the hexadecimal representation of the IEEE754 encoding.
2265 Double-precision is expected when DP_P is TRUE, otherwise the
2266 representation should be in single-precision. */
1799c0d0 2267 if (! parse_constant_immediate (&str, &val, reg_type))
62b0d0d5
YZ
2268 goto invalid_fp;
2269
2270 if (dp_p)
2271 {
04a3379a 2272 if (!can_convert_double_to_float (val, &fpword))
62b0d0d5
YZ
2273 goto invalid_fp;
2274 }
2275 else if ((uint64_t) val > 0xffffffff)
2276 goto invalid_fp;
2277 else
2278 fpword = val;
2279
2280 hex_p = TRUE;
2281 }
a06ea964
NC
2282 else
2283 {
6a9deabe
RS
2284 if (reg_name_p (str, reg_type))
2285 {
2286 set_recoverable_error (_("immediate operand required"));
2287 return FALSE;
2288 }
2289
62b0d0d5
YZ
2290 /* We must not accidentally parse an integer as a floating-point number.
2291 Make sure that the value we parse is not an integer by checking for
2292 special characters '.' or 'e'. */
a06ea964
NC
2293 for (; *fpnum != '\0' && *fpnum != ' ' && *fpnum != '\n'; fpnum++)
2294 if (*fpnum == '.' || *fpnum == 'e' || *fpnum == 'E')
2295 {
2296 found_fpchar = 1;
2297 break;
2298 }
2299
2300 if (!found_fpchar)
2301 return FALSE;
2302 }
2303
62b0d0d5 2304 if (! hex_p)
a06ea964 2305 {
a06ea964
NC
2306 int i;
2307
62b0d0d5
YZ
2308 if ((str = atof_ieee (str, 's', words)) == NULL)
2309 goto invalid_fp;
2310
a06ea964
NC
2311 /* Our FP word must be 32 bits (single-precision FP). */
2312 for (i = 0; i < 32 / LITTLENUM_NUMBER_OF_BITS; i++)
2313 {
2314 fpword <<= LITTLENUM_NUMBER_OF_BITS;
2315 fpword |= words[i];
2316 }
62b0d0d5 2317 }
a06ea964 2318
874d7e6e
RS
2319 *immed = fpword;
2320 *ccp = str;
2321 return TRUE;
a06ea964
NC
2322
2323invalid_fp:
2324 set_fatal_syntax_error (_("invalid floating-point constant"));
2325 return FALSE;
2326}
2327
2328/* Less-generic immediate-value read function with the possibility of loading
2329 a big (64-bit) immediate, as required by AdvSIMD Modified immediate
2330 instructions.
2331
2332 To prevent the expression parser from pushing a register name into the
2333 symbol table as an undefined symbol, a check is firstly done to find
1799c0d0
RS
2334 out whether STR is a register of type REG_TYPE followed by a comma or
2335 the end of line. Return FALSE if STR is such a register. */
a06ea964
NC
2336
2337static bfd_boolean
1799c0d0 2338parse_big_immediate (char **str, int64_t *imm, aarch64_reg_type reg_type)
a06ea964
NC
2339{
2340 char *ptr = *str;
2341
1799c0d0 2342 if (reg_name_p (ptr, reg_type))
a06ea964
NC
2343 {
2344 set_syntax_error (_("immediate operand required"));
2345 return FALSE;
2346 }
2347
2348 my_get_expression (&inst.reloc.exp, &ptr, GE_OPT_PREFIX, 1);
2349
2350 if (inst.reloc.exp.X_op == O_constant)
2351 *imm = inst.reloc.exp.X_add_number;
2352
2353 *str = ptr;
2354
2355 return TRUE;
2356}
2357
2358/* Set operand IDX of the *INSTR that needs a GAS internal fixup.
2359 if NEED_LIBOPCODES is non-zero, the fixup will need
2360 assistance from the libopcodes. */
2361
2362static inline void
2363aarch64_set_gas_internal_fixup (struct reloc *reloc,
2364 const aarch64_opnd_info *operand,
2365 int need_libopcodes_p)
2366{
2367 reloc->type = BFD_RELOC_AARCH64_GAS_INTERNAL_FIXUP;
2368 reloc->opnd = operand->type;
2369 if (need_libopcodes_p)
2370 reloc->need_libopcodes_p = 1;
2371};
2372
2373/* Return TRUE if the instruction needs to be fixed up later internally by
2374 the GAS; otherwise return FALSE. */
2375
2376static inline bfd_boolean
2377aarch64_gas_internal_fixup_p (void)
2378{
2379 return inst.reloc.type == BFD_RELOC_AARCH64_GAS_INTERNAL_FIXUP;
2380}
2381
2382/* Assign the immediate value to the relavant field in *OPERAND if
2383 RELOC->EXP is a constant expression; otherwise, flag that *OPERAND
2384 needs an internal fixup in a later stage.
2385 ADDR_OFF_P determines whether it is the field ADDR.OFFSET.IMM or
2386 IMM.VALUE that may get assigned with the constant. */
2387static inline void
2388assign_imm_if_const_or_fixup_later (struct reloc *reloc,
2389 aarch64_opnd_info *operand,
2390 int addr_off_p,
2391 int need_libopcodes_p,
2392 int skip_p)
2393{
2394 if (reloc->exp.X_op == O_constant)
2395 {
2396 if (addr_off_p)
2397 operand->addr.offset.imm = reloc->exp.X_add_number;
2398 else
2399 operand->imm.value = reloc->exp.X_add_number;
2400 reloc->type = BFD_RELOC_UNUSED;
2401 }
2402 else
2403 {
2404 aarch64_set_gas_internal_fixup (reloc, operand, need_libopcodes_p);
2405 /* Tell libopcodes to ignore this operand or not. This is helpful
2406 when one of the operands needs to be fixed up later but we need
2407 libopcodes to check the other operands. */
2408 operand->skip = skip_p;
2409 }
2410}
2411
2412/* Relocation modifiers. Each entry in the table contains the textual
2413 name for the relocation which may be placed before a symbol used as
2414 a load/store offset, or add immediate. It must be surrounded by a
2415 leading and trailing colon, for example:
2416
2417 ldr x0, [x1, #:rello:varsym]
2418 add x0, x1, #:rello:varsym */
2419
2420struct reloc_table_entry
2421{
2422 const char *name;
2423 int pc_rel;
6f4a313b 2424 bfd_reloc_code_real_type adr_type;
a06ea964
NC
2425 bfd_reloc_code_real_type adrp_type;
2426 bfd_reloc_code_real_type movw_type;
2427 bfd_reloc_code_real_type add_type;
2428 bfd_reloc_code_real_type ldst_type;
74ad790c 2429 bfd_reloc_code_real_type ld_literal_type;
a06ea964
NC
2430};
2431
2432static struct reloc_table_entry reloc_table[] = {
2433 /* Low 12 bits of absolute address: ADD/i and LDR/STR */
2434 {"lo12", 0,
6f4a313b 2435 0, /* adr_type */
a06ea964
NC
2436 0,
2437 0,
2438 BFD_RELOC_AARCH64_ADD_LO12,
74ad790c
MS
2439 BFD_RELOC_AARCH64_LDST_LO12,
2440 0},
a06ea964
NC
2441
2442 /* Higher 21 bits of pc-relative page offset: ADRP */
2443 {"pg_hi21", 1,
6f4a313b 2444 0, /* adr_type */
a06ea964
NC
2445 BFD_RELOC_AARCH64_ADR_HI21_PCREL,
2446 0,
2447 0,
74ad790c 2448 0,
a06ea964
NC
2449 0},
2450
2451 /* Higher 21 bits of pc-relative page offset: ADRP, no check */
2452 {"pg_hi21_nc", 1,
6f4a313b 2453 0, /* adr_type */
a06ea964
NC
2454 BFD_RELOC_AARCH64_ADR_HI21_NC_PCREL,
2455 0,
2456 0,
74ad790c 2457 0,
a06ea964
NC
2458 0},
2459
2460 /* Most significant bits 0-15 of unsigned address/value: MOVZ */
2461 {"abs_g0", 0,
6f4a313b 2462 0, /* adr_type */
a06ea964
NC
2463 0,
2464 BFD_RELOC_AARCH64_MOVW_G0,
2465 0,
74ad790c 2466 0,
a06ea964
NC
2467 0},
2468
2469 /* Most significant bits 0-15 of signed address/value: MOVN/Z */
2470 {"abs_g0_s", 0,
6f4a313b 2471 0, /* adr_type */
a06ea964
NC
2472 0,
2473 BFD_RELOC_AARCH64_MOVW_G0_S,
2474 0,
74ad790c 2475 0,
a06ea964
NC
2476 0},
2477
2478 /* Less significant bits 0-15 of address/value: MOVK, no check */
2479 {"abs_g0_nc", 0,
6f4a313b 2480 0, /* adr_type */
a06ea964
NC
2481 0,
2482 BFD_RELOC_AARCH64_MOVW_G0_NC,
2483 0,
74ad790c 2484 0,
a06ea964
NC
2485 0},
2486
2487 /* Most significant bits 16-31 of unsigned address/value: MOVZ */
2488 {"abs_g1", 0,
6f4a313b 2489 0, /* adr_type */
a06ea964
NC
2490 0,
2491 BFD_RELOC_AARCH64_MOVW_G1,
2492 0,
74ad790c 2493 0,
a06ea964
NC
2494 0},
2495
2496 /* Most significant bits 16-31 of signed address/value: MOVN/Z */
2497 {"abs_g1_s", 0,
6f4a313b 2498 0, /* adr_type */
a06ea964
NC
2499 0,
2500 BFD_RELOC_AARCH64_MOVW_G1_S,
2501 0,
74ad790c 2502 0,
a06ea964
NC
2503 0},
2504
2505 /* Less significant bits 16-31 of address/value: MOVK, no check */
2506 {"abs_g1_nc", 0,
6f4a313b 2507 0, /* adr_type */
a06ea964
NC
2508 0,
2509 BFD_RELOC_AARCH64_MOVW_G1_NC,
2510 0,
74ad790c 2511 0,
a06ea964
NC
2512 0},
2513
2514 /* Most significant bits 32-47 of unsigned address/value: MOVZ */
2515 {"abs_g2", 0,
6f4a313b 2516 0, /* adr_type */
a06ea964
NC
2517 0,
2518 BFD_RELOC_AARCH64_MOVW_G2,
2519 0,
74ad790c 2520 0,
a06ea964
NC
2521 0},
2522
2523 /* Most significant bits 32-47 of signed address/value: MOVN/Z */
2524 {"abs_g2_s", 0,
6f4a313b 2525 0, /* adr_type */
a06ea964
NC
2526 0,
2527 BFD_RELOC_AARCH64_MOVW_G2_S,
2528 0,
74ad790c 2529 0,
a06ea964
NC
2530 0},
2531
2532 /* Less significant bits 32-47 of address/value: MOVK, no check */
2533 {"abs_g2_nc", 0,
6f4a313b 2534 0, /* adr_type */
a06ea964
NC
2535 0,
2536 BFD_RELOC_AARCH64_MOVW_G2_NC,
2537 0,
74ad790c 2538 0,
a06ea964
NC
2539 0},
2540
2541 /* Most significant bits 48-63 of signed/unsigned address/value: MOVZ */
2542 {"abs_g3", 0,
6f4a313b 2543 0, /* adr_type */
a06ea964
NC
2544 0,
2545 BFD_RELOC_AARCH64_MOVW_G3,
2546 0,
74ad790c 2547 0,
a06ea964 2548 0},
4aa2c5e2 2549
a06ea964
NC
2550 /* Get to the page containing GOT entry for a symbol. */
2551 {"got", 1,
6f4a313b 2552 0, /* adr_type */
a06ea964
NC
2553 BFD_RELOC_AARCH64_ADR_GOT_PAGE,
2554 0,
2555 0,
74ad790c 2556 0,
4aa2c5e2
MS
2557 BFD_RELOC_AARCH64_GOT_LD_PREL19},
2558
a06ea964
NC
2559 /* 12 bit offset into the page containing GOT entry for that symbol. */
2560 {"got_lo12", 0,
6f4a313b 2561 0, /* adr_type */
a06ea964
NC
2562 0,
2563 0,
2564 0,
74ad790c
MS
2565 BFD_RELOC_AARCH64_LD_GOT_LO12_NC,
2566 0},
a06ea964 2567
ca632371
RL
2568 /* 0-15 bits of address/value: MOVk, no check. */
2569 {"gotoff_g0_nc", 0,
2570 0, /* adr_type */
2571 0,
2572 BFD_RELOC_AARCH64_MOVW_GOTOFF_G0_NC,
2573 0,
2574 0,
2575 0},
2576
654248e7
RL
2577 /* Most significant bits 16-31 of address/value: MOVZ. */
2578 {"gotoff_g1", 0,
2579 0, /* adr_type */
2580 0,
2581 BFD_RELOC_AARCH64_MOVW_GOTOFF_G1,
2582 0,
2583 0,
2584 0},
2585
87f5fbcc
RL
2586 /* 15 bit offset into the page containing GOT entry for that symbol. */
2587 {"gotoff_lo15", 0,
2588 0, /* adr_type */
2589 0,
2590 0,
2591 0,
2592 BFD_RELOC_AARCH64_LD64_GOTOFF_LO15,
2593 0},
2594
3b957e5b
RL
2595 /* Get to the page containing GOT TLS entry for a symbol */
2596 {"gottprel_g0_nc", 0,
2597 0, /* adr_type */
2598 0,
2599 BFD_RELOC_AARCH64_TLSIE_MOVW_GOTTPREL_G0_NC,
2600 0,
2601 0,
2602 0},
2603
2604 /* Get to the page containing GOT TLS entry for a symbol */
2605 {"gottprel_g1", 0,
2606 0, /* adr_type */
2607 0,
2608 BFD_RELOC_AARCH64_TLSIE_MOVW_GOTTPREL_G1,
2609 0,
2610 0,
2611 0},
2612
a06ea964
NC
2613 /* Get to the page containing GOT TLS entry for a symbol */
2614 {"tlsgd", 0,
3c12b054 2615 BFD_RELOC_AARCH64_TLSGD_ADR_PREL21, /* adr_type */
a06ea964
NC
2616 BFD_RELOC_AARCH64_TLSGD_ADR_PAGE21,
2617 0,
2618 0,
74ad790c 2619 0,
a06ea964
NC
2620 0},
2621
2622 /* 12 bit offset into the page containing GOT TLS entry for a symbol */
2623 {"tlsgd_lo12", 0,
6f4a313b 2624 0, /* adr_type */
a06ea964
NC
2625 0,
2626 0,
2627 BFD_RELOC_AARCH64_TLSGD_ADD_LO12_NC,
74ad790c 2628 0,
a06ea964
NC
2629 0},
2630
3e8286c0
RL
2631 /* Lower 16 bits address/value: MOVk. */
2632 {"tlsgd_g0_nc", 0,
2633 0, /* adr_type */
2634 0,
2635 BFD_RELOC_AARCH64_TLSGD_MOVW_G0_NC,
2636 0,
2637 0,
2638 0},
2639
1aa66fb1
RL
2640 /* Most significant bits 16-31 of address/value: MOVZ. */
2641 {"tlsgd_g1", 0,
2642 0, /* adr_type */
2643 0,
2644 BFD_RELOC_AARCH64_TLSGD_MOVW_G1,
2645 0,
2646 0,
2647 0},
2648
a06ea964
NC
2649 /* Get to the page containing GOT TLS entry for a symbol */
2650 {"tlsdesc", 0,
389b8029 2651 BFD_RELOC_AARCH64_TLSDESC_ADR_PREL21, /* adr_type */
418009c2 2652 BFD_RELOC_AARCH64_TLSDESC_ADR_PAGE21,
a06ea964
NC
2653 0,
2654 0,
74ad790c 2655 0,
1ada945d 2656 BFD_RELOC_AARCH64_TLSDESC_LD_PREL19},
a06ea964
NC
2657
2658 /* 12 bit offset into the page containing GOT TLS entry for a symbol */
2659 {"tlsdesc_lo12", 0,
6f4a313b 2660 0, /* adr_type */
a06ea964
NC
2661 0,
2662 0,
2663 BFD_RELOC_AARCH64_TLSDESC_ADD_LO12_NC,
74ad790c
MS
2664 BFD_RELOC_AARCH64_TLSDESC_LD_LO12_NC,
2665 0},
a06ea964 2666
6c37fedc
JW
2667 /* Get to the page containing GOT TLS entry for a symbol.
2668 The same as GD, we allocate two consecutive GOT slots
2669 for module index and module offset, the only difference
2670 with GD is the module offset should be intialized to
2671 zero without any outstanding runtime relocation. */
2672 {"tlsldm", 0,
2673 BFD_RELOC_AARCH64_TLSLD_ADR_PREL21, /* adr_type */
1107e076 2674 BFD_RELOC_AARCH64_TLSLD_ADR_PAGE21,
6c37fedc
JW
2675 0,
2676 0,
2677 0,
2678 0},
2679
a12fad50
JW
2680 /* 12 bit offset into the page containing GOT TLS entry for a symbol */
2681 {"tlsldm_lo12_nc", 0,
2682 0, /* adr_type */
2683 0,
2684 0,
2685 BFD_RELOC_AARCH64_TLSLD_ADD_LO12_NC,
2686 0,
2687 0},
2688
70151fb5
JW
2689 /* 12 bit offset into the module TLS base address. */
2690 {"dtprel_lo12", 0,
2691 0, /* adr_type */
2692 0,
2693 0,
2694 BFD_RELOC_AARCH64_TLSLD_ADD_DTPREL_LO12,
4c562523 2695 BFD_RELOC_AARCH64_TLSLD_LDST_DTPREL_LO12,
70151fb5
JW
2696 0},
2697
13289c10
JW
2698 /* Same as dtprel_lo12, no overflow check. */
2699 {"dtprel_lo12_nc", 0,
2700 0, /* adr_type */
2701 0,
2702 0,
2703 BFD_RELOC_AARCH64_TLSLD_ADD_DTPREL_LO12_NC,
4c562523 2704 BFD_RELOC_AARCH64_TLSLD_LDST_DTPREL_LO12_NC,
13289c10
JW
2705 0},
2706
49df5539
JW
2707 /* bits[23:12] of offset to the module TLS base address. */
2708 {"dtprel_hi12", 0,
2709 0, /* adr_type */
2710 0,
2711 0,
2712 BFD_RELOC_AARCH64_TLSLD_ADD_DTPREL_HI12,
2713 0,
2714 0},
2715
2716 /* bits[15:0] of offset to the module TLS base address. */
2717 {"dtprel_g0", 0,
2718 0, /* adr_type */
2719 0,
2720 BFD_RELOC_AARCH64_TLSLD_MOVW_DTPREL_G0,
2721 0,
2722 0,
2723 0},
2724
2725 /* No overflow check version of BFD_RELOC_AARCH64_TLSLD_MOVW_DTPREL_G0. */
2726 {"dtprel_g0_nc", 0,
2727 0, /* adr_type */
2728 0,
2729 BFD_RELOC_AARCH64_TLSLD_MOVW_DTPREL_G0_NC,
2730 0,
2731 0,
2732 0},
2733
2734 /* bits[31:16] of offset to the module TLS base address. */
2735 {"dtprel_g1", 0,
2736 0, /* adr_type */
2737 0,
2738 BFD_RELOC_AARCH64_TLSLD_MOVW_DTPREL_G1,
2739 0,
2740 0,
2741 0},
2742
2743 /* No overflow check version of BFD_RELOC_AARCH64_TLSLD_MOVW_DTPREL_G1. */
2744 {"dtprel_g1_nc", 0,
2745 0, /* adr_type */
2746 0,
2747 BFD_RELOC_AARCH64_TLSLD_MOVW_DTPREL_G1_NC,
2748 0,
2749 0,
2750 0},
2751
2752 /* bits[47:32] of offset to the module TLS base address. */
2753 {"dtprel_g2", 0,
2754 0, /* adr_type */
2755 0,
2756 BFD_RELOC_AARCH64_TLSLD_MOVW_DTPREL_G2,
2757 0,
2758 0,
2759 0},
2760
43a357f9
RL
2761 /* Lower 16 bit offset into GOT entry for a symbol */
2762 {"tlsdesc_off_g0_nc", 0,
2763 0, /* adr_type */
2764 0,
2765 BFD_RELOC_AARCH64_TLSDESC_OFF_G0_NC,
2766 0,
2767 0,
2768 0},
2769
2770 /* Higher 16 bit offset into GOT entry for a symbol */
2771 {"tlsdesc_off_g1", 0,
2772 0, /* adr_type */
2773 0,
2774 BFD_RELOC_AARCH64_TLSDESC_OFF_G1,
2775 0,
2776 0,
2777 0},
2778
a06ea964
NC
2779 /* Get to the page containing GOT TLS entry for a symbol */
2780 {"gottprel", 0,
6f4a313b 2781 0, /* adr_type */
a06ea964
NC
2782 BFD_RELOC_AARCH64_TLSIE_ADR_GOTTPREL_PAGE21,
2783 0,
2784 0,
74ad790c 2785 0,
043bf05a 2786 BFD_RELOC_AARCH64_TLSIE_LD_GOTTPREL_PREL19},
a06ea964
NC
2787
2788 /* 12 bit offset into the page containing GOT TLS entry for a symbol */
2789 {"gottprel_lo12", 0,
6f4a313b 2790 0, /* adr_type */
a06ea964
NC
2791 0,
2792 0,
2793 0,
74ad790c
MS
2794 BFD_RELOC_AARCH64_TLSIE_LD_GOTTPREL_LO12_NC,
2795 0},
a06ea964
NC
2796
2797 /* Get tp offset for a symbol. */
2798 {"tprel", 0,
6f4a313b 2799 0, /* adr_type */
a06ea964
NC
2800 0,
2801 0,
2802 BFD_RELOC_AARCH64_TLSLE_ADD_TPREL_LO12,
74ad790c 2803 0,
a06ea964
NC
2804 0},
2805
2806 /* Get tp offset for a symbol. */
2807 {"tprel_lo12", 0,
6f4a313b 2808 0, /* adr_type */
a06ea964
NC
2809 0,
2810 0,
2811 BFD_RELOC_AARCH64_TLSLE_ADD_TPREL_LO12,
74ad790c 2812 0,
a06ea964
NC
2813 0},
2814
2815 /* Get tp offset for a symbol. */
2816 {"tprel_hi12", 0,
6f4a313b 2817 0, /* adr_type */
a06ea964
NC
2818 0,
2819 0,
2820 BFD_RELOC_AARCH64_TLSLE_ADD_TPREL_HI12,
74ad790c 2821 0,
a06ea964
NC
2822 0},
2823
2824 /* Get tp offset for a symbol. */
2825 {"tprel_lo12_nc", 0,
6f4a313b 2826 0, /* adr_type */
a06ea964
NC
2827 0,
2828 0,
2829 BFD_RELOC_AARCH64_TLSLE_ADD_TPREL_LO12_NC,
74ad790c 2830 0,
a06ea964
NC
2831 0},
2832
2833 /* Most significant bits 32-47 of address/value: MOVZ. */
2834 {"tprel_g2", 0,
6f4a313b 2835 0, /* adr_type */
a06ea964
NC
2836 0,
2837 BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G2,
2838 0,
74ad790c 2839 0,
a06ea964
NC
2840 0},
2841
2842 /* Most significant bits 16-31 of address/value: MOVZ. */
2843 {"tprel_g1", 0,
6f4a313b 2844 0, /* adr_type */
a06ea964
NC
2845 0,
2846 BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G1,
2847 0,
74ad790c 2848 0,
a06ea964
NC
2849 0},
2850
2851 /* Most significant bits 16-31 of address/value: MOVZ, no check. */
2852 {"tprel_g1_nc", 0,
6f4a313b 2853 0, /* adr_type */
a06ea964
NC
2854 0,
2855 BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G1_NC,
2856 0,
74ad790c 2857 0,
a06ea964
NC
2858 0},
2859
2860 /* Most significant bits 0-15 of address/value: MOVZ. */
2861 {"tprel_g0", 0,
6f4a313b 2862 0, /* adr_type */
a06ea964
NC
2863 0,
2864 BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G0,
2865 0,
74ad790c 2866 0,
a06ea964
NC
2867 0},
2868
2869 /* Most significant bits 0-15 of address/value: MOVZ, no check. */
2870 {"tprel_g0_nc", 0,
6f4a313b 2871 0, /* adr_type */
a06ea964
NC
2872 0,
2873 BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G0_NC,
2874 0,
74ad790c 2875 0,
a06ea964 2876 0},
a921b5bd
JW
2877
2878 /* 15bit offset from got entry to base address of GOT table. */
2879 {"gotpage_lo15", 0,
2880 0,
2881 0,
2882 0,
2883 0,
2884 BFD_RELOC_AARCH64_LD64_GOTPAGE_LO15,
2885 0},
3d715ce4
JW
2886
2887 /* 14bit offset from got entry to base address of GOT table. */
2888 {"gotpage_lo14", 0,
2889 0,
2890 0,
2891 0,
2892 0,
2893 BFD_RELOC_AARCH64_LD32_GOTPAGE_LO14,
2894 0},
a06ea964
NC
2895};
2896
2897/* Given the address of a pointer pointing to the textual name of a
2898 relocation as may appear in assembler source, attempt to find its
2899 details in reloc_table. The pointer will be updated to the character
2900 after the trailing colon. On failure, NULL will be returned;
2901 otherwise return the reloc_table_entry. */
2902
2903static struct reloc_table_entry *
2904find_reloc_table_entry (char **str)
2905{
2906 unsigned int i;
2907 for (i = 0; i < ARRAY_SIZE (reloc_table); i++)
2908 {
2909 int length = strlen (reloc_table[i].name);
2910
2911 if (strncasecmp (reloc_table[i].name, *str, length) == 0
2912 && (*str)[length] == ':')
2913 {
2914 *str += (length + 1);
2915 return &reloc_table[i];
2916 }
2917 }
2918
2919 return NULL;
2920}
2921
2922/* Mode argument to parse_shift and parser_shifter_operand. */
2923enum parse_shift_mode
2924{
2925 SHIFTED_ARITH_IMM, /* "rn{,lsl|lsr|asl|asr|uxt|sxt #n}" or
2926 "#imm{,lsl #n}" */
2927 SHIFTED_LOGIC_IMM, /* "rn{,lsl|lsr|asl|asr|ror #n}" or
2928 "#imm" */
2929 SHIFTED_LSL, /* bare "lsl #n" */
2442d846 2930 SHIFTED_MUL, /* bare "mul #n" */
a06ea964
NC
2931 SHIFTED_LSL_MSL, /* "lsl|msl #n" */
2932 SHIFTED_REG_OFFSET /* [su]xtw|sxtx {#n} or lsl #n */
2933};
2934
2935/* Parse a <shift> operator on an AArch64 data processing instruction.
2936 Return TRUE on success; otherwise return FALSE. */
2937static bfd_boolean
2938parse_shift (char **str, aarch64_opnd_info *operand, enum parse_shift_mode mode)
2939{
2940 const struct aarch64_name_value_pair *shift_op;
2941 enum aarch64_modifier_kind kind;
2942 expressionS exp;
2943 int exp_has_prefix;
2944 char *s = *str;
2945 char *p = s;
2946
2947 for (p = *str; ISALPHA (*p); p++)
2948 ;
2949
2950 if (p == *str)
2951 {
2952 set_syntax_error (_("shift expression expected"));
2953 return FALSE;
2954 }
2955
2956 shift_op = hash_find_n (aarch64_shift_hsh, *str, p - *str);
2957
2958 if (shift_op == NULL)
2959 {
2960 set_syntax_error (_("shift operator expected"));
2961 return FALSE;
2962 }
2963
2964 kind = aarch64_get_operand_modifier (shift_op);
2965
2966 if (kind == AARCH64_MOD_MSL && mode != SHIFTED_LSL_MSL)
2967 {
2968 set_syntax_error (_("invalid use of 'MSL'"));
2969 return FALSE;
2970 }
2971
2442d846
RS
2972 if (kind == AARCH64_MOD_MUL
2973 && mode != SHIFTED_MUL)
2974 {
2975 set_syntax_error (_("invalid use of 'MUL'"));
2976 return FALSE;
2977 }
2978
a06ea964
NC
2979 switch (mode)
2980 {
2981 case SHIFTED_LOGIC_IMM:
2982 if (aarch64_extend_operator_p (kind) == TRUE)
2983 {
2984 set_syntax_error (_("extending shift is not permitted"));
2985 return FALSE;
2986 }
2987 break;
2988
2989 case SHIFTED_ARITH_IMM:
2990 if (kind == AARCH64_MOD_ROR)
2991 {
2992 set_syntax_error (_("'ROR' shift is not permitted"));
2993 return FALSE;
2994 }
2995 break;
2996
2997 case SHIFTED_LSL:
2998 if (kind != AARCH64_MOD_LSL)
2999 {
3000 set_syntax_error (_("only 'LSL' shift is permitted"));
3001 return FALSE;
3002 }
3003 break;
3004
2442d846
RS
3005 case SHIFTED_MUL:
3006 if (kind != AARCH64_MOD_MUL)
3007 {
3008 set_syntax_error (_("only 'MUL' is permitted"));
3009 return FALSE;
3010 }
3011 break;
3012
a06ea964
NC
3013 case SHIFTED_REG_OFFSET:
3014 if (kind != AARCH64_MOD_UXTW && kind != AARCH64_MOD_LSL
3015 && kind != AARCH64_MOD_SXTW && kind != AARCH64_MOD_SXTX)
3016 {
3017 set_fatal_syntax_error
3018 (_("invalid shift for the register offset addressing mode"));
3019 return FALSE;
3020 }
3021 break;
3022
3023 case SHIFTED_LSL_MSL:
3024 if (kind != AARCH64_MOD_LSL && kind != AARCH64_MOD_MSL)
3025 {
3026 set_syntax_error (_("invalid shift operator"));
3027 return FALSE;
3028 }
3029 break;
3030
3031 default:
3032 abort ();
3033 }
3034
3035 /* Whitespace can appear here if the next thing is a bare digit. */
3036 skip_whitespace (p);
3037
3038 /* Parse shift amount. */
3039 exp_has_prefix = 0;
3040 if (mode == SHIFTED_REG_OFFSET && *p == ']')
3041 exp.X_op = O_absent;
3042 else
3043 {
3044 if (is_immediate_prefix (*p))
3045 {
3046 p++;
3047 exp_has_prefix = 1;
3048 }
3049 my_get_expression (&exp, &p, GE_NO_PREFIX, 0);
3050 }
3051 if (exp.X_op == O_absent)
3052 {
3053 if (aarch64_extend_operator_p (kind) == FALSE || exp_has_prefix)
3054 {
3055 set_syntax_error (_("missing shift amount"));
3056 return FALSE;
3057 }
3058 operand->shifter.amount = 0;
3059 }
3060 else if (exp.X_op != O_constant)
3061 {
3062 set_syntax_error (_("constant shift amount required"));
3063 return FALSE;
3064 }
2442d846
RS
3065 /* For parsing purposes, MUL #n has no inherent range. The range
3066 depends on the operand and will be checked by operand-specific
3067 routines. */
3068 else if (kind != AARCH64_MOD_MUL
3069 && (exp.X_add_number < 0 || exp.X_add_number > 63))
a06ea964
NC
3070 {
3071 set_fatal_syntax_error (_("shift amount out of range 0 to 63"));
3072 return FALSE;
3073 }
3074 else
3075 {
3076 operand->shifter.amount = exp.X_add_number;
3077 operand->shifter.amount_present = 1;
3078 }
3079
3080 operand->shifter.operator_present = 1;
3081 operand->shifter.kind = kind;
3082
3083 *str = p;
3084 return TRUE;
3085}
3086
3087/* Parse a <shifter_operand> for a data processing instruction:
3088
3089 #<immediate>
3090 #<immediate>, LSL #imm
3091
3092 Validation of immediate operands is deferred to md_apply_fix.
3093
3094 Return TRUE on success; otherwise return FALSE. */
3095
3096static bfd_boolean
3097parse_shifter_operand_imm (char **str, aarch64_opnd_info *operand,
3098 enum parse_shift_mode mode)
3099{
3100 char *p;
3101
3102 if (mode != SHIFTED_ARITH_IMM && mode != SHIFTED_LOGIC_IMM)
3103 return FALSE;
3104
3105 p = *str;
3106
3107 /* Accept an immediate expression. */
3108 if (! my_get_expression (&inst.reloc.exp, &p, GE_OPT_PREFIX, 1))
3109 return FALSE;
3110
3111 /* Accept optional LSL for arithmetic immediate values. */
3112 if (mode == SHIFTED_ARITH_IMM && skip_past_comma (&p))
3113 if (! parse_shift (&p, operand, SHIFTED_LSL))
3114 return FALSE;
3115
3116 /* Not accept any shifter for logical immediate values. */
3117 if (mode == SHIFTED_LOGIC_IMM && skip_past_comma (&p)
3118 && parse_shift (&p, operand, mode))
3119 {
3120 set_syntax_error (_("unexpected shift operator"));
3121 return FALSE;
3122 }
3123
3124 *str = p;
3125 return TRUE;
3126}
3127
3128/* Parse a <shifter_operand> for a data processing instruction:
3129
3130 <Rm>
3131 <Rm>, <shift>
3132 #<immediate>
3133 #<immediate>, LSL #imm
3134
3135 where <shift> is handled by parse_shift above, and the last two
3136 cases are handled by the function above.
3137
3138 Validation of immediate operands is deferred to md_apply_fix.
3139
3140 Return TRUE on success; otherwise return FALSE. */
3141
3142static bfd_boolean
3143parse_shifter_operand (char **str, aarch64_opnd_info *operand,
3144 enum parse_shift_mode mode)
3145{
e1b988bb
RS
3146 const reg_entry *reg;
3147 aarch64_opnd_qualifier_t qualifier;
a06ea964
NC
3148 enum aarch64_operand_class opd_class
3149 = aarch64_get_operand_class (operand->type);
3150
e1b988bb
RS
3151 reg = aarch64_reg_parse_32_64 (str, &qualifier);
3152 if (reg)
a06ea964
NC
3153 {
3154 if (opd_class == AARCH64_OPND_CLASS_IMMEDIATE)
3155 {
3156 set_syntax_error (_("unexpected register in the immediate operand"));
3157 return FALSE;
3158 }
3159
e1b988bb 3160 if (!aarch64_check_reg_type (reg, REG_TYPE_R_Z))
a06ea964 3161 {
e1b988bb 3162 set_syntax_error (_(get_reg_expected_msg (REG_TYPE_R_Z)));
a06ea964
NC
3163 return FALSE;
3164 }
3165
e1b988bb
RS
3166 operand->reg.regno = reg->number;
3167 operand->qualifier = qualifier;
a06ea964
NC
3168
3169 /* Accept optional shift operation on register. */
3170 if (! skip_past_comma (str))
3171 return TRUE;
3172
3173 if (! parse_shift (str, operand, mode))
3174 return FALSE;
3175
3176 return TRUE;
3177 }
3178 else if (opd_class == AARCH64_OPND_CLASS_MODIFIED_REG)
3179 {
3180 set_syntax_error
3181 (_("integer register expected in the extended/shifted operand "
3182 "register"));
3183 return FALSE;
3184 }
3185
3186 /* We have a shifted immediate variable. */
3187 return parse_shifter_operand_imm (str, operand, mode);
3188}
3189
3190/* Return TRUE on success; return FALSE otherwise. */
3191
3192static bfd_boolean
3193parse_shifter_operand_reloc (char **str, aarch64_opnd_info *operand,
3194 enum parse_shift_mode mode)
3195{
3196 char *p = *str;
3197
3198 /* Determine if we have the sequence of characters #: or just :
3199 coming next. If we do, then we check for a :rello: relocation
3200 modifier. If we don't, punt the whole lot to
3201 parse_shifter_operand. */
3202
3203 if ((p[0] == '#' && p[1] == ':') || p[0] == ':')
3204 {
3205 struct reloc_table_entry *entry;
3206
3207 if (p[0] == '#')
3208 p += 2;
3209 else
3210 p++;
3211 *str = p;
3212
3213 /* Try to parse a relocation. Anything else is an error. */
3214 if (!(entry = find_reloc_table_entry (str)))
3215 {
3216 set_syntax_error (_("unknown relocation modifier"));
3217 return FALSE;
3218 }
3219
3220 if (entry->add_type == 0)
3221 {
3222 set_syntax_error
3223 (_("this relocation modifier is not allowed on this instruction"));
3224 return FALSE;
3225 }
3226
3227 /* Save str before we decompose it. */
3228 p = *str;
3229
3230 /* Next, we parse the expression. */
3231 if (! my_get_expression (&inst.reloc.exp, str, GE_NO_PREFIX, 1))
3232 return FALSE;
3233
3234 /* Record the relocation type (use the ADD variant here). */
3235 inst.reloc.type = entry->add_type;
3236 inst.reloc.pc_rel = entry->pc_rel;
3237
3238 /* If str is empty, we've reached the end, stop here. */
3239 if (**str == '\0')
3240 return TRUE;
3241
55d9b4c1 3242 /* Otherwise, we have a shifted reloc modifier, so rewind to
a06ea964
NC
3243 recover the variable name and continue parsing for the shifter. */
3244 *str = p;
3245 return parse_shifter_operand_imm (str, operand, mode);
3246 }
3247
3248 return parse_shifter_operand (str, operand, mode);
3249}
3250
3251/* Parse all forms of an address expression. Information is written
3252 to *OPERAND and/or inst.reloc.
3253
3254 The A64 instruction set has the following addressing modes:
3255
3256 Offset
4df068de
RS
3257 [base] // in SIMD ld/st structure
3258 [base{,#0}] // in ld/st exclusive
a06ea964
NC
3259 [base{,#imm}]
3260 [base,Xm{,LSL #imm}]
3261 [base,Xm,SXTX {#imm}]
3262 [base,Wm,(S|U)XTW {#imm}]
3263 Pre-indexed
3264 [base,#imm]!
3265 Post-indexed
3266 [base],#imm
4df068de 3267 [base],Xm // in SIMD ld/st structure
a06ea964
NC
3268 PC-relative (literal)
3269 label
4df068de
RS
3270 SVE:
3271 [base,Zm.D{,LSL #imm}]
3272 [base,Zm.S,(S|U)XTW {#imm}]
3273 [base,Zm.D,(S|U)XTW {#imm}] // ignores top 32 bits of Zm.D elements
3274 [Zn.S,#imm]
3275 [Zn.D,#imm]
3276 [Zn.S,Zm.S{,LSL #imm}] // in ADR
3277 [Zn.D,Zm.D{,LSL #imm}] // in ADR
3278 [Zn.D,Zm.D,(S|U)XTW {#imm}] // in ADR
a06ea964
NC
3279
3280 (As a convenience, the notation "=immediate" is permitted in conjunction
3281 with the pc-relative literal load instructions to automatically place an
3282 immediate value or symbolic address in a nearby literal pool and generate
3283 a hidden label which references it.)
3284
3285 Upon a successful parsing, the address structure in *OPERAND will be
3286 filled in the following way:
3287
3288 .base_regno = <base>
3289 .offset.is_reg // 1 if the offset is a register
3290 .offset.imm = <imm>
3291 .offset.regno = <Rm>
3292
3293 For different addressing modes defined in the A64 ISA:
3294
3295 Offset
3296 .pcrel=0; .preind=1; .postind=0; .writeback=0
3297 Pre-indexed
3298 .pcrel=0; .preind=1; .postind=0; .writeback=1
3299 Post-indexed
3300 .pcrel=0; .preind=0; .postind=1; .writeback=1
3301 PC-relative (literal)
3302 .pcrel=1; .preind=1; .postind=0; .writeback=0
3303
3304 The shift/extension information, if any, will be stored in .shifter.
4df068de
RS
3305 The base and offset qualifiers will be stored in *BASE_QUALIFIER and
3306 *OFFSET_QUALIFIER respectively, with NIL being used if there's no
3307 corresponding register.
a06ea964 3308
4df068de
RS
3309 BASE_TYPE says which types of base register should be accepted and
3310 OFFSET_TYPE says the same for offset registers. In all other respects,
3311 it is the caller's responsibility to check for addressing modes not
a06ea964
NC
3312 supported by the instruction, and to set inst.reloc.type. */
3313
3314static bfd_boolean
4df068de
RS
3315parse_address_main (char **str, aarch64_opnd_info *operand,
3316 aarch64_opnd_qualifier_t *base_qualifier,
3317 aarch64_opnd_qualifier_t *offset_qualifier,
3318 aarch64_reg_type base_type, aarch64_reg_type offset_type)
a06ea964
NC
3319{
3320 char *p = *str;
e1b988bb 3321 const reg_entry *reg;
a06ea964
NC
3322 expressionS *exp = &inst.reloc.exp;
3323
4df068de
RS
3324 *base_qualifier = AARCH64_OPND_QLF_NIL;
3325 *offset_qualifier = AARCH64_OPND_QLF_NIL;
a06ea964
NC
3326 if (! skip_past_char (&p, '['))
3327 {
3328 /* =immediate or label. */
3329 operand->addr.pcrel = 1;
3330 operand->addr.preind = 1;
3331
f41aef5f
RE
3332 /* #:<reloc_op>:<symbol> */
3333 skip_past_char (&p, '#');
73866052 3334 if (skip_past_char (&p, ':'))
f41aef5f 3335 {
6f4a313b 3336 bfd_reloc_code_real_type ty;
f41aef5f
RE
3337 struct reloc_table_entry *entry;
3338
3339 /* Try to parse a relocation modifier. Anything else is
3340 an error. */
3341 entry = find_reloc_table_entry (&p);
3342 if (! entry)
3343 {
3344 set_syntax_error (_("unknown relocation modifier"));
3345 return FALSE;
3346 }
3347
6f4a313b
MS
3348 switch (operand->type)
3349 {
3350 case AARCH64_OPND_ADDR_PCREL21:
3351 /* adr */
3352 ty = entry->adr_type;
3353 break;
3354
3355 default:
74ad790c 3356 ty = entry->ld_literal_type;
6f4a313b
MS
3357 break;
3358 }
3359
3360 if (ty == 0)
f41aef5f
RE
3361 {
3362 set_syntax_error
3363 (_("this relocation modifier is not allowed on this "
3364 "instruction"));
3365 return FALSE;
3366 }
3367
3368 /* #:<reloc_op>: */
3369 if (! my_get_expression (exp, &p, GE_NO_PREFIX, 1))
3370 {
3371 set_syntax_error (_("invalid relocation expression"));
3372 return FALSE;
3373 }
a06ea964 3374
f41aef5f 3375 /* #:<reloc_op>:<expr> */
6f4a313b
MS
3376 /* Record the relocation type. */
3377 inst.reloc.type = ty;
f41aef5f
RE
3378 inst.reloc.pc_rel = entry->pc_rel;
3379 }
3380 else
a06ea964 3381 {
f41aef5f
RE
3382
3383 if (skip_past_char (&p, '='))
3384 /* =immediate; need to generate the literal in the literal pool. */
3385 inst.gen_lit_pool = 1;
3386
3387 if (!my_get_expression (exp, &p, GE_NO_PREFIX, 1))
3388 {
3389 set_syntax_error (_("invalid address"));
3390 return FALSE;
3391 }
a06ea964
NC
3392 }
3393
3394 *str = p;
3395 return TRUE;
3396 }
3397
3398 /* [ */
3399
4df068de
RS
3400 reg = aarch64_addr_reg_parse (&p, base_type, base_qualifier);
3401 if (!reg || !aarch64_check_reg_type (reg, base_type))
a06ea964 3402 {
4df068de 3403 set_syntax_error (_(get_reg_expected_msg (base_type)));
a06ea964
NC
3404 return FALSE;
3405 }
e1b988bb 3406 operand->addr.base_regno = reg->number;
a06ea964
NC
3407
3408 /* [Xn */
3409 if (skip_past_comma (&p))
3410 {
3411 /* [Xn, */
3412 operand->addr.preind = 1;
3413
4df068de 3414 reg = aarch64_addr_reg_parse (&p, offset_type, offset_qualifier);
e1b988bb 3415 if (reg)
a06ea964 3416 {
4df068de 3417 if (!aarch64_check_reg_type (reg, offset_type))
e1b988bb 3418 {
4df068de 3419 set_syntax_error (_(get_reg_expected_msg (offset_type)));
e1b988bb
RS
3420 return FALSE;
3421 }
3422
a06ea964 3423 /* [Xn,Rm */
e1b988bb 3424 operand->addr.offset.regno = reg->number;
a06ea964
NC
3425 operand->addr.offset.is_reg = 1;
3426 /* Shifted index. */
3427 if (skip_past_comma (&p))
3428 {
3429 /* [Xn,Rm, */
3430 if (! parse_shift (&p, operand, SHIFTED_REG_OFFSET))
3431 /* Use the diagnostics set in parse_shift, so not set new
3432 error message here. */
3433 return FALSE;
3434 }
3435 /* We only accept:
3436 [base,Xm{,LSL #imm}]
3437 [base,Xm,SXTX {#imm}]
3438 [base,Wm,(S|U)XTW {#imm}] */
3439 if (operand->shifter.kind == AARCH64_MOD_NONE
3440 || operand->shifter.kind == AARCH64_MOD_LSL
3441 || operand->shifter.kind == AARCH64_MOD_SXTX)
3442 {
4df068de 3443 if (*offset_qualifier == AARCH64_OPND_QLF_W)
a06ea964
NC
3444 {
3445 set_syntax_error (_("invalid use of 32-bit register offset"));
3446 return FALSE;
3447 }
4df068de
RS
3448 if (aarch64_get_qualifier_esize (*base_qualifier)
3449 != aarch64_get_qualifier_esize (*offset_qualifier))
3450 {
3451 set_syntax_error (_("offset has different size from base"));
3452 return FALSE;
3453 }
a06ea964 3454 }
4df068de 3455 else if (*offset_qualifier == AARCH64_OPND_QLF_X)
a06ea964
NC
3456 {
3457 set_syntax_error (_("invalid use of 64-bit register offset"));
3458 return FALSE;
3459 }
3460 }
3461 else
3462 {
3463 /* [Xn,#:<reloc_op>:<symbol> */
3464 skip_past_char (&p, '#');
73866052 3465 if (skip_past_char (&p, ':'))
a06ea964
NC
3466 {
3467 struct reloc_table_entry *entry;
3468
3469 /* Try to parse a relocation modifier. Anything else is
3470 an error. */
3471 if (!(entry = find_reloc_table_entry (&p)))
3472 {
3473 set_syntax_error (_("unknown relocation modifier"));
3474 return FALSE;
3475 }
3476
3477 if (entry->ldst_type == 0)
3478 {
3479 set_syntax_error
3480 (_("this relocation modifier is not allowed on this "
3481 "instruction"));
3482 return FALSE;
3483 }
3484
3485 /* [Xn,#:<reloc_op>: */
3486 /* We now have the group relocation table entry corresponding to
3487 the name in the assembler source. Next, we parse the
3488 expression. */
3489 if (! my_get_expression (exp, &p, GE_NO_PREFIX, 1))
3490 {
3491 set_syntax_error (_("invalid relocation expression"));
3492 return FALSE;
3493 }
3494
3495 /* [Xn,#:<reloc_op>:<expr> */
3496 /* Record the load/store relocation type. */
3497 inst.reloc.type = entry->ldst_type;
3498 inst.reloc.pc_rel = entry->pc_rel;
3499 }
3500 else if (! my_get_expression (exp, &p, GE_OPT_PREFIX, 1))
3501 {
3502 set_syntax_error (_("invalid expression in the address"));
3503 return FALSE;
3504 }
3505 /* [Xn,<expr> */
3506 }
3507 }
3508
3509 if (! skip_past_char (&p, ']'))
3510 {
3511 set_syntax_error (_("']' expected"));
3512 return FALSE;
3513 }
3514
3515 if (skip_past_char (&p, '!'))
3516 {
3517 if (operand->addr.preind && operand->addr.offset.is_reg)
3518 {
3519 set_syntax_error (_("register offset not allowed in pre-indexed "
3520 "addressing mode"));
3521 return FALSE;
3522 }
3523 /* [Xn]! */
3524 operand->addr.writeback = 1;
3525 }
3526 else if (skip_past_comma (&p))
3527 {
3528 /* [Xn], */
3529 operand->addr.postind = 1;
3530 operand->addr.writeback = 1;
3531
3532 if (operand->addr.preind)
3533 {
3534 set_syntax_error (_("cannot combine pre- and post-indexing"));
3535 return FALSE;
3536 }
3537
4df068de 3538 reg = aarch64_reg_parse_32_64 (&p, offset_qualifier);
73866052 3539 if (reg)
a06ea964
NC
3540 {
3541 /* [Xn],Xm */
e1b988bb 3542 if (!aarch64_check_reg_type (reg, REG_TYPE_R_64))
a06ea964 3543 {
e1b988bb 3544 set_syntax_error (_(get_reg_expected_msg (REG_TYPE_R_64)));
a06ea964
NC
3545 return FALSE;
3546 }
e1b988bb
RS
3547
3548 operand->addr.offset.regno = reg->number;
a06ea964
NC
3549 operand->addr.offset.is_reg = 1;
3550 }
3551 else if (! my_get_expression (exp, &p, GE_OPT_PREFIX, 1))
3552 {
3553 /* [Xn],#expr */
3554 set_syntax_error (_("invalid expression in the address"));
3555 return FALSE;
3556 }
3557 }
3558
3559 /* If at this point neither .preind nor .postind is set, we have a
3560 bare [Rn]{!}; reject [Rn]! but accept [Rn] as a shorthand for [Rn,#0]. */
3561 if (operand->addr.preind == 0 && operand->addr.postind == 0)
3562 {
3563 if (operand->addr.writeback)
3564 {
3565 /* Reject [Rn]! */
3566 set_syntax_error (_("missing offset in the pre-indexed address"));
3567 return FALSE;
3568 }
3569 operand->addr.preind = 1;
3570 inst.reloc.exp.X_op = O_constant;
3571 inst.reloc.exp.X_add_number = 0;
3572 }
3573
3574 *str = p;
3575 return TRUE;
3576}
3577
73866052
RS
3578/* Parse a base AArch64 address (as opposed to an SVE one). Return TRUE
3579 on success. */
a06ea964 3580static bfd_boolean
73866052 3581parse_address (char **str, aarch64_opnd_info *operand)
a06ea964 3582{
4df068de
RS
3583 aarch64_opnd_qualifier_t base_qualifier, offset_qualifier;
3584 return parse_address_main (str, operand, &base_qualifier, &offset_qualifier,
3585 REG_TYPE_R64_SP, REG_TYPE_R_Z);
3586}
3587
3588/* Parse an address in which SVE vector registers are allowed.
3589 The arguments have the same meaning as for parse_address_main.
3590 Return TRUE on success. */
3591static bfd_boolean
3592parse_sve_address (char **str, aarch64_opnd_info *operand,
3593 aarch64_opnd_qualifier_t *base_qualifier,
3594 aarch64_opnd_qualifier_t *offset_qualifier)
3595{
3596 return parse_address_main (str, operand, base_qualifier, offset_qualifier,
3597 REG_TYPE_SVE_BASE, REG_TYPE_SVE_OFFSET);
a06ea964
NC
3598}
3599
3600/* Parse an operand for a MOVZ, MOVN or MOVK instruction.
3601 Return TRUE on success; otherwise return FALSE. */
3602static bfd_boolean
3603parse_half (char **str, int *internal_fixup_p)
3604{
671eeb28 3605 char *p = *str;
a06ea964 3606
a06ea964
NC
3607 skip_past_char (&p, '#');
3608
3609 gas_assert (internal_fixup_p);
3610 *internal_fixup_p = 0;
3611
3612 if (*p == ':')
3613 {
3614 struct reloc_table_entry *entry;
3615
3616 /* Try to parse a relocation. Anything else is an error. */
3617 ++p;
3618 if (!(entry = find_reloc_table_entry (&p)))
3619 {
3620 set_syntax_error (_("unknown relocation modifier"));
3621 return FALSE;
3622 }
3623
3624 if (entry->movw_type == 0)
3625 {
3626 set_syntax_error
3627 (_("this relocation modifier is not allowed on this instruction"));
3628 return FALSE;
3629 }
3630
3631 inst.reloc.type = entry->movw_type;
3632 }
3633 else
3634 *internal_fixup_p = 1;
3635
a06ea964
NC
3636 if (! my_get_expression (&inst.reloc.exp, &p, GE_NO_PREFIX, 1))
3637 return FALSE;
3638
3639 *str = p;
3640 return TRUE;
3641}
3642
3643/* Parse an operand for an ADRP instruction:
3644 ADRP <Xd>, <label>
3645 Return TRUE on success; otherwise return FALSE. */
3646
3647static bfd_boolean
3648parse_adrp (char **str)
3649{
3650 char *p;
3651
3652 p = *str;
3653 if (*p == ':')
3654 {
3655 struct reloc_table_entry *entry;
3656
3657 /* Try to parse a relocation. Anything else is an error. */
3658 ++p;
3659 if (!(entry = find_reloc_table_entry (&p)))
3660 {
3661 set_syntax_error (_("unknown relocation modifier"));
3662 return FALSE;
3663 }
3664
3665 if (entry->adrp_type == 0)
3666 {
3667 set_syntax_error
3668 (_("this relocation modifier is not allowed on this instruction"));
3669 return FALSE;
3670 }
3671
3672 inst.reloc.type = entry->adrp_type;
3673 }
3674 else
3675 inst.reloc.type = BFD_RELOC_AARCH64_ADR_HI21_PCREL;
3676
3677 inst.reloc.pc_rel = 1;
3678
3679 if (! my_get_expression (&inst.reloc.exp, &p, GE_NO_PREFIX, 1))
3680 return FALSE;
3681
3682 *str = p;
3683 return TRUE;
3684}
3685
3686/* Miscellaneous. */
3687
245d2e3f
RS
3688/* Parse a symbolic operand such as "pow2" at *STR. ARRAY is an array
3689 of SIZE tokens in which index I gives the token for field value I,
3690 or is null if field value I is invalid. REG_TYPE says which register
3691 names should be treated as registers rather than as symbolic immediates.
3692
3693 Return true on success, moving *STR past the operand and storing the
3694 field value in *VAL. */
3695
3696static int
3697parse_enum_string (char **str, int64_t *val, const char *const *array,
3698 size_t size, aarch64_reg_type reg_type)
3699{
3700 expressionS exp;
3701 char *p, *q;
3702 size_t i;
3703
3704 /* Match C-like tokens. */
3705 p = q = *str;
3706 while (ISALNUM (*q))
3707 q++;
3708
3709 for (i = 0; i < size; ++i)
3710 if (array[i]
3711 && strncasecmp (array[i], p, q - p) == 0
3712 && array[i][q - p] == 0)
3713 {
3714 *val = i;
3715 *str = q;
3716 return TRUE;
3717 }
3718
3719 if (!parse_immediate_expression (&p, &exp, reg_type))
3720 return FALSE;
3721
3722 if (exp.X_op == O_constant
3723 && (uint64_t) exp.X_add_number < size)
3724 {
3725 *val = exp.X_add_number;
3726 *str = p;
3727 return TRUE;
3728 }
3729
3730 /* Use the default error for this operand. */
3731 return FALSE;
3732}
3733
a06ea964
NC
3734/* Parse an option for a preload instruction. Returns the encoding for the
3735 option, or PARSE_FAIL. */
3736
3737static int
3738parse_pldop (char **str)
3739{
3740 char *p, *q;
3741 const struct aarch64_name_value_pair *o;
3742
3743 p = q = *str;
3744 while (ISALNUM (*q))
3745 q++;
3746
3747 o = hash_find_n (aarch64_pldop_hsh, p, q - p);
3748 if (!o)
3749 return PARSE_FAIL;
3750
3751 *str = q;
3752 return o->value;
3753}
3754
3755/* Parse an option for a barrier instruction. Returns the encoding for the
3756 option, or PARSE_FAIL. */
3757
3758static int
3759parse_barrier (char **str)
3760{
3761 char *p, *q;
3762 const asm_barrier_opt *o;
3763
3764 p = q = *str;
3765 while (ISALPHA (*q))
3766 q++;
3767
3768 o = hash_find_n (aarch64_barrier_opt_hsh, p, q - p);
3769 if (!o)
3770 return PARSE_FAIL;
3771
3772 *str = q;
3773 return o->value;
3774}
3775
1e6f4800
MW
3776/* Parse an operand for a PSB barrier. Set *HINT_OPT to the hint-option record
3777 return 0 if successful. Otherwise return PARSE_FAIL. */
3778
3779static int
3780parse_barrier_psb (char **str,
3781 const struct aarch64_name_value_pair ** hint_opt)
3782{
3783 char *p, *q;
3784 const struct aarch64_name_value_pair *o;
3785
3786 p = q = *str;
3787 while (ISALPHA (*q))
3788 q++;
3789
3790 o = hash_find_n (aarch64_hint_opt_hsh, p, q - p);
3791 if (!o)
3792 {
3793 set_fatal_syntax_error
3794 ( _("unknown or missing option to PSB"));
3795 return PARSE_FAIL;
3796 }
3797
3798 if (o->value != 0x11)
3799 {
3800 /* PSB only accepts option name 'CSYNC'. */
3801 set_syntax_error
3802 (_("the specified option is not accepted for PSB"));
3803 return PARSE_FAIL;
3804 }
3805
3806 *str = q;
3807 *hint_opt = o;
3808 return 0;
3809}
3810
a06ea964 3811/* Parse a system register or a PSTATE field name for an MSR/MRS instruction.
a203d9b7 3812 Returns the encoding for the option, or PARSE_FAIL.
a06ea964
NC
3813
3814 If IMPLE_DEFINED_P is non-zero, the function will also try to parse the
72ca8fad
MW
3815 implementation defined system register name S<op0>_<op1>_<Cn>_<Cm>_<op2>.
3816
3817 If PSTATEFIELD_P is non-zero, the function will parse the name as a PSTATE
3818 field, otherwise as a system register.
3819*/
a06ea964
NC
3820
3821static int
72ca8fad
MW
3822parse_sys_reg (char **str, struct hash_control *sys_regs,
3823 int imple_defined_p, int pstatefield_p)
a06ea964
NC
3824{
3825 char *p, *q;
3826 char buf[32];
49eec193 3827 const aarch64_sys_reg *o;
a06ea964
NC
3828 int value;
3829
3830 p = buf;
3831 for (q = *str; ISALNUM (*q) || *q == '_'; q++)
3832 if (p < buf + 31)
3833 *p++ = TOLOWER (*q);
3834 *p = '\0';
3835 /* Assert that BUF be large enough. */
3836 gas_assert (p - buf == q - *str);
3837
3838 o = hash_find (sys_regs, buf);
3839 if (!o)
3840 {
3841 if (!imple_defined_p)
3842 return PARSE_FAIL;
3843 else
3844 {
df7b4545 3845 /* Parse S<op0>_<op1>_<Cn>_<Cm>_<op2>. */
a06ea964 3846 unsigned int op0, op1, cn, cm, op2;
df7b4545
JW
3847
3848 if (sscanf (buf, "s%u_%u_c%u_c%u_%u", &op0, &op1, &cn, &cm, &op2)
3849 != 5)
a06ea964 3850 return PARSE_FAIL;
df7b4545 3851 if (op0 > 3 || op1 > 7 || cn > 15 || cm > 15 || op2 > 7)
a06ea964
NC
3852 return PARSE_FAIL;
3853 value = (op0 << 14) | (op1 << 11) | (cn << 7) | (cm << 3) | op2;
3854 }
3855 }
3856 else
49eec193 3857 {
72ca8fad
MW
3858 if (pstatefield_p && !aarch64_pstatefield_supported_p (cpu_variant, o))
3859 as_bad (_("selected processor does not support PSTATE field "
3860 "name '%s'"), buf);
3861 if (!pstatefield_p && !aarch64_sys_reg_supported_p (cpu_variant, o))
3862 as_bad (_("selected processor does not support system register "
3863 "name '%s'"), buf);
9a73e520 3864 if (aarch64_sys_reg_deprecated_p (o))
49eec193 3865 as_warn (_("system register name '%s' is deprecated and may be "
72ca8fad 3866 "removed in a future release"), buf);
49eec193
YZ
3867 value = o->value;
3868 }
a06ea964
NC
3869
3870 *str = q;
3871 return value;
3872}
3873
3874/* Parse a system reg for ic/dc/at/tlbi instructions. Returns the table entry
3875 for the option, or NULL. */
3876
3877static const aarch64_sys_ins_reg *
3878parse_sys_ins_reg (char **str, struct hash_control *sys_ins_regs)
3879{
3880 char *p, *q;
3881 char buf[32];
3882 const aarch64_sys_ins_reg *o;
3883
3884 p = buf;
3885 for (q = *str; ISALNUM (*q) || *q == '_'; q++)
3886 if (p < buf + 31)
3887 *p++ = TOLOWER (*q);
3888 *p = '\0';
3889
3890 o = hash_find (sys_ins_regs, buf);
3891 if (!o)
3892 return NULL;
3893
d6bf7ce6
MW
3894 if (!aarch64_sys_ins_reg_supported_p (cpu_variant, o))
3895 as_bad (_("selected processor does not support system register "
3896 "name '%s'"), buf);
3897
a06ea964
NC
3898 *str = q;
3899 return o;
3900}
3901\f
3902#define po_char_or_fail(chr) do { \
3903 if (! skip_past_char (&str, chr)) \
3904 goto failure; \
3905} while (0)
3906
3907#define po_reg_or_fail(regtype) do { \
3908 val = aarch64_reg_parse (&str, regtype, &rtype, NULL); \
3909 if (val == PARSE_FAIL) \
3910 { \
3911 set_default_error (); \
3912 goto failure; \
3913 } \
3914 } while (0)
3915
e1b988bb
RS
3916#define po_int_reg_or_fail(reg_type) do { \
3917 reg = aarch64_reg_parse_32_64 (&str, &qualifier); \
3918 if (!reg || !aarch64_check_reg_type (reg, reg_type)) \
a06ea964
NC
3919 { \
3920 set_default_error (); \
3921 goto failure; \
3922 } \
e1b988bb
RS
3923 info->reg.regno = reg->number; \
3924 info->qualifier = qualifier; \
a06ea964
NC
3925 } while (0)
3926
3927#define po_imm_nc_or_fail() do { \
1799c0d0 3928 if (! parse_constant_immediate (&str, &val, imm_reg_type)) \
a06ea964
NC
3929 goto failure; \
3930 } while (0)
3931
3932#define po_imm_or_fail(min, max) do { \
1799c0d0 3933 if (! parse_constant_immediate (&str, &val, imm_reg_type)) \
a06ea964
NC
3934 goto failure; \
3935 if (val < min || val > max) \
3936 { \
3937 set_fatal_syntax_error (_("immediate value out of range "\
3938#min " to "#max)); \
3939 goto failure; \
3940 } \
3941 } while (0)
3942
245d2e3f
RS
3943#define po_enum_or_fail(array) do { \
3944 if (!parse_enum_string (&str, &val, array, \
3945 ARRAY_SIZE (array), imm_reg_type)) \
3946 goto failure; \
3947 } while (0)
3948
a06ea964
NC
3949#define po_misc_or_fail(expr) do { \
3950 if (!expr) \
3951 goto failure; \
3952 } while (0)
3953\f
3954/* encode the 12-bit imm field of Add/sub immediate */
3955static inline uint32_t
3956encode_addsub_imm (uint32_t imm)
3957{
3958 return imm << 10;
3959}
3960
3961/* encode the shift amount field of Add/sub immediate */
3962static inline uint32_t
3963encode_addsub_imm_shift_amount (uint32_t cnt)
3964{
3965 return cnt << 22;
3966}
3967
3968
3969/* encode the imm field of Adr instruction */
3970static inline uint32_t
3971encode_adr_imm (uint32_t imm)
3972{
3973 return (((imm & 0x3) << 29) /* [1:0] -> [30:29] */
3974 | ((imm & (0x7ffff << 2)) << 3)); /* [20:2] -> [23:5] */
3975}
3976
3977/* encode the immediate field of Move wide immediate */
3978static inline uint32_t
3979encode_movw_imm (uint32_t imm)
3980{
3981 return imm << 5;
3982}
3983
3984/* encode the 26-bit offset of unconditional branch */
3985static inline uint32_t
3986encode_branch_ofs_26 (uint32_t ofs)
3987{
3988 return ofs & ((1 << 26) - 1);
3989}
3990
3991/* encode the 19-bit offset of conditional branch and compare & branch */
3992static inline uint32_t
3993encode_cond_branch_ofs_19 (uint32_t ofs)
3994{
3995 return (ofs & ((1 << 19) - 1)) << 5;
3996}
3997
3998/* encode the 19-bit offset of ld literal */
3999static inline uint32_t
4000encode_ld_lit_ofs_19 (uint32_t ofs)
4001{
4002 return (ofs & ((1 << 19) - 1)) << 5;
4003}
4004
4005/* Encode the 14-bit offset of test & branch. */
4006static inline uint32_t
4007encode_tst_branch_ofs_14 (uint32_t ofs)
4008{
4009 return (ofs & ((1 << 14) - 1)) << 5;
4010}
4011
4012/* Encode the 16-bit imm field of svc/hvc/smc. */
4013static inline uint32_t
4014encode_svc_imm (uint32_t imm)
4015{
4016 return imm << 5;
4017}
4018
4019/* Reencode add(s) to sub(s), or sub(s) to add(s). */
4020static inline uint32_t
4021reencode_addsub_switch_add_sub (uint32_t opcode)
4022{
4023 return opcode ^ (1 << 30);
4024}
4025
4026static inline uint32_t
4027reencode_movzn_to_movz (uint32_t opcode)
4028{
4029 return opcode | (1 << 30);
4030}
4031
4032static inline uint32_t
4033reencode_movzn_to_movn (uint32_t opcode)
4034{
4035 return opcode & ~(1 << 30);
4036}
4037
4038/* Overall per-instruction processing. */
4039
4040/* We need to be able to fix up arbitrary expressions in some statements.
4041 This is so that we can handle symbols that are an arbitrary distance from
4042 the pc. The most common cases are of the form ((+/-sym -/+ . - 8) & mask),
4043 which returns part of an address in a form which will be valid for
4044 a data instruction. We do this by pushing the expression into a symbol
4045 in the expr_section, and creating a fix for that. */
4046
4047static fixS *
4048fix_new_aarch64 (fragS * frag,
4049 int where,
4050 short int size, expressionS * exp, int pc_rel, int reloc)
4051{
4052 fixS *new_fix;
4053
4054 switch (exp->X_op)
4055 {
4056 case O_constant:
4057 case O_symbol:
4058 case O_add:
4059 case O_subtract:
4060 new_fix = fix_new_exp (frag, where, size, exp, pc_rel, reloc);
4061 break;
4062
4063 default:
4064 new_fix = fix_new (frag, where, size, make_expr_symbol (exp), 0,
4065 pc_rel, reloc);
4066 break;
4067 }
4068 return new_fix;
4069}
4070\f
4071/* Diagnostics on operands errors. */
4072
a52e6fd3
YZ
4073/* By default, output verbose error message.
4074 Disable the verbose error message by -mno-verbose-error. */
4075static int verbose_error_p = 1;
a06ea964
NC
4076
4077#ifdef DEBUG_AARCH64
4078/* N.B. this is only for the purpose of debugging. */
4079const char* operand_mismatch_kind_names[] =
4080{
4081 "AARCH64_OPDE_NIL",
4082 "AARCH64_OPDE_RECOVERABLE",
4083 "AARCH64_OPDE_SYNTAX_ERROR",
4084 "AARCH64_OPDE_FATAL_SYNTAX_ERROR",
4085 "AARCH64_OPDE_INVALID_VARIANT",
4086 "AARCH64_OPDE_OUT_OF_RANGE",
4087 "AARCH64_OPDE_UNALIGNED",
4088 "AARCH64_OPDE_REG_LIST",
4089 "AARCH64_OPDE_OTHER_ERROR",
4090};
4091#endif /* DEBUG_AARCH64 */
4092
4093/* Return TRUE if LHS is of higher severity than RHS, otherwise return FALSE.
4094
4095 When multiple errors of different kinds are found in the same assembly
4096 line, only the error of the highest severity will be picked up for
4097 issuing the diagnostics. */
4098
4099static inline bfd_boolean
4100operand_error_higher_severity_p (enum aarch64_operand_error_kind lhs,
4101 enum aarch64_operand_error_kind rhs)
4102{
4103 gas_assert (AARCH64_OPDE_RECOVERABLE > AARCH64_OPDE_NIL);
4104 gas_assert (AARCH64_OPDE_SYNTAX_ERROR > AARCH64_OPDE_RECOVERABLE);
4105 gas_assert (AARCH64_OPDE_FATAL_SYNTAX_ERROR > AARCH64_OPDE_SYNTAX_ERROR);
4106 gas_assert (AARCH64_OPDE_INVALID_VARIANT > AARCH64_OPDE_FATAL_SYNTAX_ERROR);
4107 gas_assert (AARCH64_OPDE_OUT_OF_RANGE > AARCH64_OPDE_INVALID_VARIANT);
4108 gas_assert (AARCH64_OPDE_UNALIGNED > AARCH64_OPDE_OUT_OF_RANGE);
4109 gas_assert (AARCH64_OPDE_REG_LIST > AARCH64_OPDE_UNALIGNED);
4110 gas_assert (AARCH64_OPDE_OTHER_ERROR > AARCH64_OPDE_REG_LIST);
4111 return lhs > rhs;
4112}
4113
4114/* Helper routine to get the mnemonic name from the assembly instruction
4115 line; should only be called for the diagnosis purpose, as there is
4116 string copy operation involved, which may affect the runtime
4117 performance if used in elsewhere. */
4118
4119static const char*
4120get_mnemonic_name (const char *str)
4121{
4122 static char mnemonic[32];
4123 char *ptr;
4124
4125 /* Get the first 15 bytes and assume that the full name is included. */
4126 strncpy (mnemonic, str, 31);
4127 mnemonic[31] = '\0';
4128
4129 /* Scan up to the end of the mnemonic, which must end in white space,
4130 '.', or end of string. */
4131 for (ptr = mnemonic; is_part_of_name(*ptr); ++ptr)
4132 ;
4133
4134 *ptr = '\0';
4135
4136 /* Append '...' to the truncated long name. */
4137 if (ptr - mnemonic == 31)
4138 mnemonic[28] = mnemonic[29] = mnemonic[30] = '.';
4139
4140 return mnemonic;
4141}
4142
4143static void
4144reset_aarch64_instruction (aarch64_instruction *instruction)
4145{
4146 memset (instruction, '\0', sizeof (aarch64_instruction));
4147 instruction->reloc.type = BFD_RELOC_UNUSED;
4148}
4149
4150/* Data strutures storing one user error in the assembly code related to
4151 operands. */
4152
4153struct operand_error_record
4154{
4155 const aarch64_opcode *opcode;
4156 aarch64_operand_error detail;
4157 struct operand_error_record *next;
4158};
4159
4160typedef struct operand_error_record operand_error_record;
4161
4162struct operand_errors
4163{
4164 operand_error_record *head;
4165 operand_error_record *tail;
4166};
4167
4168typedef struct operand_errors operand_errors;
4169
4170/* Top-level data structure reporting user errors for the current line of
4171 the assembly code.
4172 The way md_assemble works is that all opcodes sharing the same mnemonic
4173 name are iterated to find a match to the assembly line. In this data
4174 structure, each of the such opcodes will have one operand_error_record
4175 allocated and inserted. In other words, excessive errors related with
4176 a single opcode are disregarded. */
4177operand_errors operand_error_report;
4178
4179/* Free record nodes. */
4180static operand_error_record *free_opnd_error_record_nodes = NULL;
4181
4182/* Initialize the data structure that stores the operand mismatch
4183 information on assembling one line of the assembly code. */
4184static void
4185init_operand_error_report (void)
4186{
4187 if (operand_error_report.head != NULL)
4188 {
4189 gas_assert (operand_error_report.tail != NULL);
4190 operand_error_report.tail->next = free_opnd_error_record_nodes;
4191 free_opnd_error_record_nodes = operand_error_report.head;
4192 operand_error_report.head = NULL;
4193 operand_error_report.tail = NULL;
4194 return;
4195 }
4196 gas_assert (operand_error_report.tail == NULL);
4197}
4198
4199/* Return TRUE if some operand error has been recorded during the
4200 parsing of the current assembly line using the opcode *OPCODE;
4201 otherwise return FALSE. */
4202static inline bfd_boolean
4203opcode_has_operand_error_p (const aarch64_opcode *opcode)
4204{
4205 operand_error_record *record = operand_error_report.head;
4206 return record && record->opcode == opcode;
4207}
4208
4209/* Add the error record *NEW_RECORD to operand_error_report. The record's
4210 OPCODE field is initialized with OPCODE.
4211 N.B. only one record for each opcode, i.e. the maximum of one error is
4212 recorded for each instruction template. */
4213
4214static void
4215add_operand_error_record (const operand_error_record* new_record)
4216{
4217 const aarch64_opcode *opcode = new_record->opcode;
4218 operand_error_record* record = operand_error_report.head;
4219
4220 /* The record may have been created for this opcode. If not, we need
4221 to prepare one. */
4222 if (! opcode_has_operand_error_p (opcode))
4223 {
4224 /* Get one empty record. */
4225 if (free_opnd_error_record_nodes == NULL)
4226 {
325801bd 4227 record = XNEW (operand_error_record);
a06ea964
NC
4228 }
4229 else
4230 {
4231 record = free_opnd_error_record_nodes;
4232 free_opnd_error_record_nodes = record->next;
4233 }
4234 record->opcode = opcode;
4235 /* Insert at the head. */
4236 record->next = operand_error_report.head;
4237 operand_error_report.head = record;
4238 if (operand_error_report.tail == NULL)
4239 operand_error_report.tail = record;
4240 }
4241 else if (record->detail.kind != AARCH64_OPDE_NIL
4242 && record->detail.index <= new_record->detail.index
4243 && operand_error_higher_severity_p (record->detail.kind,
4244 new_record->detail.kind))
4245 {
4246 /* In the case of multiple errors found on operands related with a
4247 single opcode, only record the error of the leftmost operand and
4248 only if the error is of higher severity. */
4249 DEBUG_TRACE ("error %s on operand %d not added to the report due to"
4250 " the existing error %s on operand %d",
4251 operand_mismatch_kind_names[new_record->detail.kind],
4252 new_record->detail.index,
4253 operand_mismatch_kind_names[record->detail.kind],
4254 record->detail.index);
4255 return;
4256 }
4257
4258 record->detail = new_record->detail;
4259}
4260
4261static inline void
4262record_operand_error_info (const aarch64_opcode *opcode,
4263 aarch64_operand_error *error_info)
4264{
4265 operand_error_record record;
4266 record.opcode = opcode;
4267 record.detail = *error_info;
4268 add_operand_error_record (&record);
4269}
4270
4271/* Record an error of kind KIND and, if ERROR is not NULL, of the detailed
4272 error message *ERROR, for operand IDX (count from 0). */
4273
4274static void
4275record_operand_error (const aarch64_opcode *opcode, int idx,
4276 enum aarch64_operand_error_kind kind,
4277 const char* error)
4278{
4279 aarch64_operand_error info;
4280 memset(&info, 0, sizeof (info));
4281 info.index = idx;
4282 info.kind = kind;
4283 info.error = error;
4284 record_operand_error_info (opcode, &info);
4285}
4286
4287static void
4288record_operand_error_with_data (const aarch64_opcode *opcode, int idx,
4289 enum aarch64_operand_error_kind kind,
4290 const char* error, const int *extra_data)
4291{
4292 aarch64_operand_error info;
4293 info.index = idx;
4294 info.kind = kind;
4295 info.error = error;
4296 info.data[0] = extra_data[0];
4297 info.data[1] = extra_data[1];
4298 info.data[2] = extra_data[2];
4299 record_operand_error_info (opcode, &info);
4300}
4301
4302static void
4303record_operand_out_of_range_error (const aarch64_opcode *opcode, int idx,
4304 const char* error, int lower_bound,
4305 int upper_bound)
4306{
4307 int data[3] = {lower_bound, upper_bound, 0};
4308 record_operand_error_with_data (opcode, idx, AARCH64_OPDE_OUT_OF_RANGE,
4309 error, data);
4310}
4311
4312/* Remove the operand error record for *OPCODE. */
4313static void ATTRIBUTE_UNUSED
4314remove_operand_error_record (const aarch64_opcode *opcode)
4315{
4316 if (opcode_has_operand_error_p (opcode))
4317 {
4318 operand_error_record* record = operand_error_report.head;
4319 gas_assert (record != NULL && operand_error_report.tail != NULL);
4320 operand_error_report.head = record->next;
4321 record->next = free_opnd_error_record_nodes;
4322 free_opnd_error_record_nodes = record;
4323 if (operand_error_report.head == NULL)
4324 {
4325 gas_assert (operand_error_report.tail == record);
4326 operand_error_report.tail = NULL;
4327 }
4328 }
4329}
4330
4331/* Given the instruction in *INSTR, return the index of the best matched
4332 qualifier sequence in the list (an array) headed by QUALIFIERS_LIST.
4333
4334 Return -1 if there is no qualifier sequence; return the first match
4335 if there is multiple matches found. */
4336
4337static int
4338find_best_match (const aarch64_inst *instr,
4339 const aarch64_opnd_qualifier_seq_t *qualifiers_list)
4340{
4341 int i, num_opnds, max_num_matched, idx;
4342
4343 num_opnds = aarch64_num_of_operands (instr->opcode);
4344 if (num_opnds == 0)
4345 {
4346 DEBUG_TRACE ("no operand");
4347 return -1;
4348 }
4349
4350 max_num_matched = 0;
4989adac 4351 idx = 0;
a06ea964
NC
4352
4353 /* For each pattern. */
4354 for (i = 0; i < AARCH64_MAX_QLF_SEQ_NUM; ++i, ++qualifiers_list)
4355 {
4356 int j, num_matched;
4357 const aarch64_opnd_qualifier_t *qualifiers = *qualifiers_list;
4358
4359 /* Most opcodes has much fewer patterns in the list. */
4360 if (empty_qualifier_sequence_p (qualifiers) == TRUE)
4361 {
4362 DEBUG_TRACE_IF (i == 0, "empty list of qualifier sequence");
a06ea964
NC
4363 break;
4364 }
4365
4366 for (j = 0, num_matched = 0; j < num_opnds; ++j, ++qualifiers)
4367 if (*qualifiers == instr->operands[j].qualifier)
4368 ++num_matched;
4369
4370 if (num_matched > max_num_matched)
4371 {
4372 max_num_matched = num_matched;
4373 idx = i;
4374 }
4375 }
4376
4377 DEBUG_TRACE ("return with %d", idx);
4378 return idx;
4379}
4380
4381/* Assign qualifiers in the qualifier seqence (headed by QUALIFIERS) to the
4382 corresponding operands in *INSTR. */
4383
4384static inline void
4385assign_qualifier_sequence (aarch64_inst *instr,
4386 const aarch64_opnd_qualifier_t *qualifiers)
4387{
4388 int i = 0;
4389 int num_opnds = aarch64_num_of_operands (instr->opcode);
4390 gas_assert (num_opnds);
4391 for (i = 0; i < num_opnds; ++i, ++qualifiers)
4392 instr->operands[i].qualifier = *qualifiers;
4393}
4394
4395/* Print operands for the diagnosis purpose. */
4396
4397static void
4398print_operands (char *buf, const aarch64_opcode *opcode,
4399 const aarch64_opnd_info *opnds)
4400{
4401 int i;
4402
4403 for (i = 0; i < AARCH64_MAX_OPND_NUM; ++i)
4404 {
08d3b0cc 4405 char str[128];
a06ea964
NC
4406
4407 /* We regard the opcode operand info more, however we also look into
4408 the inst->operands to support the disassembling of the optional
4409 operand.
4410 The two operand code should be the same in all cases, apart from
4411 when the operand can be optional. */
4412 if (opcode->operands[i] == AARCH64_OPND_NIL
4413 || opnds[i].type == AARCH64_OPND_NIL)
4414 break;
4415
4416 /* Generate the operand string in STR. */
08d3b0cc 4417 aarch64_print_operand (str, sizeof (str), 0, opcode, opnds, i, NULL, NULL);
a06ea964
NC
4418
4419 /* Delimiter. */
4420 if (str[0] != '\0')
4421 strcat (buf, i == 0 ? " " : ",");
4422
4423 /* Append the operand string. */
4424 strcat (buf, str);
4425 }
4426}
4427
4428/* Send to stderr a string as information. */
4429
4430static void
4431output_info (const char *format, ...)
4432{
3b4dbbbf 4433 const char *file;
a06ea964
NC
4434 unsigned int line;
4435 va_list args;
4436
3b4dbbbf 4437 file = as_where (&line);
a06ea964
NC
4438 if (file)
4439 {
4440 if (line != 0)
4441 fprintf (stderr, "%s:%u: ", file, line);
4442 else
4443 fprintf (stderr, "%s: ", file);
4444 }
4445 fprintf (stderr, _("Info: "));
4446 va_start (args, format);
4447 vfprintf (stderr, format, args);
4448 va_end (args);
4449 (void) putc ('\n', stderr);
4450}
4451
4452/* Output one operand error record. */
4453
4454static void
4455output_operand_error_record (const operand_error_record *record, char *str)
4456{
28f013d5
JB
4457 const aarch64_operand_error *detail = &record->detail;
4458 int idx = detail->index;
a06ea964 4459 const aarch64_opcode *opcode = record->opcode;
28f013d5 4460 enum aarch64_opnd opd_code = (idx >= 0 ? opcode->operands[idx]
a06ea964 4461 : AARCH64_OPND_NIL);
a06ea964
NC
4462
4463 switch (detail->kind)
4464 {
4465 case AARCH64_OPDE_NIL:
4466 gas_assert (0);
4467 break;
4468
4469 case AARCH64_OPDE_SYNTAX_ERROR:
4470 case AARCH64_OPDE_RECOVERABLE:
4471 case AARCH64_OPDE_FATAL_SYNTAX_ERROR:
4472 case AARCH64_OPDE_OTHER_ERROR:
a06ea964
NC
4473 /* Use the prepared error message if there is, otherwise use the
4474 operand description string to describe the error. */
4475 if (detail->error != NULL)
4476 {
28f013d5 4477 if (idx < 0)
a06ea964
NC
4478 as_bad (_("%s -- `%s'"), detail->error, str);
4479 else
4480 as_bad (_("%s at operand %d -- `%s'"),
28f013d5 4481 detail->error, idx + 1, str);
a06ea964
NC
4482 }
4483 else
28f013d5
JB
4484 {
4485 gas_assert (idx >= 0);
4486 as_bad (_("operand %d should be %s -- `%s'"), idx + 1,
a06ea964 4487 aarch64_get_operand_desc (opd_code), str);
28f013d5 4488 }
a06ea964
NC
4489 break;
4490
4491 case AARCH64_OPDE_INVALID_VARIANT:
4492 as_bad (_("operand mismatch -- `%s'"), str);
4493 if (verbose_error_p)
4494 {
4495 /* We will try to correct the erroneous instruction and also provide
4496 more information e.g. all other valid variants.
4497
4498 The string representation of the corrected instruction and other
4499 valid variants are generated by
4500
4501 1) obtaining the intermediate representation of the erroneous
4502 instruction;
4503 2) manipulating the IR, e.g. replacing the operand qualifier;
4504 3) printing out the instruction by calling the printer functions
4505 shared with the disassembler.
4506
4507 The limitation of this method is that the exact input assembly
4508 line cannot be accurately reproduced in some cases, for example an
4509 optional operand present in the actual assembly line will be
4510 omitted in the output; likewise for the optional syntax rules,
4511 e.g. the # before the immediate. Another limitation is that the
4512 assembly symbols and relocation operations in the assembly line
4513 currently cannot be printed out in the error report. Last but not
4514 least, when there is other error(s) co-exist with this error, the
4515 'corrected' instruction may be still incorrect, e.g. given
4516 'ldnp h0,h1,[x0,#6]!'
4517 this diagnosis will provide the version:
4518 'ldnp s0,s1,[x0,#6]!'
4519 which is still not right. */
4520 size_t len = strlen (get_mnemonic_name (str));
4521 int i, qlf_idx;
4522 bfd_boolean result;
08d3b0cc 4523 char buf[2048];
a06ea964
NC
4524 aarch64_inst *inst_base = &inst.base;
4525 const aarch64_opnd_qualifier_seq_t *qualifiers_list;
4526
4527 /* Init inst. */
4528 reset_aarch64_instruction (&inst);
4529 inst_base->opcode = opcode;
4530
4531 /* Reset the error report so that there is no side effect on the
4532 following operand parsing. */
4533 init_operand_error_report ();
4534
4535 /* Fill inst. */
4536 result = parse_operands (str + len, opcode)
4537 && programmer_friendly_fixup (&inst);
4538 gas_assert (result);
4539 result = aarch64_opcode_encode (opcode, inst_base, &inst_base->value,
4540 NULL, NULL);
4541 gas_assert (!result);
4542
4543 /* Find the most matched qualifier sequence. */
4544 qlf_idx = find_best_match (inst_base, opcode->qualifiers_list);
4545 gas_assert (qlf_idx > -1);
4546
4547 /* Assign the qualifiers. */
4548 assign_qualifier_sequence (inst_base,
4549 opcode->qualifiers_list[qlf_idx]);
4550
4551 /* Print the hint. */
4552 output_info (_(" did you mean this?"));
08d3b0cc 4553 snprintf (buf, sizeof (buf), "\t%s", get_mnemonic_name (str));
a06ea964
NC
4554 print_operands (buf, opcode, inst_base->operands);
4555 output_info (_(" %s"), buf);
4556
4557 /* Print out other variant(s) if there is any. */
4558 if (qlf_idx != 0 ||
4559 !empty_qualifier_sequence_p (opcode->qualifiers_list[1]))
4560 output_info (_(" other valid variant(s):"));
4561
4562 /* For each pattern. */
4563 qualifiers_list = opcode->qualifiers_list;
4564 for (i = 0; i < AARCH64_MAX_QLF_SEQ_NUM; ++i, ++qualifiers_list)
4565 {
4566 /* Most opcodes has much fewer patterns in the list.
4567 First NIL qualifier indicates the end in the list. */
4568 if (empty_qualifier_sequence_p (*qualifiers_list) == TRUE)
4569 break;
4570
4571 if (i != qlf_idx)
4572 {
4573 /* Mnemonics name. */
08d3b0cc 4574 snprintf (buf, sizeof (buf), "\t%s", get_mnemonic_name (str));
a06ea964
NC
4575
4576 /* Assign the qualifiers. */
4577 assign_qualifier_sequence (inst_base, *qualifiers_list);
4578
4579 /* Print instruction. */
4580 print_operands (buf, opcode, inst_base->operands);
4581
4582 output_info (_(" %s"), buf);
4583 }
4584 }
4585 }
4586 break;
4587
0c608d6b
RS
4588 case AARCH64_OPDE_UNTIED_OPERAND:
4589 as_bad (_("operand %d must be the same register as operand 1 -- `%s'"),
4590 detail->index + 1, str);
4591 break;
4592
a06ea964 4593 case AARCH64_OPDE_OUT_OF_RANGE:
f5555712
YZ
4594 if (detail->data[0] != detail->data[1])
4595 as_bad (_("%s out of range %d to %d at operand %d -- `%s'"),
4596 detail->error ? detail->error : _("immediate value"),
28f013d5 4597 detail->data[0], detail->data[1], idx + 1, str);
f5555712
YZ
4598 else
4599 as_bad (_("%s expected to be %d at operand %d -- `%s'"),
4600 detail->error ? detail->error : _("immediate value"),
28f013d5 4601 detail->data[0], idx + 1, str);
a06ea964
NC
4602 break;
4603
4604 case AARCH64_OPDE_REG_LIST:
4605 if (detail->data[0] == 1)
4606 as_bad (_("invalid number of registers in the list; "
4607 "only 1 register is expected at operand %d -- `%s'"),
28f013d5 4608 idx + 1, str);
a06ea964
NC
4609 else
4610 as_bad (_("invalid number of registers in the list; "
4611 "%d registers are expected at operand %d -- `%s'"),
28f013d5 4612 detail->data[0], idx + 1, str);
a06ea964
NC
4613 break;
4614
4615 case AARCH64_OPDE_UNALIGNED:
4616 as_bad (_("immediate value should be a multiple of "
4617 "%d at operand %d -- `%s'"),
28f013d5 4618 detail->data[0], idx + 1, str);
a06ea964
NC
4619 break;
4620
4621 default:
4622 gas_assert (0);
4623 break;
4624 }
4625}
4626
4627/* Process and output the error message about the operand mismatching.
4628
4629 When this function is called, the operand error information had
4630 been collected for an assembly line and there will be multiple
4631 errors in the case of mulitple instruction templates; output the
4632 error message that most closely describes the problem. */
4633
4634static void
4635output_operand_error_report (char *str)
4636{
4637 int largest_error_pos;
4638 const char *msg = NULL;
4639 enum aarch64_operand_error_kind kind;
4640 operand_error_record *curr;
4641 operand_error_record *head = operand_error_report.head;
4642 operand_error_record *record = NULL;
4643
4644 /* No error to report. */
4645 if (head == NULL)
4646 return;
4647
4648 gas_assert (head != NULL && operand_error_report.tail != NULL);
4649
4650 /* Only one error. */
4651 if (head == operand_error_report.tail)
4652 {
4653 DEBUG_TRACE ("single opcode entry with error kind: %s",
4654 operand_mismatch_kind_names[head->detail.kind]);
4655 output_operand_error_record (head, str);
4656 return;
4657 }
4658
4659 /* Find the error kind of the highest severity. */
4660 DEBUG_TRACE ("multiple opcode entres with error kind");
4661 kind = AARCH64_OPDE_NIL;
4662 for (curr = head; curr != NULL; curr = curr->next)
4663 {
4664 gas_assert (curr->detail.kind != AARCH64_OPDE_NIL);
4665 DEBUG_TRACE ("\t%s", operand_mismatch_kind_names[curr->detail.kind]);
4666 if (operand_error_higher_severity_p (curr->detail.kind, kind))
4667 kind = curr->detail.kind;
4668 }
4669 gas_assert (kind != AARCH64_OPDE_NIL);
4670
4671 /* Pick up one of errors of KIND to report. */
4672 largest_error_pos = -2; /* Index can be -1 which means unknown index. */
4673 for (curr = head; curr != NULL; curr = curr->next)
4674 {
4675 if (curr->detail.kind != kind)
4676 continue;
4677 /* If there are multiple errors, pick up the one with the highest
4678 mismatching operand index. In the case of multiple errors with
4679 the equally highest operand index, pick up the first one or the
4680 first one with non-NULL error message. */
4681 if (curr->detail.index > largest_error_pos
4682 || (curr->detail.index == largest_error_pos && msg == NULL
4683 && curr->detail.error != NULL))
4684 {
4685 largest_error_pos = curr->detail.index;
4686 record = curr;
4687 msg = record->detail.error;
4688 }
4689 }
4690
4691 gas_assert (largest_error_pos != -2 && record != NULL);
4692 DEBUG_TRACE ("Pick up error kind %s to report",
4693 operand_mismatch_kind_names[record->detail.kind]);
4694
4695 /* Output. */
4696 output_operand_error_record (record, str);
4697}
4698\f
4699/* Write an AARCH64 instruction to buf - always little-endian. */
4700static void
4701put_aarch64_insn (char *buf, uint32_t insn)
4702{
4703 unsigned char *where = (unsigned char *) buf;
4704 where[0] = insn;
4705 where[1] = insn >> 8;
4706 where[2] = insn >> 16;
4707 where[3] = insn >> 24;
4708}
4709
4710static uint32_t
4711get_aarch64_insn (char *buf)
4712{
4713 unsigned char *where = (unsigned char *) buf;
4714 uint32_t result;
4715 result = (where[0] | (where[1] << 8) | (where[2] << 16) | (where[3] << 24));
4716 return result;
4717}
4718
4719static void
4720output_inst (struct aarch64_inst *new_inst)
4721{
4722 char *to = NULL;
4723
4724 to = frag_more (INSN_SIZE);
4725
4726 frag_now->tc_frag_data.recorded = 1;
4727
4728 put_aarch64_insn (to, inst.base.value);
4729
4730 if (inst.reloc.type != BFD_RELOC_UNUSED)
4731 {
4732 fixS *fixp = fix_new_aarch64 (frag_now, to - frag_now->fr_literal,
4733 INSN_SIZE, &inst.reloc.exp,
4734 inst.reloc.pc_rel,
4735 inst.reloc.type);
4736 DEBUG_TRACE ("Prepared relocation fix up");
4737 /* Don't check the addend value against the instruction size,
4738 that's the job of our code in md_apply_fix(). */
4739 fixp->fx_no_overflow = 1;
4740 if (new_inst != NULL)
4741 fixp->tc_fix_data.inst = new_inst;
4742 if (aarch64_gas_internal_fixup_p ())
4743 {
4744 gas_assert (inst.reloc.opnd != AARCH64_OPND_NIL);
4745 fixp->tc_fix_data.opnd = inst.reloc.opnd;
4746 fixp->fx_addnumber = inst.reloc.flags;
4747 }
4748 }
4749
4750 dwarf2_emit_insn (INSN_SIZE);
4751}
4752
4753/* Link together opcodes of the same name. */
4754
4755struct templates
4756{
4757 aarch64_opcode *opcode;
4758 struct templates *next;
4759};
4760
4761typedef struct templates templates;
4762
4763static templates *
4764lookup_mnemonic (const char *start, int len)
4765{
4766 templates *templ = NULL;
4767
4768 templ = hash_find_n (aarch64_ops_hsh, start, len);
4769 return templ;
4770}
4771
4772/* Subroutine of md_assemble, responsible for looking up the primary
4773 opcode from the mnemonic the user wrote. STR points to the
4774 beginning of the mnemonic. */
4775
4776static templates *
4777opcode_lookup (char **str)
4778{
4779 char *end, *base;
4780 const aarch64_cond *cond;
4781 char condname[16];
4782 int len;
4783
4784 /* Scan up to the end of the mnemonic, which must end in white space,
4785 '.', or end of string. */
4786 for (base = end = *str; is_part_of_name(*end); end++)
4787 if (*end == '.')
4788 break;
4789
4790 if (end == base)
4791 return 0;
4792
4793 inst.cond = COND_ALWAYS;
4794
4795 /* Handle a possible condition. */
4796 if (end[0] == '.')
4797 {
4798 cond = hash_find_n (aarch64_cond_hsh, end + 1, 2);
4799 if (cond)
4800 {
4801 inst.cond = cond->value;
4802 *str = end + 3;
4803 }
4804 else
4805 {
4806 *str = end;
4807 return 0;
4808 }
4809 }
4810 else
4811 *str = end;
4812
4813 len = end - base;
4814
4815 if (inst.cond == COND_ALWAYS)
4816 {
4817 /* Look for unaffixed mnemonic. */
4818 return lookup_mnemonic (base, len);
4819 }
4820 else if (len <= 13)
4821 {
4822 /* append ".c" to mnemonic if conditional */
4823 memcpy (condname, base, len);
4824 memcpy (condname + len, ".c", 2);
4825 base = condname;
4826 len += 2;
4827 return lookup_mnemonic (base, len);
4828 }
4829
4830 return NULL;
4831}
4832
8f9a77af
RS
4833/* Internal helper routine converting a vector_type_el structure *VECTYPE
4834 to a corresponding operand qualifier. */
a06ea964
NC
4835
4836static inline aarch64_opnd_qualifier_t
8f9a77af 4837vectype_to_qualifier (const struct vector_type_el *vectype)
a06ea964 4838{
f06935a5 4839 /* Element size in bytes indexed by vector_el_type. */
a06ea964
NC
4840 const unsigned char ele_size[5]
4841 = {1, 2, 4, 8, 16};
65f2205d
MW
4842 const unsigned int ele_base [5] =
4843 {
4844 AARCH64_OPND_QLF_V_8B,
3067d3b9 4845 AARCH64_OPND_QLF_V_2H,
65f2205d
MW
4846 AARCH64_OPND_QLF_V_2S,
4847 AARCH64_OPND_QLF_V_1D,
4848 AARCH64_OPND_QLF_V_1Q
4849 };
a06ea964
NC
4850
4851 if (!vectype->defined || vectype->type == NT_invtype)
4852 goto vectype_conversion_fail;
4853
d50c751e
RS
4854 if (vectype->type == NT_zero)
4855 return AARCH64_OPND_QLF_P_Z;
4856 if (vectype->type == NT_merge)
4857 return AARCH64_OPND_QLF_P_M;
4858
a06ea964
NC
4859 gas_assert (vectype->type >= NT_b && vectype->type <= NT_q);
4860
f11ad6bc 4861 if (vectype->defined & (NTA_HASINDEX | NTA_HASVARWIDTH))
a06ea964
NC
4862 /* Vector element register. */
4863 return AARCH64_OPND_QLF_S_B + vectype->type;
4864 else
4865 {
4866 /* Vector register. */
4867 int reg_size = ele_size[vectype->type] * vectype->width;
4868 unsigned offset;
65f2205d 4869 unsigned shift;
3067d3b9 4870 if (reg_size != 16 && reg_size != 8 && reg_size != 4)
a06ea964 4871 goto vectype_conversion_fail;
65f2205d
MW
4872
4873 /* The conversion is by calculating the offset from the base operand
4874 qualifier for the vector type. The operand qualifiers are regular
4875 enough that the offset can established by shifting the vector width by
4876 a vector-type dependent amount. */
4877 shift = 0;
4878 if (vectype->type == NT_b)
4879 shift = 4;
3067d3b9 4880 else if (vectype->type == NT_h || vectype->type == NT_s)
65f2205d
MW
4881 shift = 2;
4882 else if (vectype->type >= NT_d)
4883 shift = 1;
4884 else
4885 gas_assert (0);
4886
4887 offset = ele_base [vectype->type] + (vectype->width >> shift);
4888 gas_assert (AARCH64_OPND_QLF_V_8B <= offset
4889 && offset <= AARCH64_OPND_QLF_V_1Q);
4890 return offset;
a06ea964
NC
4891 }
4892
4893vectype_conversion_fail:
4894 first_error (_("bad vector arrangement type"));
4895 return AARCH64_OPND_QLF_NIL;
4896}
4897
4898/* Process an optional operand that is found omitted from the assembly line.
4899 Fill *OPERAND for such an operand of type TYPE. OPCODE points to the
4900 instruction's opcode entry while IDX is the index of this omitted operand.
4901 */
4902
4903static void
4904process_omitted_operand (enum aarch64_opnd type, const aarch64_opcode *opcode,
4905 int idx, aarch64_opnd_info *operand)
4906{
4907 aarch64_insn default_value = get_optional_operand_default_value (opcode);
4908 gas_assert (optional_operand_p (opcode, idx));
4909 gas_assert (!operand->present);
4910
4911 switch (type)
4912 {
4913 case AARCH64_OPND_Rd:
4914 case AARCH64_OPND_Rn:
4915 case AARCH64_OPND_Rm:
4916 case AARCH64_OPND_Rt:
4917 case AARCH64_OPND_Rt2:
4918 case AARCH64_OPND_Rs:
4919 case AARCH64_OPND_Ra:
4920 case AARCH64_OPND_Rt_SYS:
4921 case AARCH64_OPND_Rd_SP:
4922 case AARCH64_OPND_Rn_SP:
4923 case AARCH64_OPND_Fd:
4924 case AARCH64_OPND_Fn:
4925 case AARCH64_OPND_Fm:
4926 case AARCH64_OPND_Fa:
4927 case AARCH64_OPND_Ft:
4928 case AARCH64_OPND_Ft2:
4929 case AARCH64_OPND_Sd:
4930 case AARCH64_OPND_Sn:
4931 case AARCH64_OPND_Sm:
4932 case AARCH64_OPND_Vd:
4933 case AARCH64_OPND_Vn:
4934 case AARCH64_OPND_Vm:
4935 case AARCH64_OPND_VdD1:
4936 case AARCH64_OPND_VnD1:
4937 operand->reg.regno = default_value;
4938 break;
4939
4940 case AARCH64_OPND_Ed:
4941 case AARCH64_OPND_En:
4942 case AARCH64_OPND_Em:
4943 operand->reglane.regno = default_value;
4944 break;
4945
4946 case AARCH64_OPND_IDX:
4947 case AARCH64_OPND_BIT_NUM:
4948 case AARCH64_OPND_IMMR:
4949 case AARCH64_OPND_IMMS:
4950 case AARCH64_OPND_SHLL_IMM:
4951 case AARCH64_OPND_IMM_VLSL:
4952 case AARCH64_OPND_IMM_VLSR:
4953 case AARCH64_OPND_CCMP_IMM:
4954 case AARCH64_OPND_FBITS:
4955 case AARCH64_OPND_UIMM4:
4956 case AARCH64_OPND_UIMM3_OP1:
4957 case AARCH64_OPND_UIMM3_OP2:
4958 case AARCH64_OPND_IMM:
4959 case AARCH64_OPND_WIDTH:
4960 case AARCH64_OPND_UIMM7:
4961 case AARCH64_OPND_NZCV:
245d2e3f
RS
4962 case AARCH64_OPND_SVE_PATTERN:
4963 case AARCH64_OPND_SVE_PRFOP:
a06ea964
NC
4964 operand->imm.value = default_value;
4965 break;
4966
2442d846
RS
4967 case AARCH64_OPND_SVE_PATTERN_SCALED:
4968 operand->imm.value = default_value;
4969 operand->shifter.kind = AARCH64_MOD_MUL;
4970 operand->shifter.amount = 1;
4971 break;
4972
a06ea964
NC
4973 case AARCH64_OPND_EXCEPTION:
4974 inst.reloc.type = BFD_RELOC_UNUSED;
4975 break;
4976
4977 case AARCH64_OPND_BARRIER_ISB:
4978 operand->barrier = aarch64_barrier_options + default_value;
4979
4980 default:
4981 break;
4982 }
4983}
4984
4985/* Process the relocation type for move wide instructions.
4986 Return TRUE on success; otherwise return FALSE. */
4987
4988static bfd_boolean
4989process_movw_reloc_info (void)
4990{
4991 int is32;
4992 unsigned shift;
4993
4994 is32 = inst.base.operands[0].qualifier == AARCH64_OPND_QLF_W ? 1 : 0;
4995
4996 if (inst.base.opcode->op == OP_MOVK)
4997 switch (inst.reloc.type)
4998 {
4999 case BFD_RELOC_AARCH64_MOVW_G0_S:
5000 case BFD_RELOC_AARCH64_MOVW_G1_S:
5001 case BFD_RELOC_AARCH64_MOVW_G2_S:
1aa66fb1 5002 case BFD_RELOC_AARCH64_TLSGD_MOVW_G1:
a06ea964 5003 case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G0:
a06ea964 5004 case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G1:
a06ea964
NC
5005 case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G2:
5006 set_syntax_error
5007 (_("the specified relocation type is not allowed for MOVK"));
5008 return FALSE;
5009 default:
5010 break;
5011 }
5012
5013 switch (inst.reloc.type)
5014 {
5015 case BFD_RELOC_AARCH64_MOVW_G0:
a06ea964 5016 case BFD_RELOC_AARCH64_MOVW_G0_NC:
f09c556a 5017 case BFD_RELOC_AARCH64_MOVW_G0_S:
ca632371 5018 case BFD_RELOC_AARCH64_MOVW_GOTOFF_G0_NC:
43a357f9 5019 case BFD_RELOC_AARCH64_TLSDESC_OFF_G0_NC:
3e8286c0 5020 case BFD_RELOC_AARCH64_TLSGD_MOVW_G0_NC:
3b957e5b 5021 case BFD_RELOC_AARCH64_TLSIE_MOVW_GOTTPREL_G0_NC:
49df5539
JW
5022 case BFD_RELOC_AARCH64_TLSLD_MOVW_DTPREL_G0:
5023 case BFD_RELOC_AARCH64_TLSLD_MOVW_DTPREL_G0_NC:
a06ea964
NC
5024 case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G0:
5025 case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G0_NC:
5026 shift = 0;
5027 break;
5028 case BFD_RELOC_AARCH64_MOVW_G1:
a06ea964 5029 case BFD_RELOC_AARCH64_MOVW_G1_NC:
f09c556a 5030 case BFD_RELOC_AARCH64_MOVW_G1_S:
654248e7 5031 case BFD_RELOC_AARCH64_MOVW_GOTOFF_G1:
43a357f9 5032 case BFD_RELOC_AARCH64_TLSDESC_OFF_G1:
1aa66fb1 5033 case BFD_RELOC_AARCH64_TLSGD_MOVW_G1:
3b957e5b 5034 case BFD_RELOC_AARCH64_TLSIE_MOVW_GOTTPREL_G1:
49df5539
JW
5035 case BFD_RELOC_AARCH64_TLSLD_MOVW_DTPREL_G1:
5036 case BFD_RELOC_AARCH64_TLSLD_MOVW_DTPREL_G1_NC:
a06ea964
NC
5037 case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G1:
5038 case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G1_NC:
5039 shift = 16;
5040 break;
5041 case BFD_RELOC_AARCH64_MOVW_G2:
a06ea964 5042 case BFD_RELOC_AARCH64_MOVW_G2_NC:
f09c556a 5043 case BFD_RELOC_AARCH64_MOVW_G2_S:
49df5539 5044 case BFD_RELOC_AARCH64_TLSLD_MOVW_DTPREL_G2:
a06ea964
NC
5045 case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G2:
5046 if (is32)
5047 {
5048 set_fatal_syntax_error
5049 (_("the specified relocation type is not allowed for 32-bit "
5050 "register"));
5051 return FALSE;
5052 }
5053 shift = 32;
5054 break;
5055 case BFD_RELOC_AARCH64_MOVW_G3:
5056 if (is32)
5057 {
5058 set_fatal_syntax_error
5059 (_("the specified relocation type is not allowed for 32-bit "
5060 "register"));
5061 return FALSE;
5062 }
5063 shift = 48;
5064 break;
5065 default:
5066 /* More cases should be added when more MOVW-related relocation types
5067 are supported in GAS. */
5068 gas_assert (aarch64_gas_internal_fixup_p ());
5069 /* The shift amount should have already been set by the parser. */
5070 return TRUE;
5071 }
5072 inst.base.operands[1].shifter.amount = shift;
5073 return TRUE;
5074}
5075
5076/* A primitive log caculator. */
5077
5078static inline unsigned int
5079get_logsz (unsigned int size)
5080{
5081 const unsigned char ls[16] =
5082 {0, 1, -1, 2, -1, -1, -1, 3, -1, -1, -1, -1, -1, -1, -1, 4};
5083 if (size > 16)
5084 {
5085 gas_assert (0);
5086 return -1;
5087 }
5088 gas_assert (ls[size - 1] != (unsigned char)-1);
5089 return ls[size - 1];
5090}
5091
5092/* Determine and return the real reloc type code for an instruction
5093 with the pseudo reloc type code BFD_RELOC_AARCH64_LDST_LO12. */
5094
5095static inline bfd_reloc_code_real_type
5096ldst_lo12_determine_real_reloc_type (void)
5097{
4c562523 5098 unsigned logsz;
a06ea964
NC
5099 enum aarch64_opnd_qualifier opd0_qlf = inst.base.operands[0].qualifier;
5100 enum aarch64_opnd_qualifier opd1_qlf = inst.base.operands[1].qualifier;
5101
4c562523
JW
5102 const bfd_reloc_code_real_type reloc_ldst_lo12[3][5] = {
5103 {
5104 BFD_RELOC_AARCH64_LDST8_LO12,
5105 BFD_RELOC_AARCH64_LDST16_LO12,
5106 BFD_RELOC_AARCH64_LDST32_LO12,
5107 BFD_RELOC_AARCH64_LDST64_LO12,
a06ea964 5108 BFD_RELOC_AARCH64_LDST128_LO12
4c562523
JW
5109 },
5110 {
5111 BFD_RELOC_AARCH64_TLSLD_LDST8_DTPREL_LO12,
5112 BFD_RELOC_AARCH64_TLSLD_LDST16_DTPREL_LO12,
5113 BFD_RELOC_AARCH64_TLSLD_LDST32_DTPREL_LO12,
5114 BFD_RELOC_AARCH64_TLSLD_LDST64_DTPREL_LO12,
5115 BFD_RELOC_AARCH64_NONE
5116 },
5117 {
5118 BFD_RELOC_AARCH64_TLSLD_LDST8_DTPREL_LO12_NC,
5119 BFD_RELOC_AARCH64_TLSLD_LDST16_DTPREL_LO12_NC,
5120 BFD_RELOC_AARCH64_TLSLD_LDST32_DTPREL_LO12_NC,
5121 BFD_RELOC_AARCH64_TLSLD_LDST64_DTPREL_LO12_NC,
5122 BFD_RELOC_AARCH64_NONE
5123 }
a06ea964
NC
5124 };
5125
4c562523
JW
5126 gas_assert (inst.reloc.type == BFD_RELOC_AARCH64_LDST_LO12
5127 || inst.reloc.type == BFD_RELOC_AARCH64_TLSLD_LDST_DTPREL_LO12
5128 || (inst.reloc.type
5129 == BFD_RELOC_AARCH64_TLSLD_LDST_DTPREL_LO12_NC));
a06ea964
NC
5130 gas_assert (inst.base.opcode->operands[1] == AARCH64_OPND_ADDR_UIMM12);
5131
5132 if (opd1_qlf == AARCH64_OPND_QLF_NIL)
5133 opd1_qlf =
5134 aarch64_get_expected_qualifier (inst.base.opcode->qualifiers_list,
5135 1, opd0_qlf, 0);
5136 gas_assert (opd1_qlf != AARCH64_OPND_QLF_NIL);
5137
5138 logsz = get_logsz (aarch64_get_qualifier_esize (opd1_qlf));
4c562523
JW
5139 if (inst.reloc.type == BFD_RELOC_AARCH64_TLSLD_LDST_DTPREL_LO12
5140 || inst.reloc.type == BFD_RELOC_AARCH64_TLSLD_LDST_DTPREL_LO12_NC)
5141 gas_assert (logsz <= 3);
5142 else
5143 gas_assert (logsz <= 4);
a06ea964 5144
4c562523
JW
5145 /* In reloc.c, these pseudo relocation types should be defined in similar
5146 order as above reloc_ldst_lo12 array. Because the array index calcuation
5147 below relies on this. */
5148 return reloc_ldst_lo12[inst.reloc.type - BFD_RELOC_AARCH64_LDST_LO12][logsz];
a06ea964
NC
5149}
5150
5151/* Check whether a register list REGINFO is valid. The registers must be
5152 numbered in increasing order (modulo 32), in increments of one or two.
5153
5154 If ACCEPT_ALTERNATE is non-zero, the register numbers should be in
5155 increments of two.
5156
5157 Return FALSE if such a register list is invalid, otherwise return TRUE. */
5158
5159static bfd_boolean
5160reg_list_valid_p (uint32_t reginfo, int accept_alternate)
5161{
5162 uint32_t i, nb_regs, prev_regno, incr;
5163
5164 nb_regs = 1 + (reginfo & 0x3);
5165 reginfo >>= 2;
5166 prev_regno = reginfo & 0x1f;
5167 incr = accept_alternate ? 2 : 1;
5168
5169 for (i = 1; i < nb_regs; ++i)
5170 {
5171 uint32_t curr_regno;
5172 reginfo >>= 5;
5173 curr_regno = reginfo & 0x1f;
5174 if (curr_regno != ((prev_regno + incr) & 0x1f))
5175 return FALSE;
5176 prev_regno = curr_regno;
5177 }
5178
5179 return TRUE;
5180}
5181
5182/* Generic instruction operand parser. This does no encoding and no
5183 semantic validation; it merely squirrels values away in the inst
5184 structure. Returns TRUE or FALSE depending on whether the
5185 specified grammar matched. */
5186
5187static bfd_boolean
5188parse_operands (char *str, const aarch64_opcode *opcode)
5189{
5190 int i;
5191 char *backtrack_pos = 0;
5192 const enum aarch64_opnd *operands = opcode->operands;
1799c0d0 5193 aarch64_reg_type imm_reg_type;
a06ea964
NC
5194
5195 clear_error ();
5196 skip_whitespace (str);
5197
1799c0d0
RS
5198 imm_reg_type = REG_TYPE_R_Z_BHSDQ_V;
5199
a06ea964
NC
5200 for (i = 0; operands[i] != AARCH64_OPND_NIL; i++)
5201 {
5202 int64_t val;
e1b988bb 5203 const reg_entry *reg;
a06ea964
NC
5204 int comma_skipped_p = 0;
5205 aarch64_reg_type rtype;
8f9a77af 5206 struct vector_type_el vectype;
4df068de 5207 aarch64_opnd_qualifier_t qualifier, base_qualifier, offset_qualifier;
a06ea964 5208 aarch64_opnd_info *info = &inst.base.operands[i];
f11ad6bc 5209 aarch64_reg_type reg_type;
a06ea964
NC
5210
5211 DEBUG_TRACE ("parse operand %d", i);
5212
5213 /* Assign the operand code. */
5214 info->type = operands[i];
5215
5216 if (optional_operand_p (opcode, i))
5217 {
5218 /* Remember where we are in case we need to backtrack. */
5219 gas_assert (!backtrack_pos);
5220 backtrack_pos = str;
5221 }
5222
5223 /* Expect comma between operands; the backtrack mechanizm will take
5224 care of cases of omitted optional operand. */
5225 if (i > 0 && ! skip_past_char (&str, ','))
5226 {
5227 set_syntax_error (_("comma expected between operands"));
5228 goto failure;
5229 }
5230 else
5231 comma_skipped_p = 1;
5232
5233 switch (operands[i])
5234 {
5235 case AARCH64_OPND_Rd:
5236 case AARCH64_OPND_Rn:
5237 case AARCH64_OPND_Rm:
5238 case AARCH64_OPND_Rt:
5239 case AARCH64_OPND_Rt2:
5240 case AARCH64_OPND_Rs:
5241 case AARCH64_OPND_Ra:
5242 case AARCH64_OPND_Rt_SYS:
ee804238 5243 case AARCH64_OPND_PAIRREG:
e1b988bb 5244 po_int_reg_or_fail (REG_TYPE_R_Z);
a06ea964
NC
5245 break;
5246
5247 case AARCH64_OPND_Rd_SP:
5248 case AARCH64_OPND_Rn_SP:
e1b988bb 5249 po_int_reg_or_fail (REG_TYPE_R_SP);
a06ea964
NC
5250 break;
5251
5252 case AARCH64_OPND_Rm_EXT:
5253 case AARCH64_OPND_Rm_SFT:
5254 po_misc_or_fail (parse_shifter_operand
5255 (&str, info, (operands[i] == AARCH64_OPND_Rm_EXT
5256 ? SHIFTED_ARITH_IMM
5257 : SHIFTED_LOGIC_IMM)));
5258 if (!info->shifter.operator_present)
5259 {
5260 /* Default to LSL if not present. Libopcodes prefers shifter
5261 kind to be explicit. */
5262 gas_assert (info->shifter.kind == AARCH64_MOD_NONE);
5263 info->shifter.kind = AARCH64_MOD_LSL;
5264 /* For Rm_EXT, libopcodes will carry out further check on whether
5265 or not stack pointer is used in the instruction (Recall that
5266 "the extend operator is not optional unless at least one of
5267 "Rd" or "Rn" is '11111' (i.e. WSP)"). */
5268 }
5269 break;
5270
5271 case AARCH64_OPND_Fd:
5272 case AARCH64_OPND_Fn:
5273 case AARCH64_OPND_Fm:
5274 case AARCH64_OPND_Fa:
5275 case AARCH64_OPND_Ft:
5276 case AARCH64_OPND_Ft2:
5277 case AARCH64_OPND_Sd:
5278 case AARCH64_OPND_Sn:
5279 case AARCH64_OPND_Sm:
5280 val = aarch64_reg_parse (&str, REG_TYPE_BHSDQ, &rtype, NULL);
5281 if (val == PARSE_FAIL)
5282 {
5283 first_error (_(get_reg_expected_msg (REG_TYPE_BHSDQ)));
5284 goto failure;
5285 }
5286 gas_assert (rtype >= REG_TYPE_FP_B && rtype <= REG_TYPE_FP_Q);
5287
5288 info->reg.regno = val;
5289 info->qualifier = AARCH64_OPND_QLF_S_B + (rtype - REG_TYPE_FP_B);
5290 break;
5291
f11ad6bc
RS
5292 case AARCH64_OPND_SVE_Pd:
5293 case AARCH64_OPND_SVE_Pg3:
5294 case AARCH64_OPND_SVE_Pg4_5:
5295 case AARCH64_OPND_SVE_Pg4_10:
5296 case AARCH64_OPND_SVE_Pg4_16:
5297 case AARCH64_OPND_SVE_Pm:
5298 case AARCH64_OPND_SVE_Pn:
5299 case AARCH64_OPND_SVE_Pt:
5300 reg_type = REG_TYPE_PN;
5301 goto vector_reg;
5302
5303 case AARCH64_OPND_SVE_Za_5:
5304 case AARCH64_OPND_SVE_Za_16:
5305 case AARCH64_OPND_SVE_Zd:
5306 case AARCH64_OPND_SVE_Zm_5:
5307 case AARCH64_OPND_SVE_Zm_16:
5308 case AARCH64_OPND_SVE_Zn:
5309 case AARCH64_OPND_SVE_Zt:
5310 reg_type = REG_TYPE_ZN;
5311 goto vector_reg;
5312
a06ea964
NC
5313 case AARCH64_OPND_Vd:
5314 case AARCH64_OPND_Vn:
5315 case AARCH64_OPND_Vm:
f11ad6bc
RS
5316 reg_type = REG_TYPE_VN;
5317 vector_reg:
5318 val = aarch64_reg_parse (&str, reg_type, NULL, &vectype);
a06ea964
NC
5319 if (val == PARSE_FAIL)
5320 {
f11ad6bc 5321 first_error (_(get_reg_expected_msg (reg_type)));
a06ea964
NC
5322 goto failure;
5323 }
5324 if (vectype.defined & NTA_HASINDEX)
5325 goto failure;
5326
5327 info->reg.regno = val;
f11ad6bc
RS
5328 if ((reg_type == REG_TYPE_PN || reg_type == REG_TYPE_ZN)
5329 && vectype.type == NT_invtype)
5330 /* Unqualified Pn and Zn registers are allowed in certain
5331 contexts. Rely on F_STRICT qualifier checking to catch
5332 invalid uses. */
5333 info->qualifier = AARCH64_OPND_QLF_NIL;
5334 else
5335 {
5336 info->qualifier = vectype_to_qualifier (&vectype);
5337 if (info->qualifier == AARCH64_OPND_QLF_NIL)
5338 goto failure;
5339 }
a06ea964
NC
5340 break;
5341
5342 case AARCH64_OPND_VdD1:
5343 case AARCH64_OPND_VnD1:
5344 val = aarch64_reg_parse (&str, REG_TYPE_VN, NULL, &vectype);
5345 if (val == PARSE_FAIL)
5346 {
5347 set_first_syntax_error (_(get_reg_expected_msg (REG_TYPE_VN)));
5348 goto failure;
5349 }
5350 if (vectype.type != NT_d || vectype.index != 1)
5351 {
5352 set_fatal_syntax_error
5353 (_("the top half of a 128-bit FP/SIMD register is expected"));
5354 goto failure;
5355 }
5356 info->reg.regno = val;
5357 /* N.B: VdD1 and VnD1 are treated as an fp or advsimd scalar register
5358 here; it is correct for the purpose of encoding/decoding since
5359 only the register number is explicitly encoded in the related
5360 instructions, although this appears a bit hacky. */
5361 info->qualifier = AARCH64_OPND_QLF_S_D;
5362 break;
5363
f11ad6bc
RS
5364 case AARCH64_OPND_SVE_Zn_INDEX:
5365 reg_type = REG_TYPE_ZN;
5366 goto vector_reg_index;
5367
a06ea964
NC
5368 case AARCH64_OPND_Ed:
5369 case AARCH64_OPND_En:
5370 case AARCH64_OPND_Em:
f11ad6bc
RS
5371 reg_type = REG_TYPE_VN;
5372 vector_reg_index:
5373 val = aarch64_reg_parse (&str, reg_type, NULL, &vectype);
a06ea964
NC
5374 if (val == PARSE_FAIL)
5375 {
f11ad6bc 5376 first_error (_(get_reg_expected_msg (reg_type)));
a06ea964
NC
5377 goto failure;
5378 }
5379 if (vectype.type == NT_invtype || !(vectype.defined & NTA_HASINDEX))
5380 goto failure;
5381
5382 info->reglane.regno = val;
5383 info->reglane.index = vectype.index;
5384 info->qualifier = vectype_to_qualifier (&vectype);
5385 if (info->qualifier == AARCH64_OPND_QLF_NIL)
5386 goto failure;
5387 break;
5388
f11ad6bc
RS
5389 case AARCH64_OPND_SVE_ZnxN:
5390 case AARCH64_OPND_SVE_ZtxN:
5391 reg_type = REG_TYPE_ZN;
5392 goto vector_reg_list;
5393
a06ea964
NC
5394 case AARCH64_OPND_LVn:
5395 case AARCH64_OPND_LVt:
5396 case AARCH64_OPND_LVt_AL:
5397 case AARCH64_OPND_LEt:
f11ad6bc
RS
5398 reg_type = REG_TYPE_VN;
5399 vector_reg_list:
5400 if (reg_type == REG_TYPE_ZN
5401 && get_opcode_dependent_value (opcode) == 1
5402 && *str != '{')
a06ea964 5403 {
f11ad6bc
RS
5404 val = aarch64_reg_parse (&str, reg_type, NULL, &vectype);
5405 if (val == PARSE_FAIL)
5406 {
5407 first_error (_(get_reg_expected_msg (reg_type)));
5408 goto failure;
5409 }
5410 info->reglist.first_regno = val;
5411 info->reglist.num_regs = 1;
5412 }
5413 else
5414 {
5415 val = parse_vector_reg_list (&str, reg_type, &vectype);
5416 if (val == PARSE_FAIL)
5417 goto failure;
5418 if (! reg_list_valid_p (val, /* accept_alternate */ 0))
5419 {
5420 set_fatal_syntax_error (_("invalid register list"));
5421 goto failure;
5422 }
5423 info->reglist.first_regno = (val >> 2) & 0x1f;
5424 info->reglist.num_regs = (val & 0x3) + 1;
a06ea964 5425 }
a06ea964
NC
5426 if (operands[i] == AARCH64_OPND_LEt)
5427 {
5428 if (!(vectype.defined & NTA_HASINDEX))
5429 goto failure;
5430 info->reglist.has_index = 1;
5431 info->reglist.index = vectype.index;
5432 }
f11ad6bc
RS
5433 else
5434 {
5435 if (vectype.defined & NTA_HASINDEX)
5436 goto failure;
5437 if (!(vectype.defined & NTA_HASTYPE))
5438 {
5439 if (reg_type == REG_TYPE_ZN)
5440 set_fatal_syntax_error (_("missing type suffix"));
5441 goto failure;
5442 }
5443 }
a06ea964
NC
5444 info->qualifier = vectype_to_qualifier (&vectype);
5445 if (info->qualifier == AARCH64_OPND_QLF_NIL)
5446 goto failure;
5447 break;
5448
5449 case AARCH64_OPND_Cn:
5450 case AARCH64_OPND_Cm:
5451 po_reg_or_fail (REG_TYPE_CN);
5452 if (val > 15)
5453 {
5454 set_fatal_syntax_error (_(get_reg_expected_msg (REG_TYPE_CN)));
5455 goto failure;
5456 }
5457 inst.base.operands[i].reg.regno = val;
5458 break;
5459
5460 case AARCH64_OPND_SHLL_IMM:
5461 case AARCH64_OPND_IMM_VLSR:
5462 po_imm_or_fail (1, 64);
5463 info->imm.value = val;
5464 break;
5465
5466 case AARCH64_OPND_CCMP_IMM:
5467 case AARCH64_OPND_FBITS:
5468 case AARCH64_OPND_UIMM4:
5469 case AARCH64_OPND_UIMM3_OP1:
5470 case AARCH64_OPND_UIMM3_OP2:
5471 case AARCH64_OPND_IMM_VLSL:
5472 case AARCH64_OPND_IMM:
5473 case AARCH64_OPND_WIDTH:
5474 po_imm_nc_or_fail ();
5475 info->imm.value = val;
5476 break;
5477
245d2e3f
RS
5478 case AARCH64_OPND_SVE_PATTERN:
5479 po_enum_or_fail (aarch64_sve_pattern_array);
5480 info->imm.value = val;
5481 break;
5482
2442d846
RS
5483 case AARCH64_OPND_SVE_PATTERN_SCALED:
5484 po_enum_or_fail (aarch64_sve_pattern_array);
5485 info->imm.value = val;
5486 if (skip_past_comma (&str)
5487 && !parse_shift (&str, info, SHIFTED_MUL))
5488 goto failure;
5489 if (!info->shifter.operator_present)
5490 {
5491 gas_assert (info->shifter.kind == AARCH64_MOD_NONE);
5492 info->shifter.kind = AARCH64_MOD_MUL;
5493 info->shifter.amount = 1;
5494 }
5495 break;
5496
245d2e3f
RS
5497 case AARCH64_OPND_SVE_PRFOP:
5498 po_enum_or_fail (aarch64_sve_prfop_array);
5499 info->imm.value = val;
5500 break;
5501
a06ea964
NC
5502 case AARCH64_OPND_UIMM7:
5503 po_imm_or_fail (0, 127);
5504 info->imm.value = val;
5505 break;
5506
5507 case AARCH64_OPND_IDX:
5508 case AARCH64_OPND_BIT_NUM:
5509 case AARCH64_OPND_IMMR:
5510 case AARCH64_OPND_IMMS:
5511 po_imm_or_fail (0, 63);
5512 info->imm.value = val;
5513 break;
5514
5515 case AARCH64_OPND_IMM0:
5516 po_imm_nc_or_fail ();
5517 if (val != 0)
5518 {
5519 set_fatal_syntax_error (_("immediate zero expected"));
5520 goto failure;
5521 }
5522 info->imm.value = 0;
5523 break;
5524
5525 case AARCH64_OPND_FPIMM0:
5526 {
5527 int qfloat;
5528 bfd_boolean res1 = FALSE, res2 = FALSE;
5529 /* N.B. -0.0 will be rejected; although -0.0 shouldn't be rejected,
5530 it is probably not worth the effort to support it. */
1799c0d0
RS
5531 if (!(res1 = parse_aarch64_imm_float (&str, &qfloat, FALSE,
5532 imm_reg_type))
6a9deabe
RS
5533 && (error_p ()
5534 || !(res2 = parse_constant_immediate (&str, &val,
5535 imm_reg_type))))
a06ea964
NC
5536 goto failure;
5537 if ((res1 && qfloat == 0) || (res2 && val == 0))
5538 {
5539 info->imm.value = 0;
5540 info->imm.is_fp = 1;
5541 break;
5542 }
5543 set_fatal_syntax_error (_("immediate zero expected"));
5544 goto failure;
5545 }
5546
5547 case AARCH64_OPND_IMM_MOV:
5548 {
5549 char *saved = str;
8db49cc2
WN
5550 if (reg_name_p (str, REG_TYPE_R_Z_SP) ||
5551 reg_name_p (str, REG_TYPE_VN))
a06ea964
NC
5552 goto failure;
5553 str = saved;
5554 po_misc_or_fail (my_get_expression (&inst.reloc.exp, &str,
5555 GE_OPT_PREFIX, 1));
5556 /* The MOV immediate alias will be fixed up by fix_mov_imm_insn
5557 later. fix_mov_imm_insn will try to determine a machine
5558 instruction (MOVZ, MOVN or ORR) for it and will issue an error
5559 message if the immediate cannot be moved by a single
5560 instruction. */
5561 aarch64_set_gas_internal_fixup (&inst.reloc, info, 1);
5562 inst.base.operands[i].skip = 1;
5563 }
5564 break;
5565
5566 case AARCH64_OPND_SIMD_IMM:
5567 case AARCH64_OPND_SIMD_IMM_SFT:
1799c0d0 5568 if (! parse_big_immediate (&str, &val, imm_reg_type))
a06ea964
NC
5569 goto failure;
5570 assign_imm_if_const_or_fixup_later (&inst.reloc, info,
5571 /* addr_off_p */ 0,
5572 /* need_libopcodes_p */ 1,
5573 /* skip_p */ 1);
5574 /* Parse shift.
5575 N.B. although AARCH64_OPND_SIMD_IMM doesn't permit any
5576 shift, we don't check it here; we leave the checking to
5577 the libopcodes (operand_general_constraint_met_p). By
5578 doing this, we achieve better diagnostics. */
5579 if (skip_past_comma (&str)
5580 && ! parse_shift (&str, info, SHIFTED_LSL_MSL))
5581 goto failure;
5582 if (!info->shifter.operator_present
5583 && info->type == AARCH64_OPND_SIMD_IMM_SFT)
5584 {
5585 /* Default to LSL if not present. Libopcodes prefers shifter
5586 kind to be explicit. */
5587 gas_assert (info->shifter.kind == AARCH64_MOD_NONE);
5588 info->shifter.kind = AARCH64_MOD_LSL;
5589 }
5590 break;
5591
5592 case AARCH64_OPND_FPIMM:
5593 case AARCH64_OPND_SIMD_FPIMM:
5594 {
5595 int qfloat;
62b0d0d5
YZ
5596 bfd_boolean dp_p
5597 = (aarch64_get_qualifier_esize (inst.base.operands[0].qualifier)
5598 == 8);
6a9deabe 5599 if (!parse_aarch64_imm_float (&str, &qfloat, dp_p, imm_reg_type)
874d7e6e 5600 || !aarch64_imm_float_p (qfloat))
a06ea964 5601 {
6a9deabe
RS
5602 if (!error_p ())
5603 set_fatal_syntax_error (_("invalid floating-point"
5604 " constant"));
a06ea964
NC
5605 goto failure;
5606 }
5607 inst.base.operands[i].imm.value = encode_imm_float_bits (qfloat);
5608 inst.base.operands[i].imm.is_fp = 1;
5609 }
5610 break;
5611
5612 case AARCH64_OPND_LIMM:
5613 po_misc_or_fail (parse_shifter_operand (&str, info,
5614 SHIFTED_LOGIC_IMM));
5615 if (info->shifter.operator_present)
5616 {
5617 set_fatal_syntax_error
5618 (_("shift not allowed for bitmask immediate"));
5619 goto failure;
5620 }
5621 assign_imm_if_const_or_fixup_later (&inst.reloc, info,
5622 /* addr_off_p */ 0,
5623 /* need_libopcodes_p */ 1,
5624 /* skip_p */ 1);
5625 break;
5626
5627 case AARCH64_OPND_AIMM:
5628 if (opcode->op == OP_ADD)
5629 /* ADD may have relocation types. */
5630 po_misc_or_fail (parse_shifter_operand_reloc (&str, info,
5631 SHIFTED_ARITH_IMM));
5632 else
5633 po_misc_or_fail (parse_shifter_operand (&str, info,
5634 SHIFTED_ARITH_IMM));
5635 switch (inst.reloc.type)
5636 {
5637 case BFD_RELOC_AARCH64_TLSLE_ADD_TPREL_HI12:
5638 info->shifter.amount = 12;
5639 break;
5640 case BFD_RELOC_UNUSED:
5641 aarch64_set_gas_internal_fixup (&inst.reloc, info, 0);
5642 if (info->shifter.kind != AARCH64_MOD_NONE)
5643 inst.reloc.flags = FIXUP_F_HAS_EXPLICIT_SHIFT;
5644 inst.reloc.pc_rel = 0;
5645 break;
5646 default:
5647 break;
5648 }
5649 info->imm.value = 0;
5650 if (!info->shifter.operator_present)
5651 {
5652 /* Default to LSL if not present. Libopcodes prefers shifter
5653 kind to be explicit. */
5654 gas_assert (info->shifter.kind == AARCH64_MOD_NONE);
5655 info->shifter.kind = AARCH64_MOD_LSL;
5656 }
5657 break;
5658
5659 case AARCH64_OPND_HALF:
5660 {
5661 /* #<imm16> or relocation. */
5662 int internal_fixup_p;
5663 po_misc_or_fail (parse_half (&str, &internal_fixup_p));
5664 if (internal_fixup_p)
5665 aarch64_set_gas_internal_fixup (&inst.reloc, info, 0);
5666 skip_whitespace (str);
5667 if (skip_past_comma (&str))
5668 {
5669 /* {, LSL #<shift>} */
5670 if (! aarch64_gas_internal_fixup_p ())
5671 {
5672 set_fatal_syntax_error (_("can't mix relocation modifier "
5673 "with explicit shift"));
5674 goto failure;
5675 }
5676 po_misc_or_fail (parse_shift (&str, info, SHIFTED_LSL));
5677 }
5678 else
5679 inst.base.operands[i].shifter.amount = 0;
5680 inst.base.operands[i].shifter.kind = AARCH64_MOD_LSL;
5681 inst.base.operands[i].imm.value = 0;
5682 if (! process_movw_reloc_info ())
5683 goto failure;
5684 }
5685 break;
5686
5687 case AARCH64_OPND_EXCEPTION:
1799c0d0
RS
5688 po_misc_or_fail (parse_immediate_expression (&str, &inst.reloc.exp,
5689 imm_reg_type));
a06ea964
NC
5690 assign_imm_if_const_or_fixup_later (&inst.reloc, info,
5691 /* addr_off_p */ 0,
5692 /* need_libopcodes_p */ 0,
5693 /* skip_p */ 1);
5694 break;
5695
5696 case AARCH64_OPND_NZCV:
5697 {
5698 const asm_nzcv *nzcv = hash_find_n (aarch64_nzcv_hsh, str, 4);
5699 if (nzcv != NULL)
5700 {
5701 str += 4;
5702 info->imm.value = nzcv->value;
5703 break;
5704 }
5705 po_imm_or_fail (0, 15);
5706 info->imm.value = val;
5707 }
5708 break;
5709
5710 case AARCH64_OPND_COND:
68a64283 5711 case AARCH64_OPND_COND1:
a06ea964
NC
5712 info->cond = hash_find_n (aarch64_cond_hsh, str, 2);
5713 str += 2;
5714 if (info->cond == NULL)
5715 {
5716 set_syntax_error (_("invalid condition"));
5717 goto failure;
5718 }
68a64283
YZ
5719 else if (operands[i] == AARCH64_OPND_COND1
5720 && (info->cond->value & 0xe) == 0xe)
5721 {
5722 /* Not allow AL or NV. */
5723 set_default_error ();
5724 goto failure;
5725 }
a06ea964
NC
5726 break;
5727
5728 case AARCH64_OPND_ADDR_ADRP:
5729 po_misc_or_fail (parse_adrp (&str));
5730 /* Clear the value as operand needs to be relocated. */
5731 info->imm.value = 0;
5732 break;
5733
5734 case AARCH64_OPND_ADDR_PCREL14:
5735 case AARCH64_OPND_ADDR_PCREL19:
5736 case AARCH64_OPND_ADDR_PCREL21:
5737 case AARCH64_OPND_ADDR_PCREL26:
73866052 5738 po_misc_or_fail (parse_address (&str, info));
a06ea964
NC
5739 if (!info->addr.pcrel)
5740 {
5741 set_syntax_error (_("invalid pc-relative address"));
5742 goto failure;
5743 }
5744 if (inst.gen_lit_pool
5745 && (opcode->iclass != loadlit || opcode->op == OP_PRFM_LIT))
5746 {
5747 /* Only permit "=value" in the literal load instructions.
5748 The literal will be generated by programmer_friendly_fixup. */
5749 set_syntax_error (_("invalid use of \"=immediate\""));
5750 goto failure;
5751 }
5752 if (inst.reloc.exp.X_op == O_symbol && find_reloc_table_entry (&str))
5753 {
5754 set_syntax_error (_("unrecognized relocation suffix"));
5755 goto failure;
5756 }
5757 if (inst.reloc.exp.X_op == O_constant && !inst.gen_lit_pool)
5758 {
5759 info->imm.value = inst.reloc.exp.X_add_number;
5760 inst.reloc.type = BFD_RELOC_UNUSED;
5761 }
5762 else
5763 {
5764 info->imm.value = 0;
f41aef5f
RE
5765 if (inst.reloc.type == BFD_RELOC_UNUSED)
5766 switch (opcode->iclass)
5767 {
5768 case compbranch:
5769 case condbranch:
5770 /* e.g. CBZ or B.COND */
5771 gas_assert (operands[i] == AARCH64_OPND_ADDR_PCREL19);
5772 inst.reloc.type = BFD_RELOC_AARCH64_BRANCH19;
5773 break;
5774 case testbranch:
5775 /* e.g. TBZ */
5776 gas_assert (operands[i] == AARCH64_OPND_ADDR_PCREL14);
5777 inst.reloc.type = BFD_RELOC_AARCH64_TSTBR14;
5778 break;
5779 case branch_imm:
5780 /* e.g. B or BL */
5781 gas_assert (operands[i] == AARCH64_OPND_ADDR_PCREL26);
5782 inst.reloc.type =
5783 (opcode->op == OP_BL) ? BFD_RELOC_AARCH64_CALL26
5784 : BFD_RELOC_AARCH64_JUMP26;
5785 break;
5786 case loadlit:
5787 gas_assert (operands[i] == AARCH64_OPND_ADDR_PCREL19);
5788 inst.reloc.type = BFD_RELOC_AARCH64_LD_LO19_PCREL;
5789 break;
5790 case pcreladdr:
5791 gas_assert (operands[i] == AARCH64_OPND_ADDR_PCREL21);
5792 inst.reloc.type = BFD_RELOC_AARCH64_ADR_LO21_PCREL;
5793 break;
5794 default:
5795 gas_assert (0);
5796 abort ();
5797 }
a06ea964
NC
5798 inst.reloc.pc_rel = 1;
5799 }
5800 break;
5801
5802 case AARCH64_OPND_ADDR_SIMPLE:
5803 case AARCH64_OPND_SIMD_ADDR_SIMPLE:
e1b988bb
RS
5804 {
5805 /* [<Xn|SP>{, #<simm>}] */
5806 char *start = str;
5807 /* First use the normal address-parsing routines, to get
5808 the usual syntax errors. */
73866052 5809 po_misc_or_fail (parse_address (&str, info));
e1b988bb
RS
5810 if (info->addr.pcrel || info->addr.offset.is_reg
5811 || !info->addr.preind || info->addr.postind
5812 || info->addr.writeback)
5813 {
5814 set_syntax_error (_("invalid addressing mode"));
5815 goto failure;
5816 }
5817
5818 /* Then retry, matching the specific syntax of these addresses. */
5819 str = start;
5820 po_char_or_fail ('[');
5821 po_reg_or_fail (REG_TYPE_R64_SP);
5822 /* Accept optional ", #0". */
5823 if (operands[i] == AARCH64_OPND_ADDR_SIMPLE
5824 && skip_past_char (&str, ','))
5825 {
5826 skip_past_char (&str, '#');
5827 if (! skip_past_char (&str, '0'))
5828 {
5829 set_fatal_syntax_error
5830 (_("the optional immediate offset can only be 0"));
5831 goto failure;
5832 }
5833 }
5834 po_char_or_fail (']');
5835 break;
5836 }
a06ea964
NC
5837
5838 case AARCH64_OPND_ADDR_REGOFF:
5839 /* [<Xn|SP>, <R><m>{, <extend> {<amount>}}] */
73866052 5840 po_misc_or_fail (parse_address (&str, info));
4df068de 5841 regoff_addr:
a06ea964
NC
5842 if (info->addr.pcrel || !info->addr.offset.is_reg
5843 || !info->addr.preind || info->addr.postind
5844 || info->addr.writeback)
5845 {
5846 set_syntax_error (_("invalid addressing mode"));
5847 goto failure;
5848 }
5849 if (!info->shifter.operator_present)
5850 {
5851 /* Default to LSL if not present. Libopcodes prefers shifter
5852 kind to be explicit. */
5853 gas_assert (info->shifter.kind == AARCH64_MOD_NONE);
5854 info->shifter.kind = AARCH64_MOD_LSL;
5855 }
5856 /* Qualifier to be deduced by libopcodes. */
5857 break;
5858
5859 case AARCH64_OPND_ADDR_SIMM7:
73866052 5860 po_misc_or_fail (parse_address (&str, info));
a06ea964
NC
5861 if (info->addr.pcrel || info->addr.offset.is_reg
5862 || (!info->addr.preind && !info->addr.postind))
5863 {
5864 set_syntax_error (_("invalid addressing mode"));
5865 goto failure;
5866 }
73866052
RS
5867 if (inst.reloc.type != BFD_RELOC_UNUSED)
5868 {
5869 set_syntax_error (_("relocation not allowed"));
5870 goto failure;
5871 }
a06ea964
NC
5872 assign_imm_if_const_or_fixup_later (&inst.reloc, info,
5873 /* addr_off_p */ 1,
5874 /* need_libopcodes_p */ 1,
5875 /* skip_p */ 0);
5876 break;
5877
5878 case AARCH64_OPND_ADDR_SIMM9:
5879 case AARCH64_OPND_ADDR_SIMM9_2:
73866052 5880 po_misc_or_fail (parse_address (&str, info));
a06ea964
NC
5881 if (info->addr.pcrel || info->addr.offset.is_reg
5882 || (!info->addr.preind && !info->addr.postind)
5883 || (operands[i] == AARCH64_OPND_ADDR_SIMM9_2
5884 && info->addr.writeback))
5885 {
5886 set_syntax_error (_("invalid addressing mode"));
5887 goto failure;
5888 }
5889 if (inst.reloc.type != BFD_RELOC_UNUSED)
5890 {
5891 set_syntax_error (_("relocation not allowed"));
5892 goto failure;
5893 }
5894 assign_imm_if_const_or_fixup_later (&inst.reloc, info,
5895 /* addr_off_p */ 1,
5896 /* need_libopcodes_p */ 1,
5897 /* skip_p */ 0);
5898 break;
5899
5900 case AARCH64_OPND_ADDR_UIMM12:
73866052 5901 po_misc_or_fail (parse_address (&str, info));
a06ea964
NC
5902 if (info->addr.pcrel || info->addr.offset.is_reg
5903 || !info->addr.preind || info->addr.writeback)
5904 {
5905 set_syntax_error (_("invalid addressing mode"));
5906 goto failure;
5907 }
5908 if (inst.reloc.type == BFD_RELOC_UNUSED)
5909 aarch64_set_gas_internal_fixup (&inst.reloc, info, 1);
4c562523
JW
5910 else if (inst.reloc.type == BFD_RELOC_AARCH64_LDST_LO12
5911 || (inst.reloc.type
5912 == BFD_RELOC_AARCH64_TLSLD_LDST_DTPREL_LO12)
5913 || (inst.reloc.type
5914 == BFD_RELOC_AARCH64_TLSLD_LDST_DTPREL_LO12_NC))
a06ea964
NC
5915 inst.reloc.type = ldst_lo12_determine_real_reloc_type ();
5916 /* Leave qualifier to be determined by libopcodes. */
5917 break;
5918
5919 case AARCH64_OPND_SIMD_ADDR_POST:
5920 /* [<Xn|SP>], <Xm|#<amount>> */
73866052 5921 po_misc_or_fail (parse_address (&str, info));
a06ea964
NC
5922 if (!info->addr.postind || !info->addr.writeback)
5923 {
5924 set_syntax_error (_("invalid addressing mode"));
5925 goto failure;
5926 }
5927 if (!info->addr.offset.is_reg)
5928 {
5929 if (inst.reloc.exp.X_op == O_constant)
5930 info->addr.offset.imm = inst.reloc.exp.X_add_number;
5931 else
5932 {
5933 set_fatal_syntax_error
5934 (_("writeback value should be an immediate constant"));
5935 goto failure;
5936 }
5937 }
5938 /* No qualifier. */
5939 break;
5940
4df068de
RS
5941 case AARCH64_OPND_SVE_ADDR_RI_U6:
5942 case AARCH64_OPND_SVE_ADDR_RI_U6x2:
5943 case AARCH64_OPND_SVE_ADDR_RI_U6x4:
5944 case AARCH64_OPND_SVE_ADDR_RI_U6x8:
5945 /* [X<n>{, #imm}]
5946 but recognizing SVE registers. */
5947 po_misc_or_fail (parse_sve_address (&str, info, &base_qualifier,
5948 &offset_qualifier));
5949 if (base_qualifier != AARCH64_OPND_QLF_X)
5950 {
5951 set_syntax_error (_("invalid addressing mode"));
5952 goto failure;
5953 }
5954 sve_regimm:
5955 if (info->addr.pcrel || info->addr.offset.is_reg
5956 || !info->addr.preind || info->addr.writeback)
5957 {
5958 set_syntax_error (_("invalid addressing mode"));
5959 goto failure;
5960 }
5961 if (inst.reloc.type != BFD_RELOC_UNUSED
5962 || inst.reloc.exp.X_op != O_constant)
5963 {
5964 /* Make sure this has priority over
5965 "invalid addressing mode". */
5966 set_fatal_syntax_error (_("constant offset required"));
5967 goto failure;
5968 }
5969 info->addr.offset.imm = inst.reloc.exp.X_add_number;
5970 break;
5971
5972 case AARCH64_OPND_SVE_ADDR_RR:
5973 case AARCH64_OPND_SVE_ADDR_RR_LSL1:
5974 case AARCH64_OPND_SVE_ADDR_RR_LSL2:
5975 case AARCH64_OPND_SVE_ADDR_RR_LSL3:
5976 case AARCH64_OPND_SVE_ADDR_RX:
5977 case AARCH64_OPND_SVE_ADDR_RX_LSL1:
5978 case AARCH64_OPND_SVE_ADDR_RX_LSL2:
5979 case AARCH64_OPND_SVE_ADDR_RX_LSL3:
5980 /* [<Xn|SP>, <R><m>{, lsl #<amount>}]
5981 but recognizing SVE registers. */
5982 po_misc_or_fail (parse_sve_address (&str, info, &base_qualifier,
5983 &offset_qualifier));
5984 if (base_qualifier != AARCH64_OPND_QLF_X
5985 || offset_qualifier != AARCH64_OPND_QLF_X)
5986 {
5987 set_syntax_error (_("invalid addressing mode"));
5988 goto failure;
5989 }
5990 goto regoff_addr;
5991
5992 case AARCH64_OPND_SVE_ADDR_RZ:
5993 case AARCH64_OPND_SVE_ADDR_RZ_LSL1:
5994 case AARCH64_OPND_SVE_ADDR_RZ_LSL2:
5995 case AARCH64_OPND_SVE_ADDR_RZ_LSL3:
5996 case AARCH64_OPND_SVE_ADDR_RZ_XTW_14:
5997 case AARCH64_OPND_SVE_ADDR_RZ_XTW_22:
5998 case AARCH64_OPND_SVE_ADDR_RZ_XTW1_14:
5999 case AARCH64_OPND_SVE_ADDR_RZ_XTW1_22:
6000 case AARCH64_OPND_SVE_ADDR_RZ_XTW2_14:
6001 case AARCH64_OPND_SVE_ADDR_RZ_XTW2_22:
6002 case AARCH64_OPND_SVE_ADDR_RZ_XTW3_14:
6003 case AARCH64_OPND_SVE_ADDR_RZ_XTW3_22:
6004 /* [<Xn|SP>, Z<m>.D{, LSL #<amount>}]
6005 [<Xn|SP>, Z<m>.<T>, <extend> {#<amount>}] */
6006 po_misc_or_fail (parse_sve_address (&str, info, &base_qualifier,
6007 &offset_qualifier));
6008 if (base_qualifier != AARCH64_OPND_QLF_X
6009 || (offset_qualifier != AARCH64_OPND_QLF_S_S
6010 && offset_qualifier != AARCH64_OPND_QLF_S_D))
6011 {
6012 set_syntax_error (_("invalid addressing mode"));
6013 goto failure;
6014 }
6015 info->qualifier = offset_qualifier;
6016 goto regoff_addr;
6017
6018 case AARCH64_OPND_SVE_ADDR_ZI_U5:
6019 case AARCH64_OPND_SVE_ADDR_ZI_U5x2:
6020 case AARCH64_OPND_SVE_ADDR_ZI_U5x4:
6021 case AARCH64_OPND_SVE_ADDR_ZI_U5x8:
6022 /* [Z<n>.<T>{, #imm}] */
6023 po_misc_or_fail (parse_sve_address (&str, info, &base_qualifier,
6024 &offset_qualifier));
6025 if (base_qualifier != AARCH64_OPND_QLF_S_S
6026 && base_qualifier != AARCH64_OPND_QLF_S_D)
6027 {
6028 set_syntax_error (_("invalid addressing mode"));
6029 goto failure;
6030 }
6031 info->qualifier = base_qualifier;
6032 goto sve_regimm;
6033
6034 case AARCH64_OPND_SVE_ADDR_ZZ_LSL:
6035 case AARCH64_OPND_SVE_ADDR_ZZ_SXTW:
6036 case AARCH64_OPND_SVE_ADDR_ZZ_UXTW:
6037 /* [Z<n>.<T>, Z<m>.<T>{, LSL #<amount>}]
6038 [Z<n>.D, Z<m>.D, <extend> {#<amount>}]
6039
6040 We don't reject:
6041
6042 [Z<n>.S, Z<m>.S, <extend> {#<amount>}]
6043
6044 here since we get better error messages by leaving it to
6045 the qualifier checking routines. */
6046 po_misc_or_fail (parse_sve_address (&str, info, &base_qualifier,
6047 &offset_qualifier));
6048 if ((base_qualifier != AARCH64_OPND_QLF_S_S
6049 && base_qualifier != AARCH64_OPND_QLF_S_D)
6050 || offset_qualifier != base_qualifier)
6051 {
6052 set_syntax_error (_("invalid addressing mode"));
6053 goto failure;
6054 }
6055 info->qualifier = base_qualifier;
6056 goto regoff_addr;
6057
a06ea964 6058 case AARCH64_OPND_SYSREG:
72ca8fad 6059 if ((val = parse_sys_reg (&str, aarch64_sys_regs_hsh, 1, 0))
a203d9b7 6060 == PARSE_FAIL)
a06ea964 6061 {
a203d9b7
YZ
6062 set_syntax_error (_("unknown or missing system register name"));
6063 goto failure;
a06ea964 6064 }
a203d9b7 6065 inst.base.operands[i].sysreg = val;
a06ea964
NC
6066 break;
6067
6068 case AARCH64_OPND_PSTATEFIELD:
72ca8fad 6069 if ((val = parse_sys_reg (&str, aarch64_pstatefield_hsh, 0, 1))
a3251895 6070 == PARSE_FAIL)
a06ea964
NC
6071 {
6072 set_syntax_error (_("unknown or missing PSTATE field name"));
6073 goto failure;
6074 }
6075 inst.base.operands[i].pstatefield = val;
6076 break;
6077
6078 case AARCH64_OPND_SYSREG_IC:
6079 inst.base.operands[i].sysins_op =
6080 parse_sys_ins_reg (&str, aarch64_sys_regs_ic_hsh);
6081 goto sys_reg_ins;
6082 case AARCH64_OPND_SYSREG_DC:
6083 inst.base.operands[i].sysins_op =
6084 parse_sys_ins_reg (&str, aarch64_sys_regs_dc_hsh);
6085 goto sys_reg_ins;
6086 case AARCH64_OPND_SYSREG_AT:
6087 inst.base.operands[i].sysins_op =
6088 parse_sys_ins_reg (&str, aarch64_sys_regs_at_hsh);
6089 goto sys_reg_ins;
6090 case AARCH64_OPND_SYSREG_TLBI:
6091 inst.base.operands[i].sysins_op =
6092 parse_sys_ins_reg (&str, aarch64_sys_regs_tlbi_hsh);
6093sys_reg_ins:
6094 if (inst.base.operands[i].sysins_op == NULL)
6095 {
6096 set_fatal_syntax_error ( _("unknown or missing operation name"));
6097 goto failure;
6098 }
6099 break;
6100
6101 case AARCH64_OPND_BARRIER:
6102 case AARCH64_OPND_BARRIER_ISB:
6103 val = parse_barrier (&str);
6104 if (val != PARSE_FAIL
6105 && operands[i] == AARCH64_OPND_BARRIER_ISB && val != 0xf)
6106 {
6107 /* ISB only accepts options name 'sy'. */
6108 set_syntax_error
6109 (_("the specified option is not accepted in ISB"));
6110 /* Turn off backtrack as this optional operand is present. */
6111 backtrack_pos = 0;
6112 goto failure;
6113 }
6114 /* This is an extension to accept a 0..15 immediate. */
6115 if (val == PARSE_FAIL)
6116 po_imm_or_fail (0, 15);
6117 info->barrier = aarch64_barrier_options + val;
6118 break;
6119
6120 case AARCH64_OPND_PRFOP:
6121 val = parse_pldop (&str);
6122 /* This is an extension to accept a 0..31 immediate. */
6123 if (val == PARSE_FAIL)
6124 po_imm_or_fail (0, 31);
6125 inst.base.operands[i].prfop = aarch64_prfops + val;
6126 break;
6127
1e6f4800
MW
6128 case AARCH64_OPND_BARRIER_PSB:
6129 val = parse_barrier_psb (&str, &(info->hint_option));
6130 if (val == PARSE_FAIL)
6131 goto failure;
6132 break;
6133
a06ea964
NC
6134 default:
6135 as_fatal (_("unhandled operand code %d"), operands[i]);
6136 }
6137
6138 /* If we get here, this operand was successfully parsed. */
6139 inst.base.operands[i].present = 1;
6140 continue;
6141
6142failure:
6143 /* The parse routine should already have set the error, but in case
6144 not, set a default one here. */
6145 if (! error_p ())
6146 set_default_error ();
6147
6148 if (! backtrack_pos)
6149 goto parse_operands_return;
6150
f4c51f60
JW
6151 {
6152 /* We reach here because this operand is marked as optional, and
6153 either no operand was supplied or the operand was supplied but it
6154 was syntactically incorrect. In the latter case we report an
6155 error. In the former case we perform a few more checks before
6156 dropping through to the code to insert the default operand. */
6157
6158 char *tmp = backtrack_pos;
6159 char endchar = END_OF_INSN;
6160
6161 if (i != (aarch64_num_of_operands (opcode) - 1))
6162 endchar = ',';
6163 skip_past_char (&tmp, ',');
6164
6165 if (*tmp != endchar)
6166 /* The user has supplied an operand in the wrong format. */
6167 goto parse_operands_return;
6168
6169 /* Make sure there is not a comma before the optional operand.
6170 For example the fifth operand of 'sys' is optional:
6171
6172 sys #0,c0,c0,#0, <--- wrong
6173 sys #0,c0,c0,#0 <--- correct. */
6174 if (comma_skipped_p && i && endchar == END_OF_INSN)
6175 {
6176 set_fatal_syntax_error
6177 (_("unexpected comma before the omitted optional operand"));
6178 goto parse_operands_return;
6179 }
6180 }
6181
a06ea964
NC
6182 /* Reaching here means we are dealing with an optional operand that is
6183 omitted from the assembly line. */
6184 gas_assert (optional_operand_p (opcode, i));
6185 info->present = 0;
6186 process_omitted_operand (operands[i], opcode, i, info);
6187
6188 /* Try again, skipping the optional operand at backtrack_pos. */
6189 str = backtrack_pos;
6190 backtrack_pos = 0;
6191
a06ea964
NC
6192 /* Clear any error record after the omitted optional operand has been
6193 successfully handled. */
6194 clear_error ();
6195 }
6196
6197 /* Check if we have parsed all the operands. */
6198 if (*str != '\0' && ! error_p ())
6199 {
6200 /* Set I to the index of the last present operand; this is
6201 for the purpose of diagnostics. */
6202 for (i -= 1; i >= 0 && !inst.base.operands[i].present; --i)
6203 ;
6204 set_fatal_syntax_error
6205 (_("unexpected characters following instruction"));
6206 }
6207
6208parse_operands_return:
6209
6210 if (error_p ())
6211 {
6212 DEBUG_TRACE ("parsing FAIL: %s - %s",
6213 operand_mismatch_kind_names[get_error_kind ()],
6214 get_error_message ());
6215 /* Record the operand error properly; this is useful when there
6216 are multiple instruction templates for a mnemonic name, so that
6217 later on, we can select the error that most closely describes
6218 the problem. */
6219 record_operand_error (opcode, i, get_error_kind (),
6220 get_error_message ());
6221 return FALSE;
6222 }
6223 else
6224 {
6225 DEBUG_TRACE ("parsing SUCCESS");
6226 return TRUE;
6227 }
6228}
6229
6230/* It does some fix-up to provide some programmer friendly feature while
6231 keeping the libopcodes happy, i.e. libopcodes only accepts
6232 the preferred architectural syntax.
6233 Return FALSE if there is any failure; otherwise return TRUE. */
6234
6235static bfd_boolean
6236programmer_friendly_fixup (aarch64_instruction *instr)
6237{
6238 aarch64_inst *base = &instr->base;
6239 const aarch64_opcode *opcode = base->opcode;
6240 enum aarch64_op op = opcode->op;
6241 aarch64_opnd_info *operands = base->operands;
6242
6243 DEBUG_TRACE ("enter");
6244
6245 switch (opcode->iclass)
6246 {
6247 case testbranch:
6248 /* TBNZ Xn|Wn, #uimm6, label
6249 Test and Branch Not Zero: conditionally jumps to label if bit number
6250 uimm6 in register Xn is not zero. The bit number implies the width of
6251 the register, which may be written and should be disassembled as Wn if
6252 uimm is less than 32. */
6253 if (operands[0].qualifier == AARCH64_OPND_QLF_W)
6254 {
6255 if (operands[1].imm.value >= 32)
6256 {
6257 record_operand_out_of_range_error (opcode, 1, _("immediate value"),
6258 0, 31);
6259 return FALSE;
6260 }
6261 operands[0].qualifier = AARCH64_OPND_QLF_X;
6262 }
6263 break;
6264 case loadlit:
6265 /* LDR Wt, label | =value
6266 As a convenience assemblers will typically permit the notation
6267 "=value" in conjunction with the pc-relative literal load instructions
6268 to automatically place an immediate value or symbolic address in a
6269 nearby literal pool and generate a hidden label which references it.
6270 ISREG has been set to 0 in the case of =value. */
6271 if (instr->gen_lit_pool
6272 && (op == OP_LDR_LIT || op == OP_LDRV_LIT || op == OP_LDRSW_LIT))
6273 {
6274 int size = aarch64_get_qualifier_esize (operands[0].qualifier);
6275 if (op == OP_LDRSW_LIT)
6276 size = 4;
6277 if (instr->reloc.exp.X_op != O_constant
67a32447 6278 && instr->reloc.exp.X_op != O_big
a06ea964
NC
6279 && instr->reloc.exp.X_op != O_symbol)
6280 {
6281 record_operand_error (opcode, 1,
6282 AARCH64_OPDE_FATAL_SYNTAX_ERROR,
6283 _("constant expression expected"));
6284 return FALSE;
6285 }
6286 if (! add_to_lit_pool (&instr->reloc.exp, size))
6287 {
6288 record_operand_error (opcode, 1,
6289 AARCH64_OPDE_OTHER_ERROR,
6290 _("literal pool insertion failed"));
6291 return FALSE;
6292 }
6293 }
6294 break;
a06ea964
NC
6295 case log_shift:
6296 case bitfield:
6297 /* UXT[BHW] Wd, Wn
6298 Unsigned Extend Byte|Halfword|Word: UXT[BH] is architectural alias
6299 for UBFM Wd,Wn,#0,#7|15, while UXTW is pseudo instruction which is
6300 encoded using ORR Wd, WZR, Wn (MOV Wd,Wn).
6301 A programmer-friendly assembler should accept a destination Xd in
6302 place of Wd, however that is not the preferred form for disassembly.
6303 */
6304 if ((op == OP_UXTB || op == OP_UXTH || op == OP_UXTW)
6305 && operands[1].qualifier == AARCH64_OPND_QLF_W
6306 && operands[0].qualifier == AARCH64_OPND_QLF_X)
6307 operands[0].qualifier = AARCH64_OPND_QLF_W;
6308 break;
6309
6310 case addsub_ext:
6311 {
6312 /* In the 64-bit form, the final register operand is written as Wm
6313 for all but the (possibly omitted) UXTX/LSL and SXTX
6314 operators.
6315 As a programmer-friendly assembler, we accept e.g.
6316 ADDS <Xd>, <Xn|SP>, <Xm>{, UXTB {#<amount>}} and change it to
6317 ADDS <Xd>, <Xn|SP>, <Wm>{, UXTB {#<amount>}}. */
6318 int idx = aarch64_operand_index (opcode->operands,
6319 AARCH64_OPND_Rm_EXT);
6320 gas_assert (idx == 1 || idx == 2);
6321 if (operands[0].qualifier == AARCH64_OPND_QLF_X
6322 && operands[idx].qualifier == AARCH64_OPND_QLF_X
6323 && operands[idx].shifter.kind != AARCH64_MOD_LSL
6324 && operands[idx].shifter.kind != AARCH64_MOD_UXTX
6325 && operands[idx].shifter.kind != AARCH64_MOD_SXTX)
6326 operands[idx].qualifier = AARCH64_OPND_QLF_W;
6327 }
6328 break;
6329
6330 default:
6331 break;
6332 }
6333
6334 DEBUG_TRACE ("exit with SUCCESS");
6335 return TRUE;
6336}
6337
5c47e525 6338/* Check for loads and stores that will cause unpredictable behavior. */
54a28c4c
JW
6339
6340static void
6341warn_unpredictable_ldst (aarch64_instruction *instr, char *str)
6342{
6343 aarch64_inst *base = &instr->base;
6344 const aarch64_opcode *opcode = base->opcode;
6345 const aarch64_opnd_info *opnds = base->operands;
6346 switch (opcode->iclass)
6347 {
6348 case ldst_pos:
6349 case ldst_imm9:
6350 case ldst_unscaled:
6351 case ldst_unpriv:
5c47e525
RE
6352 /* Loading/storing the base register is unpredictable if writeback. */
6353 if ((aarch64_get_operand_class (opnds[0].type)
6354 == AARCH64_OPND_CLASS_INT_REG)
6355 && opnds[0].reg.regno == opnds[1].addr.base_regno
4bf8c6e8 6356 && opnds[1].addr.base_regno != REG_SP
54a28c4c 6357 && opnds[1].addr.writeback)
5c47e525 6358 as_warn (_("unpredictable transfer with writeback -- `%s'"), str);
54a28c4c
JW
6359 break;
6360 case ldstpair_off:
6361 case ldstnapair_offs:
6362 case ldstpair_indexed:
5c47e525
RE
6363 /* Loading/storing the base register is unpredictable if writeback. */
6364 if ((aarch64_get_operand_class (opnds[0].type)
6365 == AARCH64_OPND_CLASS_INT_REG)
6366 && (opnds[0].reg.regno == opnds[2].addr.base_regno
6367 || opnds[1].reg.regno == opnds[2].addr.base_regno)
4bf8c6e8 6368 && opnds[2].addr.base_regno != REG_SP
54a28c4c 6369 && opnds[2].addr.writeback)
5c47e525
RE
6370 as_warn (_("unpredictable transfer with writeback -- `%s'"), str);
6371 /* Load operations must load different registers. */
54a28c4c
JW
6372 if ((opcode->opcode & (1 << 22))
6373 && opnds[0].reg.regno == opnds[1].reg.regno)
6374 as_warn (_("unpredictable load of register pair -- `%s'"), str);
6375 break;
6376 default:
6377 break;
6378 }
6379}
6380
a06ea964
NC
6381/* A wrapper function to interface with libopcodes on encoding and
6382 record the error message if there is any.
6383
6384 Return TRUE on success; otherwise return FALSE. */
6385
6386static bfd_boolean
6387do_encode (const aarch64_opcode *opcode, aarch64_inst *instr,
6388 aarch64_insn *code)
6389{
6390 aarch64_operand_error error_info;
6391 error_info.kind = AARCH64_OPDE_NIL;
6392 if (aarch64_opcode_encode (opcode, instr, code, NULL, &error_info))
6393 return TRUE;
6394 else
6395 {
6396 gas_assert (error_info.kind != AARCH64_OPDE_NIL);
6397 record_operand_error_info (opcode, &error_info);
6398 return FALSE;
6399 }
6400}
6401
6402#ifdef DEBUG_AARCH64
6403static inline void
6404dump_opcode_operands (const aarch64_opcode *opcode)
6405{
6406 int i = 0;
6407 while (opcode->operands[i] != AARCH64_OPND_NIL)
6408 {
6409 aarch64_verbose ("\t\t opnd%d: %s", i,
6410 aarch64_get_operand_name (opcode->operands[i])[0] != '\0'
6411 ? aarch64_get_operand_name (opcode->operands[i])
6412 : aarch64_get_operand_desc (opcode->operands[i]));
6413 ++i;
6414 }
6415}
6416#endif /* DEBUG_AARCH64 */
6417
6418/* This is the guts of the machine-dependent assembler. STR points to a
6419 machine dependent instruction. This function is supposed to emit
6420 the frags/bytes it assembles to. */
6421
6422void
6423md_assemble (char *str)
6424{
6425 char *p = str;
6426 templates *template;
6427 aarch64_opcode *opcode;
6428 aarch64_inst *inst_base;
6429 unsigned saved_cond;
6430
6431 /* Align the previous label if needed. */
6432 if (last_label_seen != NULL)
6433 {
6434 symbol_set_frag (last_label_seen, frag_now);
6435 S_SET_VALUE (last_label_seen, (valueT) frag_now_fix ());
6436 S_SET_SEGMENT (last_label_seen, now_seg);
6437 }
6438
6439 inst.reloc.type = BFD_RELOC_UNUSED;
6440
6441 DEBUG_TRACE ("\n\n");
6442 DEBUG_TRACE ("==============================");
6443 DEBUG_TRACE ("Enter md_assemble with %s", str);
6444
6445 template = opcode_lookup (&p);
6446 if (!template)
6447 {
6448 /* It wasn't an instruction, but it might be a register alias of
6449 the form alias .req reg directive. */
6450 if (!create_register_alias (str, p))
6451 as_bad (_("unknown mnemonic `%s' -- `%s'"), get_mnemonic_name (str),
6452 str);
6453 return;
6454 }
6455
6456 skip_whitespace (p);
6457 if (*p == ',')
6458 {
6459 as_bad (_("unexpected comma after the mnemonic name `%s' -- `%s'"),
6460 get_mnemonic_name (str), str);
6461 return;
6462 }
6463
6464 init_operand_error_report ();
6465
eb9d6cc9
RL
6466 /* Sections are assumed to start aligned. In executable section, there is no
6467 MAP_DATA symbol pending. So we only align the address during
6468 MAP_DATA --> MAP_INSN transition.
6469 For other sections, this is not guaranteed. */
6470 enum mstate mapstate = seg_info (now_seg)->tc_segment_info_data.mapstate;
6471 if (!need_pass_2 && subseg_text_p (now_seg) && mapstate == MAP_DATA)
6472 frag_align_code (2, 0);
6473
a06ea964
NC
6474 saved_cond = inst.cond;
6475 reset_aarch64_instruction (&inst);
6476 inst.cond = saved_cond;
6477
6478 /* Iterate through all opcode entries with the same mnemonic name. */
6479 do
6480 {
6481 opcode = template->opcode;
6482
6483 DEBUG_TRACE ("opcode %s found", opcode->name);
6484#ifdef DEBUG_AARCH64
6485 if (debug_dump)
6486 dump_opcode_operands (opcode);
6487#endif /* DEBUG_AARCH64 */
6488
a06ea964
NC
6489 mapping_state (MAP_INSN);
6490
6491 inst_base = &inst.base;
6492 inst_base->opcode = opcode;
6493
6494 /* Truly conditionally executed instructions, e.g. b.cond. */
6495 if (opcode->flags & F_COND)
6496 {
6497 gas_assert (inst.cond != COND_ALWAYS);
6498 inst_base->cond = get_cond_from_value (inst.cond);
6499 DEBUG_TRACE ("condition found %s", inst_base->cond->names[0]);
6500 }
6501 else if (inst.cond != COND_ALWAYS)
6502 {
6503 /* It shouldn't arrive here, where the assembly looks like a
6504 conditional instruction but the found opcode is unconditional. */
6505 gas_assert (0);
6506 continue;
6507 }
6508
6509 if (parse_operands (p, opcode)
6510 && programmer_friendly_fixup (&inst)
6511 && do_encode (inst_base->opcode, &inst.base, &inst_base->value))
6512 {
3f06bfce
YZ
6513 /* Check that this instruction is supported for this CPU. */
6514 if (!opcode->avariant
93d8990c 6515 || !AARCH64_CPU_HAS_ALL_FEATURES (cpu_variant, *opcode->avariant))
3f06bfce
YZ
6516 {
6517 as_bad (_("selected processor does not support `%s'"), str);
6518 return;
6519 }
6520
54a28c4c
JW
6521 warn_unpredictable_ldst (&inst, str);
6522
a06ea964
NC
6523 if (inst.reloc.type == BFD_RELOC_UNUSED
6524 || !inst.reloc.need_libopcodes_p)
6525 output_inst (NULL);
6526 else
6527 {
6528 /* If there is relocation generated for the instruction,
6529 store the instruction information for the future fix-up. */
6530 struct aarch64_inst *copy;
6531 gas_assert (inst.reloc.type != BFD_RELOC_UNUSED);
325801bd 6532 copy = XNEW (struct aarch64_inst);
a06ea964
NC
6533 memcpy (copy, &inst.base, sizeof (struct aarch64_inst));
6534 output_inst (copy);
6535 }
6536 return;
6537 }
6538
6539 template = template->next;
6540 if (template != NULL)
6541 {
6542 reset_aarch64_instruction (&inst);
6543 inst.cond = saved_cond;
6544 }
6545 }
6546 while (template != NULL);
6547
6548 /* Issue the error messages if any. */
6549 output_operand_error_report (str);
6550}
6551
6552/* Various frobbings of labels and their addresses. */
6553
6554void
6555aarch64_start_line_hook (void)
6556{
6557 last_label_seen = NULL;
6558}
6559
6560void
6561aarch64_frob_label (symbolS * sym)
6562{
6563 last_label_seen = sym;
6564
6565 dwarf2_emit_label (sym);
6566}
6567
6568int
6569aarch64_data_in_code (void)
6570{
6571 if (!strncmp (input_line_pointer + 1, "data:", 5))
6572 {
6573 *input_line_pointer = '/';
6574 input_line_pointer += 5;
6575 *input_line_pointer = 0;
6576 return 1;
6577 }
6578
6579 return 0;
6580}
6581
6582char *
6583aarch64_canonicalize_symbol_name (char *name)
6584{
6585 int len;
6586
6587 if ((len = strlen (name)) > 5 && streq (name + len - 5, "/data"))
6588 *(name + len - 5) = 0;
6589
6590 return name;
6591}
6592\f
6593/* Table of all register names defined by default. The user can
6594 define additional names with .req. Note that all register names
6595 should appear in both upper and lowercase variants. Some registers
6596 also have mixed-case names. */
6597
6598#define REGDEF(s,n,t) { #s, n, REG_TYPE_##t, TRUE }
6599#define REGNUM(p,n,t) REGDEF(p##n, n, t)
f11ad6bc 6600#define REGSET16(p,t) \
a06ea964
NC
6601 REGNUM(p, 0,t), REGNUM(p, 1,t), REGNUM(p, 2,t), REGNUM(p, 3,t), \
6602 REGNUM(p, 4,t), REGNUM(p, 5,t), REGNUM(p, 6,t), REGNUM(p, 7,t), \
6603 REGNUM(p, 8,t), REGNUM(p, 9,t), REGNUM(p,10,t), REGNUM(p,11,t), \
f11ad6bc
RS
6604 REGNUM(p,12,t), REGNUM(p,13,t), REGNUM(p,14,t), REGNUM(p,15,t)
6605#define REGSET31(p,t) \
6606 REGSET16(p, t), \
a06ea964
NC
6607 REGNUM(p,16,t), REGNUM(p,17,t), REGNUM(p,18,t), REGNUM(p,19,t), \
6608 REGNUM(p,20,t), REGNUM(p,21,t), REGNUM(p,22,t), REGNUM(p,23,t), \
6609 REGNUM(p,24,t), REGNUM(p,25,t), REGNUM(p,26,t), REGNUM(p,27,t), \
6610 REGNUM(p,28,t), REGNUM(p,29,t), REGNUM(p,30,t)
6611#define REGSET(p,t) \
6612 REGSET31(p,t), REGNUM(p,31,t)
6613
6614/* These go into aarch64_reg_hsh hash-table. */
6615static const reg_entry reg_names[] = {
6616 /* Integer registers. */
6617 REGSET31 (x, R_64), REGSET31 (X, R_64),
6618 REGSET31 (w, R_32), REGSET31 (W, R_32),
6619
6620 REGDEF (wsp, 31, SP_32), REGDEF (WSP, 31, SP_32),
6621 REGDEF (sp, 31, SP_64), REGDEF (SP, 31, SP_64),
6622
6623 REGDEF (wzr, 31, Z_32), REGDEF (WZR, 31, Z_32),
6624 REGDEF (xzr, 31, Z_64), REGDEF (XZR, 31, Z_64),
6625
6626 /* Coprocessor register numbers. */
6627 REGSET (c, CN), REGSET (C, CN),
6628
6629 /* Floating-point single precision registers. */
6630 REGSET (s, FP_S), REGSET (S, FP_S),
6631
6632 /* Floating-point double precision registers. */
6633 REGSET (d, FP_D), REGSET (D, FP_D),
6634
6635 /* Floating-point half precision registers. */
6636 REGSET (h, FP_H), REGSET (H, FP_H),
6637
6638 /* Floating-point byte precision registers. */
6639 REGSET (b, FP_B), REGSET (B, FP_B),
6640
6641 /* Floating-point quad precision registers. */
6642 REGSET (q, FP_Q), REGSET (Q, FP_Q),
6643
6644 /* FP/SIMD registers. */
6645 REGSET (v, VN), REGSET (V, VN),
f11ad6bc
RS
6646
6647 /* SVE vector registers. */
6648 REGSET (z, ZN), REGSET (Z, ZN),
6649
6650 /* SVE predicate registers. */
6651 REGSET16 (p, PN), REGSET16 (P, PN)
a06ea964
NC
6652};
6653
6654#undef REGDEF
6655#undef REGNUM
f11ad6bc
RS
6656#undef REGSET16
6657#undef REGSET31
a06ea964
NC
6658#undef REGSET
6659
6660#define N 1
6661#define n 0
6662#define Z 1
6663#define z 0
6664#define C 1
6665#define c 0
6666#define V 1
6667#define v 0
6668#define B(a,b,c,d) (((a) << 3) | ((b) << 2) | ((c) << 1) | (d))
6669static const asm_nzcv nzcv_names[] = {
6670 {"nzcv", B (n, z, c, v)},
6671 {"nzcV", B (n, z, c, V)},
6672 {"nzCv", B (n, z, C, v)},
6673 {"nzCV", B (n, z, C, V)},
6674 {"nZcv", B (n, Z, c, v)},
6675 {"nZcV", B (n, Z, c, V)},
6676 {"nZCv", B (n, Z, C, v)},
6677 {"nZCV", B (n, Z, C, V)},
6678 {"Nzcv", B (N, z, c, v)},
6679 {"NzcV", B (N, z, c, V)},
6680 {"NzCv", B (N, z, C, v)},
6681 {"NzCV", B (N, z, C, V)},
6682 {"NZcv", B (N, Z, c, v)},
6683 {"NZcV", B (N, Z, c, V)},
6684 {"NZCv", B (N, Z, C, v)},
6685 {"NZCV", B (N, Z, C, V)}
6686};
6687
6688#undef N
6689#undef n
6690#undef Z
6691#undef z
6692#undef C
6693#undef c
6694#undef V
6695#undef v
6696#undef B
6697\f
6698/* MD interface: bits in the object file. */
6699
6700/* Turn an integer of n bytes (in val) into a stream of bytes appropriate
6701 for use in the a.out file, and stores them in the array pointed to by buf.
6702 This knows about the endian-ness of the target machine and does
6703 THE RIGHT THING, whatever it is. Possible values for n are 1 (byte)
6704 2 (short) and 4 (long) Floating numbers are put out as a series of
6705 LITTLENUMS (shorts, here at least). */
6706
6707void
6708md_number_to_chars (char *buf, valueT val, int n)
6709{
6710 if (target_big_endian)
6711 number_to_chars_bigendian (buf, val, n);
6712 else
6713 number_to_chars_littleendian (buf, val, n);
6714}
6715
6716/* MD interface: Sections. */
6717
6718/* Estimate the size of a frag before relaxing. Assume everything fits in
6719 4 bytes. */
6720
6721int
6722md_estimate_size_before_relax (fragS * fragp, segT segtype ATTRIBUTE_UNUSED)
6723{
6724 fragp->fr_var = 4;
6725 return 4;
6726}
6727
6728/* Round up a section size to the appropriate boundary. */
6729
6730valueT
6731md_section_align (segT segment ATTRIBUTE_UNUSED, valueT size)
6732{
6733 return size;
6734}
6735
6736/* This is called from HANDLE_ALIGN in write.c. Fill in the contents
f803aa8e
DPT
6737 of an rs_align_code fragment.
6738
6739 Here we fill the frag with the appropriate info for padding the
6740 output stream. The resulting frag will consist of a fixed (fr_fix)
6741 and of a repeating (fr_var) part.
6742
6743 The fixed content is always emitted before the repeating content and
6744 these two parts are used as follows in constructing the output:
6745 - the fixed part will be used to align to a valid instruction word
6746 boundary, in case that we start at a misaligned address; as no
6747 executable instruction can live at the misaligned location, we
6748 simply fill with zeros;
6749 - the variable part will be used to cover the remaining padding and
6750 we fill using the AArch64 NOP instruction.
6751
6752 Note that the size of a RS_ALIGN_CODE fragment is always 7 to provide
6753 enough storage space for up to 3 bytes for padding the back to a valid
6754 instruction alignment and exactly 4 bytes to store the NOP pattern. */
a06ea964
NC
6755
6756void
6757aarch64_handle_align (fragS * fragP)
6758{
6759 /* NOP = d503201f */
6760 /* AArch64 instructions are always little-endian. */
d9235011 6761 static unsigned char const aarch64_noop[4] = { 0x1f, 0x20, 0x03, 0xd5 };
a06ea964
NC
6762
6763 int bytes, fix, noop_size;
6764 char *p;
a06ea964
NC
6765
6766 if (fragP->fr_type != rs_align_code)
6767 return;
6768
6769 bytes = fragP->fr_next->fr_address - fragP->fr_address - fragP->fr_fix;
6770 p = fragP->fr_literal + fragP->fr_fix;
a06ea964
NC
6771
6772#ifdef OBJ_ELF
6773 gas_assert (fragP->tc_frag_data.recorded);
6774#endif
6775
a06ea964 6776 noop_size = sizeof (aarch64_noop);
a06ea964 6777
f803aa8e
DPT
6778 fix = bytes & (noop_size - 1);
6779 if (fix)
a06ea964 6780 {
a06ea964
NC
6781#ifdef OBJ_ELF
6782 insert_data_mapping_symbol (MAP_INSN, fragP->fr_fix, fragP, fix);
6783#endif
6784 memset (p, 0, fix);
6785 p += fix;
f803aa8e 6786 fragP->fr_fix += fix;
a06ea964
NC
6787 }
6788
f803aa8e
DPT
6789 if (noop_size)
6790 memcpy (p, aarch64_noop, noop_size);
6791 fragP->fr_var = noop_size;
a06ea964
NC
6792}
6793
6794/* Perform target specific initialisation of a frag.
6795 Note - despite the name this initialisation is not done when the frag
6796 is created, but only when its type is assigned. A frag can be created
6797 and used a long time before its type is set, so beware of assuming that
6798 this initialisationis performed first. */
6799
6800#ifndef OBJ_ELF
6801void
6802aarch64_init_frag (fragS * fragP ATTRIBUTE_UNUSED,
6803 int max_chars ATTRIBUTE_UNUSED)
6804{
6805}
6806
6807#else /* OBJ_ELF is defined. */
6808void
6809aarch64_init_frag (fragS * fragP, int max_chars)
6810{
6811 /* Record a mapping symbol for alignment frags. We will delete this
6812 later if the alignment ends up empty. */
6813 if (!fragP->tc_frag_data.recorded)
c7ad08e6
RL
6814 fragP->tc_frag_data.recorded = 1;
6815
6816 switch (fragP->fr_type)
a06ea964 6817 {
c7ad08e6
RL
6818 case rs_align_test:
6819 case rs_fill:
6820 mapping_state_2 (MAP_DATA, max_chars);
6821 break;
7ea12e5c
NC
6822 case rs_align:
6823 /* PR 20364: We can get alignment frags in code sections,
6824 so do not just assume that we should use the MAP_DATA state. */
6825 mapping_state_2 (subseg_text_p (now_seg) ? MAP_INSN : MAP_DATA, max_chars);
6826 break;
c7ad08e6
RL
6827 case rs_align_code:
6828 mapping_state_2 (MAP_INSN, max_chars);
6829 break;
6830 default:
6831 break;
a06ea964
NC
6832 }
6833}
6834\f
6835/* Initialize the DWARF-2 unwind information for this procedure. */
6836
6837void
6838tc_aarch64_frame_initial_instructions (void)
6839{
6840 cfi_add_CFA_def_cfa (REG_SP, 0);
6841}
6842#endif /* OBJ_ELF */
6843
6844/* Convert REGNAME to a DWARF-2 register number. */
6845
6846int
6847tc_aarch64_regname_to_dw2regnum (char *regname)
6848{
6849 const reg_entry *reg = parse_reg (&regname);
6850 if (reg == NULL)
6851 return -1;
6852
6853 switch (reg->type)
6854 {
6855 case REG_TYPE_SP_32:
6856 case REG_TYPE_SP_64:
6857 case REG_TYPE_R_32:
6858 case REG_TYPE_R_64:
a2cac51c
RH
6859 return reg->number;
6860
a06ea964
NC
6861 case REG_TYPE_FP_B:
6862 case REG_TYPE_FP_H:
6863 case REG_TYPE_FP_S:
6864 case REG_TYPE_FP_D:
6865 case REG_TYPE_FP_Q:
a2cac51c
RH
6866 return reg->number + 64;
6867
a06ea964
NC
6868 default:
6869 break;
6870 }
6871 return -1;
6872}
6873
cec5225b
YZ
6874/* Implement DWARF2_ADDR_SIZE. */
6875
6876int
6877aarch64_dwarf2_addr_size (void)
6878{
6879#if defined (OBJ_MAYBE_ELF) || defined (OBJ_ELF)
6880 if (ilp32_p)
6881 return 4;
6882#endif
6883 return bfd_arch_bits_per_address (stdoutput) / 8;
6884}
6885
a06ea964
NC
6886/* MD interface: Symbol and relocation handling. */
6887
6888/* Return the address within the segment that a PC-relative fixup is
6889 relative to. For AArch64 PC-relative fixups applied to instructions
6890 are generally relative to the location plus AARCH64_PCREL_OFFSET bytes. */
6891
6892long
6893md_pcrel_from_section (fixS * fixP, segT seg)
6894{
6895 offsetT base = fixP->fx_where + fixP->fx_frag->fr_address;
6896
6897 /* If this is pc-relative and we are going to emit a relocation
6898 then we just want to put out any pipeline compensation that the linker
6899 will need. Otherwise we want to use the calculated base. */
6900 if (fixP->fx_pcrel
6901 && ((fixP->fx_addsy && S_GET_SEGMENT (fixP->fx_addsy) != seg)
6902 || aarch64_force_relocation (fixP)))
6903 base = 0;
6904
6905 /* AArch64 should be consistent for all pc-relative relocations. */
6906 return base + AARCH64_PCREL_OFFSET;
6907}
6908
6909/* Under ELF we need to default _GLOBAL_OFFSET_TABLE.
6910 Otherwise we have no need to default values of symbols. */
6911
6912symbolS *
6913md_undefined_symbol (char *name ATTRIBUTE_UNUSED)
6914{
6915#ifdef OBJ_ELF
6916 if (name[0] == '_' && name[1] == 'G'
6917 && streq (name, GLOBAL_OFFSET_TABLE_NAME))
6918 {
6919 if (!GOT_symbol)
6920 {
6921 if (symbol_find (name))
6922 as_bad (_("GOT already in the symbol table"));
6923
6924 GOT_symbol = symbol_new (name, undefined_section,
6925 (valueT) 0, &zero_address_frag);
6926 }
6927
6928 return GOT_symbol;
6929 }
6930#endif
6931
6932 return 0;
6933}
6934
6935/* Return non-zero if the indicated VALUE has overflowed the maximum
6936 range expressible by a unsigned number with the indicated number of
6937 BITS. */
6938
6939static bfd_boolean
6940unsigned_overflow (valueT value, unsigned bits)
6941{
6942 valueT lim;
6943 if (bits >= sizeof (valueT) * 8)
6944 return FALSE;
6945 lim = (valueT) 1 << bits;
6946 return (value >= lim);
6947}
6948
6949
6950/* Return non-zero if the indicated VALUE has overflowed the maximum
6951 range expressible by an signed number with the indicated number of
6952 BITS. */
6953
6954static bfd_boolean
6955signed_overflow (offsetT value, unsigned bits)
6956{
6957 offsetT lim;
6958 if (bits >= sizeof (offsetT) * 8)
6959 return FALSE;
6960 lim = (offsetT) 1 << (bits - 1);
6961 return (value < -lim || value >= lim);
6962}
6963
6964/* Given an instruction in *INST, which is expected to be a scaled, 12-bit,
6965 unsigned immediate offset load/store instruction, try to encode it as
6966 an unscaled, 9-bit, signed immediate offset load/store instruction.
6967 Return TRUE if it is successful; otherwise return FALSE.
6968
6969 As a programmer-friendly assembler, LDUR/STUR instructions can be generated
6970 in response to the standard LDR/STR mnemonics when the immediate offset is
6971 unambiguous, i.e. when it is negative or unaligned. */
6972
6973static bfd_boolean
6974try_to_encode_as_unscaled_ldst (aarch64_inst *instr)
6975{
6976 int idx;
6977 enum aarch64_op new_op;
6978 const aarch64_opcode *new_opcode;
6979
6980 gas_assert (instr->opcode->iclass == ldst_pos);
6981
6982 switch (instr->opcode->op)
6983 {
6984 case OP_LDRB_POS:new_op = OP_LDURB; break;
6985 case OP_STRB_POS: new_op = OP_STURB; break;
6986 case OP_LDRSB_POS: new_op = OP_LDURSB; break;
6987 case OP_LDRH_POS: new_op = OP_LDURH; break;
6988 case OP_STRH_POS: new_op = OP_STURH; break;
6989 case OP_LDRSH_POS: new_op = OP_LDURSH; break;
6990 case OP_LDR_POS: new_op = OP_LDUR; break;
6991 case OP_STR_POS: new_op = OP_STUR; break;
6992 case OP_LDRF_POS: new_op = OP_LDURV; break;
6993 case OP_STRF_POS: new_op = OP_STURV; break;
6994 case OP_LDRSW_POS: new_op = OP_LDURSW; break;
6995 case OP_PRFM_POS: new_op = OP_PRFUM; break;
6996 default: new_op = OP_NIL; break;
6997 }
6998
6999 if (new_op == OP_NIL)
7000 return FALSE;
7001
7002 new_opcode = aarch64_get_opcode (new_op);
7003 gas_assert (new_opcode != NULL);
7004
7005 DEBUG_TRACE ("Check programmer-friendly STURB/LDURB -> STRB/LDRB: %d == %d",
7006 instr->opcode->op, new_opcode->op);
7007
7008 aarch64_replace_opcode (instr, new_opcode);
7009
7010 /* Clear up the ADDR_SIMM9's qualifier; otherwise the
7011 qualifier matching may fail because the out-of-date qualifier will
7012 prevent the operand being updated with a new and correct qualifier. */
7013 idx = aarch64_operand_index (instr->opcode->operands,
7014 AARCH64_OPND_ADDR_SIMM9);
7015 gas_assert (idx == 1);
7016 instr->operands[idx].qualifier = AARCH64_OPND_QLF_NIL;
7017
7018 DEBUG_TRACE ("Found LDURB entry to encode programmer-friendly LDRB");
7019
7020 if (!aarch64_opcode_encode (instr->opcode, instr, &instr->value, NULL, NULL))
7021 return FALSE;
7022
7023 return TRUE;
7024}
7025
7026/* Called by fix_insn to fix a MOV immediate alias instruction.
7027
7028 Operand for a generic move immediate instruction, which is an alias
7029 instruction that generates a single MOVZ, MOVN or ORR instruction to loads
7030 a 32-bit/64-bit immediate value into general register. An assembler error
7031 shall result if the immediate cannot be created by a single one of these
7032 instructions. If there is a choice, then to ensure reversability an
7033 assembler must prefer a MOVZ to MOVN, and MOVZ or MOVN to ORR. */
7034
7035static void
7036fix_mov_imm_insn (fixS *fixP, char *buf, aarch64_inst *instr, offsetT value)
7037{
7038 const aarch64_opcode *opcode;
7039
7040 /* Need to check if the destination is SP/ZR. The check has to be done
7041 before any aarch64_replace_opcode. */
7042 int try_mov_wide_p = !aarch64_stack_pointer_p (&instr->operands[0]);
7043 int try_mov_bitmask_p = !aarch64_zero_register_p (&instr->operands[0]);
7044
7045 instr->operands[1].imm.value = value;
7046 instr->operands[1].skip = 0;
7047
7048 if (try_mov_wide_p)
7049 {
7050 /* Try the MOVZ alias. */
7051 opcode = aarch64_get_opcode (OP_MOV_IMM_WIDE);
7052 aarch64_replace_opcode (instr, opcode);
7053 if (aarch64_opcode_encode (instr->opcode, instr,
7054 &instr->value, NULL, NULL))
7055 {
7056 put_aarch64_insn (buf, instr->value);
7057 return;
7058 }
7059 /* Try the MOVK alias. */
7060 opcode = aarch64_get_opcode (OP_MOV_IMM_WIDEN);
7061 aarch64_replace_opcode (instr, opcode);
7062 if (aarch64_opcode_encode (instr->opcode, instr,
7063 &instr->value, NULL, NULL))
7064 {
7065 put_aarch64_insn (buf, instr->value);
7066 return;
7067 }
7068 }
7069
7070 if (try_mov_bitmask_p)
7071 {
7072 /* Try the ORR alias. */
7073 opcode = aarch64_get_opcode (OP_MOV_IMM_LOG);
7074 aarch64_replace_opcode (instr, opcode);
7075 if (aarch64_opcode_encode (instr->opcode, instr,
7076 &instr->value, NULL, NULL))
7077 {
7078 put_aarch64_insn (buf, instr->value);
7079 return;
7080 }
7081 }
7082
7083 as_bad_where (fixP->fx_file, fixP->fx_line,
7084 _("immediate cannot be moved by a single instruction"));
7085}
7086
7087/* An instruction operand which is immediate related may have symbol used
7088 in the assembly, e.g.
7089
7090 mov w0, u32
7091 .set u32, 0x00ffff00
7092
7093 At the time when the assembly instruction is parsed, a referenced symbol,
7094 like 'u32' in the above example may not have been seen; a fixS is created
7095 in such a case and is handled here after symbols have been resolved.
7096 Instruction is fixed up with VALUE using the information in *FIXP plus
7097 extra information in FLAGS.
7098
7099 This function is called by md_apply_fix to fix up instructions that need
7100 a fix-up described above but does not involve any linker-time relocation. */
7101
7102static void
7103fix_insn (fixS *fixP, uint32_t flags, offsetT value)
7104{
7105 int idx;
7106 uint32_t insn;
7107 char *buf = fixP->fx_where + fixP->fx_frag->fr_literal;
7108 enum aarch64_opnd opnd = fixP->tc_fix_data.opnd;
7109 aarch64_inst *new_inst = fixP->tc_fix_data.inst;
7110
7111 if (new_inst)
7112 {
7113 /* Now the instruction is about to be fixed-up, so the operand that
7114 was previously marked as 'ignored' needs to be unmarked in order
7115 to get the encoding done properly. */
7116 idx = aarch64_operand_index (new_inst->opcode->operands, opnd);
7117 new_inst->operands[idx].skip = 0;
7118 }
7119
7120 gas_assert (opnd != AARCH64_OPND_NIL);
7121
7122 switch (opnd)
7123 {
7124 case AARCH64_OPND_EXCEPTION:
7125 if (unsigned_overflow (value, 16))
7126 as_bad_where (fixP->fx_file, fixP->fx_line,
7127 _("immediate out of range"));
7128 insn = get_aarch64_insn (buf);
7129 insn |= encode_svc_imm (value);
7130 put_aarch64_insn (buf, insn);
7131 break;
7132
7133 case AARCH64_OPND_AIMM:
7134 /* ADD or SUB with immediate.
7135 NOTE this assumes we come here with a add/sub shifted reg encoding
7136 3 322|2222|2 2 2 21111 111111
7137 1 098|7654|3 2 1 09876 543210 98765 43210
7138 0b000000 sf 000|1011|shift 0 Rm imm6 Rn Rd ADD
7139 2b000000 sf 010|1011|shift 0 Rm imm6 Rn Rd ADDS
7140 4b000000 sf 100|1011|shift 0 Rm imm6 Rn Rd SUB
7141 6b000000 sf 110|1011|shift 0 Rm imm6 Rn Rd SUBS
7142 ->
7143 3 322|2222|2 2 221111111111
7144 1 098|7654|3 2 109876543210 98765 43210
7145 11000000 sf 001|0001|shift imm12 Rn Rd ADD
7146 31000000 sf 011|0001|shift imm12 Rn Rd ADDS
7147 51000000 sf 101|0001|shift imm12 Rn Rd SUB
7148 71000000 sf 111|0001|shift imm12 Rn Rd SUBS
7149 Fields sf Rn Rd are already set. */
7150 insn = get_aarch64_insn (buf);
7151 if (value < 0)
7152 {
7153 /* Add <-> sub. */
7154 insn = reencode_addsub_switch_add_sub (insn);
7155 value = -value;
7156 }
7157
7158 if ((flags & FIXUP_F_HAS_EXPLICIT_SHIFT) == 0
7159 && unsigned_overflow (value, 12))
7160 {
7161 /* Try to shift the value by 12 to make it fit. */
7162 if (((value >> 12) << 12) == value
7163 && ! unsigned_overflow (value, 12 + 12))
7164 {
7165 value >>= 12;
7166 insn |= encode_addsub_imm_shift_amount (1);
7167 }
7168 }
7169
7170 if (unsigned_overflow (value, 12))
7171 as_bad_where (fixP->fx_file, fixP->fx_line,
7172 _("immediate out of range"));
7173
7174 insn |= encode_addsub_imm (value);
7175
7176 put_aarch64_insn (buf, insn);
7177 break;
7178
7179 case AARCH64_OPND_SIMD_IMM:
7180 case AARCH64_OPND_SIMD_IMM_SFT:
7181 case AARCH64_OPND_LIMM:
7182 /* Bit mask immediate. */
7183 gas_assert (new_inst != NULL);
7184 idx = aarch64_operand_index (new_inst->opcode->operands, opnd);
7185 new_inst->operands[idx].imm.value = value;
7186 if (aarch64_opcode_encode (new_inst->opcode, new_inst,
7187 &new_inst->value, NULL, NULL))
7188 put_aarch64_insn (buf, new_inst->value);
7189 else
7190 as_bad_where (fixP->fx_file, fixP->fx_line,
7191 _("invalid immediate"));
7192 break;
7193
7194 case AARCH64_OPND_HALF:
7195 /* 16-bit unsigned immediate. */
7196 if (unsigned_overflow (value, 16))
7197 as_bad_where (fixP->fx_file, fixP->fx_line,
7198 _("immediate out of range"));
7199 insn = get_aarch64_insn (buf);
7200 insn |= encode_movw_imm (value & 0xffff);
7201 put_aarch64_insn (buf, insn);
7202 break;
7203
7204 case AARCH64_OPND_IMM_MOV:
7205 /* Operand for a generic move immediate instruction, which is
7206 an alias instruction that generates a single MOVZ, MOVN or ORR
7207 instruction to loads a 32-bit/64-bit immediate value into general
7208 register. An assembler error shall result if the immediate cannot be
7209 created by a single one of these instructions. If there is a choice,
7210 then to ensure reversability an assembler must prefer a MOVZ to MOVN,
7211 and MOVZ or MOVN to ORR. */
7212 gas_assert (new_inst != NULL);
7213 fix_mov_imm_insn (fixP, buf, new_inst, value);
7214 break;
7215
7216 case AARCH64_OPND_ADDR_SIMM7:
7217 case AARCH64_OPND_ADDR_SIMM9:
7218 case AARCH64_OPND_ADDR_SIMM9_2:
7219 case AARCH64_OPND_ADDR_UIMM12:
7220 /* Immediate offset in an address. */
7221 insn = get_aarch64_insn (buf);
7222
7223 gas_assert (new_inst != NULL && new_inst->value == insn);
7224 gas_assert (new_inst->opcode->operands[1] == opnd
7225 || new_inst->opcode->operands[2] == opnd);
7226
7227 /* Get the index of the address operand. */
7228 if (new_inst->opcode->operands[1] == opnd)
7229 /* e.g. STR <Xt>, [<Xn|SP>, <R><m>{, <extend> {<amount>}}]. */
7230 idx = 1;
7231 else
7232 /* e.g. LDP <Qt1>, <Qt2>, [<Xn|SP>{, #<imm>}]. */
7233 idx = 2;
7234
7235 /* Update the resolved offset value. */
7236 new_inst->operands[idx].addr.offset.imm = value;
7237
7238 /* Encode/fix-up. */
7239 if (aarch64_opcode_encode (new_inst->opcode, new_inst,
7240 &new_inst->value, NULL, NULL))
7241 {
7242 put_aarch64_insn (buf, new_inst->value);
7243 break;
7244 }
7245 else if (new_inst->opcode->iclass == ldst_pos
7246 && try_to_encode_as_unscaled_ldst (new_inst))
7247 {
7248 put_aarch64_insn (buf, new_inst->value);
7249 break;
7250 }
7251
7252 as_bad_where (fixP->fx_file, fixP->fx_line,
7253 _("immediate offset out of range"));
7254 break;
7255
7256 default:
7257 gas_assert (0);
7258 as_fatal (_("unhandled operand code %d"), opnd);
7259 }
7260}
7261
7262/* Apply a fixup (fixP) to segment data, once it has been determined
7263 by our caller that we have all the info we need to fix it up.
7264
7265 Parameter valP is the pointer to the value of the bits. */
7266
7267void
7268md_apply_fix (fixS * fixP, valueT * valP, segT seg)
7269{
7270 offsetT value = *valP;
7271 uint32_t insn;
7272 char *buf = fixP->fx_where + fixP->fx_frag->fr_literal;
7273 int scale;
7274 unsigned flags = fixP->fx_addnumber;
7275
7276 DEBUG_TRACE ("\n\n");
7277 DEBUG_TRACE ("~~~~~~~~~~~~~~~~~~~~~~~~~");
7278 DEBUG_TRACE ("Enter md_apply_fix");
7279
7280 gas_assert (fixP->fx_r_type <= BFD_RELOC_UNUSED);
7281
7282 /* Note whether this will delete the relocation. */
7283
7284 if (fixP->fx_addsy == 0 && !fixP->fx_pcrel)
7285 fixP->fx_done = 1;
7286
7287 /* Process the relocations. */
7288 switch (fixP->fx_r_type)
7289 {
7290 case BFD_RELOC_NONE:
7291 /* This will need to go in the object file. */
7292 fixP->fx_done = 0;
7293 break;
7294
7295 case BFD_RELOC_8:
7296 case BFD_RELOC_8_PCREL:
7297 if (fixP->fx_done || !seg->use_rela_p)
7298 md_number_to_chars (buf, value, 1);
7299 break;
7300
7301 case BFD_RELOC_16:
7302 case BFD_RELOC_16_PCREL:
7303 if (fixP->fx_done || !seg->use_rela_p)
7304 md_number_to_chars (buf, value, 2);
7305 break;
7306
7307 case BFD_RELOC_32:
7308 case BFD_RELOC_32_PCREL:
7309 if (fixP->fx_done || !seg->use_rela_p)
7310 md_number_to_chars (buf, value, 4);
7311 break;
7312
7313 case BFD_RELOC_64:
7314 case BFD_RELOC_64_PCREL:
7315 if (fixP->fx_done || !seg->use_rela_p)
7316 md_number_to_chars (buf, value, 8);
7317 break;
7318
7319 case BFD_RELOC_AARCH64_GAS_INTERNAL_FIXUP:
7320 /* We claim that these fixups have been processed here, even if
7321 in fact we generate an error because we do not have a reloc
7322 for them, so tc_gen_reloc() will reject them. */
7323 fixP->fx_done = 1;
7324 if (fixP->fx_addsy && !S_IS_DEFINED (fixP->fx_addsy))
7325 {
7326 as_bad_where (fixP->fx_file, fixP->fx_line,
7327 _("undefined symbol %s used as an immediate value"),
7328 S_GET_NAME (fixP->fx_addsy));
7329 goto apply_fix_return;
7330 }
7331 fix_insn (fixP, flags, value);
7332 break;
7333
7334 case BFD_RELOC_AARCH64_LD_LO19_PCREL:
a06ea964
NC
7335 if (fixP->fx_done || !seg->use_rela_p)
7336 {
89d2a2a3
MS
7337 if (value & 3)
7338 as_bad_where (fixP->fx_file, fixP->fx_line,
7339 _("pc-relative load offset not word aligned"));
7340 if (signed_overflow (value, 21))
7341 as_bad_where (fixP->fx_file, fixP->fx_line,
7342 _("pc-relative load offset out of range"));
a06ea964
NC
7343 insn = get_aarch64_insn (buf);
7344 insn |= encode_ld_lit_ofs_19 (value >> 2);
7345 put_aarch64_insn (buf, insn);
7346 }
7347 break;
7348
7349 case BFD_RELOC_AARCH64_ADR_LO21_PCREL:
a06ea964
NC
7350 if (fixP->fx_done || !seg->use_rela_p)
7351 {
89d2a2a3
MS
7352 if (signed_overflow (value, 21))
7353 as_bad_where (fixP->fx_file, fixP->fx_line,
7354 _("pc-relative address offset out of range"));
a06ea964
NC
7355 insn = get_aarch64_insn (buf);
7356 insn |= encode_adr_imm (value);
7357 put_aarch64_insn (buf, insn);
7358 }
7359 break;
7360
7361 case BFD_RELOC_AARCH64_BRANCH19:
a06ea964
NC
7362 if (fixP->fx_done || !seg->use_rela_p)
7363 {
89d2a2a3
MS
7364 if (value & 3)
7365 as_bad_where (fixP->fx_file, fixP->fx_line,
7366 _("conditional branch target not word aligned"));
7367 if (signed_overflow (value, 21))
7368 as_bad_where (fixP->fx_file, fixP->fx_line,
7369 _("conditional branch out of range"));
a06ea964
NC
7370 insn = get_aarch64_insn (buf);
7371 insn |= encode_cond_branch_ofs_19 (value >> 2);
7372 put_aarch64_insn (buf, insn);
7373 }
7374 break;
7375
7376 case BFD_RELOC_AARCH64_TSTBR14:
a06ea964
NC
7377 if (fixP->fx_done || !seg->use_rela_p)
7378 {
89d2a2a3
MS
7379 if (value & 3)
7380 as_bad_where (fixP->fx_file, fixP->fx_line,
7381 _("conditional branch target not word aligned"));
7382 if (signed_overflow (value, 16))
7383 as_bad_where (fixP->fx_file, fixP->fx_line,
7384 _("conditional branch out of range"));
a06ea964
NC
7385 insn = get_aarch64_insn (buf);
7386 insn |= encode_tst_branch_ofs_14 (value >> 2);
7387 put_aarch64_insn (buf, insn);
7388 }
7389 break;
7390
a06ea964 7391 case BFD_RELOC_AARCH64_CALL26:
f09c556a 7392 case BFD_RELOC_AARCH64_JUMP26:
a06ea964
NC
7393 if (fixP->fx_done || !seg->use_rela_p)
7394 {
89d2a2a3
MS
7395 if (value & 3)
7396 as_bad_where (fixP->fx_file, fixP->fx_line,
7397 _("branch target not word aligned"));
7398 if (signed_overflow (value, 28))
7399 as_bad_where (fixP->fx_file, fixP->fx_line,
7400 _("branch out of range"));
a06ea964
NC
7401 insn = get_aarch64_insn (buf);
7402 insn |= encode_branch_ofs_26 (value >> 2);
7403 put_aarch64_insn (buf, insn);
7404 }
7405 break;
7406
7407 case BFD_RELOC_AARCH64_MOVW_G0:
a06ea964 7408 case BFD_RELOC_AARCH64_MOVW_G0_NC:
f09c556a 7409 case BFD_RELOC_AARCH64_MOVW_G0_S:
ca632371 7410 case BFD_RELOC_AARCH64_MOVW_GOTOFF_G0_NC:
a06ea964
NC
7411 scale = 0;
7412 goto movw_common;
7413 case BFD_RELOC_AARCH64_MOVW_G1:
a06ea964 7414 case BFD_RELOC_AARCH64_MOVW_G1_NC:
f09c556a 7415 case BFD_RELOC_AARCH64_MOVW_G1_S:
654248e7 7416 case BFD_RELOC_AARCH64_MOVW_GOTOFF_G1:
a06ea964
NC
7417 scale = 16;
7418 goto movw_common;
43a357f9
RL
7419 case BFD_RELOC_AARCH64_TLSDESC_OFF_G0_NC:
7420 scale = 0;
7421 S_SET_THREAD_LOCAL (fixP->fx_addsy);
7422 /* Should always be exported to object file, see
7423 aarch64_force_relocation(). */
7424 gas_assert (!fixP->fx_done);
7425 gas_assert (seg->use_rela_p);
7426 goto movw_common;
7427 case BFD_RELOC_AARCH64_TLSDESC_OFF_G1:
7428 scale = 16;
7429 S_SET_THREAD_LOCAL (fixP->fx_addsy);
7430 /* Should always be exported to object file, see
7431 aarch64_force_relocation(). */
7432 gas_assert (!fixP->fx_done);
7433 gas_assert (seg->use_rela_p);
7434 goto movw_common;
a06ea964 7435 case BFD_RELOC_AARCH64_MOVW_G2:
a06ea964 7436 case BFD_RELOC_AARCH64_MOVW_G2_NC:
f09c556a 7437 case BFD_RELOC_AARCH64_MOVW_G2_S:
a06ea964
NC
7438 scale = 32;
7439 goto movw_common;
7440 case BFD_RELOC_AARCH64_MOVW_G3:
7441 scale = 48;
7442 movw_common:
7443 if (fixP->fx_done || !seg->use_rela_p)
7444 {
7445 insn = get_aarch64_insn (buf);
7446
7447 if (!fixP->fx_done)
7448 {
7449 /* REL signed addend must fit in 16 bits */
7450 if (signed_overflow (value, 16))
7451 as_bad_where (fixP->fx_file, fixP->fx_line,
7452 _("offset out of range"));
7453 }
7454 else
7455 {
7456 /* Check for overflow and scale. */
7457 switch (fixP->fx_r_type)
7458 {
7459 case BFD_RELOC_AARCH64_MOVW_G0:
7460 case BFD_RELOC_AARCH64_MOVW_G1:
7461 case BFD_RELOC_AARCH64_MOVW_G2:
7462 case BFD_RELOC_AARCH64_MOVW_G3:
654248e7 7463 case BFD_RELOC_AARCH64_MOVW_GOTOFF_G1:
43a357f9 7464 case BFD_RELOC_AARCH64_TLSDESC_OFF_G1:
a06ea964
NC
7465 if (unsigned_overflow (value, scale + 16))
7466 as_bad_where (fixP->fx_file, fixP->fx_line,
7467 _("unsigned value out of range"));
7468 break;
7469 case BFD_RELOC_AARCH64_MOVW_G0_S:
7470 case BFD_RELOC_AARCH64_MOVW_G1_S:
7471 case BFD_RELOC_AARCH64_MOVW_G2_S:
7472 /* NOTE: We can only come here with movz or movn. */
7473 if (signed_overflow (value, scale + 16))
7474 as_bad_where (fixP->fx_file, fixP->fx_line,
7475 _("signed value out of range"));
7476 if (value < 0)
7477 {
7478 /* Force use of MOVN. */
7479 value = ~value;
7480 insn = reencode_movzn_to_movn (insn);
7481 }
7482 else
7483 {
7484 /* Force use of MOVZ. */
7485 insn = reencode_movzn_to_movz (insn);
7486 }
7487 break;
7488 default:
7489 /* Unchecked relocations. */
7490 break;
7491 }
7492 value >>= scale;
7493 }
7494
7495 /* Insert value into MOVN/MOVZ/MOVK instruction. */
7496 insn |= encode_movw_imm (value & 0xffff);
7497
7498 put_aarch64_insn (buf, insn);
7499 }
7500 break;
7501
a6bb11b2
YZ
7502 case BFD_RELOC_AARCH64_TLSIE_LD_GOTTPREL_LO12_NC:
7503 fixP->fx_r_type = (ilp32_p
7504 ? BFD_RELOC_AARCH64_TLSIE_LD32_GOTTPREL_LO12_NC
7505 : BFD_RELOC_AARCH64_TLSIE_LD64_GOTTPREL_LO12_NC);
7506 S_SET_THREAD_LOCAL (fixP->fx_addsy);
7507 /* Should always be exported to object file, see
7508 aarch64_force_relocation(). */
7509 gas_assert (!fixP->fx_done);
7510 gas_assert (seg->use_rela_p);
7511 break;
7512
7513 case BFD_RELOC_AARCH64_TLSDESC_LD_LO12_NC:
7514 fixP->fx_r_type = (ilp32_p
7515 ? BFD_RELOC_AARCH64_TLSDESC_LD32_LO12_NC
7516 : BFD_RELOC_AARCH64_TLSDESC_LD64_LO12_NC);
7517 S_SET_THREAD_LOCAL (fixP->fx_addsy);
7518 /* Should always be exported to object file, see
7519 aarch64_force_relocation(). */
7520 gas_assert (!fixP->fx_done);
7521 gas_assert (seg->use_rela_p);
7522 break;
7523
2c0a3565
MS
7524 case BFD_RELOC_AARCH64_TLSDESC_ADD_LO12_NC:
7525 case BFD_RELOC_AARCH64_TLSDESC_ADR_PAGE21:
389b8029 7526 case BFD_RELOC_AARCH64_TLSDESC_ADR_PREL21:
2c0a3565
MS
7527 case BFD_RELOC_AARCH64_TLSDESC_LD32_LO12_NC:
7528 case BFD_RELOC_AARCH64_TLSDESC_LD64_LO12_NC:
1ada945d 7529 case BFD_RELOC_AARCH64_TLSDESC_LD_PREL19:
a06ea964 7530 case BFD_RELOC_AARCH64_TLSGD_ADD_LO12_NC:
2c0a3565 7531 case BFD_RELOC_AARCH64_TLSGD_ADR_PAGE21:
3c12b054 7532 case BFD_RELOC_AARCH64_TLSGD_ADR_PREL21:
3e8286c0 7533 case BFD_RELOC_AARCH64_TLSGD_MOVW_G0_NC:
1aa66fb1 7534 case BFD_RELOC_AARCH64_TLSGD_MOVW_G1:
a06ea964 7535 case BFD_RELOC_AARCH64_TLSIE_ADR_GOTTPREL_PAGE21:
a6bb11b2 7536 case BFD_RELOC_AARCH64_TLSIE_LD32_GOTTPREL_LO12_NC:
2c0a3565 7537 case BFD_RELOC_AARCH64_TLSIE_LD64_GOTTPREL_LO12_NC:
043bf05a 7538 case BFD_RELOC_AARCH64_TLSIE_LD_GOTTPREL_PREL19:
3b957e5b
RL
7539 case BFD_RELOC_AARCH64_TLSIE_MOVW_GOTTPREL_G0_NC:
7540 case BFD_RELOC_AARCH64_TLSIE_MOVW_GOTTPREL_G1:
49df5539 7541 case BFD_RELOC_AARCH64_TLSLD_ADD_DTPREL_HI12:
70151fb5 7542 case BFD_RELOC_AARCH64_TLSLD_ADD_DTPREL_LO12:
13289c10 7543 case BFD_RELOC_AARCH64_TLSLD_ADD_DTPREL_LO12_NC:
a12fad50 7544 case BFD_RELOC_AARCH64_TLSLD_ADD_LO12_NC:
1107e076 7545 case BFD_RELOC_AARCH64_TLSLD_ADR_PAGE21:
6c37fedc 7546 case BFD_RELOC_AARCH64_TLSLD_ADR_PREL21:
4c562523
JW
7547 case BFD_RELOC_AARCH64_TLSLD_LDST16_DTPREL_LO12:
7548 case BFD_RELOC_AARCH64_TLSLD_LDST16_DTPREL_LO12_NC:
7549 case BFD_RELOC_AARCH64_TLSLD_LDST32_DTPREL_LO12:
7550 case BFD_RELOC_AARCH64_TLSLD_LDST32_DTPREL_LO12_NC:
7551 case BFD_RELOC_AARCH64_TLSLD_LDST64_DTPREL_LO12:
7552 case BFD_RELOC_AARCH64_TLSLD_LDST64_DTPREL_LO12_NC:
7553 case BFD_RELOC_AARCH64_TLSLD_LDST8_DTPREL_LO12:
7554 case BFD_RELOC_AARCH64_TLSLD_LDST8_DTPREL_LO12_NC:
49df5539
JW
7555 case BFD_RELOC_AARCH64_TLSLD_MOVW_DTPREL_G0:
7556 case BFD_RELOC_AARCH64_TLSLD_MOVW_DTPREL_G0_NC:
7557 case BFD_RELOC_AARCH64_TLSLD_MOVW_DTPREL_G1:
7558 case BFD_RELOC_AARCH64_TLSLD_MOVW_DTPREL_G1_NC:
7559 case BFD_RELOC_AARCH64_TLSLD_MOVW_DTPREL_G2:
a06ea964 7560 case BFD_RELOC_AARCH64_TLSLE_ADD_TPREL_HI12:
2c0a3565 7561 case BFD_RELOC_AARCH64_TLSLE_ADD_TPREL_LO12:
a06ea964 7562 case BFD_RELOC_AARCH64_TLSLE_ADD_TPREL_LO12_NC:
a06ea964
NC
7563 case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G0:
7564 case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G0_NC:
2c0a3565
MS
7565 case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G1:
7566 case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G1_NC:
7567 case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G2:
a06ea964
NC
7568 S_SET_THREAD_LOCAL (fixP->fx_addsy);
7569 /* Should always be exported to object file, see
7570 aarch64_force_relocation(). */
7571 gas_assert (!fixP->fx_done);
7572 gas_assert (seg->use_rela_p);
7573 break;
7574
a6bb11b2
YZ
7575 case BFD_RELOC_AARCH64_LD_GOT_LO12_NC:
7576 /* Should always be exported to object file, see
7577 aarch64_force_relocation(). */
7578 fixP->fx_r_type = (ilp32_p
7579 ? BFD_RELOC_AARCH64_LD32_GOT_LO12_NC
7580 : BFD_RELOC_AARCH64_LD64_GOT_LO12_NC);
7581 gas_assert (!fixP->fx_done);
7582 gas_assert (seg->use_rela_p);
7583 break;
7584
a06ea964 7585 case BFD_RELOC_AARCH64_ADD_LO12:
f09c556a
JW
7586 case BFD_RELOC_AARCH64_ADR_GOT_PAGE:
7587 case BFD_RELOC_AARCH64_ADR_HI21_NC_PCREL:
7588 case BFD_RELOC_AARCH64_ADR_HI21_PCREL:
7589 case BFD_RELOC_AARCH64_GOT_LD_PREL19:
7590 case BFD_RELOC_AARCH64_LD32_GOT_LO12_NC:
3d715ce4 7591 case BFD_RELOC_AARCH64_LD32_GOTPAGE_LO14:
87f5fbcc 7592 case BFD_RELOC_AARCH64_LD64_GOTOFF_LO15:
a921b5bd 7593 case BFD_RELOC_AARCH64_LD64_GOTPAGE_LO15:
f09c556a
JW
7594 case BFD_RELOC_AARCH64_LD64_GOT_LO12_NC:
7595 case BFD_RELOC_AARCH64_LDST128_LO12:
a06ea964
NC
7596 case BFD_RELOC_AARCH64_LDST16_LO12:
7597 case BFD_RELOC_AARCH64_LDST32_LO12:
7598 case BFD_RELOC_AARCH64_LDST64_LO12:
f09c556a 7599 case BFD_RELOC_AARCH64_LDST8_LO12:
a06ea964
NC
7600 /* Should always be exported to object file, see
7601 aarch64_force_relocation(). */
7602 gas_assert (!fixP->fx_done);
7603 gas_assert (seg->use_rela_p);
7604 break;
7605
7606 case BFD_RELOC_AARCH64_TLSDESC_ADD:
a06ea964 7607 case BFD_RELOC_AARCH64_TLSDESC_CALL:
f09c556a 7608 case BFD_RELOC_AARCH64_TLSDESC_LDR:
a06ea964
NC
7609 break;
7610
b97e87cc
NC
7611 case BFD_RELOC_UNUSED:
7612 /* An error will already have been reported. */
7613 break;
7614
a06ea964
NC
7615 default:
7616 as_bad_where (fixP->fx_file, fixP->fx_line,
7617 _("unexpected %s fixup"),
7618 bfd_get_reloc_code_name (fixP->fx_r_type));
7619 break;
7620 }
7621
7622apply_fix_return:
7623 /* Free the allocated the struct aarch64_inst.
7624 N.B. currently there are very limited number of fix-up types actually use
7625 this field, so the impact on the performance should be minimal . */
7626 if (fixP->tc_fix_data.inst != NULL)
7627 free (fixP->tc_fix_data.inst);
7628
7629 return;
7630}
7631
7632/* Translate internal representation of relocation info to BFD target
7633 format. */
7634
7635arelent *
7636tc_gen_reloc (asection * section, fixS * fixp)
7637{
7638 arelent *reloc;
7639 bfd_reloc_code_real_type code;
7640
325801bd 7641 reloc = XNEW (arelent);
a06ea964 7642
325801bd 7643 reloc->sym_ptr_ptr = XNEW (asymbol *);
a06ea964
NC
7644 *reloc->sym_ptr_ptr = symbol_get_bfdsym (fixp->fx_addsy);
7645 reloc->address = fixp->fx_frag->fr_address + fixp->fx_where;
7646
7647 if (fixp->fx_pcrel)
7648 {
7649 if (section->use_rela_p)
7650 fixp->fx_offset -= md_pcrel_from_section (fixp, section);
7651 else
7652 fixp->fx_offset = reloc->address;
7653 }
7654 reloc->addend = fixp->fx_offset;
7655
7656 code = fixp->fx_r_type;
7657 switch (code)
7658 {
7659 case BFD_RELOC_16:
7660 if (fixp->fx_pcrel)
7661 code = BFD_RELOC_16_PCREL;
7662 break;
7663
7664 case BFD_RELOC_32:
7665 if (fixp->fx_pcrel)
7666 code = BFD_RELOC_32_PCREL;
7667 break;
7668
7669 case BFD_RELOC_64:
7670 if (fixp->fx_pcrel)
7671 code = BFD_RELOC_64_PCREL;
7672 break;
7673
7674 default:
7675 break;
7676 }
7677
7678 reloc->howto = bfd_reloc_type_lookup (stdoutput, code);
7679 if (reloc->howto == NULL)
7680 {
7681 as_bad_where (fixp->fx_file, fixp->fx_line,
7682 _
7683 ("cannot represent %s relocation in this object file format"),
7684 bfd_get_reloc_code_name (code));
7685 return NULL;
7686 }
7687
7688 return reloc;
7689}
7690
7691/* This fix_new is called by cons via TC_CONS_FIX_NEW. */
7692
7693void
7694cons_fix_new_aarch64 (fragS * frag, int where, int size, expressionS * exp)
7695{
7696 bfd_reloc_code_real_type type;
7697 int pcrel = 0;
7698
7699 /* Pick a reloc.
7700 FIXME: @@ Should look at CPU word size. */
7701 switch (size)
7702 {
7703 case 1:
7704 type = BFD_RELOC_8;
7705 break;
7706 case 2:
7707 type = BFD_RELOC_16;
7708 break;
7709 case 4:
7710 type = BFD_RELOC_32;
7711 break;
7712 case 8:
7713 type = BFD_RELOC_64;
7714 break;
7715 default:
7716 as_bad (_("cannot do %u-byte relocation"), size);
7717 type = BFD_RELOC_UNUSED;
7718 break;
7719 }
7720
7721 fix_new_exp (frag, where, (int) size, exp, pcrel, type);
7722}
7723
7724int
7725aarch64_force_relocation (struct fix *fixp)
7726{
7727 switch (fixp->fx_r_type)
7728 {
7729 case BFD_RELOC_AARCH64_GAS_INTERNAL_FIXUP:
7730 /* Perform these "immediate" internal relocations
7731 even if the symbol is extern or weak. */
7732 return 0;
7733
a6bb11b2 7734 case BFD_RELOC_AARCH64_LD_GOT_LO12_NC:
f09c556a
JW
7735 case BFD_RELOC_AARCH64_TLSDESC_LD_LO12_NC:
7736 case BFD_RELOC_AARCH64_TLSIE_LD_GOTTPREL_LO12_NC:
a6bb11b2
YZ
7737 /* Pseudo relocs that need to be fixed up according to
7738 ilp32_p. */
7739 return 0;
7740
2c0a3565
MS
7741 case BFD_RELOC_AARCH64_ADD_LO12:
7742 case BFD_RELOC_AARCH64_ADR_GOT_PAGE:
7743 case BFD_RELOC_AARCH64_ADR_HI21_NC_PCREL:
7744 case BFD_RELOC_AARCH64_ADR_HI21_PCREL:
7745 case BFD_RELOC_AARCH64_GOT_LD_PREL19:
7746 case BFD_RELOC_AARCH64_LD32_GOT_LO12_NC:
3d715ce4 7747 case BFD_RELOC_AARCH64_LD32_GOTPAGE_LO14:
87f5fbcc 7748 case BFD_RELOC_AARCH64_LD64_GOTOFF_LO15:
a921b5bd 7749 case BFD_RELOC_AARCH64_LD64_GOTPAGE_LO15:
2c0a3565
MS
7750 case BFD_RELOC_AARCH64_LD64_GOT_LO12_NC:
7751 case BFD_RELOC_AARCH64_LDST128_LO12:
7752 case BFD_RELOC_AARCH64_LDST16_LO12:
7753 case BFD_RELOC_AARCH64_LDST32_LO12:
7754 case BFD_RELOC_AARCH64_LDST64_LO12:
7755 case BFD_RELOC_AARCH64_LDST8_LO12:
7756 case BFD_RELOC_AARCH64_TLSDESC_ADD_LO12_NC:
7757 case BFD_RELOC_AARCH64_TLSDESC_ADR_PAGE21:
389b8029 7758 case BFD_RELOC_AARCH64_TLSDESC_ADR_PREL21:
2c0a3565
MS
7759 case BFD_RELOC_AARCH64_TLSDESC_LD32_LO12_NC:
7760 case BFD_RELOC_AARCH64_TLSDESC_LD64_LO12_NC:
1ada945d 7761 case BFD_RELOC_AARCH64_TLSDESC_LD_PREL19:
43a357f9
RL
7762 case BFD_RELOC_AARCH64_TLSDESC_OFF_G0_NC:
7763 case BFD_RELOC_AARCH64_TLSDESC_OFF_G1:
a06ea964 7764 case BFD_RELOC_AARCH64_TLSGD_ADD_LO12_NC:
2c0a3565 7765 case BFD_RELOC_AARCH64_TLSGD_ADR_PAGE21:
3c12b054 7766 case BFD_RELOC_AARCH64_TLSGD_ADR_PREL21:
3e8286c0 7767 case BFD_RELOC_AARCH64_TLSGD_MOVW_G0_NC:
1aa66fb1 7768 case BFD_RELOC_AARCH64_TLSGD_MOVW_G1:
a06ea964 7769 case BFD_RELOC_AARCH64_TLSIE_ADR_GOTTPREL_PAGE21:
a6bb11b2 7770 case BFD_RELOC_AARCH64_TLSIE_LD32_GOTTPREL_LO12_NC:
2c0a3565 7771 case BFD_RELOC_AARCH64_TLSIE_LD64_GOTTPREL_LO12_NC:
043bf05a 7772 case BFD_RELOC_AARCH64_TLSIE_LD_GOTTPREL_PREL19:
3b957e5b
RL
7773 case BFD_RELOC_AARCH64_TLSIE_MOVW_GOTTPREL_G0_NC:
7774 case BFD_RELOC_AARCH64_TLSIE_MOVW_GOTTPREL_G1:
7775 case BFD_RELOC_AARCH64_TLSLD_ADD_DTPREL_HI12:
70151fb5 7776 case BFD_RELOC_AARCH64_TLSLD_ADD_DTPREL_LO12:
13289c10 7777 case BFD_RELOC_AARCH64_TLSLD_ADD_DTPREL_LO12_NC:
a12fad50 7778 case BFD_RELOC_AARCH64_TLSLD_ADD_LO12_NC:
1107e076 7779 case BFD_RELOC_AARCH64_TLSLD_ADR_PAGE21:
6c37fedc 7780 case BFD_RELOC_AARCH64_TLSLD_ADR_PREL21:
4c562523
JW
7781 case BFD_RELOC_AARCH64_TLSLD_LDST16_DTPREL_LO12:
7782 case BFD_RELOC_AARCH64_TLSLD_LDST16_DTPREL_LO12_NC:
7783 case BFD_RELOC_AARCH64_TLSLD_LDST32_DTPREL_LO12:
7784 case BFD_RELOC_AARCH64_TLSLD_LDST32_DTPREL_LO12_NC:
7785 case BFD_RELOC_AARCH64_TLSLD_LDST64_DTPREL_LO12:
7786 case BFD_RELOC_AARCH64_TLSLD_LDST64_DTPREL_LO12_NC:
7787 case BFD_RELOC_AARCH64_TLSLD_LDST8_DTPREL_LO12:
7788 case BFD_RELOC_AARCH64_TLSLD_LDST8_DTPREL_LO12_NC:
49df5539
JW
7789 case BFD_RELOC_AARCH64_TLSLD_MOVW_DTPREL_G0:
7790 case BFD_RELOC_AARCH64_TLSLD_MOVW_DTPREL_G0_NC:
7791 case BFD_RELOC_AARCH64_TLSLD_MOVW_DTPREL_G1:
7792 case BFD_RELOC_AARCH64_TLSLD_MOVW_DTPREL_G1_NC:
7793 case BFD_RELOC_AARCH64_TLSLD_MOVW_DTPREL_G2:
a06ea964 7794 case BFD_RELOC_AARCH64_TLSLE_ADD_TPREL_HI12:
2c0a3565 7795 case BFD_RELOC_AARCH64_TLSLE_ADD_TPREL_LO12:
a06ea964 7796 case BFD_RELOC_AARCH64_TLSLE_ADD_TPREL_LO12_NC:
a06ea964
NC
7797 case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G0:
7798 case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G0_NC:
2c0a3565
MS
7799 case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G1:
7800 case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G1_NC:
7801 case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G2:
a06ea964
NC
7802 /* Always leave these relocations for the linker. */
7803 return 1;
7804
7805 default:
7806 break;
7807 }
7808
7809 return generic_force_reloc (fixp);
7810}
7811
7812#ifdef OBJ_ELF
7813
7814const char *
7815elf64_aarch64_target_format (void)
7816{
a75cf613
ES
7817 if (strcmp (TARGET_OS, "cloudabi") == 0)
7818 {
7819 /* FIXME: What to do for ilp32_p ? */
7820 return target_big_endian ? "elf64-bigaarch64-cloudabi" : "elf64-littleaarch64-cloudabi";
7821 }
a06ea964 7822 if (target_big_endian)
cec5225b 7823 return ilp32_p ? "elf32-bigaarch64" : "elf64-bigaarch64";
a06ea964 7824 else
cec5225b 7825 return ilp32_p ? "elf32-littleaarch64" : "elf64-littleaarch64";
a06ea964
NC
7826}
7827
7828void
7829aarch64elf_frob_symbol (symbolS * symp, int *puntp)
7830{
7831 elf_frob_symbol (symp, puntp);
7832}
7833#endif
7834
7835/* MD interface: Finalization. */
7836
7837/* A good place to do this, although this was probably not intended
7838 for this kind of use. We need to dump the literal pool before
7839 references are made to a null symbol pointer. */
7840
7841void
7842aarch64_cleanup (void)
7843{
7844 literal_pool *pool;
7845
7846 for (pool = list_of_pools; pool; pool = pool->next)
7847 {
7848 /* Put it at the end of the relevant section. */
7849 subseg_set (pool->section, pool->sub_section);
7850 s_ltorg (0);
7851 }
7852}
7853
7854#ifdef OBJ_ELF
7855/* Remove any excess mapping symbols generated for alignment frags in
7856 SEC. We may have created a mapping symbol before a zero byte
7857 alignment; remove it if there's a mapping symbol after the
7858 alignment. */
7859static void
7860check_mapping_symbols (bfd * abfd ATTRIBUTE_UNUSED, asection * sec,
7861 void *dummy ATTRIBUTE_UNUSED)
7862{
7863 segment_info_type *seginfo = seg_info (sec);
7864 fragS *fragp;
7865
7866 if (seginfo == NULL || seginfo->frchainP == NULL)
7867 return;
7868
7869 for (fragp = seginfo->frchainP->frch_root;
7870 fragp != NULL; fragp = fragp->fr_next)
7871 {
7872 symbolS *sym = fragp->tc_frag_data.last_map;
7873 fragS *next = fragp->fr_next;
7874
7875 /* Variable-sized frags have been converted to fixed size by
7876 this point. But if this was variable-sized to start with,
7877 there will be a fixed-size frag after it. So don't handle
7878 next == NULL. */
7879 if (sym == NULL || next == NULL)
7880 continue;
7881
7882 if (S_GET_VALUE (sym) < next->fr_address)
7883 /* Not at the end of this frag. */
7884 continue;
7885 know (S_GET_VALUE (sym) == next->fr_address);
7886
7887 do
7888 {
7889 if (next->tc_frag_data.first_map != NULL)
7890 {
7891 /* Next frag starts with a mapping symbol. Discard this
7892 one. */
7893 symbol_remove (sym, &symbol_rootP, &symbol_lastP);
7894 break;
7895 }
7896
7897 if (next->fr_next == NULL)
7898 {
7899 /* This mapping symbol is at the end of the section. Discard
7900 it. */
7901 know (next->fr_fix == 0 && next->fr_var == 0);
7902 symbol_remove (sym, &symbol_rootP, &symbol_lastP);
7903 break;
7904 }
7905
7906 /* As long as we have empty frags without any mapping symbols,
7907 keep looking. */
7908 /* If the next frag is non-empty and does not start with a
7909 mapping symbol, then this mapping symbol is required. */
7910 if (next->fr_address != next->fr_next->fr_address)
7911 break;
7912
7913 next = next->fr_next;
7914 }
7915 while (next != NULL);
7916 }
7917}
7918#endif
7919
7920/* Adjust the symbol table. */
7921
7922void
7923aarch64_adjust_symtab (void)
7924{
7925#ifdef OBJ_ELF
7926 /* Remove any overlapping mapping symbols generated by alignment frags. */
7927 bfd_map_over_sections (stdoutput, check_mapping_symbols, (char *) 0);
7928 /* Now do generic ELF adjustments. */
7929 elf_adjust_symtab ();
7930#endif
7931}
7932
7933static void
7934checked_hash_insert (struct hash_control *table, const char *key, void *value)
7935{
7936 const char *hash_err;
7937
7938 hash_err = hash_insert (table, key, value);
7939 if (hash_err)
7940 printf ("Internal Error: Can't hash %s\n", key);
7941}
7942
7943static void
7944fill_instruction_hash_table (void)
7945{
7946 aarch64_opcode *opcode = aarch64_opcode_table;
7947
7948 while (opcode->name != NULL)
7949 {
7950 templates *templ, *new_templ;
7951 templ = hash_find (aarch64_ops_hsh, opcode->name);
7952
add39d23 7953 new_templ = XNEW (templates);
a06ea964
NC
7954 new_templ->opcode = opcode;
7955 new_templ->next = NULL;
7956
7957 if (!templ)
7958 checked_hash_insert (aarch64_ops_hsh, opcode->name, (void *) new_templ);
7959 else
7960 {
7961 new_templ->next = templ->next;
7962 templ->next = new_templ;
7963 }
7964 ++opcode;
7965 }
7966}
7967
7968static inline void
7969convert_to_upper (char *dst, const char *src, size_t num)
7970{
7971 unsigned int i;
7972 for (i = 0; i < num && *src != '\0'; ++i, ++dst, ++src)
7973 *dst = TOUPPER (*src);
7974 *dst = '\0';
7975}
7976
7977/* Assume STR point to a lower-case string, allocate, convert and return
7978 the corresponding upper-case string. */
7979static inline const char*
7980get_upper_str (const char *str)
7981{
7982 char *ret;
7983 size_t len = strlen (str);
325801bd 7984 ret = XNEWVEC (char, len + 1);
a06ea964
NC
7985 convert_to_upper (ret, str, len);
7986 return ret;
7987}
7988
7989/* MD interface: Initialization. */
7990
7991void
7992md_begin (void)
7993{
7994 unsigned mach;
7995 unsigned int i;
7996
7997 if ((aarch64_ops_hsh = hash_new ()) == NULL
7998 || (aarch64_cond_hsh = hash_new ()) == NULL
7999 || (aarch64_shift_hsh = hash_new ()) == NULL
8000 || (aarch64_sys_regs_hsh = hash_new ()) == NULL
8001 || (aarch64_pstatefield_hsh = hash_new ()) == NULL
8002 || (aarch64_sys_regs_ic_hsh = hash_new ()) == NULL
8003 || (aarch64_sys_regs_dc_hsh = hash_new ()) == NULL
8004 || (aarch64_sys_regs_at_hsh = hash_new ()) == NULL
8005 || (aarch64_sys_regs_tlbi_hsh = hash_new ()) == NULL
8006 || (aarch64_reg_hsh = hash_new ()) == NULL
8007 || (aarch64_barrier_opt_hsh = hash_new ()) == NULL
8008 || (aarch64_nzcv_hsh = hash_new ()) == NULL
1e6f4800
MW
8009 || (aarch64_pldop_hsh = hash_new ()) == NULL
8010 || (aarch64_hint_opt_hsh = hash_new ()) == NULL)
a06ea964
NC
8011 as_fatal (_("virtual memory exhausted"));
8012
8013 fill_instruction_hash_table ();
8014
8015 for (i = 0; aarch64_sys_regs[i].name != NULL; ++i)
8016 checked_hash_insert (aarch64_sys_regs_hsh, aarch64_sys_regs[i].name,
8017 (void *) (aarch64_sys_regs + i));
8018
8019 for (i = 0; aarch64_pstatefields[i].name != NULL; ++i)
8020 checked_hash_insert (aarch64_pstatefield_hsh,
8021 aarch64_pstatefields[i].name,
8022 (void *) (aarch64_pstatefields + i));
8023
875880c6 8024 for (i = 0; aarch64_sys_regs_ic[i].name != NULL; i++)
a06ea964 8025 checked_hash_insert (aarch64_sys_regs_ic_hsh,
875880c6 8026 aarch64_sys_regs_ic[i].name,
a06ea964
NC
8027 (void *) (aarch64_sys_regs_ic + i));
8028
875880c6 8029 for (i = 0; aarch64_sys_regs_dc[i].name != NULL; i++)
a06ea964 8030 checked_hash_insert (aarch64_sys_regs_dc_hsh,
875880c6 8031 aarch64_sys_regs_dc[i].name,
a06ea964
NC
8032 (void *) (aarch64_sys_regs_dc + i));
8033
875880c6 8034 for (i = 0; aarch64_sys_regs_at[i].name != NULL; i++)
a06ea964 8035 checked_hash_insert (aarch64_sys_regs_at_hsh,
875880c6 8036 aarch64_sys_regs_at[i].name,
a06ea964
NC
8037 (void *) (aarch64_sys_regs_at + i));
8038
875880c6 8039 for (i = 0; aarch64_sys_regs_tlbi[i].name != NULL; i++)
a06ea964 8040 checked_hash_insert (aarch64_sys_regs_tlbi_hsh,
875880c6 8041 aarch64_sys_regs_tlbi[i].name,
a06ea964
NC
8042 (void *) (aarch64_sys_regs_tlbi + i));
8043
8044 for (i = 0; i < ARRAY_SIZE (reg_names); i++)
8045 checked_hash_insert (aarch64_reg_hsh, reg_names[i].name,
8046 (void *) (reg_names + i));
8047
8048 for (i = 0; i < ARRAY_SIZE (nzcv_names); i++)
8049 checked_hash_insert (aarch64_nzcv_hsh, nzcv_names[i].template,
8050 (void *) (nzcv_names + i));
8051
8052 for (i = 0; aarch64_operand_modifiers[i].name != NULL; i++)
8053 {
8054 const char *name = aarch64_operand_modifiers[i].name;
8055 checked_hash_insert (aarch64_shift_hsh, name,
8056 (void *) (aarch64_operand_modifiers + i));
8057 /* Also hash the name in the upper case. */
8058 checked_hash_insert (aarch64_shift_hsh, get_upper_str (name),
8059 (void *) (aarch64_operand_modifiers + i));
8060 }
8061
8062 for (i = 0; i < ARRAY_SIZE (aarch64_conds); i++)
8063 {
8064 unsigned int j;
8065 /* A condition code may have alias(es), e.g. "cc", "lo" and "ul" are
8066 the same condition code. */
8067 for (j = 0; j < ARRAY_SIZE (aarch64_conds[i].names); ++j)
8068 {
8069 const char *name = aarch64_conds[i].names[j];
8070 if (name == NULL)
8071 break;
8072 checked_hash_insert (aarch64_cond_hsh, name,
8073 (void *) (aarch64_conds + i));
8074 /* Also hash the name in the upper case. */
8075 checked_hash_insert (aarch64_cond_hsh, get_upper_str (name),
8076 (void *) (aarch64_conds + i));
8077 }
8078 }
8079
8080 for (i = 0; i < ARRAY_SIZE (aarch64_barrier_options); i++)
8081 {
8082 const char *name = aarch64_barrier_options[i].name;
8083 /* Skip xx00 - the unallocated values of option. */
8084 if ((i & 0x3) == 0)
8085 continue;
8086 checked_hash_insert (aarch64_barrier_opt_hsh, name,
8087 (void *) (aarch64_barrier_options + i));
8088 /* Also hash the name in the upper case. */
8089 checked_hash_insert (aarch64_barrier_opt_hsh, get_upper_str (name),
8090 (void *) (aarch64_barrier_options + i));
8091 }
8092
8093 for (i = 0; i < ARRAY_SIZE (aarch64_prfops); i++)
8094 {
8095 const char* name = aarch64_prfops[i].name;
a1ccaec9
YZ
8096 /* Skip the unallocated hint encodings. */
8097 if (name == NULL)
a06ea964
NC
8098 continue;
8099 checked_hash_insert (aarch64_pldop_hsh, name,
8100 (void *) (aarch64_prfops + i));
8101 /* Also hash the name in the upper case. */
8102 checked_hash_insert (aarch64_pldop_hsh, get_upper_str (name),
8103 (void *) (aarch64_prfops + i));
8104 }
8105
1e6f4800
MW
8106 for (i = 0; aarch64_hint_options[i].name != NULL; i++)
8107 {
8108 const char* name = aarch64_hint_options[i].name;
8109
8110 checked_hash_insert (aarch64_hint_opt_hsh, name,
8111 (void *) (aarch64_hint_options + i));
8112 /* Also hash the name in the upper case. */
8113 checked_hash_insert (aarch64_pldop_hsh, get_upper_str (name),
8114 (void *) (aarch64_hint_options + i));
8115 }
8116
a06ea964
NC
8117 /* Set the cpu variant based on the command-line options. */
8118 if (!mcpu_cpu_opt)
8119 mcpu_cpu_opt = march_cpu_opt;
8120
8121 if (!mcpu_cpu_opt)
8122 mcpu_cpu_opt = &cpu_default;
8123
8124 cpu_variant = *mcpu_cpu_opt;
8125
8126 /* Record the CPU type. */
cec5225b 8127 mach = ilp32_p ? bfd_mach_aarch64_ilp32 : bfd_mach_aarch64;
a06ea964
NC
8128
8129 bfd_set_arch_mach (stdoutput, TARGET_ARCH, mach);
8130}
8131
8132/* Command line processing. */
8133
8134const char *md_shortopts = "m:";
8135
8136#ifdef AARCH64_BI_ENDIAN
8137#define OPTION_EB (OPTION_MD_BASE + 0)
8138#define OPTION_EL (OPTION_MD_BASE + 1)
8139#else
8140#if TARGET_BYTES_BIG_ENDIAN
8141#define OPTION_EB (OPTION_MD_BASE + 0)
8142#else
8143#define OPTION_EL (OPTION_MD_BASE + 1)
8144#endif
8145#endif
8146
8147struct option md_longopts[] = {
8148#ifdef OPTION_EB
8149 {"EB", no_argument, NULL, OPTION_EB},
8150#endif
8151#ifdef OPTION_EL
8152 {"EL", no_argument, NULL, OPTION_EL},
8153#endif
8154 {NULL, no_argument, NULL, 0}
8155};
8156
8157size_t md_longopts_size = sizeof (md_longopts);
8158
8159struct aarch64_option_table
8160{
e0471c16
TS
8161 const char *option; /* Option name to match. */
8162 const char *help; /* Help information. */
a06ea964
NC
8163 int *var; /* Variable to change. */
8164 int value; /* What to change it to. */
8165 char *deprecated; /* If non-null, print this message. */
8166};
8167
8168static struct aarch64_option_table aarch64_opts[] = {
8169 {"mbig-endian", N_("assemble for big-endian"), &target_big_endian, 1, NULL},
8170 {"mlittle-endian", N_("assemble for little-endian"), &target_big_endian, 0,
8171 NULL},
8172#ifdef DEBUG_AARCH64
8173 {"mdebug-dump", N_("temporary switch for dumping"), &debug_dump, 1, NULL},
8174#endif /* DEBUG_AARCH64 */
8175 {"mverbose-error", N_("output verbose error messages"), &verbose_error_p, 1,
8176 NULL},
a52e6fd3
YZ
8177 {"mno-verbose-error", N_("do not output verbose error messages"),
8178 &verbose_error_p, 0, NULL},
a06ea964
NC
8179 {NULL, NULL, NULL, 0, NULL}
8180};
8181
8182struct aarch64_cpu_option_table
8183{
e0471c16 8184 const char *name;
a06ea964
NC
8185 const aarch64_feature_set value;
8186 /* The canonical name of the CPU, or NULL to use NAME converted to upper
8187 case. */
8188 const char *canonical_name;
8189};
8190
8191/* This list should, at a minimum, contain all the cpu names
8192 recognized by GCC. */
8193static const struct aarch64_cpu_option_table aarch64_cpus[] = {
8194 {"all", AARCH64_ANY, NULL},
9c352f1c
JG
8195 {"cortex-a35", AARCH64_FEATURE (AARCH64_ARCH_V8,
8196 AARCH64_FEATURE_CRC), "Cortex-A35"},
aa31c464
JW
8197 {"cortex-a53", AARCH64_FEATURE (AARCH64_ARCH_V8,
8198 AARCH64_FEATURE_CRC), "Cortex-A53"},
8199 {"cortex-a57", AARCH64_FEATURE (AARCH64_ARCH_V8,
8200 AARCH64_FEATURE_CRC), "Cortex-A57"},
2abdd192
JW
8201 {"cortex-a72", AARCH64_FEATURE (AARCH64_ARCH_V8,
8202 AARCH64_FEATURE_CRC), "Cortex-A72"},
1aa70332
KT
8203 {"cortex-a73", AARCH64_FEATURE (AARCH64_ARCH_V8,
8204 AARCH64_FEATURE_CRC), "Cortex-A73"},
2412d878
EM
8205 {"exynos-m1", AARCH64_FEATURE (AARCH64_ARCH_V8,
8206 AARCH64_FEATURE_CRC | AARCH64_FEATURE_CRYPTO),
8207 "Samsung Exynos M1"},
6b21c2bf
JW
8208 {"qdf24xx", AARCH64_FEATURE (AARCH64_ARCH_V8,
8209 AARCH64_FEATURE_CRC | AARCH64_FEATURE_CRYPTO),
8210 "Qualcomm QDF24XX"},
faade851
JW
8211 {"thunderx", AARCH64_FEATURE (AARCH64_ARCH_V8,
8212 AARCH64_FEATURE_CRC | AARCH64_FEATURE_CRYPTO),
8213 "Cavium ThunderX"},
9f99c22e
VP
8214 {"vulcan", AARCH64_FEATURE (AARCH64_ARCH_V8_1,
8215 AARCH64_FEATURE_CRYPTO),
0a8be2fe 8216 "Broadcom Vulcan"},
070cb956
PT
8217 /* The 'xgene-1' name is an older name for 'xgene1', which was used
8218 in earlier releases and is superseded by 'xgene1' in all
8219 tools. */
9877c63c 8220 {"xgene-1", AARCH64_ARCH_V8, "APM X-Gene 1"},
070cb956 8221 {"xgene1", AARCH64_ARCH_V8, "APM X-Gene 1"},
aa31c464
JW
8222 {"xgene2", AARCH64_FEATURE (AARCH64_ARCH_V8,
8223 AARCH64_FEATURE_CRC), "APM X-Gene 2"},
a06ea964
NC
8224 {"generic", AARCH64_ARCH_V8, NULL},
8225
a06ea964
NC
8226 {NULL, AARCH64_ARCH_NONE, NULL}
8227};
8228
8229struct aarch64_arch_option_table
8230{
e0471c16 8231 const char *name;
a06ea964
NC
8232 const aarch64_feature_set value;
8233};
8234
8235/* This list should, at a minimum, contain all the architecture names
8236 recognized by GCC. */
8237static const struct aarch64_arch_option_table aarch64_archs[] = {
8238 {"all", AARCH64_ANY},
5a1ad39d 8239 {"armv8-a", AARCH64_ARCH_V8},
88f0ea34 8240 {"armv8.1-a", AARCH64_ARCH_V8_1},
acb787b0 8241 {"armv8.2-a", AARCH64_ARCH_V8_2},
a06ea964
NC
8242 {NULL, AARCH64_ARCH_NONE}
8243};
8244
8245/* ISA extensions. */
8246struct aarch64_option_cpu_value_table
8247{
e0471c16 8248 const char *name;
a06ea964 8249 const aarch64_feature_set value;
93d8990c 8250 const aarch64_feature_set require; /* Feature dependencies. */
a06ea964
NC
8251};
8252
8253static const struct aarch64_option_cpu_value_table aarch64_features[] = {
93d8990c
SN
8254 {"crc", AARCH64_FEATURE (AARCH64_FEATURE_CRC, 0),
8255 AARCH64_ARCH_NONE},
8256 {"crypto", AARCH64_FEATURE (AARCH64_FEATURE_CRYPTO, 0),
8257 AARCH64_ARCH_NONE},
8258 {"fp", AARCH64_FEATURE (AARCH64_FEATURE_FP, 0),
8259 AARCH64_ARCH_NONE},
8260 {"lse", AARCH64_FEATURE (AARCH64_FEATURE_LSE, 0),
8261 AARCH64_ARCH_NONE},
8262 {"simd", AARCH64_FEATURE (AARCH64_FEATURE_SIMD, 0),
8263 AARCH64_ARCH_NONE},
8264 {"pan", AARCH64_FEATURE (AARCH64_FEATURE_PAN, 0),
8265 AARCH64_ARCH_NONE},
8266 {"lor", AARCH64_FEATURE (AARCH64_FEATURE_LOR, 0),
8267 AARCH64_ARCH_NONE},
8268 {"ras", AARCH64_FEATURE (AARCH64_FEATURE_RAS, 0),
8269 AARCH64_ARCH_NONE},
8270 {"rdma", AARCH64_FEATURE (AARCH64_FEATURE_RDMA, 0),
8271 AARCH64_FEATURE (AARCH64_FEATURE_SIMD, 0)},
8272 {"fp16", AARCH64_FEATURE (AARCH64_FEATURE_F16, 0),
8273 AARCH64_FEATURE (AARCH64_FEATURE_FP, 0)},
8274 {"profile", AARCH64_FEATURE (AARCH64_FEATURE_PROFILE, 0),
8275 AARCH64_ARCH_NONE},
8276 {NULL, AARCH64_ARCH_NONE, AARCH64_ARCH_NONE},
a06ea964
NC
8277};
8278
8279struct aarch64_long_option_table
8280{
e0471c16
TS
8281 const char *option; /* Substring to match. */
8282 const char *help; /* Help information. */
17b9d67d 8283 int (*func) (const char *subopt); /* Function to decode sub-option. */
a06ea964
NC
8284 char *deprecated; /* If non-null, print this message. */
8285};
8286
93d8990c
SN
8287/* Transitive closure of features depending on set. */
8288static aarch64_feature_set
8289aarch64_feature_disable_set (aarch64_feature_set set)
8290{
8291 const struct aarch64_option_cpu_value_table *opt;
8292 aarch64_feature_set prev = 0;
8293
8294 while (prev != set) {
8295 prev = set;
8296 for (opt = aarch64_features; opt->name != NULL; opt++)
8297 if (AARCH64_CPU_HAS_ANY_FEATURES (opt->require, set))
8298 AARCH64_MERGE_FEATURE_SETS (set, set, opt->value);
8299 }
8300 return set;
8301}
8302
8303/* Transitive closure of dependencies of set. */
8304static aarch64_feature_set
8305aarch64_feature_enable_set (aarch64_feature_set set)
8306{
8307 const struct aarch64_option_cpu_value_table *opt;
8308 aarch64_feature_set prev = 0;
8309
8310 while (prev != set) {
8311 prev = set;
8312 for (opt = aarch64_features; opt->name != NULL; opt++)
8313 if (AARCH64_CPU_HAS_FEATURE (set, opt->value))
8314 AARCH64_MERGE_FEATURE_SETS (set, set, opt->require);
8315 }
8316 return set;
8317}
8318
a06ea964 8319static int
82b8a785 8320aarch64_parse_features (const char *str, const aarch64_feature_set **opt_p,
ae527cd8 8321 bfd_boolean ext_only)
a06ea964
NC
8322{
8323 /* We insist on extensions being added before being removed. We achieve
8324 this by using the ADDING_VALUE variable to indicate whether we are
8325 adding an extension (1) or removing it (0) and only allowing it to
8326 change in the order -1 -> 1 -> 0. */
8327 int adding_value = -1;
325801bd 8328 aarch64_feature_set *ext_set = XNEW (aarch64_feature_set);
a06ea964
NC
8329
8330 /* Copy the feature set, so that we can modify it. */
8331 *ext_set = **opt_p;
8332 *opt_p = ext_set;
8333
8334 while (str != NULL && *str != 0)
8335 {
8336 const struct aarch64_option_cpu_value_table *opt;
82b8a785 8337 const char *ext = NULL;
a06ea964
NC
8338 int optlen;
8339
ae527cd8 8340 if (!ext_only)
a06ea964 8341 {
ae527cd8
JB
8342 if (*str != '+')
8343 {
8344 as_bad (_("invalid architectural extension"));
8345 return 0;
8346 }
a06ea964 8347
ae527cd8
JB
8348 ext = strchr (++str, '+');
8349 }
a06ea964
NC
8350
8351 if (ext != NULL)
8352 optlen = ext - str;
8353 else
8354 optlen = strlen (str);
8355
8356 if (optlen >= 2 && strncmp (str, "no", 2) == 0)
8357 {
8358 if (adding_value != 0)
8359 adding_value = 0;
8360 optlen -= 2;
8361 str += 2;
8362 }
8363 else if (optlen > 0)
8364 {
8365 if (adding_value == -1)
8366 adding_value = 1;
8367 else if (adding_value != 1)
8368 {
8369 as_bad (_("must specify extensions to add before specifying "
8370 "those to remove"));
8371 return FALSE;
8372 }
8373 }
8374
8375 if (optlen == 0)
8376 {
8377 as_bad (_("missing architectural extension"));
8378 return 0;
8379 }
8380
8381 gas_assert (adding_value != -1);
8382
8383 for (opt = aarch64_features; opt->name != NULL; opt++)
8384 if (strncmp (opt->name, str, optlen) == 0)
8385 {
93d8990c
SN
8386 aarch64_feature_set set;
8387
a06ea964
NC
8388 /* Add or remove the extension. */
8389 if (adding_value)
93d8990c
SN
8390 {
8391 set = aarch64_feature_enable_set (opt->value);
8392 AARCH64_MERGE_FEATURE_SETS (*ext_set, *ext_set, set);
8393 }
a06ea964 8394 else
93d8990c
SN
8395 {
8396 set = aarch64_feature_disable_set (opt->value);
8397 AARCH64_CLEAR_FEATURE (*ext_set, *ext_set, set);
8398 }
a06ea964
NC
8399 break;
8400 }
8401
8402 if (opt->name == NULL)
8403 {
8404 as_bad (_("unknown architectural extension `%s'"), str);
8405 return 0;
8406 }
8407
8408 str = ext;
8409 };
8410
8411 return 1;
8412}
8413
8414static int
17b9d67d 8415aarch64_parse_cpu (const char *str)
a06ea964
NC
8416{
8417 const struct aarch64_cpu_option_table *opt;
82b8a785 8418 const char *ext = strchr (str, '+');
a06ea964
NC
8419 size_t optlen;
8420
8421 if (ext != NULL)
8422 optlen = ext - str;
8423 else
8424 optlen = strlen (str);
8425
8426 if (optlen == 0)
8427 {
8428 as_bad (_("missing cpu name `%s'"), str);
8429 return 0;
8430 }
8431
8432 for (opt = aarch64_cpus; opt->name != NULL; opt++)
8433 if (strlen (opt->name) == optlen && strncmp (str, opt->name, optlen) == 0)
8434 {
8435 mcpu_cpu_opt = &opt->value;
8436 if (ext != NULL)
ae527cd8 8437 return aarch64_parse_features (ext, &mcpu_cpu_opt, FALSE);
a06ea964
NC
8438
8439 return 1;
8440 }
8441
8442 as_bad (_("unknown cpu `%s'"), str);
8443 return 0;
8444}
8445
8446static int
17b9d67d 8447aarch64_parse_arch (const char *str)
a06ea964
NC
8448{
8449 const struct aarch64_arch_option_table *opt;
82b8a785 8450 const char *ext = strchr (str, '+');
a06ea964
NC
8451 size_t optlen;
8452
8453 if (ext != NULL)
8454 optlen = ext - str;
8455 else
8456 optlen = strlen (str);
8457
8458 if (optlen == 0)
8459 {
8460 as_bad (_("missing architecture name `%s'"), str);
8461 return 0;
8462 }
8463
8464 for (opt = aarch64_archs; opt->name != NULL; opt++)
8465 if (strlen (opt->name) == optlen && strncmp (str, opt->name, optlen) == 0)
8466 {
8467 march_cpu_opt = &opt->value;
8468 if (ext != NULL)
ae527cd8 8469 return aarch64_parse_features (ext, &march_cpu_opt, FALSE);
a06ea964
NC
8470
8471 return 1;
8472 }
8473
8474 as_bad (_("unknown architecture `%s'\n"), str);
8475 return 0;
8476}
8477
69091a2c
YZ
8478/* ABIs. */
8479struct aarch64_option_abi_value_table
8480{
e0471c16 8481 const char *name;
69091a2c
YZ
8482 enum aarch64_abi_type value;
8483};
8484
8485static const struct aarch64_option_abi_value_table aarch64_abis[] = {
8486 {"ilp32", AARCH64_ABI_ILP32},
8487 {"lp64", AARCH64_ABI_LP64},
69091a2c
YZ
8488};
8489
8490static int
17b9d67d 8491aarch64_parse_abi (const char *str)
69091a2c 8492{
5703197e 8493 unsigned int i;
69091a2c 8494
5703197e 8495 if (str[0] == '\0')
69091a2c
YZ
8496 {
8497 as_bad (_("missing abi name `%s'"), str);
8498 return 0;
8499 }
8500
5703197e
TS
8501 for (i = 0; i < ARRAY_SIZE (aarch64_abis); i++)
8502 if (strcmp (str, aarch64_abis[i].name) == 0)
69091a2c 8503 {
5703197e 8504 aarch64_abi = aarch64_abis[i].value;
69091a2c
YZ
8505 return 1;
8506 }
8507
8508 as_bad (_("unknown abi `%s'\n"), str);
8509 return 0;
8510}
8511
a06ea964 8512static struct aarch64_long_option_table aarch64_long_opts[] = {
69091a2c
YZ
8513#ifdef OBJ_ELF
8514 {"mabi=", N_("<abi name>\t specify for ABI <abi name>"),
8515 aarch64_parse_abi, NULL},
8516#endif /* OBJ_ELF */
a06ea964
NC
8517 {"mcpu=", N_("<cpu name>\t assemble for CPU <cpu name>"),
8518 aarch64_parse_cpu, NULL},
8519 {"march=", N_("<arch name>\t assemble for architecture <arch name>"),
8520 aarch64_parse_arch, NULL},
8521 {NULL, NULL, 0, NULL}
8522};
8523
8524int
17b9d67d 8525md_parse_option (int c, const char *arg)
a06ea964
NC
8526{
8527 struct aarch64_option_table *opt;
8528 struct aarch64_long_option_table *lopt;
8529
8530 switch (c)
8531 {
8532#ifdef OPTION_EB
8533 case OPTION_EB:
8534 target_big_endian = 1;
8535 break;
8536#endif
8537
8538#ifdef OPTION_EL
8539 case OPTION_EL:
8540 target_big_endian = 0;
8541 break;
8542#endif
8543
8544 case 'a':
8545 /* Listing option. Just ignore these, we don't support additional
8546 ones. */
8547 return 0;
8548
8549 default:
8550 for (opt = aarch64_opts; opt->option != NULL; opt++)
8551 {
8552 if (c == opt->option[0]
8553 && ((arg == NULL && opt->option[1] == 0)
8554 || streq (arg, opt->option + 1)))
8555 {
8556 /* If the option is deprecated, tell the user. */
8557 if (opt->deprecated != NULL)
8558 as_tsktsk (_("option `-%c%s' is deprecated: %s"), c,
8559 arg ? arg : "", _(opt->deprecated));
8560
8561 if (opt->var != NULL)
8562 *opt->var = opt->value;
8563
8564 return 1;
8565 }
8566 }
8567
8568 for (lopt = aarch64_long_opts; lopt->option != NULL; lopt++)
8569 {
8570 /* These options are expected to have an argument. */
8571 if (c == lopt->option[0]
8572 && arg != NULL
8573 && strncmp (arg, lopt->option + 1,
8574 strlen (lopt->option + 1)) == 0)
8575 {
8576 /* If the option is deprecated, tell the user. */
8577 if (lopt->deprecated != NULL)
8578 as_tsktsk (_("option `-%c%s' is deprecated: %s"), c, arg,
8579 _(lopt->deprecated));
8580
8581 /* Call the sup-option parser. */
8582 return lopt->func (arg + strlen (lopt->option) - 1);
8583 }
8584 }
8585
8586 return 0;
8587 }
8588
8589 return 1;
8590}
8591
8592void
8593md_show_usage (FILE * fp)
8594{
8595 struct aarch64_option_table *opt;
8596 struct aarch64_long_option_table *lopt;
8597
8598 fprintf (fp, _(" AArch64-specific assembler options:\n"));
8599
8600 for (opt = aarch64_opts; opt->option != NULL; opt++)
8601 if (opt->help != NULL)
8602 fprintf (fp, " -%-23s%s\n", opt->option, _(opt->help));
8603
8604 for (lopt = aarch64_long_opts; lopt->option != NULL; lopt++)
8605 if (lopt->help != NULL)
8606 fprintf (fp, " -%s%s\n", lopt->option, _(lopt->help));
8607
8608#ifdef OPTION_EB
8609 fprintf (fp, _("\
8610 -EB assemble code for a big-endian cpu\n"));
8611#endif
8612
8613#ifdef OPTION_EL
8614 fprintf (fp, _("\
8615 -EL assemble code for a little-endian cpu\n"));
8616#endif
8617}
8618
8619/* Parse a .cpu directive. */
8620
8621static void
8622s_aarch64_cpu (int ignored ATTRIBUTE_UNUSED)
8623{
8624 const struct aarch64_cpu_option_table *opt;
8625 char saved_char;
8626 char *name;
8627 char *ext;
8628 size_t optlen;
8629
8630 name = input_line_pointer;
8631 while (*input_line_pointer && !ISSPACE (*input_line_pointer))
8632 input_line_pointer++;
8633 saved_char = *input_line_pointer;
8634 *input_line_pointer = 0;
8635
8636 ext = strchr (name, '+');
8637
8638 if (ext != NULL)
8639 optlen = ext - name;
8640 else
8641 optlen = strlen (name);
8642
8643 /* Skip the first "all" entry. */
8644 for (opt = aarch64_cpus + 1; opt->name != NULL; opt++)
8645 if (strlen (opt->name) == optlen
8646 && strncmp (name, opt->name, optlen) == 0)
8647 {
8648 mcpu_cpu_opt = &opt->value;
8649 if (ext != NULL)
ae527cd8 8650 if (!aarch64_parse_features (ext, &mcpu_cpu_opt, FALSE))
a06ea964
NC
8651 return;
8652
8653 cpu_variant = *mcpu_cpu_opt;
8654
8655 *input_line_pointer = saved_char;
8656 demand_empty_rest_of_line ();
8657 return;
8658 }
8659 as_bad (_("unknown cpu `%s'"), name);
8660 *input_line_pointer = saved_char;
8661 ignore_rest_of_line ();
8662}
8663
8664
8665/* Parse a .arch directive. */
8666
8667static void
8668s_aarch64_arch (int ignored ATTRIBUTE_UNUSED)
8669{
8670 const struct aarch64_arch_option_table *opt;
8671 char saved_char;
8672 char *name;
8673 char *ext;
8674 size_t optlen;
8675
8676 name = input_line_pointer;
8677 while (*input_line_pointer && !ISSPACE (*input_line_pointer))
8678 input_line_pointer++;
8679 saved_char = *input_line_pointer;
8680 *input_line_pointer = 0;
8681
8682 ext = strchr (name, '+');
8683
8684 if (ext != NULL)
8685 optlen = ext - name;
8686 else
8687 optlen = strlen (name);
8688
8689 /* Skip the first "all" entry. */
8690 for (opt = aarch64_archs + 1; opt->name != NULL; opt++)
8691 if (strlen (opt->name) == optlen
8692 && strncmp (name, opt->name, optlen) == 0)
8693 {
8694 mcpu_cpu_opt = &opt->value;
8695 if (ext != NULL)
ae527cd8 8696 if (!aarch64_parse_features (ext, &mcpu_cpu_opt, FALSE))
a06ea964
NC
8697 return;
8698
8699 cpu_variant = *mcpu_cpu_opt;
8700
8701 *input_line_pointer = saved_char;
8702 demand_empty_rest_of_line ();
8703 return;
8704 }
8705
8706 as_bad (_("unknown architecture `%s'\n"), name);
8707 *input_line_pointer = saved_char;
8708 ignore_rest_of_line ();
8709}
8710
ae527cd8
JB
8711/* Parse a .arch_extension directive. */
8712
8713static void
8714s_aarch64_arch_extension (int ignored ATTRIBUTE_UNUSED)
8715{
8716 char saved_char;
8717 char *ext = input_line_pointer;;
8718
8719 while (*input_line_pointer && !ISSPACE (*input_line_pointer))
8720 input_line_pointer++;
8721 saved_char = *input_line_pointer;
8722 *input_line_pointer = 0;
8723
8724 if (!aarch64_parse_features (ext, &mcpu_cpu_opt, TRUE))
8725 return;
8726
8727 cpu_variant = *mcpu_cpu_opt;
8728
8729 *input_line_pointer = saved_char;
8730 demand_empty_rest_of_line ();
8731}
8732
a06ea964
NC
8733/* Copy symbol information. */
8734
8735void
8736aarch64_copy_symbol_attributes (symbolS * dest, symbolS * src)
8737{
8738 AARCH64_GET_FLAG (dest) = AARCH64_GET_FLAG (src);
8739}
This page took 0.651681 seconds and 4 git commands to generate.