Correct ChangeLog dates for git commit 3f0a5f17d7f
[deliverable/binutils-gdb.git] / gas / config / tc-xtensa.c
CommitLineData
e0001a05 1/* tc-xtensa.c -- Assemble Xtensa instructions.
219d1afa 2 Copyright (C) 2003-2018 Free Software Foundation, Inc.
e0001a05
NC
3
4 This file is part of GAS, the GNU Assembler.
5
6 GAS is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
ec2655a6 8 the Free Software Foundation; either version 3, or (at your option)
e0001a05
NC
9 any later version.
10
11 GAS is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
15
16 You should have received a copy of the GNU General Public License
17 along with GAS; see the file COPYING. If not, write to
4b4da160
NC
18 the Free Software Foundation, 51 Franklin Street - Fifth Floor, Boston,
19 MA 02110-1301, USA. */
e0001a05 20
e0001a05 21#include "as.h"
df7b86aa 22#include <limits.h>
e0001a05
NC
23#include "sb.h"
24#include "safe-ctype.h"
25#include "tc-xtensa.h"
e0001a05
NC
26#include "subsegs.h"
27#include "xtensa-relax.h"
cda2eb9e 28#include "dwarf2dbg.h"
b224e962 29#include "xtensa-istack.h"
e0001a05
NC
30#include "struc-symbol.h"
31#include "xtensa-config.h"
b0b79343 32#include "elf/xtensa.h"
e0001a05 33
2caa7ca0
BW
34/* Provide default values for new configuration settings. */
35#ifndef XSHAL_ABI
36#define XSHAL_ABI 0
37#endif
38
e0001a05
NC
39#ifndef uint32
40#define uint32 unsigned int
41#endif
42#ifndef int32
43#define int32 signed int
44#endif
45
46/* Notes:
47
e0001a05
NC
48 Naming conventions (used somewhat inconsistently):
49 The xtensa_ functions are exported
50 The xg_ functions are internal
51
52 We also have a couple of different extensibility mechanisms.
53 1) The idiom replacement:
54 This is used when a line is first parsed to
55 replace an instruction pattern with another instruction
56 It is currently limited to replacements of instructions
57 with constant operands.
58 2) The xtensa-relax.c mechanism that has stronger instruction
59 replacement patterns. When an instruction's immediate field
60 does not fit the next instruction sequence is attempted.
61 In addition, "narrow" opcodes are supported this way. */
62
63
64/* Define characters with special meanings to GAS. */
65const char comment_chars[] = "#";
66const char line_comment_chars[] = "#";
67const char line_separator_chars[] = ";";
68const char EXP_CHARS[] = "eE";
69const char FLT_CHARS[] = "rRsSfFdDxXpP";
70
71
43cd72b9
BW
72/* Flags to indicate whether the hardware supports the density and
73 absolute literals options. */
e0001a05 74
f7e16c2a
MF
75bfd_boolean density_supported;
76bfd_boolean absolute_literals_supported;
43cd72b9 77
43cd72b9
BW
78static vliw_insn cur_vinsn;
79
77cba8a3 80unsigned xtensa_num_pipe_stages;
f7e16c2a 81unsigned xtensa_fetch_width;
43cd72b9
BW
82
83static enum debug_info_type xt_saved_debug_type = DEBUG_NONE;
84
85/* Some functions are only valid in the front end. This variable
c138bc38 86 allows us to assert that we haven't crossed over into the
43cd72b9
BW
87 back end. */
88static bfd_boolean past_xtensa_end = FALSE;
e0001a05
NC
89
90/* Flags for properties of the last instruction in a segment. */
91#define FLAG_IS_A0_WRITER 0x1
92#define FLAG_IS_BAD_LOOPEND 0x2
93
94
95/* We define a special segment names ".literal" to place literals
96 into. The .fini and .init sections are special because they
97 contain code that is moved together by the linker. We give them
98 their own special .fini.literal and .init.literal sections. */
99
100#define LITERAL_SECTION_NAME xtensa_section_rename (".literal")
43cd72b9 101#define LIT4_SECTION_NAME xtensa_section_rename (".lit4")
e0001a05 102#define INIT_SECTION_NAME xtensa_section_rename (".init")
74869ac7 103#define FINI_SECTION_NAME xtensa_section_rename (".fini")
e0001a05
NC
104
105
43cd72b9 106/* This type is used for the directive_stack to keep track of the
74869ac7
BW
107 state of the literal collection pools. If lit_prefix is set, it is
108 used to determine the literal section names; otherwise, the literal
109 sections are determined based on the current text section. The
110 lit_seg and lit4_seg fields cache these literal sections, with the
111 current_text_seg field used a tag to indicate whether the cached
112 values are valid. */
e0001a05
NC
113
114typedef struct lit_state_struct
115{
74869ac7
BW
116 char *lit_prefix;
117 segT current_text_seg;
e0001a05 118 segT lit_seg;
43cd72b9 119 segT lit4_seg;
e0001a05
NC
120} lit_state;
121
122static lit_state default_lit_sections;
123
124
74869ac7
BW
125/* We keep a list of literal segments. The seg_list type is the node
126 for this list. The literal_head pointer is the head of the list,
127 with the literal_head_h dummy node at the start. */
e0001a05
NC
128
129typedef struct seg_list_struct
130{
131 struct seg_list_struct *next;
132 segT seg;
133} seg_list;
134
135static seg_list literal_head_h;
136static seg_list *literal_head = &literal_head_h;
e0001a05
NC
137
138
82e7541d
BW
139/* Lists of symbols. We keep a list of symbols that label the current
140 instruction, so that we can adjust the symbols when inserting alignment
141 for various instructions. We also keep a list of all the symbols on
142 literals, so that we can fix up those symbols when the literals are
143 later moved into the text sections. */
144
145typedef struct sym_list_struct
146{
147 struct sym_list_struct *next;
148 symbolS *sym;
149} sym_list;
150
151static sym_list *insn_labels = NULL;
152static sym_list *free_insn_labels = NULL;
153static sym_list *saved_insn_labels = NULL;
154
155static sym_list *literal_syms;
156
157
43cd72b9
BW
158/* Flags to determine whether to prefer const16 or l32r
159 if both options are available. */
160int prefer_const16 = 0;
161int prefer_l32r = 0;
162
e0001a05
NC
163/* Global flag to indicate when we are emitting literals. */
164int generating_literals = 0;
165
43cd72b9
BW
166/* The following PROPERTY table definitions are copied from
167 <elf/xtensa.h> and must be kept in sync with the code there. */
168
169/* Flags in the property tables to specify whether blocks of memory
170 are literals, instructions, data, or unreachable. For
171 instructions, blocks that begin loop targets and branch targets are
172 designated. Blocks that do not allow density, instruction
173 reordering or transformation are also specified. Finally, for
174 branch targets, branch target alignment priority is included.
175 Alignment of the next block is specified in the current block
176 and the size of the current block does not include any fill required
177 to align to the next block. */
178
179#define XTENSA_PROP_LITERAL 0x00000001
180#define XTENSA_PROP_INSN 0x00000002
181#define XTENSA_PROP_DATA 0x00000004
182#define XTENSA_PROP_UNREACHABLE 0x00000008
183/* Instruction only properties at beginning of code. */
184#define XTENSA_PROP_INSN_LOOP_TARGET 0x00000010
185#define XTENSA_PROP_INSN_BRANCH_TARGET 0x00000020
186/* Instruction only properties about code. */
187#define XTENSA_PROP_INSN_NO_DENSITY 0x00000040
188#define XTENSA_PROP_INSN_NO_REORDER 0x00000080
99ded152
BW
189/* Historically, NO_TRANSFORM was a property of instructions,
190 but it should apply to literals under certain circumstances. */
191#define XTENSA_PROP_NO_TRANSFORM 0x00000100
43cd72b9
BW
192
193/* Branch target alignment information. This transmits information
194 to the linker optimization about the priority of aligning a
195 particular block for branch target alignment: None, low priority,
196 high priority, or required. These only need to be checked in
197 instruction blocks marked as XTENSA_PROP_INSN_BRANCH_TARGET.
198 Common usage is
199
200 switch (GET_XTENSA_PROP_BT_ALIGN (flags))
201 case XTENSA_PROP_BT_ALIGN_NONE:
202 case XTENSA_PROP_BT_ALIGN_LOW:
203 case XTENSA_PROP_BT_ALIGN_HIGH:
204 case XTENSA_PROP_BT_ALIGN_REQUIRE:
205*/
206#define XTENSA_PROP_BT_ALIGN_MASK 0x00000600
207
208/* No branch target alignment. */
209#define XTENSA_PROP_BT_ALIGN_NONE 0x0
210/* Low priority branch target alignment. */
211#define XTENSA_PROP_BT_ALIGN_LOW 0x1
212/* High priority branch target alignment. */
213#define XTENSA_PROP_BT_ALIGN_HIGH 0x2
214/* Required branch target alignment. */
215#define XTENSA_PROP_BT_ALIGN_REQUIRE 0x3
216
43cd72b9
BW
217#define SET_XTENSA_PROP_BT_ALIGN(flag, align) \
218 (((flag) & (~XTENSA_PROP_BT_ALIGN_MASK)) | \
219 (((align) << 9) & XTENSA_PROP_BT_ALIGN_MASK))
220
221
222/* Alignment is specified in the block BEFORE the one that needs
223 alignment. Up to 5 bits. Use GET_XTENSA_PROP_ALIGNMENT(flags) to
224 get the required alignment specified as a power of 2. Use
225 SET_XTENSA_PROP_ALIGNMENT(flags, pow2) to set the required
226 alignment. Be careful of side effects since the SET will evaluate
227 flags twice. Also, note that the SIZE of a block in the property
228 table does not include the alignment size, so the alignment fill
229 must be calculated to determine if two blocks are contiguous.
230 TEXT_ALIGN is not currently implemented but is a placeholder for a
231 possible future implementation. */
232
233#define XTENSA_PROP_ALIGN 0x00000800
234
235#define XTENSA_PROP_ALIGNMENT_MASK 0x0001f000
236
43cd72b9
BW
237#define SET_XTENSA_PROP_ALIGNMENT(flag, align) \
238 (((flag) & (~XTENSA_PROP_ALIGNMENT_MASK)) | \
239 (((align) << 12) & XTENSA_PROP_ALIGNMENT_MASK))
240
241#define XTENSA_PROP_INSN_ABSLIT 0x00020000
242
243
244/* Structure for saving instruction and alignment per-fragment data
245 that will be written to the object file. This structure is
246 equivalent to the actual data that will be written out to the file
247 but is easier to use. We provide a conversion to file flags
248 in frag_flags_to_number. */
249
250typedef struct frag_flags_struct frag_flags;
251
252struct frag_flags_struct
253{
254 /* is_literal should only be used after xtensa_move_literals.
255 If you need to check if you are generating a literal fragment,
256 then use the generating_literals global. */
257
258 unsigned is_literal : 1;
259 unsigned is_insn : 1;
260 unsigned is_data : 1;
261 unsigned is_unreachable : 1;
262
99ded152
BW
263 /* is_specific_opcode implies no_transform. */
264 unsigned is_no_transform : 1;
265
43cd72b9
BW
266 struct
267 {
268 unsigned is_loop_target : 1;
269 unsigned is_branch_target : 1; /* Branch targets have a priority. */
270 unsigned bt_align_priority : 2;
271
272 unsigned is_no_density : 1;
273 /* no_longcalls flag does not need to be placed in the object file. */
43cd72b9
BW
274
275 unsigned is_no_reorder : 1;
276
277 /* Uses absolute literal addressing for l32r. */
278 unsigned is_abslit : 1;
279 } insn;
280 unsigned is_align : 1;
281 unsigned alignment : 5;
282};
283
284
285/* Structure for saving information about a block of property data
286 for frags that have the same flags. */
287struct xtensa_block_info_struct
288{
289 segT sec;
290 bfd_vma offset;
291 size_t size;
292 frag_flags flags;
293 struct xtensa_block_info_struct *next;
294};
295
e0001a05
NC
296
297/* Structure for saving the current state before emitting literals. */
298typedef struct emit_state_struct
299{
300 const char *name;
301 segT now_seg;
302 subsegT now_subseg;
303 int generating_literals;
304} emit_state;
305
306
43cd72b9
BW
307/* Opcode placement information */
308
309typedef unsigned long long bitfield;
310#define bit_is_set(bit, bf) ((bf) & (0x01ll << (bit)))
311#define set_bit(bit, bf) ((bf) |= (0x01ll << (bit)))
312#define clear_bit(bit, bf) ((bf) &= ~(0x01ll << (bit)))
313
314#define MAX_FORMATS 32
315
316typedef struct op_placement_info_struct
317{
318 int num_formats;
319 /* A number describing how restrictive the issue is for this
320 opcode. For example, an opcode that fits lots of different
c138bc38 321 formats has a high freedom, as does an opcode that fits
43cd72b9 322 only one format but many slots in that format. The most
c138bc38 323 restrictive is the opcode that fits only one slot in one
43cd72b9
BW
324 format. */
325 int issuef;
43cd72b9 326 xtensa_format narrowest;
43cd72b9 327 char narrowest_size;
b2d179be 328 char narrowest_slot;
43cd72b9
BW
329
330 /* formats is a bitfield with the Nth bit set
331 if the opcode fits in the Nth xtensa_format. */
332 bitfield formats;
333
334 /* slots[N]'s Mth bit is set if the op fits in the
335 Mth slot of the Nth xtensa_format. */
336 bitfield slots[MAX_FORMATS];
337
338 /* A count of the number of slots in a given format
339 an op can fit (i.e., the bitcount of the slot field above). */
340 char slots_in_format[MAX_FORMATS];
341
342} op_placement_info, *op_placement_info_table;
343
344op_placement_info_table op_placement_table;
345
346
347/* Extra expression types. */
348
349#define O_pltrel O_md1 /* like O_symbol but use a PLT reloc */
350#define O_hi16 O_md2 /* use high 16 bits of symbolic value */
351#define O_lo16 O_md3 /* use low 16 bits of symbolic value */
1bbb5f21 352#define O_pcrel O_md4 /* value is a PC-relative offset */
28dbbc02
BW
353#define O_tlsfunc O_md5 /* TLS_FUNC/TLSDESC_FN relocation */
354#define O_tlsarg O_md6 /* TLS_ARG/TLSDESC_ARG relocation */
355#define O_tlscall O_md7 /* TLS_CALL relocation */
356#define O_tpoff O_md8 /* TPOFF relocation */
357#define O_dtpoff O_md9 /* DTPOFF relocation */
43cd72b9 358
bbdd25a8
BW
359struct suffix_reloc_map
360{
b9bb4a93 361 const char *suffix;
bbdd25a8
BW
362 int length;
363 bfd_reloc_code_real_type reloc;
cc34adb2 364 operatorT operator;
bbdd25a8
BW
365};
366
367#define SUFFIX_MAP(str, reloc, op) { str, sizeof (str) - 1, reloc, op }
368
369static struct suffix_reloc_map suffix_relocs[] =
370{
371 SUFFIX_MAP ("l", BFD_RELOC_LO16, O_lo16),
372 SUFFIX_MAP ("h", BFD_RELOC_HI16, O_hi16),
373 SUFFIX_MAP ("plt", BFD_RELOC_XTENSA_PLT, O_pltrel),
1bbb5f21 374 SUFFIX_MAP ("pcrel", BFD_RELOC_32_PCREL, O_pcrel),
28dbbc02
BW
375 SUFFIX_MAP ("tlsfunc", BFD_RELOC_XTENSA_TLS_FUNC, O_tlsfunc),
376 SUFFIX_MAP ("tlsarg", BFD_RELOC_XTENSA_TLS_ARG, O_tlsarg),
377 SUFFIX_MAP ("tlscall", BFD_RELOC_XTENSA_TLS_CALL, O_tlscall),
378 SUFFIX_MAP ("tpoff", BFD_RELOC_XTENSA_TLS_TPOFF, O_tpoff),
379 SUFFIX_MAP ("dtpoff", BFD_RELOC_XTENSA_TLS_DTPOFF, O_dtpoff),
bbdd25a8
BW
380};
381
43cd72b9 382
e0001a05
NC
383/* Directives. */
384
385typedef enum
386{
387 directive_none = 0,
388 directive_literal,
389 directive_density,
43cd72b9 390 directive_transform,
e0001a05
NC
391 directive_freeregs,
392 directive_longcalls,
43cd72b9
BW
393 directive_literal_prefix,
394 directive_schedule,
395 directive_absolute_literals,
396 directive_last_directive
e0001a05
NC
397} directiveE;
398
399typedef struct
400{
401 const char *name;
402 bfd_boolean can_be_negated;
403} directive_infoS;
404
405const directive_infoS directive_info[] =
406{
43cd72b9
BW
407 { "none", FALSE },
408 { "literal", FALSE },
409 { "density", TRUE },
410 { "transform", TRUE },
411 { "freeregs", FALSE },
412 { "longcalls", TRUE },
413 { "literal_prefix", FALSE },
414 { "schedule", TRUE },
415 { "absolute-literals", TRUE }
e0001a05
NC
416};
417
418bfd_boolean directive_state[] =
419{
420 FALSE, /* none */
421 FALSE, /* literal */
e0001a05 422 FALSE, /* density */
43cd72b9 423 TRUE, /* transform */
e0001a05
NC
424 FALSE, /* freeregs */
425 FALSE, /* longcalls */
43cd72b9 426 FALSE, /* literal_prefix */
2caa7ca0 427 FALSE, /* schedule */
43cd72b9 428 FALSE /* absolute_literals */
e0001a05
NC
429};
430
b46824bd
MF
431/* A circular list of all potential and actual literal pool locations
432 in a segment. */
433struct litpool_frag
434{
435 struct litpool_frag *next;
436 struct litpool_frag *prev;
437 fragS *fragP;
438 addressT addr;
439 short priority; /* 1, 2, or 3 -- 1 is highest */
440 short original_priority;
cd665a94 441 int literal_count;
b46824bd
MF
442};
443
444/* Map a segment to its litpool_frag list. */
445struct litpool_seg
446{
447 struct litpool_seg *next;
448 asection *seg;
449 struct litpool_frag frag_list;
450 int frag_count; /* since last litpool location */
451};
452
453static struct litpool_seg litpool_seg_list;
454
cd665a94
MF
455/* Limit maximal size of auto litpool by half of the j range. */
456#define MAX_AUTO_POOL_LITERALS 16384
457
458/* Limit maximal size of explicit literal pool by l32r range. */
459#define MAX_EXPLICIT_POOL_LITERALS 65536
460
461#define MAX_POOL_LITERALS \
462 (auto_litpools ? MAX_AUTO_POOL_LITERALS : MAX_EXPLICIT_POOL_LITERALS)
e0001a05
NC
463
464/* Directive functions. */
465
7fa3d080
BW
466static void xtensa_begin_directive (int);
467static void xtensa_end_directive (int);
74869ac7 468static void xtensa_literal_prefix (void);
7fa3d080
BW
469static void xtensa_literal_position (int);
470static void xtensa_literal_pseudo (int);
471static void xtensa_frequency_pseudo (int);
472static void xtensa_elf_cons (int);
fb227da0 473static void xtensa_leb128 (int);
e0001a05 474
7fa3d080 475/* Parsing and Idiom Translation. */
e0001a05 476
7fa3d080 477static bfd_reloc_code_real_type xtensa_elf_suffix (char **, expressionS *);
e0001a05 478
e0001a05
NC
479/* Various Other Internal Functions. */
480
84b08ed9
BW
481extern bfd_boolean xg_is_single_relaxable_insn (TInsn *, TInsn *, bfd_boolean);
482static bfd_boolean xg_build_to_insn (TInsn *, TInsn *, BuildInstr *);
7fa3d080
BW
483static void xtensa_mark_literal_pool_location (void);
484static addressT get_expanded_loop_offset (xtensa_opcode);
485static fragS *get_literal_pool_location (segT);
486static void set_literal_pool_location (segT, fragS *);
487static void xtensa_set_frag_assembly_state (fragS *);
488static void finish_vinsn (vliw_insn *);
489static bfd_boolean emit_single_op (TInsn *);
34e41783 490static int total_frag_text_expansion (fragS *);
a82c7d90
DW
491static bfd_boolean use_trampolines = TRUE;
492static void xtensa_check_frag_count (void);
493static void xtensa_create_trampoline_frag (bfd_boolean);
494static void xtensa_maybe_create_trampoline_frag (void);
495struct trampoline_frag;
46888d71
MF
496static int init_trampoline_frag (fragS *);
497static fixS *xg_append_jump (fragS *fragP, symbolS *sym, offsetT offset);
b46824bd
MF
498static void xtensa_maybe_create_literal_pool_frag (bfd_boolean, bfd_boolean);
499static bfd_boolean auto_litpools = FALSE;
cd665a94 500static int auto_litpool_limit = 0;
e0001a05
NC
501
502/* Alignment Functions. */
503
d77b99c9
BW
504static int get_text_align_power (unsigned);
505static int get_text_align_max_fill_size (int, bfd_boolean, bfd_boolean);
664df4e4 506static int branch_align_power (segT);
e0001a05
NC
507
508/* Helpers for xtensa_relax_frag(). */
509
7fa3d080 510static long relax_frag_add_nop (fragS *);
e0001a05 511
b08b5071 512/* Accessors for additional per-subsegment information. */
e0001a05 513
7fa3d080
BW
514static unsigned get_last_insn_flags (segT, subsegT);
515static void set_last_insn_flags (segT, subsegT, unsigned, bfd_boolean);
b08b5071
BW
516static float get_subseg_total_freq (segT, subsegT);
517static float get_subseg_target_freq (segT, subsegT);
518static void set_subseg_freq (segT, subsegT, float, float);
e0001a05
NC
519
520/* Segment list functions. */
521
7fa3d080
BW
522static void xtensa_move_literals (void);
523static void xtensa_reorder_segments (void);
524static void xtensa_switch_to_literal_fragment (emit_state *);
525static void xtensa_switch_to_non_abs_literal_fragment (emit_state *);
526static void xtensa_switch_section_emit_state (emit_state *, segT, subsegT);
527static void xtensa_restore_emit_state (emit_state *);
74869ac7 528static segT cache_literal_section (bfd_boolean);
e0001a05 529
43cd72b9
BW
530/* op_placement_info functions. */
531
7fa3d080
BW
532static void init_op_placement_info_table (void);
533extern bfd_boolean opcode_fits_format_slot (xtensa_opcode, xtensa_format, int);
534static int xg_get_single_size (xtensa_opcode);
535static xtensa_format xg_get_single_format (xtensa_opcode);
b2d179be 536static int xg_get_single_slot (xtensa_opcode);
43cd72b9 537
e0001a05 538/* TInsn and IStack functions. */
43cd72b9 539
7fa3d080
BW
540static bfd_boolean tinsn_has_symbolic_operands (const TInsn *);
541static bfd_boolean tinsn_has_invalid_symbolic_operands (const TInsn *);
542static bfd_boolean tinsn_has_complex_operands (const TInsn *);
543static bfd_boolean tinsn_to_insnbuf (TInsn *, xtensa_insnbuf);
544static bfd_boolean tinsn_check_arguments (const TInsn *);
545static void tinsn_from_chars (TInsn *, char *, int);
546static void tinsn_immed_from_frag (TInsn *, fragS *, int);
547static int get_num_stack_text_bytes (IStack *);
548static int get_num_stack_literal_bytes (IStack *);
a82c7d90 549static bfd_boolean tinsn_to_slotbuf (xtensa_format, int, TInsn *, xtensa_insnbuf);
e0001a05 550
43cd72b9
BW
551/* vliw_insn functions. */
552
7fa3d080 553static void xg_init_vinsn (vliw_insn *);
d8392fd9 554static void xg_copy_vinsn (vliw_insn *, vliw_insn *);
7fa3d080
BW
555static void xg_clear_vinsn (vliw_insn *);
556static bfd_boolean vinsn_has_specific_opcodes (vliw_insn *);
557static void xg_free_vinsn (vliw_insn *);
43cd72b9 558static bfd_boolean vinsn_to_insnbuf
7fa3d080
BW
559 (vliw_insn *, char *, fragS *, bfd_boolean);
560static void vinsn_from_chars (vliw_insn *, char *);
43cd72b9 561
e0001a05 562/* Expression Utilities. */
43cd72b9 563
7fa3d080
BW
564bfd_boolean expr_is_const (const expressionS *);
565offsetT get_expr_const (const expressionS *);
566void set_expr_const (expressionS *, offsetT);
567bfd_boolean expr_is_register (const expressionS *);
568offsetT get_expr_register (const expressionS *);
569void set_expr_symbol_offset (expressionS *, symbolS *, offsetT);
7fa3d080
BW
570bfd_boolean expr_is_equal (expressionS *, expressionS *);
571static void copy_expr (expressionS *, const expressionS *);
e0001a05 572
9456465c
BW
573/* Section renaming. */
574
7fa3d080 575static void build_section_rename (const char *);
e0001a05 576
e0001a05
NC
577
578/* ISA imported from bfd. */
579extern xtensa_isa xtensa_default_isa;
580
581extern int target_big_endian;
582
583static xtensa_opcode xtensa_addi_opcode;
584static xtensa_opcode xtensa_addmi_opcode;
585static xtensa_opcode xtensa_call0_opcode;
586static xtensa_opcode xtensa_call4_opcode;
587static xtensa_opcode xtensa_call8_opcode;
588static xtensa_opcode xtensa_call12_opcode;
589static xtensa_opcode xtensa_callx0_opcode;
590static xtensa_opcode xtensa_callx4_opcode;
591static xtensa_opcode xtensa_callx8_opcode;
592static xtensa_opcode xtensa_callx12_opcode;
43cd72b9 593static xtensa_opcode xtensa_const16_opcode;
e0001a05 594static xtensa_opcode xtensa_entry_opcode;
d12f9798 595static xtensa_opcode xtensa_extui_opcode;
43cd72b9
BW
596static xtensa_opcode xtensa_movi_opcode;
597static xtensa_opcode xtensa_movi_n_opcode;
e0001a05 598static xtensa_opcode xtensa_isync_opcode;
19e8f41a 599static xtensa_opcode xtensa_j_opcode;
e0001a05 600static xtensa_opcode xtensa_jx_opcode;
43cd72b9 601static xtensa_opcode xtensa_l32r_opcode;
e0001a05
NC
602static xtensa_opcode xtensa_loop_opcode;
603static xtensa_opcode xtensa_loopnez_opcode;
604static xtensa_opcode xtensa_loopgtz_opcode;
43cd72b9 605static xtensa_opcode xtensa_nop_opcode;
e0001a05
NC
606static xtensa_opcode xtensa_nop_n_opcode;
607static xtensa_opcode xtensa_or_opcode;
608static xtensa_opcode xtensa_ret_opcode;
609static xtensa_opcode xtensa_ret_n_opcode;
610static xtensa_opcode xtensa_retw_opcode;
611static xtensa_opcode xtensa_retw_n_opcode;
43cd72b9 612static xtensa_opcode xtensa_rsr_lcount_opcode;
e0001a05 613static xtensa_opcode xtensa_waiti_opcode;
62af60e2 614static int config_max_slots = 0;
e0001a05
NC
615
616\f
617/* Command-line Options. */
618
619bfd_boolean use_literal_section = TRUE;
19fc3723 620enum flix_level produce_flix = FLIX_ALL;
e0001a05 621static bfd_boolean align_targets = TRUE;
43cd72b9 622static bfd_boolean warn_unaligned_branch_targets = FALSE;
e0001a05 623static bfd_boolean has_a0_b_retw = FALSE;
43cd72b9
BW
624static bfd_boolean workaround_a0_b_retw = FALSE;
625static bfd_boolean workaround_b_j_loop_end = FALSE;
626static bfd_boolean workaround_short_loop = FALSE;
e0001a05 627static bfd_boolean maybe_has_short_loop = FALSE;
43cd72b9 628static bfd_boolean workaround_close_loop_end = FALSE;
e0001a05 629static bfd_boolean maybe_has_close_loop_end = FALSE;
03aaa593 630static bfd_boolean enforce_three_byte_loop_align = FALSE;
e0001a05 631
43cd72b9
BW
632/* When workaround_short_loops is TRUE, all loops with early exits must
633 have at least 3 instructions. workaround_all_short_loops is a modifier
634 to the workaround_short_loop flag. In addition to the
635 workaround_short_loop actions, all straightline loopgtz and loopnez
636 must have at least 3 instructions. */
e0001a05 637
43cd72b9 638static bfd_boolean workaround_all_short_loops = FALSE;
e0001a05 639
7fa3d080
BW
640
641static void
642xtensa_setup_hw_workarounds (int earliest, int latest)
643{
644 if (earliest > latest)
645 as_fatal (_("illegal range of target hardware versions"));
646
647 /* Enable all workarounds for pre-T1050.0 hardware. */
648 if (earliest < 105000 || latest < 105000)
649 {
650 workaround_a0_b_retw |= TRUE;
651 workaround_b_j_loop_end |= TRUE;
652 workaround_short_loop |= TRUE;
653 workaround_close_loop_end |= TRUE;
654 workaround_all_short_loops |= TRUE;
03aaa593 655 enforce_three_byte_loop_align = TRUE;
7fa3d080
BW
656 }
657}
658
659
e0001a05
NC
660enum
661{
662 option_density = OPTION_MD_BASE,
663 option_no_density,
664
19fc3723
SA
665 option_flix,
666 option_no_generate_flix,
667 option_no_flix,
668
e0001a05
NC
669 option_relax,
670 option_no_relax,
671
43cd72b9
BW
672 option_link_relax,
673 option_no_link_relax,
674
e0001a05
NC
675 option_generics,
676 option_no_generics,
677
43cd72b9
BW
678 option_transform,
679 option_no_transform,
680
e0001a05
NC
681 option_text_section_literals,
682 option_no_text_section_literals,
683
43cd72b9
BW
684 option_absolute_literals,
685 option_no_absolute_literals,
686
e0001a05
NC
687 option_align_targets,
688 option_no_align_targets,
689
43cd72b9 690 option_warn_unaligned_targets,
e0001a05
NC
691
692 option_longcalls,
693 option_no_longcalls,
694
695 option_workaround_a0_b_retw,
696 option_no_workaround_a0_b_retw,
697
698 option_workaround_b_j_loop_end,
699 option_no_workaround_b_j_loop_end,
700
701 option_workaround_short_loop,
702 option_no_workaround_short_loop,
703
704 option_workaround_all_short_loops,
705 option_no_workaround_all_short_loops,
706
707 option_workaround_close_loop_end,
708 option_no_workaround_close_loop_end,
709
710 option_no_workarounds,
711
e0001a05 712 option_rename_section_name,
e0001a05 713
43cd72b9
BW
714 option_prefer_l32r,
715 option_prefer_const16,
716
a82c7d90
DW
717 option_target_hardware,
718
719 option_trampolines,
720 option_no_trampolines,
b46824bd
MF
721
722 option_auto_litpools,
723 option_no_auto_litpools,
724 option_auto_litpool_limit,
e0001a05
NC
725};
726
727const char *md_shortopts = "";
728
729struct option md_longopts[] =
730{
43cd72b9
BW
731 { "density", no_argument, NULL, option_density },
732 { "no-density", no_argument, NULL, option_no_density },
733
19fc3723
SA
734 { "flix", no_argument, NULL, option_flix },
735 { "no-generate-flix", no_argument, NULL, option_no_generate_flix },
736 { "no-allow-flix", no_argument, NULL, option_no_flix },
737
43cd72b9
BW
738 /* Both "relax" and "generics" are deprecated and treated as equivalent
739 to the "transform" option. */
740 { "relax", no_argument, NULL, option_relax },
741 { "no-relax", no_argument, NULL, option_no_relax },
742 { "generics", no_argument, NULL, option_generics },
743 { "no-generics", no_argument, NULL, option_no_generics },
744
745 { "transform", no_argument, NULL, option_transform },
746 { "no-transform", no_argument, NULL, option_no_transform },
747 { "text-section-literals", no_argument, NULL, option_text_section_literals },
748 { "no-text-section-literals", no_argument, NULL,
749 option_no_text_section_literals },
750 { "absolute-literals", no_argument, NULL, option_absolute_literals },
751 { "no-absolute-literals", no_argument, NULL, option_no_absolute_literals },
e0001a05
NC
752 /* This option was changed from -align-target to -target-align
753 because it conflicted with the "-al" option. */
43cd72b9 754 { "target-align", no_argument, NULL, option_align_targets },
7fa3d080
BW
755 { "no-target-align", no_argument, NULL, option_no_align_targets },
756 { "warn-unaligned-targets", no_argument, NULL,
757 option_warn_unaligned_targets },
43cd72b9
BW
758 { "longcalls", no_argument, NULL, option_longcalls },
759 { "no-longcalls", no_argument, NULL, option_no_longcalls },
760
761 { "no-workaround-a0-b-retw", no_argument, NULL,
762 option_no_workaround_a0_b_retw },
763 { "workaround-a0-b-retw", no_argument, NULL, option_workaround_a0_b_retw },
e0001a05 764
43cd72b9
BW
765 { "no-workaround-b-j-loop-end", no_argument, NULL,
766 option_no_workaround_b_j_loop_end },
767 { "workaround-b-j-loop-end", no_argument, NULL,
768 option_workaround_b_j_loop_end },
e0001a05 769
43cd72b9
BW
770 { "no-workaround-short-loops", no_argument, NULL,
771 option_no_workaround_short_loop },
7fa3d080
BW
772 { "workaround-short-loops", no_argument, NULL,
773 option_workaround_short_loop },
e0001a05 774
43cd72b9
BW
775 { "no-workaround-all-short-loops", no_argument, NULL,
776 option_no_workaround_all_short_loops },
777 { "workaround-all-short-loop", no_argument, NULL,
778 option_workaround_all_short_loops },
779
780 { "prefer-l32r", no_argument, NULL, option_prefer_l32r },
781 { "prefer-const16", no_argument, NULL, option_prefer_const16 },
782
783 { "no-workarounds", no_argument, NULL, option_no_workarounds },
784
785 { "no-workaround-close-loop-end", no_argument, NULL,
786 option_no_workaround_close_loop_end },
787 { "workaround-close-loop-end", no_argument, NULL,
788 option_workaround_close_loop_end },
e0001a05 789
7fa3d080 790 { "rename-section", required_argument, NULL, option_rename_section_name },
e0001a05 791
43cd72b9
BW
792 { "link-relax", no_argument, NULL, option_link_relax },
793 { "no-link-relax", no_argument, NULL, option_no_link_relax },
794
795 { "target-hardware", required_argument, NULL, option_target_hardware },
796
a82c7d90
DW
797 { "trampolines", no_argument, NULL, option_trampolines },
798 { "no-trampolines", no_argument, NULL, option_no_trampolines },
799
b46824bd
MF
800 { "auto-litpools", no_argument, NULL, option_auto_litpools },
801 { "no-auto-litpools", no_argument, NULL, option_no_auto_litpools },
802 { "auto-litpool-limit", required_argument, NULL, option_auto_litpool_limit },
803
43cd72b9 804 { NULL, no_argument, NULL, 0 }
e0001a05
NC
805};
806
807size_t md_longopts_size = sizeof md_longopts;
808
809
810int
17b9d67d 811md_parse_option (int c, const char *arg)
e0001a05
NC
812{
813 switch (c)
814 {
815 case option_density:
43cd72b9 816 as_warn (_("--density option is ignored"));
e0001a05
NC
817 return 1;
818 case option_no_density:
43cd72b9 819 as_warn (_("--no-density option is ignored"));
e0001a05 820 return 1;
43cd72b9
BW
821 case option_link_relax:
822 linkrelax = 1;
e0001a05 823 return 1;
43cd72b9
BW
824 case option_no_link_relax:
825 linkrelax = 0;
e0001a05 826 return 1;
19fc3723
SA
827 case option_flix:
828 produce_flix = FLIX_ALL;
829 return 1;
830 case option_no_generate_flix:
831 produce_flix = FLIX_NO_GENERATE;
832 return 1;
833 case option_no_flix:
834 produce_flix = FLIX_NONE;
835 return 1;
43cd72b9
BW
836 case option_generics:
837 as_warn (_("--generics is deprecated; use --transform instead"));
838 return md_parse_option (option_transform, arg);
839 case option_no_generics:
840 as_warn (_("--no-generics is deprecated; use --no-transform instead"));
841 return md_parse_option (option_no_transform, arg);
842 case option_relax:
843 as_warn (_("--relax is deprecated; use --transform instead"));
844 return md_parse_option (option_transform, arg);
845 case option_no_relax:
846 as_warn (_("--no-relax is deprecated; use --no-transform instead"));
847 return md_parse_option (option_no_transform, arg);
e0001a05
NC
848 case option_longcalls:
849 directive_state[directive_longcalls] = TRUE;
850 return 1;
851 case option_no_longcalls:
852 directive_state[directive_longcalls] = FALSE;
853 return 1;
854 case option_text_section_literals:
855 use_literal_section = FALSE;
856 return 1;
857 case option_no_text_section_literals:
858 use_literal_section = TRUE;
859 return 1;
43cd72b9
BW
860 case option_absolute_literals:
861 if (!absolute_literals_supported)
862 {
863 as_fatal (_("--absolute-literals option not supported in this Xtensa configuration"));
864 return 0;
865 }
866 directive_state[directive_absolute_literals] = TRUE;
867 return 1;
868 case option_no_absolute_literals:
869 directive_state[directive_absolute_literals] = FALSE;
870 return 1;
871
e0001a05
NC
872 case option_workaround_a0_b_retw:
873 workaround_a0_b_retw = TRUE;
e0001a05
NC
874 return 1;
875 case option_no_workaround_a0_b_retw:
876 workaround_a0_b_retw = FALSE;
e0001a05
NC
877 return 1;
878 case option_workaround_b_j_loop_end:
879 workaround_b_j_loop_end = TRUE;
e0001a05
NC
880 return 1;
881 case option_no_workaround_b_j_loop_end:
882 workaround_b_j_loop_end = FALSE;
e0001a05
NC
883 return 1;
884
885 case option_workaround_short_loop:
886 workaround_short_loop = TRUE;
e0001a05
NC
887 return 1;
888 case option_no_workaround_short_loop:
889 workaround_short_loop = FALSE;
e0001a05
NC
890 return 1;
891
892 case option_workaround_all_short_loops:
893 workaround_all_short_loops = TRUE;
e0001a05
NC
894 return 1;
895 case option_no_workaround_all_short_loops:
896 workaround_all_short_loops = FALSE;
e0001a05
NC
897 return 1;
898
899 case option_workaround_close_loop_end:
900 workaround_close_loop_end = TRUE;
e0001a05
NC
901 return 1;
902 case option_no_workaround_close_loop_end:
903 workaround_close_loop_end = FALSE;
e0001a05
NC
904 return 1;
905
906 case option_no_workarounds:
907 workaround_a0_b_retw = FALSE;
e0001a05 908 workaround_b_j_loop_end = FALSE;
e0001a05 909 workaround_short_loop = FALSE;
e0001a05 910 workaround_all_short_loops = FALSE;
e0001a05 911 workaround_close_loop_end = FALSE;
e0001a05 912 return 1;
43cd72b9 913
e0001a05
NC
914 case option_align_targets:
915 align_targets = TRUE;
916 return 1;
917 case option_no_align_targets:
918 align_targets = FALSE;
919 return 1;
920
43cd72b9
BW
921 case option_warn_unaligned_targets:
922 warn_unaligned_branch_targets = TRUE;
e0001a05
NC
923 return 1;
924
e0001a05
NC
925 case option_rename_section_name:
926 build_section_rename (arg);
927 return 1;
e0001a05
NC
928
929 case 'Q':
930 /* -Qy, -Qn: SVR4 arguments controlling whether a .comment section
931 should be emitted or not. FIXME: Not implemented. */
932 return 1;
c138bc38 933
43cd72b9
BW
934 case option_prefer_l32r:
935 if (prefer_const16)
936 as_fatal (_("prefer-l32r conflicts with prefer-const16"));
937 prefer_l32r = 1;
938 return 1;
939
940 case option_prefer_const16:
941 if (prefer_l32r)
942 as_fatal (_("prefer-const16 conflicts with prefer-l32r"));
943 prefer_const16 = 1;
944 return 1;
945
c138bc38 946 case option_target_hardware:
43cd72b9
BW
947 {
948 int earliest, latest = 0;
17b9d67d 949 char *end;
43cd72b9
BW
950 if (*arg == 0 || *arg == '-')
951 as_fatal (_("invalid target hardware version"));
952
17b9d67d 953 earliest = strtol (arg, &end, 0);
43cd72b9 954
17b9d67d 955 if (*end == 0)
43cd72b9 956 latest = earliest;
17b9d67d 957 else if (*end == '-')
43cd72b9 958 {
17b9d67d 959 if (*++end == 0)
43cd72b9 960 as_fatal (_("invalid target hardware version"));
17b9d67d 961 latest = strtol (end, &end, 0);
43cd72b9 962 }
17b9d67d 963 if (*end != 0)
43cd72b9
BW
964 as_fatal (_("invalid target hardware version"));
965
966 xtensa_setup_hw_workarounds (earliest, latest);
967 return 1;
968 }
969
970 case option_transform:
971 /* This option has no affect other than to use the defaults,
972 which are already set. */
973 return 1;
974
975 case option_no_transform:
976 /* This option turns off all transformations of any kind.
977 However, because we want to preserve the state of other
978 directives, we only change its own field. Thus, before
979 you perform any transformation, always check if transform
980 is available. If you use the functions we provide for this
981 purpose, you will be ok. */
982 directive_state[directive_transform] = FALSE;
983 return 1;
984
a82c7d90
DW
985 case option_trampolines:
986 use_trampolines = TRUE;
987 return 1;
988
989 case option_no_trampolines:
990 use_trampolines = FALSE;
991 return 1;
992
b46824bd
MF
993 case option_auto_litpools:
994 auto_litpools = TRUE;
995 use_literal_section = FALSE;
cd665a94
MF
996 if (auto_litpool_limit <= 0)
997 auto_litpool_limit = MAX_AUTO_POOL_LITERALS / 2;
b46824bd
MF
998 return 1;
999
1000 case option_no_auto_litpools:
1001 auto_litpools = FALSE;
1002 auto_litpool_limit = -1;
1003 return 1;
1004
1005 case option_auto_litpool_limit:
1006 {
1007 int value = 0;
17b9d67d 1008 char *end;
b46824bd
MF
1009 if (auto_litpool_limit < 0)
1010 as_fatal (_("no-auto-litpools is incompatible with auto-litpool-limit"));
1011 if (*arg == 0 || *arg == '-')
1012 as_fatal (_("invalid auto-litpool-limit argument"));
17b9d67d
TS
1013 value = strtol (arg, &end, 10);
1014 if (*end != 0)
b46824bd
MF
1015 as_fatal (_("invalid auto-litpool-limit argument"));
1016 if (value < 100 || value > 10000)
1017 as_fatal (_("invalid auto-litpool-limit argument (range is 100-10000)"));
1018 auto_litpool_limit = value;
1019 auto_litpools = TRUE;
1020 use_literal_section = FALSE;
1021 return 1;
1022 }
1023
e0001a05
NC
1024 default:
1025 return 0;
1026 }
1027}
1028
1029
1030void
7fa3d080 1031md_show_usage (FILE *stream)
e0001a05 1032{
43cd72b9
BW
1033 fputs ("\n\
1034Xtensa options:\n\
9456465c
BW
1035 --[no-]text-section-literals\n\
1036 [Do not] put literals in the text section\n\
1037 --[no-]absolute-literals\n\
1038 [Do not] default to use non-PC-relative literals\n\
1039 --[no-]target-align [Do not] try to align branch targets\n\
1040 --[no-]longcalls [Do not] emit 32-bit call sequences\n\
1041 --[no-]transform [Do not] transform instructions\n\
19fc3723
SA
1042 --flix both allow hand-written and generate flix bundles\n\
1043 --no-generate-flix allow hand-written but do not generate\n\
1044 flix bundles\n\
1045 --no-allow-flix neither allow hand-written nor generate\n\
1046 flix bundles\n\
a82c7d90
DW
1047 --rename-section old=new Rename section 'old' to 'new'\n\
1048 --[no-]trampolines [Do not] generate trampolines (jumps to jumps)\n\
b46824bd
MF
1049 when jumps do not reach their targets\n\
1050 --[no-]auto-litpools [Do not] automatically create literal pools\n\
1051 --auto-litpool-limit=<value>\n\
1052 (range 100-10000) Maximum number of blocks of\n\
1053 instructions to emit between literal pool\n\
1054 locations; implies --auto-litpools flag\n", stream);
e0001a05
NC
1055}
1056
7fa3d080
BW
1057\f
1058/* Functions related to the list of current label symbols. */
43cd72b9
BW
1059
1060static void
7fa3d080 1061xtensa_add_insn_label (symbolS *sym)
43cd72b9 1062{
7fa3d080 1063 sym_list *l;
43cd72b9 1064
7fa3d080 1065 if (!free_insn_labels)
325801bd 1066 l = XNEW (sym_list);
7fa3d080 1067 else
43cd72b9 1068 {
7fa3d080
BW
1069 l = free_insn_labels;
1070 free_insn_labels = l->next;
1071 }
1072
1073 l->sym = sym;
1074 l->next = insn_labels;
1075 insn_labels = l;
1076}
1077
1078
1079static void
1080xtensa_clear_insn_labels (void)
1081{
1082 sym_list **pl;
1083
1084 for (pl = &free_insn_labels; *pl != NULL; pl = &(*pl)->next)
1085 ;
1086 *pl = insn_labels;
1087 insn_labels = NULL;
1088}
1089
1090
7fa3d080 1091static void
c3ea6048 1092xtensa_move_labels (fragS *new_frag, valueT new_offset)
7fa3d080
BW
1093{
1094 sym_list *lit;
1095
1096 for (lit = insn_labels; lit; lit = lit->next)
1097 {
1098 symbolS *lit_sym = lit->sym;
c3ea6048
BW
1099 S_SET_VALUE (lit_sym, new_offset);
1100 symbol_set_frag (lit_sym, new_frag);
43cd72b9
BW
1101 }
1102}
1103
e0001a05
NC
1104\f
1105/* Directive data and functions. */
1106
1107typedef struct state_stackS_struct
1108{
1109 directiveE directive;
1110 bfd_boolean negated;
1111 bfd_boolean old_state;
1112 const char *file;
1113 unsigned int line;
1114 const void *datum;
1115 struct state_stackS_struct *prev;
1116} state_stackS;
1117
1118state_stackS *directive_state_stack;
1119
1120const pseudo_typeS md_pseudo_table[] =
1121{
43cd72b9
BW
1122 { "align", s_align_bytes, 0 }, /* Defaulting is invalid (0). */
1123 { "literal_position", xtensa_literal_position, 0 },
1124 { "frame", s_ignore, 0 }, /* Formerly used for STABS debugging. */
1125 { "long", xtensa_elf_cons, 4 },
1126 { "word", xtensa_elf_cons, 4 },
1bbb5f21 1127 { "4byte", xtensa_elf_cons, 4 },
43cd72b9 1128 { "short", xtensa_elf_cons, 2 },
1bbb5f21 1129 { "2byte", xtensa_elf_cons, 2 },
fb227da0
BW
1130 { "sleb128", xtensa_leb128, 1},
1131 { "uleb128", xtensa_leb128, 0},
43cd72b9
BW
1132 { "begin", xtensa_begin_directive, 0 },
1133 { "end", xtensa_end_directive, 0 },
43cd72b9
BW
1134 { "literal", xtensa_literal_pseudo, 0 },
1135 { "frequency", xtensa_frequency_pseudo, 0 },
1136 { NULL, 0, 0 },
e0001a05
NC
1137};
1138
1139
7fa3d080
BW
1140static bfd_boolean
1141use_transform (void)
e0001a05 1142{
43cd72b9
BW
1143 /* After md_end, you should be checking frag by frag, rather
1144 than state directives. */
9c2799c2 1145 gas_assert (!past_xtensa_end);
43cd72b9 1146 return directive_state[directive_transform];
e0001a05
NC
1147}
1148
1149
7fa3d080
BW
1150static bfd_boolean
1151do_align_targets (void)
e0001a05 1152{
7b1cc377
BW
1153 /* Do not use this function after md_end; just look at align_targets
1154 instead. There is no target-align directive, so alignment is either
1155 enabled for all frags or not done at all. */
9c2799c2 1156 gas_assert (!past_xtensa_end);
43cd72b9 1157 return align_targets && use_transform ();
e0001a05
NC
1158}
1159
1160
1161static void
7fa3d080 1162directive_push (directiveE directive, bfd_boolean negated, const void *datum)
e0001a05 1163{
3b4dbbbf 1164 const char *file;
e0001a05 1165 unsigned int line;
325801bd 1166 state_stackS *stack = XNEW (state_stackS);
e0001a05 1167
3b4dbbbf 1168 file = as_where (&line);
e0001a05
NC
1169
1170 stack->directive = directive;
1171 stack->negated = negated;
1172 stack->old_state = directive_state[directive];
1173 stack->file = file;
1174 stack->line = line;
1175 stack->datum = datum;
1176 stack->prev = directive_state_stack;
1177 directive_state_stack = stack;
1178
1179 directive_state[directive] = !negated;
1180}
1181
7fa3d080 1182
e0001a05 1183static void
7fa3d080
BW
1184directive_pop (directiveE *directive,
1185 bfd_boolean *negated,
1186 const char **file,
1187 unsigned int *line,
1188 const void **datum)
e0001a05
NC
1189{
1190 state_stackS *top = directive_state_stack;
1191
1192 if (!directive_state_stack)
1193 {
33eaf5de 1194 as_bad (_("unmatched .end directive"));
e0001a05
NC
1195 *directive = directive_none;
1196 return;
1197 }
1198
1199 directive_state[directive_state_stack->directive] = top->old_state;
1200 *directive = top->directive;
1201 *negated = top->negated;
1202 *file = top->file;
1203 *line = top->line;
1204 *datum = top->datum;
1205 directive_state_stack = top->prev;
1206 free (top);
1207}
1208
1209
1210static void
7fa3d080 1211directive_balance (void)
e0001a05
NC
1212{
1213 while (directive_state_stack)
1214 {
1215 directiveE directive;
1216 bfd_boolean negated;
1217 const char *file;
1218 unsigned int line;
1219 const void *datum;
1220
1221 directive_pop (&directive, &negated, &file, &line, &datum);
1222 as_warn_where ((char *) file, line,
1223 _(".begin directive with no matching .end directive"));
1224 }
1225}
1226
1227
1228static bfd_boolean
7fa3d080 1229inside_directive (directiveE dir)
e0001a05
NC
1230{
1231 state_stackS *top = directive_state_stack;
1232
1233 while (top && top->directive != dir)
1234 top = top->prev;
1235
1236 return (top != NULL);
1237}
1238
1239
1240static void
7fa3d080 1241get_directive (directiveE *directive, bfd_boolean *negated)
e0001a05
NC
1242{
1243 int len;
1244 unsigned i;
b9bb4a93 1245 const char *directive_string;
e0001a05
NC
1246
1247 if (strncmp (input_line_pointer, "no-", 3) != 0)
1248 *negated = FALSE;
1249 else
1250 {
1251 *negated = TRUE;
1252 input_line_pointer += 3;
1253 }
1254
1255 len = strspn (input_line_pointer,
43cd72b9
BW
1256 "abcdefghijklmnopqrstuvwxyz_-/0123456789.");
1257
1258 /* This code is a hack to make .begin [no-][generics|relax] exactly
1259 equivalent to .begin [no-]transform. We should remove it when
1260 we stop accepting those options. */
c138bc38 1261
43cd72b9
BW
1262 if (strncmp (input_line_pointer, "generics", strlen ("generics")) == 0)
1263 {
1264 as_warn (_("[no-]generics is deprecated; use [no-]transform instead"));
1265 directive_string = "transform";
1266 }
1267 else if (strncmp (input_line_pointer, "relax", strlen ("relax")) == 0)
1268 {
1269 as_warn (_("[no-]relax is deprecated; use [no-]transform instead"));
1270 directive_string = "transform";
c138bc38 1271 }
43cd72b9
BW
1272 else
1273 directive_string = input_line_pointer;
e0001a05
NC
1274
1275 for (i = 0; i < sizeof (directive_info) / sizeof (*directive_info); ++i)
1276 {
43cd72b9 1277 if (strncmp (directive_string, directive_info[i].name, len) == 0)
e0001a05
NC
1278 {
1279 input_line_pointer += len;
1280 *directive = (directiveE) i;
1281 if (*negated && !directive_info[i].can_be_negated)
43cd72b9 1282 as_bad (_("directive %s cannot be negated"),
e0001a05
NC
1283 directive_info[i].name);
1284 return;
1285 }
1286 }
1287
1288 as_bad (_("unknown directive"));
1289 *directive = (directiveE) XTENSA_UNDEFINED;
1290}
1291
1292
1293static void
7fa3d080 1294xtensa_begin_directive (int ignore ATTRIBUTE_UNUSED)
e0001a05
NC
1295{
1296 directiveE directive;
1297 bfd_boolean negated;
1298 emit_state *state;
e0001a05
NC
1299 lit_state *ls;
1300
1301 get_directive (&directive, &negated);
1302 if (directive == (directiveE) XTENSA_UNDEFINED)
1303 {
1304 discard_rest_of_line ();
1305 return;
1306 }
1307
43cd72b9
BW
1308 if (cur_vinsn.inside_bundle)
1309 as_bad (_("directives are not valid inside bundles"));
1310
e0001a05
NC
1311 switch (directive)
1312 {
1313 case directive_literal:
82e7541d
BW
1314 if (!inside_directive (directive_literal))
1315 {
1316 /* Previous labels go with whatever follows this directive, not with
1317 the literal, so save them now. */
1318 saved_insn_labels = insn_labels;
1319 insn_labels = NULL;
1320 }
43cd72b9 1321 as_warn (_(".begin literal is deprecated; use .literal instead"));
325801bd 1322 state = XNEW (emit_state);
e0001a05
NC
1323 xtensa_switch_to_literal_fragment (state);
1324 directive_push (directive_literal, negated, state);
1325 break;
1326
1327 case directive_literal_prefix:
c138bc38 1328 /* Have to flush pending output because a movi relaxed to an l32r
43cd72b9
BW
1329 might produce a literal. */
1330 md_flush_pending_output ();
e0001a05
NC
1331 /* Check to see if the current fragment is a literal
1332 fragment. If it is, then this operation is not allowed. */
43cd72b9 1333 if (generating_literals)
e0001a05
NC
1334 {
1335 as_bad (_("cannot set literal_prefix inside literal fragment"));
1336 return;
1337 }
1338
1339 /* Allocate the literal state for this section and push
1340 onto the directive stack. */
325801bd 1341 ls = XNEW (lit_state);
9c2799c2 1342 gas_assert (ls);
e0001a05
NC
1343
1344 *ls = default_lit_sections;
e0001a05
NC
1345 directive_push (directive_literal_prefix, negated, ls);
1346
e0001a05 1347 /* Process the new prefix. */
74869ac7 1348 xtensa_literal_prefix ();
e0001a05
NC
1349 break;
1350
1351 case directive_freeregs:
1352 /* This information is currently unused, but we'll accept the statement
1353 and just discard the rest of the line. This won't check the syntax,
1354 but it will accept every correct freeregs directive. */
1355 input_line_pointer += strcspn (input_line_pointer, "\n");
1356 directive_push (directive_freeregs, negated, 0);
1357 break;
1358
43cd72b9
BW
1359 case directive_schedule:
1360 md_flush_pending_output ();
1361 frag_var (rs_fill, 0, 0, frag_now->fr_subtype,
1362 frag_now->fr_symbol, frag_now->fr_offset, NULL);
1363 directive_push (directive_schedule, negated, 0);
1364 xtensa_set_frag_assembly_state (frag_now);
1365 break;
1366
e0001a05 1367 case directive_density:
43cd72b9
BW
1368 as_warn (_(".begin [no-]density is ignored"));
1369 break;
1370
1371 case directive_absolute_literals:
1372 md_flush_pending_output ();
1373 if (!absolute_literals_supported && !negated)
e0001a05 1374 {
43cd72b9 1375 as_warn (_("Xtensa absolute literals option not supported; ignored"));
e0001a05
NC
1376 break;
1377 }
43cd72b9
BW
1378 xtensa_set_frag_assembly_state (frag_now);
1379 directive_push (directive, negated, 0);
1380 break;
e0001a05
NC
1381
1382 default:
43cd72b9
BW
1383 md_flush_pending_output ();
1384 xtensa_set_frag_assembly_state (frag_now);
e0001a05
NC
1385 directive_push (directive, negated, 0);
1386 break;
1387 }
1388
1389 demand_empty_rest_of_line ();
1390}
1391
1392
1393static void
7fa3d080 1394xtensa_end_directive (int ignore ATTRIBUTE_UNUSED)
e0001a05
NC
1395{
1396 directiveE begin_directive, end_directive;
1397 bfd_boolean begin_negated, end_negated;
1398 const char *file;
1399 unsigned int line;
1400 emit_state *state;
43cd72b9 1401 emit_state **state_ptr;
e0001a05
NC
1402 lit_state *s;
1403
43cd72b9
BW
1404 if (cur_vinsn.inside_bundle)
1405 as_bad (_("directives are not valid inside bundles"));
82e7541d 1406
e0001a05 1407 get_directive (&end_directive, &end_negated);
43cd72b9
BW
1408
1409 md_flush_pending_output ();
1410
87975d2a 1411 switch ((int) end_directive)
e0001a05 1412 {
87975d2a 1413 case XTENSA_UNDEFINED:
e0001a05
NC
1414 discard_rest_of_line ();
1415 return;
e0001a05 1416
87975d2a 1417 case (int) directive_density:
43cd72b9 1418 as_warn (_(".end [no-]density is ignored"));
e0001a05 1419 demand_empty_rest_of_line ();
43cd72b9
BW
1420 break;
1421
87975d2a 1422 case (int) directive_absolute_literals:
43cd72b9
BW
1423 if (!absolute_literals_supported && !end_negated)
1424 {
1425 as_warn (_("Xtensa absolute literals option not supported; ignored"));
1426 demand_empty_rest_of_line ();
1427 return;
1428 }
1429 break;
1430
1431 default:
1432 break;
e0001a05
NC
1433 }
1434
43cd72b9 1435 state_ptr = &state; /* use state_ptr to avoid type-punning warning */
e0001a05 1436 directive_pop (&begin_directive, &begin_negated, &file, &line,
43cd72b9 1437 (const void **) state_ptr);
e0001a05
NC
1438
1439 if (begin_directive != directive_none)
1440 {
1441 if (begin_directive != end_directive || begin_negated != end_negated)
1442 {
1443 as_bad (_("does not match begin %s%s at %s:%d"),
1444 begin_negated ? "no-" : "",
1445 directive_info[begin_directive].name, file, line);
1446 }
1447 else
1448 {
1449 switch (end_directive)
1450 {
1451 case directive_literal:
1452 frag_var (rs_fill, 0, 0, 0, NULL, 0, NULL);
1453 xtensa_restore_emit_state (state);
43cd72b9 1454 xtensa_set_frag_assembly_state (frag_now);
e0001a05 1455 free (state);
82e7541d
BW
1456 if (!inside_directive (directive_literal))
1457 {
1458 /* Restore the list of current labels. */
1459 xtensa_clear_insn_labels ();
1460 insn_labels = saved_insn_labels;
1461 }
e0001a05
NC
1462 break;
1463
e0001a05
NC
1464 case directive_literal_prefix:
1465 /* Restore the default collection sections from saved state. */
1466 s = (lit_state *) state;
9c2799c2 1467 gas_assert (s);
e8247da7 1468 default_lit_sections = *s;
e0001a05 1469
74869ac7
BW
1470 /* Free the state storage. */
1471 free (s->lit_prefix);
e0001a05
NC
1472 free (s);
1473 break;
1474
43cd72b9
BW
1475 case directive_schedule:
1476 case directive_freeregs:
1477 break;
1478
e0001a05 1479 default:
43cd72b9 1480 xtensa_set_frag_assembly_state (frag_now);
e0001a05
NC
1481 break;
1482 }
1483 }
1484 }
1485
1486 demand_empty_rest_of_line ();
1487}
1488
1489
1490/* Place an aligned literal fragment at the current location. */
1491
1492static void
7fa3d080 1493xtensa_literal_position (int ignore ATTRIBUTE_UNUSED)
e0001a05 1494{
43cd72b9
BW
1495 md_flush_pending_output ();
1496
e0001a05
NC
1497 if (inside_directive (directive_literal))
1498 as_warn (_(".literal_position inside literal directive; ignoring"));
43cd72b9 1499 xtensa_mark_literal_pool_location ();
e0001a05
NC
1500
1501 demand_empty_rest_of_line ();
82e7541d 1502 xtensa_clear_insn_labels ();
e0001a05
NC
1503}
1504
1505
43cd72b9 1506/* Support .literal label, expr, ... */
e0001a05
NC
1507
1508static void
7fa3d080 1509xtensa_literal_pseudo (int ignored ATTRIBUTE_UNUSED)
e0001a05
NC
1510{
1511 emit_state state;
1745fcba 1512 char *p, *base_name;
e0001a05 1513 char c;
e0001a05
NC
1514 segT dest_seg;
1515
82e7541d
BW
1516 if (inside_directive (directive_literal))
1517 {
1518 as_bad (_(".literal not allowed inside .begin literal region"));
1519 ignore_rest_of_line ();
1520 return;
1521 }
1522
43cd72b9
BW
1523 md_flush_pending_output ();
1524
82e7541d
BW
1525 /* Previous labels go with whatever follows this directive, not with
1526 the literal, so save them now. */
1527 saved_insn_labels = insn_labels;
1528 insn_labels = NULL;
1529
e0001a05
NC
1530 /* If we are using text-section literals, then this is the right value... */
1531 dest_seg = now_seg;
1532
1533 base_name = input_line_pointer;
1534
1535 xtensa_switch_to_literal_fragment (&state);
1536
43cd72b9 1537 /* ...but if we aren't using text-section-literals, then we
e0001a05 1538 need to put them in the section we just switched to. */
43cd72b9 1539 if (use_literal_section || directive_state[directive_absolute_literals])
e0001a05
NC
1540 dest_seg = now_seg;
1541
87975d2a
AM
1542 /* FIXME, despite the previous comments, dest_seg is unused... */
1543 (void) dest_seg;
1544
43cd72b9
BW
1545 /* All literals are aligned to four-byte boundaries. */
1546 frag_align (2, 0, 0);
1547 record_alignment (now_seg, 2);
e0001a05 1548
d02603dc 1549 c = get_symbol_name (&base_name);
e0001a05
NC
1550 /* Just after name is now '\0'. */
1551 p = input_line_pointer;
1552 *p = c;
d02603dc 1553 SKIP_WHITESPACE_AFTER_NAME ();
e0001a05
NC
1554
1555 if (*input_line_pointer != ',' && *input_line_pointer != ':')
1556 {
1557 as_bad (_("expected comma or colon after symbol name; "
1558 "rest of line ignored"));
1559 ignore_rest_of_line ();
1560 xtensa_restore_emit_state (&state);
1561 return;
1562 }
e0001a05 1563
d02603dc 1564 *p = 0;
e0001a05 1565 colon (base_name);
e0001a05 1566 *p = c;
d02603dc 1567
43cd72b9 1568 input_line_pointer++; /* skip ',' or ':' */
e0001a05 1569
43cd72b9 1570 xtensa_elf_cons (4);
e0001a05
NC
1571
1572 xtensa_restore_emit_state (&state);
82e7541d
BW
1573
1574 /* Restore the list of current labels. */
1575 xtensa_clear_insn_labels ();
1576 insn_labels = saved_insn_labels;
e0001a05
NC
1577}
1578
1579
1580static void
74869ac7 1581xtensa_literal_prefix (void)
e0001a05 1582{
74869ac7
BW
1583 char *name;
1584 int len;
1585
1586 /* Parse the new prefix from the input_line_pointer. */
1587 SKIP_WHITESPACE ();
1588 len = strspn (input_line_pointer,
1589 "ABCDEFGHIJKLMNOPQRSTUVWXYZ"
1590 "abcdefghijklmnopqrstuvwxyz_/0123456789.$");
e0001a05
NC
1591
1592 /* Get a null-terminated copy of the name. */
29a2809e 1593 name = xmemdup0 (input_line_pointer, len);
e0001a05 1594
74869ac7
BW
1595 /* Skip the name in the input line. */
1596 input_line_pointer += len;
43cd72b9 1597
74869ac7 1598 default_lit_sections.lit_prefix = name;
43cd72b9 1599
74869ac7 1600 /* Clear cached literal sections, since the prefix has changed. */
43cd72b9
BW
1601 default_lit_sections.lit_seg = NULL;
1602 default_lit_sections.lit4_seg = NULL;
43cd72b9
BW
1603}
1604
1605
1606/* Support ".frequency branch_target_frequency fall_through_frequency". */
1607
1608static void
7fa3d080 1609xtensa_frequency_pseudo (int ignored ATTRIBUTE_UNUSED)
43cd72b9
BW
1610{
1611 float fall_through_f, target_f;
43cd72b9
BW
1612
1613 fall_through_f = (float) strtod (input_line_pointer, &input_line_pointer);
1614 if (fall_through_f < 0)
1615 {
1616 as_bad (_("fall through frequency must be greater than 0"));
1617 ignore_rest_of_line ();
1618 return;
1619 }
1620
1621 target_f = (float) strtod (input_line_pointer, &input_line_pointer);
1622 if (target_f < 0)
1623 {
1624 as_bad (_("branch target frequency must be greater than 0"));
1625 ignore_rest_of_line ();
1626 return;
1627 }
1628
b08b5071 1629 set_subseg_freq (now_seg, now_subseg, target_f + fall_through_f, target_f);
43cd72b9
BW
1630
1631 demand_empty_rest_of_line ();
1632}
1633
1634
1635/* Like normal .long/.short/.word, except support @plt, etc.
1636 Clobbers input_line_pointer, checks end-of-line. */
1637
1638static void
7fa3d080 1639xtensa_elf_cons (int nbytes)
43cd72b9
BW
1640{
1641 expressionS exp;
1642 bfd_reloc_code_real_type reloc;
1643
1644 md_flush_pending_output ();
1645
1646 if (cur_vinsn.inside_bundle)
1647 as_bad (_("directives are not valid inside bundles"));
1648
1649 if (is_it_end_of_statement ())
1650 {
1651 demand_empty_rest_of_line ();
1652 return;
1653 }
1654
1655 do
1656 {
1657 expression (&exp);
1658 if (exp.X_op == O_symbol
1659 && *input_line_pointer == '@'
1660 && ((reloc = xtensa_elf_suffix (&input_line_pointer, &exp))
1661 != BFD_RELOC_NONE))
1662 {
1663 reloc_howto_type *reloc_howto =
1664 bfd_reloc_type_lookup (stdoutput, reloc);
1665
1666 if (reloc == BFD_RELOC_UNUSED || !reloc_howto)
1667 as_bad (_("unsupported relocation"));
1668 else if ((reloc >= BFD_RELOC_XTENSA_SLOT0_OP
1669 && reloc <= BFD_RELOC_XTENSA_SLOT14_OP)
1670 || (reloc >= BFD_RELOC_XTENSA_SLOT0_ALT
1671 && reloc <= BFD_RELOC_XTENSA_SLOT14_ALT))
1672 as_bad (_("opcode-specific %s relocation used outside "
1673 "an instruction"), reloc_howto->name);
1674 else if (nbytes != (int) bfd_get_reloc_size (reloc_howto))
992a06ee
AM
1675 as_bad (ngettext ("%s relocations do not fit in %d byte",
1676 "%s relocations do not fit in %d bytes",
1677 nbytes),
43cd72b9 1678 reloc_howto->name, nbytes);
28dbbc02
BW
1679 else if (reloc == BFD_RELOC_XTENSA_TLS_FUNC
1680 || reloc == BFD_RELOC_XTENSA_TLS_ARG
1681 || reloc == BFD_RELOC_XTENSA_TLS_CALL)
1682 as_bad (_("invalid use of %s relocation"), reloc_howto->name);
43cd72b9
BW
1683 else
1684 {
1685 char *p = frag_more ((int) nbytes);
1686 xtensa_set_frag_assembly_state (frag_now);
1687 fix_new_exp (frag_now, p - frag_now->fr_literal,
1bbb5f21 1688 nbytes, &exp, reloc_howto->pc_relative, reloc);
43cd72b9
BW
1689 }
1690 }
1691 else
1f7efbae
BW
1692 {
1693 xtensa_set_frag_assembly_state (frag_now);
1694 emit_expr (&exp, (unsigned int) nbytes);
1695 }
43cd72b9
BW
1696 }
1697 while (*input_line_pointer++ == ',');
1698
1699 input_line_pointer--; /* Put terminator back into stream. */
1700 demand_empty_rest_of_line ();
1701}
1702
fb227da0
BW
1703static bfd_boolean is_leb128_expr;
1704
1705static void
1706xtensa_leb128 (int sign)
1707{
1708 is_leb128_expr = TRUE;
1709 s_leb128 (sign);
1710 is_leb128_expr = FALSE;
1711}
1712
7fa3d080
BW
1713\f
1714/* Parsing and Idiom Translation. */
43cd72b9
BW
1715
1716/* Parse @plt, etc. and return the desired relocation. */
1717static bfd_reloc_code_real_type
7fa3d080 1718xtensa_elf_suffix (char **str_p, expressionS *exp_p)
43cd72b9 1719{
43cd72b9
BW
1720 char ident[20];
1721 char *str = *str_p;
1722 char *str2;
1723 int ch;
1724 int len;
e066bf5f 1725 unsigned int i;
43cd72b9
BW
1726
1727 if (*str++ != '@')
1728 return BFD_RELOC_NONE;
1729
1730 for (ch = *str, str2 = ident;
1731 (str2 < ident + sizeof (ident) - 1
1732 && (ISALNUM (ch) || ch == '@'));
1733 ch = *++str)
1734 {
1735 *str2++ = (ISLOWER (ch)) ? ch : TOLOWER (ch);
1736 }
1737
1738 *str2 = '\0';
1739 len = str2 - ident;
1740
1741 ch = ident[0];
e066bf5f
TS
1742 for (i = 0; i < ARRAY_SIZE (suffix_relocs); i++)
1743 if (ch == suffix_relocs[i].suffix[0]
1744 && len == suffix_relocs[i].length
1745 && memcmp (ident, suffix_relocs[i].suffix, suffix_relocs[i].length) == 0)
43cd72b9
BW
1746 {
1747 /* Now check for "identifier@suffix+constant". */
1748 if (*str == '-' || *str == '+')
1749 {
1750 char *orig_line = input_line_pointer;
1751 expressionS new_exp;
1752
1753 input_line_pointer = str;
1754 expression (&new_exp);
1755 if (new_exp.X_op == O_constant)
1756 {
1757 exp_p->X_add_number += new_exp.X_add_number;
1758 str = input_line_pointer;
1759 }
1760
1761 if (&input_line_pointer != str_p)
1762 input_line_pointer = orig_line;
1763 }
1764
1765 *str_p = str;
e066bf5f 1766 return suffix_relocs[i].reloc;
43cd72b9
BW
1767 }
1768
1769 return BFD_RELOC_UNUSED;
e0001a05
NC
1770}
1771
e0001a05 1772
bbdd25a8 1773/* Find the matching operator type. */
cc34adb2 1774static operatorT
bbdd25a8
BW
1775map_suffix_reloc_to_operator (bfd_reloc_code_real_type reloc)
1776{
cc34adb2 1777 operatorT operator = O_illegal;
e066bf5f 1778 unsigned int i;
3739860c 1779
e066bf5f 1780 for (i = 0; i < ARRAY_SIZE (suffix_relocs); i++)
bbdd25a8 1781 {
e066bf5f 1782 if (suffix_relocs[i].reloc == reloc)
bbdd25a8 1783 {
e066bf5f 1784 operator = suffix_relocs[i].operator;
bbdd25a8
BW
1785 break;
1786 }
1787 }
cc34adb2 1788 gas_assert (operator != O_illegal);
bbdd25a8
BW
1789 return operator;
1790}
1791
1792
1793/* Find the matching reloc type. */
1794static bfd_reloc_code_real_type
28dbbc02 1795map_operator_to_reloc (unsigned char operator, bfd_boolean is_literal)
bbdd25a8 1796{
e066bf5f 1797 unsigned int i;
bbdd25a8
BW
1798 bfd_reloc_code_real_type reloc = BFD_RELOC_UNUSED;
1799
e066bf5f 1800 for (i = 0; i < ARRAY_SIZE (suffix_relocs); i++)
bbdd25a8 1801 {
e066bf5f 1802 if (suffix_relocs[i].operator == operator)
bbdd25a8 1803 {
e066bf5f 1804 reloc = suffix_relocs[i].reloc;
bbdd25a8
BW
1805 break;
1806 }
1807 }
1808
28dbbc02
BW
1809 if (is_literal)
1810 {
1811 if (reloc == BFD_RELOC_XTENSA_TLS_FUNC)
1812 return BFD_RELOC_XTENSA_TLSDESC_FN;
1813 else if (reloc == BFD_RELOC_XTENSA_TLS_ARG)
1814 return BFD_RELOC_XTENSA_TLSDESC_ARG;
1815 }
1816
bbdd25a8
BW
1817 if (reloc == BFD_RELOC_UNUSED)
1818 return BFD_RELOC_32;
1819
1820 return reloc;
1821}
1822
1823
e0001a05 1824static const char *
7fa3d080 1825expression_end (const char *name)
e0001a05
NC
1826{
1827 while (1)
1828 {
1829 switch (*name)
1830 {
43cd72b9 1831 case '}':
e0001a05
NC
1832 case ';':
1833 case '\0':
1834 case ',':
43cd72b9 1835 case ':':
e0001a05
NC
1836 return name;
1837 case ' ':
1838 case '\t':
1839 ++name;
1840 continue;
1841 default:
1842 return 0;
1843 }
1844 }
1845}
1846
1847
1848#define ERROR_REG_NUM ((unsigned) -1)
1849
1850static unsigned
7fa3d080 1851tc_get_register (const char *prefix)
e0001a05
NC
1852{
1853 unsigned reg;
1854 const char *next_expr;
1855 const char *old_line_pointer;
1856
1857 SKIP_WHITESPACE ();
1858 old_line_pointer = input_line_pointer;
1859
1860 if (*input_line_pointer == '$')
1861 ++input_line_pointer;
1862
1863 /* Accept "sp" as a synonym for "a1". */
1864 if (input_line_pointer[0] == 's' && input_line_pointer[1] == 'p'
1865 && expression_end (input_line_pointer + 2))
1866 {
1867 input_line_pointer += 2;
1868 return 1; /* AR[1] */
1869 }
1870
1871 while (*input_line_pointer++ == *prefix++)
1872 ;
1873 --input_line_pointer;
1874 --prefix;
1875
1876 if (*prefix)
1877 {
1878 as_bad (_("bad register name: %s"), old_line_pointer);
1879 return ERROR_REG_NUM;
1880 }
1881
1882 if (!ISDIGIT ((unsigned char) *input_line_pointer))
1883 {
1884 as_bad (_("bad register number: %s"), input_line_pointer);
1885 return ERROR_REG_NUM;
1886 }
1887
1888 reg = 0;
1889
1890 while (ISDIGIT ((int) *input_line_pointer))
1891 reg = reg * 10 + *input_line_pointer++ - '0';
1892
1893 if (!(next_expr = expression_end (input_line_pointer)))
1894 {
1895 as_bad (_("bad register name: %s"), old_line_pointer);
1896 return ERROR_REG_NUM;
1897 }
1898
1899 input_line_pointer = (char *) next_expr;
1900
1901 return reg;
1902}
1903
1904
e0001a05 1905static void
7fa3d080 1906expression_maybe_register (xtensa_opcode opc, int opnd, expressionS *tok)
e0001a05 1907{
43cd72b9 1908 xtensa_isa isa = xtensa_default_isa;
e0001a05 1909
43cd72b9
BW
1910 /* Check if this is an immediate operand. */
1911 if (xtensa_operand_is_register (isa, opc, opnd) == 0)
e0001a05 1912 {
43cd72b9 1913 bfd_reloc_code_real_type reloc;
e0001a05 1914 segT t = expression (tok);
91d6fa6a 1915
43cd72b9
BW
1916 if (t == absolute_section
1917 && xtensa_operand_is_PCrelative (isa, opc, opnd) == 1)
e0001a05 1918 {
9c2799c2 1919 gas_assert (tok->X_op == O_constant);
e0001a05
NC
1920 tok->X_op = O_symbol;
1921 tok->X_add_symbol = &abs_symbol;
1922 }
43cd72b9
BW
1923
1924 if ((tok->X_op == O_constant || tok->X_op == O_symbol)
bbdd25a8
BW
1925 && ((reloc = xtensa_elf_suffix (&input_line_pointer, tok))
1926 != BFD_RELOC_NONE))
e0001a05 1927 {
1bbb5f21 1928 switch (reloc)
43cd72b9 1929 {
1bbb5f21
BW
1930 case BFD_RELOC_LO16:
1931 if (tok->X_op == O_constant)
bbdd25a8 1932 {
43cd72b9 1933 tok->X_add_number &= 0xffff;
bbdd25a8 1934 return;
1bbb5f21
BW
1935 }
1936 break;
1937 case BFD_RELOC_HI16:
1938 if (tok->X_op == O_constant)
1939 {
43cd72b9 1940 tok->X_add_number = ((unsigned) tok->X_add_number) >> 16;
bbdd25a8 1941 return;
bbdd25a8 1942 }
1bbb5f21
BW
1943 break;
1944 case BFD_RELOC_UNUSED:
1945 as_bad (_("unsupported relocation"));
1946 return;
1947 case BFD_RELOC_32_PCREL:
1948 as_bad (_("pcrel relocation not allowed in an instruction"));
1949 return;
1950 default:
1951 break;
43cd72b9 1952 }
bbdd25a8 1953 tok->X_op = map_suffix_reloc_to_operator (reloc);
e0001a05 1954 }
e0001a05
NC
1955 }
1956 else
1957 {
43cd72b9
BW
1958 xtensa_regfile opnd_rf = xtensa_operand_regfile (isa, opc, opnd);
1959 unsigned reg = tc_get_register (xtensa_regfile_shortname (isa, opnd_rf));
e0001a05
NC
1960
1961 if (reg != ERROR_REG_NUM) /* Already errored */
1962 {
1963 uint32 buf = reg;
43cd72b9 1964 if (xtensa_operand_encode (isa, opc, opnd, &buf))
e0001a05
NC
1965 as_bad (_("register number out of range"));
1966 }
1967
1968 tok->X_op = O_register;
1969 tok->X_add_symbol = 0;
1970 tok->X_add_number = reg;
1971 }
1972}
1973
1974
1975/* Split up the arguments for an opcode or pseudo-op. */
1976
1977static int
7fa3d080 1978tokenize_arguments (char **args, char *str)
e0001a05
NC
1979{
1980 char *old_input_line_pointer;
1981 bfd_boolean saw_comma = FALSE;
1982 bfd_boolean saw_arg = FALSE;
43cd72b9 1983 bfd_boolean saw_colon = FALSE;
e0001a05
NC
1984 int num_args = 0;
1985 char *arg_end, *arg;
1986 int arg_len;
43cd72b9
BW
1987
1988 /* Save and restore input_line_pointer around this function. */
e0001a05
NC
1989 old_input_line_pointer = input_line_pointer;
1990 input_line_pointer = str;
1991
1992 while (*input_line_pointer)
1993 {
1994 SKIP_WHITESPACE ();
1995 switch (*input_line_pointer)
1996 {
1997 case '\0':
43cd72b9 1998 case '}':
e0001a05
NC
1999 goto fini;
2000
43cd72b9
BW
2001 case ':':
2002 input_line_pointer++;
2003 if (saw_comma || saw_colon || !saw_arg)
2004 goto err;
2005 saw_colon = TRUE;
2006 break;
2007
e0001a05
NC
2008 case ',':
2009 input_line_pointer++;
43cd72b9 2010 if (saw_comma || saw_colon || !saw_arg)
e0001a05
NC
2011 goto err;
2012 saw_comma = TRUE;
2013 break;
2014
2015 default:
43cd72b9 2016 if (!saw_comma && !saw_colon && saw_arg)
e0001a05
NC
2017 goto err;
2018
2019 arg_end = input_line_pointer + 1;
2020 while (!expression_end (arg_end))
2021 arg_end += 1;
43cd72b9 2022
e0001a05 2023 arg_len = arg_end - input_line_pointer;
325801bd 2024 arg = XNEWVEC (char, (saw_colon ? 1 : 0) + arg_len + 1);
e0001a05
NC
2025 args[num_args] = arg;
2026
43cd72b9
BW
2027 if (saw_colon)
2028 *arg++ = ':';
e0001a05
NC
2029 strncpy (arg, input_line_pointer, arg_len);
2030 arg[arg_len] = '\0';
43cd72b9 2031
e0001a05
NC
2032 input_line_pointer = arg_end;
2033 num_args += 1;
c138bc38 2034 saw_comma = FALSE;
43cd72b9 2035 saw_colon = FALSE;
c138bc38 2036 saw_arg = TRUE;
e0001a05
NC
2037 break;
2038 }
2039 }
2040
2041fini:
43cd72b9 2042 if (saw_comma || saw_colon)
e0001a05
NC
2043 goto err;
2044 input_line_pointer = old_input_line_pointer;
2045 return num_args;
2046
2047err:
43cd72b9
BW
2048 if (saw_comma)
2049 as_bad (_("extra comma"));
2050 else if (saw_colon)
2051 as_bad (_("extra colon"));
2052 else if (!saw_arg)
c138bc38 2053 as_bad (_("missing argument"));
43cd72b9
BW
2054 else
2055 as_bad (_("missing comma or colon"));
e0001a05
NC
2056 input_line_pointer = old_input_line_pointer;
2057 return -1;
2058}
2059
2060
43cd72b9 2061/* Parse the arguments to an opcode. Return TRUE on error. */
e0001a05
NC
2062
2063static bfd_boolean
7fa3d080 2064parse_arguments (TInsn *insn, int num_args, char **arg_strings)
e0001a05 2065{
43cd72b9 2066 expressionS *tok, *last_tok;
e0001a05
NC
2067 xtensa_opcode opcode = insn->opcode;
2068 bfd_boolean had_error = TRUE;
43cd72b9
BW
2069 xtensa_isa isa = xtensa_default_isa;
2070 int n, num_regs = 0;
e0001a05 2071 int opcode_operand_count;
43cd72b9
BW
2072 int opnd_cnt, last_opnd_cnt;
2073 unsigned int next_reg = 0;
e0001a05
NC
2074 char *old_input_line_pointer;
2075
2076 if (insn->insn_type == ITYPE_LITERAL)
2077 opcode_operand_count = 1;
2078 else
43cd72b9 2079 opcode_operand_count = xtensa_opcode_num_operands (isa, opcode);
e0001a05 2080
43cd72b9 2081 tok = insn->tok;
e0001a05
NC
2082 memset (tok, 0, sizeof (*tok) * MAX_INSN_ARGS);
2083
2084 /* Save and restore input_line_pointer around this function. */
43cd72b9
BW
2085 old_input_line_pointer = input_line_pointer;
2086
2087 last_tok = 0;
2088 last_opnd_cnt = -1;
2089 opnd_cnt = 0;
2090
2091 /* Skip invisible operands. */
2092 while (xtensa_operand_is_visible (isa, opcode, opnd_cnt) == 0)
2093 {
2094 opnd_cnt += 1;
2095 tok++;
2096 }
e0001a05
NC
2097
2098 for (n = 0; n < num_args; n++)
43cd72b9 2099 {
e0001a05 2100 input_line_pointer = arg_strings[n];
43cd72b9
BW
2101 if (*input_line_pointer == ':')
2102 {
2103 xtensa_regfile opnd_rf;
2104 input_line_pointer++;
2105 if (num_regs == 0)
2106 goto err;
9c2799c2 2107 gas_assert (opnd_cnt > 0);
43cd72b9
BW
2108 num_regs--;
2109 opnd_rf = xtensa_operand_regfile (isa, opcode, last_opnd_cnt);
2110 if (next_reg
2111 != tc_get_register (xtensa_regfile_shortname (isa, opnd_rf)))
2112 as_warn (_("incorrect register number, ignoring"));
2113 next_reg++;
2114 }
2115 else
2116 {
2117 if (opnd_cnt >= opcode_operand_count)
2118 {
2119 as_warn (_("too many arguments"));
2120 goto err;
2121 }
9c2799c2 2122 gas_assert (opnd_cnt < MAX_INSN_ARGS);
43cd72b9
BW
2123
2124 expression_maybe_register (opcode, opnd_cnt, tok);
2125 next_reg = tok->X_add_number + 1;
2126
2127 if (tok->X_op == O_illegal || tok->X_op == O_absent)
2128 goto err;
2129 if (xtensa_operand_is_register (isa, opcode, opnd_cnt) == 1)
2130 {
2131 num_regs = xtensa_operand_num_regs (isa, opcode, opnd_cnt) - 1;
2132 /* minus 1 because we are seeing one right now */
2133 }
2134 else
2135 num_regs = 0;
e0001a05 2136
43cd72b9
BW
2137 last_tok = tok;
2138 last_opnd_cnt = opnd_cnt;
1ec520b7 2139 demand_empty_rest_of_line ();
e0001a05 2140
43cd72b9
BW
2141 do
2142 {
2143 opnd_cnt += 1;
2144 tok++;
2145 }
2146 while (xtensa_operand_is_visible (isa, opcode, opnd_cnt) == 0);
2147 }
2148 }
e0001a05 2149
43cd72b9
BW
2150 if (num_regs > 0 && ((int) next_reg != last_tok->X_add_number + 1))
2151 goto err;
e0001a05
NC
2152
2153 insn->ntok = tok - insn->tok;
c138bc38 2154 had_error = FALSE;
e0001a05
NC
2155
2156 err:
43cd72b9 2157 input_line_pointer = old_input_line_pointer;
e0001a05
NC
2158 return had_error;
2159}
2160
2161
43cd72b9 2162static int
7fa3d080 2163get_invisible_operands (TInsn *insn)
43cd72b9
BW
2164{
2165 xtensa_isa isa = xtensa_default_isa;
2166 static xtensa_insnbuf slotbuf = NULL;
2167 xtensa_format fmt;
2168 xtensa_opcode opc = insn->opcode;
2169 int slot, opnd, fmt_found;
2170 unsigned val;
2171
2172 if (!slotbuf)
2173 slotbuf = xtensa_insnbuf_alloc (isa);
2174
2175 /* Find format/slot where this can be encoded. */
2176 fmt_found = 0;
2177 slot = 0;
2178 for (fmt = 0; fmt < xtensa_isa_num_formats (isa); fmt++)
2179 {
2180 for (slot = 0; slot < xtensa_format_num_slots (isa, fmt); slot++)
2181 {
2182 if (xtensa_opcode_encode (isa, fmt, slot, slotbuf, opc) == 0)
2183 {
2184 fmt_found = 1;
2185 break;
2186 }
2187 }
2188 if (fmt_found) break;
2189 }
2190
2191 if (!fmt_found)
2192 {
2193 as_bad (_("cannot encode opcode \"%s\""), xtensa_opcode_name (isa, opc));
2194 return -1;
2195 }
2196
2197 /* First encode all the visible operands
2198 (to deal with shared field operands). */
2199 for (opnd = 0; opnd < insn->ntok; opnd++)
2200 {
2201 if (xtensa_operand_is_visible (isa, opc, opnd) == 1
2202 && (insn->tok[opnd].X_op == O_register
2203 || insn->tok[opnd].X_op == O_constant))
2204 {
2205 val = insn->tok[opnd].X_add_number;
2206 xtensa_operand_encode (isa, opc, opnd, &val);
2207 xtensa_operand_set_field (isa, opc, opnd, fmt, slot, slotbuf, val);
2208 }
2209 }
2210
2211 /* Then pull out the values for the invisible ones. */
2212 for (opnd = 0; opnd < insn->ntok; opnd++)
2213 {
2214 if (xtensa_operand_is_visible (isa, opc, opnd) == 0)
2215 {
2216 xtensa_operand_get_field (isa, opc, opnd, fmt, slot, slotbuf, &val);
2217 xtensa_operand_decode (isa, opc, opnd, &val);
2218 insn->tok[opnd].X_add_number = val;
2219 if (xtensa_operand_is_register (isa, opc, opnd) == 1)
2220 insn->tok[opnd].X_op = O_register;
2221 else
2222 insn->tok[opnd].X_op = O_constant;
2223 }
2224 }
2225
2226 return 0;
2227}
2228
2229
e0001a05 2230static void
7fa3d080 2231xg_reverse_shift_count (char **cnt_argp)
e0001a05
NC
2232{
2233 char *cnt_arg, *new_arg;
2234 cnt_arg = *cnt_argp;
2235
2236 /* replace the argument with "31-(argument)" */
78fb7e37 2237 new_arg = concat ("31-(", cnt_arg, ")", (char *) NULL);
e0001a05
NC
2238
2239 free (cnt_arg);
2240 *cnt_argp = new_arg;
2241}
2242
2243
2244/* If "arg" is a constant expression, return non-zero with the value
2245 in *valp. */
2246
2247static int
7fa3d080 2248xg_arg_is_constant (char *arg, offsetT *valp)
e0001a05
NC
2249{
2250 expressionS exp;
2251 char *save_ptr = input_line_pointer;
2252
2253 input_line_pointer = arg;
2254 expression (&exp);
2255 input_line_pointer = save_ptr;
2256
2257 if (exp.X_op == O_constant)
2258 {
2259 *valp = exp.X_add_number;
2260 return 1;
2261 }
2262
2263 return 0;
2264}
2265
2266
2267static void
b9bb4a93 2268xg_replace_opname (char **popname, const char *newop)
e0001a05
NC
2269{
2270 free (*popname);
4ec9d7d5 2271 *popname = xstrdup (newop);
e0001a05
NC
2272}
2273
2274
2275static int
7fa3d080
BW
2276xg_check_num_args (int *pnum_args,
2277 int expected_num,
2278 char *opname,
2279 char **arg_strings)
e0001a05
NC
2280{
2281 int num_args = *pnum_args;
2282
43cd72b9 2283 if (num_args < expected_num)
e0001a05
NC
2284 {
2285 as_bad (_("not enough operands (%d) for '%s'; expected %d"),
2286 num_args, opname, expected_num);
2287 return -1;
2288 }
2289
2290 if (num_args > expected_num)
2291 {
2292 as_warn (_("too many operands (%d) for '%s'; expected %d"),
2293 num_args, opname, expected_num);
2294 while (num_args-- > expected_num)
2295 {
2296 free (arg_strings[num_args]);
2297 arg_strings[num_args] = 0;
2298 }
2299 *pnum_args = expected_num;
2300 return -1;
2301 }
2302
2303 return 0;
2304}
2305
2306
43cd72b9
BW
2307/* If the register is not specified as part of the opcode,
2308 then get it from the operand and move it to the opcode. */
2309
e0001a05 2310static int
7fa3d080 2311xg_translate_sysreg_op (char **popname, int *pnum_args, char **arg_strings)
e0001a05 2312{
43cd72b9
BW
2313 xtensa_isa isa = xtensa_default_isa;
2314 xtensa_sysreg sr;
e0001a05 2315 char *opname, *new_opname;
43cd72b9
BW
2316 const char *sr_name;
2317 int is_user, is_write;
e0001a05
NC
2318
2319 opname = *popname;
2320 if (*opname == '_')
80ca4e2c 2321 opname += 1;
43cd72b9
BW
2322 is_user = (opname[1] == 'u');
2323 is_write = (opname[0] == 'w');
e0001a05 2324
43cd72b9 2325 /* Opname == [rw]ur or [rwx]sr... */
e0001a05 2326
43cd72b9
BW
2327 if (xg_check_num_args (pnum_args, 2, opname, arg_strings))
2328 return -1;
e0001a05 2329
43cd72b9
BW
2330 /* Check if the argument is a symbolic register name. */
2331 sr = xtensa_sysreg_lookup_name (isa, arg_strings[1]);
2332 /* Handle WSR to "INTSET" as a special case. */
2333 if (sr == XTENSA_UNDEFINED && is_write && !is_user
2334 && !strcasecmp (arg_strings[1], "intset"))
2335 sr = xtensa_sysreg_lookup_name (isa, "interrupt");
2336 if (sr == XTENSA_UNDEFINED
2337 || (xtensa_sysreg_is_user (isa, sr) == 1) != is_user)
2338 {
2339 /* Maybe it's a register number.... */
2340 offsetT val;
e0001a05
NC
2341 if (!xg_arg_is_constant (arg_strings[1], &val))
2342 {
43cd72b9
BW
2343 as_bad (_("invalid register '%s' for '%s' instruction"),
2344 arg_strings[1], opname);
e0001a05
NC
2345 return -1;
2346 }
43cd72b9
BW
2347 sr = xtensa_sysreg_lookup (isa, val, is_user);
2348 if (sr == XTENSA_UNDEFINED)
e0001a05 2349 {
43cd72b9 2350 as_bad (_("invalid register number (%ld) for '%s' instruction"),
dd49a749 2351 (long) val, opname);
e0001a05
NC
2352 return -1;
2353 }
43cd72b9 2354 }
e0001a05 2355
43cd72b9
BW
2356 /* Remove the last argument, which is now part of the opcode. */
2357 free (arg_strings[1]);
2358 arg_strings[1] = 0;
2359 *pnum_args = 1;
2360
2361 /* Translate the opcode. */
2362 sr_name = xtensa_sysreg_name (isa, sr);
2363 /* Another special case for "WSR.INTSET".... */
2364 if (is_write && !is_user && !strcasecmp ("interrupt", sr_name))
2365 sr_name = "intset";
4ec9d7d5 2366 new_opname = concat (*popname, ".", sr_name, (char *) NULL);
43cd72b9
BW
2367 free (*popname);
2368 *popname = new_opname;
2369
2370 return 0;
2371}
2372
2373
2374static int
7fa3d080 2375xtensa_translate_old_userreg_ops (char **popname)
43cd72b9
BW
2376{
2377 xtensa_isa isa = xtensa_default_isa;
2378 xtensa_sysreg sr;
2379 char *opname, *new_opname;
2380 const char *sr_name;
2381 bfd_boolean has_underbar = FALSE;
2382
2383 opname = *popname;
2384 if (opname[0] == '_')
2385 {
2386 has_underbar = TRUE;
2387 opname += 1;
2388 }
2389
2390 sr = xtensa_sysreg_lookup_name (isa, opname + 1);
2391 if (sr != XTENSA_UNDEFINED)
2392 {
2393 /* The new default name ("nnn") is different from the old default
2394 name ("URnnn"). The old default is handled below, and we don't
2395 want to recognize [RW]nnn, so do nothing if the name is the (new)
2396 default. */
2397 static char namebuf[10];
2398 sprintf (namebuf, "%d", xtensa_sysreg_number (isa, sr));
2399 if (strcmp (namebuf, opname + 1) == 0)
2400 return 0;
2401 }
2402 else
2403 {
2404 offsetT val;
2405 char *end;
2406
2407 /* Only continue if the reg name is "URnnn". */
2408 if (opname[1] != 'u' || opname[2] != 'r')
2409 return 0;
2410 val = strtoul (opname + 3, &end, 10);
2411 if (*end != '\0')
2412 return 0;
2413
2414 sr = xtensa_sysreg_lookup (isa, val, 1);
2415 if (sr == XTENSA_UNDEFINED)
2416 {
2417 as_bad (_("invalid register number (%ld) for '%s'"),
dd49a749 2418 (long) val, opname);
43cd72b9
BW
2419 return -1;
2420 }
2421 }
2422
2423 /* Translate the opcode. */
2424 sr_name = xtensa_sysreg_name (isa, sr);
add39d23 2425 new_opname = XNEWVEC (char, strlen (sr_name) + 6);
43cd72b9
BW
2426 sprintf (new_opname, "%s%cur.%s", (has_underbar ? "_" : ""),
2427 opname[0], sr_name);
2428 free (*popname);
2429 *popname = new_opname;
2430
2431 return 0;
2432}
2433
2434
2435static int
b9bb4a93
TS
2436xtensa_translate_zero_immed (const char *old_op,
2437 const char *new_op,
7fa3d080
BW
2438 char **popname,
2439 int *pnum_args,
2440 char **arg_strings)
43cd72b9
BW
2441{
2442 char *opname;
2443 offsetT val;
2444
2445 opname = *popname;
9c2799c2 2446 gas_assert (opname[0] != '_');
43cd72b9
BW
2447
2448 if (strcmp (opname, old_op) != 0)
2449 return 0;
e0001a05 2450
43cd72b9
BW
2451 if (xg_check_num_args (pnum_args, 3, opname, arg_strings))
2452 return -1;
2453 if (xg_arg_is_constant (arg_strings[1], &val) && val == 0)
2454 {
2455 xg_replace_opname (popname, new_op);
2456 free (arg_strings[1]);
2457 arg_strings[1] = arg_strings[2];
2458 arg_strings[2] = 0;
2459 *pnum_args = 2;
e0001a05
NC
2460 }
2461
2462 return 0;
2463}
2464
2465
2466/* If the instruction is an idiom (i.e., a built-in macro), translate it.
2467 Returns non-zero if an error was found. */
2468
2469static int
7fa3d080 2470xg_translate_idioms (char **popname, int *pnum_args, char **arg_strings)
e0001a05
NC
2471{
2472 char *opname = *popname;
2473 bfd_boolean has_underbar = FALSE;
2474
2475 if (*opname == '_')
2476 {
2477 has_underbar = TRUE;
2478 opname += 1;
2479 }
2480
2481 if (strcmp (opname, "mov") == 0)
2482 {
43cd72b9 2483 if (use_transform () && !has_underbar && density_supported)
e0001a05
NC
2484 xg_replace_opname (popname, "mov.n");
2485 else
2486 {
2487 if (xg_check_num_args (pnum_args, 2, opname, arg_strings))
2488 return -1;
2489 xg_replace_opname (popname, (has_underbar ? "_or" : "or"));
4ec9d7d5 2490 arg_strings[2] = xstrdup (arg_strings[1]);
e0001a05
NC
2491 *pnum_args = 3;
2492 }
2493 return 0;
2494 }
2495
2496 if (strcmp (opname, "bbsi.l") == 0)
2497 {
2498 if (xg_check_num_args (pnum_args, 3, opname, arg_strings))
2499 return -1;
2500 xg_replace_opname (popname, (has_underbar ? "_bbsi" : "bbsi"));
2501 if (target_big_endian)
2502 xg_reverse_shift_count (&arg_strings[1]);
2503 return 0;
2504 }
2505
2506 if (strcmp (opname, "bbci.l") == 0)
2507 {
2508 if (xg_check_num_args (pnum_args, 3, opname, arg_strings))
2509 return -1;
2510 xg_replace_opname (popname, (has_underbar ? "_bbci" : "bbci"));
2511 if (target_big_endian)
2512 xg_reverse_shift_count (&arg_strings[1]);
2513 return 0;
2514 }
2515
eb6d9dce 2516 /* Don't do anything special with NOPs inside FLIX instructions. They
3739860c 2517 are handled elsewhere. Real NOP instructions are always available
eb6d9dce
BW
2518 in configurations with FLIX, so this should never be an issue but
2519 check for it anyway. */
2520 if (!cur_vinsn.inside_bundle && xtensa_nop_opcode == XTENSA_UNDEFINED
43cd72b9 2521 && strcmp (opname, "nop") == 0)
e0001a05 2522 {
43cd72b9 2523 if (use_transform () && !has_underbar && density_supported)
e0001a05
NC
2524 xg_replace_opname (popname, "nop.n");
2525 else
2526 {
2527 if (xg_check_num_args (pnum_args, 0, opname, arg_strings))
2528 return -1;
2529 xg_replace_opname (popname, (has_underbar ? "_or" : "or"));
4ec9d7d5
TS
2530 arg_strings[0] = xstrdup ("a1");
2531 arg_strings[1] = xstrdup ("a1");
2532 arg_strings[2] = xstrdup ("a1");
e0001a05
NC
2533 *pnum_args = 3;
2534 }
2535 return 0;
2536 }
2537
43cd72b9
BW
2538 /* Recognize [RW]UR and [RWX]SR. */
2539 if ((((opname[0] == 'r' || opname[0] == 'w')
2540 && (opname[1] == 'u' || opname[1] == 's'))
2541 || (opname[0] == 'x' && opname[1] == 's'))
2542 && opname[2] == 'r'
2543 && opname[3] == '\0')
e0001a05
NC
2544 return xg_translate_sysreg_op (popname, pnum_args, arg_strings);
2545
43cd72b9
BW
2546 /* Backward compatibility for RUR and WUR: Recognize [RW]UR<nnn> and
2547 [RW]<name> if <name> is the non-default name of a user register. */
2548 if ((opname[0] == 'r' || opname[0] == 'w')
2549 && xtensa_opcode_lookup (xtensa_default_isa, opname) == XTENSA_UNDEFINED)
2550 return xtensa_translate_old_userreg_ops (popname);
e0001a05 2551
43cd72b9
BW
2552 /* Relax branches that don't allow comparisons against an immediate value
2553 of zero to the corresponding branches with implicit zero immediates. */
2554 if (!has_underbar && use_transform ())
2555 {
2556 if (xtensa_translate_zero_immed ("bnei", "bnez", popname,
2557 pnum_args, arg_strings))
2558 return -1;
e0001a05 2559
43cd72b9
BW
2560 if (xtensa_translate_zero_immed ("beqi", "beqz", popname,
2561 pnum_args, arg_strings))
2562 return -1;
e0001a05 2563
43cd72b9
BW
2564 if (xtensa_translate_zero_immed ("bgei", "bgez", popname,
2565 pnum_args, arg_strings))
2566 return -1;
e0001a05 2567
43cd72b9
BW
2568 if (xtensa_translate_zero_immed ("blti", "bltz", popname,
2569 pnum_args, arg_strings))
2570 return -1;
2571 }
e0001a05 2572
43cd72b9
BW
2573 return 0;
2574}
e0001a05 2575
43cd72b9
BW
2576\f
2577/* Functions for dealing with the Xtensa ISA. */
e0001a05 2578
43cd72b9
BW
2579/* Currently the assembler only allows us to use a single target per
2580 fragment. Because of this, only one operand for a given
2581 instruction may be symbolic. If there is a PC-relative operand,
2582 the last one is chosen. Otherwise, the result is the number of the
2583 last immediate operand, and if there are none of those, we fail and
2584 return -1. */
e0001a05 2585
7fa3d080
BW
2586static int
2587get_relaxable_immed (xtensa_opcode opcode)
43cd72b9
BW
2588{
2589 int last_immed = -1;
2590 int noperands, opi;
e0001a05 2591
43cd72b9
BW
2592 if (opcode == XTENSA_UNDEFINED)
2593 return -1;
e0001a05 2594
43cd72b9
BW
2595 noperands = xtensa_opcode_num_operands (xtensa_default_isa, opcode);
2596 for (opi = noperands - 1; opi >= 0; opi--)
2597 {
2598 if (xtensa_operand_is_visible (xtensa_default_isa, opcode, opi) == 0)
2599 continue;
2600 if (xtensa_operand_is_PCrelative (xtensa_default_isa, opcode, opi) == 1)
2601 return opi;
2602 if (last_immed == -1
2603 && xtensa_operand_is_register (xtensa_default_isa, opcode, opi) == 0)
2604 last_immed = opi;
e0001a05 2605 }
43cd72b9 2606 return last_immed;
e0001a05
NC
2607}
2608
e0001a05 2609
43cd72b9 2610static xtensa_opcode
7fa3d080 2611get_opcode_from_buf (const char *buf, int slot)
e0001a05 2612{
43cd72b9
BW
2613 static xtensa_insnbuf insnbuf = NULL;
2614 static xtensa_insnbuf slotbuf = NULL;
2615 xtensa_isa isa = xtensa_default_isa;
2616 xtensa_format fmt;
2617
2618 if (!insnbuf)
e0001a05 2619 {
43cd72b9
BW
2620 insnbuf = xtensa_insnbuf_alloc (isa);
2621 slotbuf = xtensa_insnbuf_alloc (isa);
e0001a05 2622 }
e0001a05 2623
d77b99c9 2624 xtensa_insnbuf_from_chars (isa, insnbuf, (const unsigned char *) buf, 0);
43cd72b9
BW
2625 fmt = xtensa_format_decode (isa, insnbuf);
2626 if (fmt == XTENSA_UNDEFINED)
2627 return XTENSA_UNDEFINED;
e0001a05 2628
43cd72b9
BW
2629 if (slot >= xtensa_format_num_slots (isa, fmt))
2630 return XTENSA_UNDEFINED;
e0001a05 2631
43cd72b9
BW
2632 xtensa_format_get_slot (isa, fmt, slot, insnbuf, slotbuf);
2633 return xtensa_opcode_decode (isa, fmt, slot, slotbuf);
e0001a05
NC
2634}
2635
2636
43cd72b9 2637#ifdef TENSILICA_DEBUG
e0001a05 2638
43cd72b9 2639/* For debugging, print out the mapping of opcode numbers to opcodes. */
e0001a05 2640
7fa3d080
BW
2641static void
2642xtensa_print_insn_table (void)
43cd72b9
BW
2643{
2644 int num_opcodes, num_operands;
2645 xtensa_opcode opcode;
2646 xtensa_isa isa = xtensa_default_isa;
e0001a05 2647
43cd72b9
BW
2648 num_opcodes = xtensa_isa_num_opcodes (xtensa_default_isa);
2649 for (opcode = 0; opcode < num_opcodes; opcode++)
e0001a05 2650 {
43cd72b9
BW
2651 int opn;
2652 fprintf (stderr, "%d: %s: ", opcode, xtensa_opcode_name (isa, opcode));
2653 num_operands = xtensa_opcode_num_operands (isa, opcode);
2654 for (opn = 0; opn < num_operands; opn++)
2655 {
2656 if (xtensa_operand_is_visible (isa, opcode, opn) == 0)
2657 continue;
2658 if (xtensa_operand_is_register (isa, opcode, opn) == 1)
2659 {
2660 xtensa_regfile opnd_rf =
2661 xtensa_operand_regfile (isa, opcode, opn);
2662 fprintf (stderr, "%s ", xtensa_regfile_shortname (isa, opnd_rf));
2663 }
2664 else if (xtensa_operand_is_PCrelative (isa, opcode, opn) == 1)
2665 fputs ("[lLr] ", stderr);
2666 else
2667 fputs ("i ", stderr);
2668 }
2669 fprintf (stderr, "\n");
e0001a05 2670 }
e0001a05
NC
2671}
2672
2673
43cd72b9 2674static void
7fa3d080 2675print_vliw_insn (xtensa_insnbuf vbuf)
e0001a05 2676{
e0001a05 2677 xtensa_isa isa = xtensa_default_isa;
43cd72b9
BW
2678 xtensa_format f = xtensa_format_decode (isa, vbuf);
2679 xtensa_insnbuf sbuf = xtensa_insnbuf_alloc (isa);
2680 int op;
e0001a05 2681
43cd72b9 2682 fprintf (stderr, "format = %d\n", f);
e0001a05 2683
43cd72b9
BW
2684 for (op = 0; op < xtensa_format_num_slots (isa, f); op++)
2685 {
2686 xtensa_opcode opcode;
2687 const char *opname;
2688 int operands;
2689
2690 xtensa_format_get_slot (isa, f, op, vbuf, sbuf);
2691 opcode = xtensa_opcode_decode (isa, f, op, sbuf);
2692 opname = xtensa_opcode_name (isa, opcode);
2693
2694 fprintf (stderr, "op in slot %i is %s;\n", op, opname);
2695 fprintf (stderr, " operands = ");
2696 for (operands = 0;
2697 operands < xtensa_opcode_num_operands (isa, opcode);
2698 operands++)
2699 {
2700 unsigned int val;
2701 if (xtensa_operand_is_visible (isa, opcode, operands) == 0)
2702 continue;
2703 xtensa_operand_get_field (isa, opcode, operands, f, op, sbuf, &val);
2704 xtensa_operand_decode (isa, opcode, operands, &val);
2705 fprintf (stderr, "%d ", val);
2706 }
2707 fprintf (stderr, "\n");
2708 }
2709 xtensa_insnbuf_free (isa, sbuf);
e0001a05
NC
2710}
2711
43cd72b9
BW
2712#endif /* TENSILICA_DEBUG */
2713
e0001a05
NC
2714
2715static bfd_boolean
7fa3d080 2716is_direct_call_opcode (xtensa_opcode opcode)
e0001a05 2717{
43cd72b9
BW
2718 xtensa_isa isa = xtensa_default_isa;
2719 int n, num_operands;
e0001a05 2720
64b607e6 2721 if (xtensa_opcode_is_call (isa, opcode) != 1)
e0001a05
NC
2722 return FALSE;
2723
43cd72b9
BW
2724 num_operands = xtensa_opcode_num_operands (isa, opcode);
2725 for (n = 0; n < num_operands; n++)
2726 {
2727 if (xtensa_operand_is_register (isa, opcode, n) == 0
2728 && xtensa_operand_is_PCrelative (isa, opcode, n) == 1)
2729 return TRUE;
2730 }
2731 return FALSE;
e0001a05
NC
2732}
2733
2734
43cd72b9
BW
2735/* Convert from BFD relocation type code to slot and operand number.
2736 Returns non-zero on failure. */
e0001a05 2737
43cd72b9 2738static int
7fa3d080 2739decode_reloc (bfd_reloc_code_real_type reloc, int *slot, bfd_boolean *is_alt)
e0001a05 2740{
43cd72b9
BW
2741 if (reloc >= BFD_RELOC_XTENSA_SLOT0_OP
2742 && reloc <= BFD_RELOC_XTENSA_SLOT14_OP)
e0001a05 2743 {
43cd72b9
BW
2744 *slot = reloc - BFD_RELOC_XTENSA_SLOT0_OP;
2745 *is_alt = FALSE;
e0001a05 2746 }
43cd72b9
BW
2747 else if (reloc >= BFD_RELOC_XTENSA_SLOT0_ALT
2748 && reloc <= BFD_RELOC_XTENSA_SLOT14_ALT)
e0001a05 2749 {
43cd72b9
BW
2750 *slot = reloc - BFD_RELOC_XTENSA_SLOT0_ALT;
2751 *is_alt = TRUE;
e0001a05 2752 }
43cd72b9
BW
2753 else
2754 return -1;
2755
2756 return 0;
e0001a05
NC
2757}
2758
2759
43cd72b9
BW
2760/* Convert from slot number to BFD relocation type code for the
2761 standard PC-relative relocations. Return BFD_RELOC_NONE on
2762 failure. */
e0001a05 2763
43cd72b9 2764static bfd_reloc_code_real_type
7fa3d080 2765encode_reloc (int slot)
e0001a05 2766{
43cd72b9
BW
2767 if (slot < 0 || slot > 14)
2768 return BFD_RELOC_NONE;
2769
2770 return BFD_RELOC_XTENSA_SLOT0_OP + slot;
e0001a05
NC
2771}
2772
2773
43cd72b9
BW
2774/* Convert from slot numbers to BFD relocation type code for the
2775 "alternate" relocations. Return BFD_RELOC_NONE on failure. */
e0001a05 2776
43cd72b9 2777static bfd_reloc_code_real_type
7fa3d080 2778encode_alt_reloc (int slot)
e0001a05 2779{
43cd72b9
BW
2780 if (slot < 0 || slot > 14)
2781 return BFD_RELOC_NONE;
2782
2783 return BFD_RELOC_XTENSA_SLOT0_ALT + slot;
e0001a05
NC
2784}
2785
2786
2787static void
7fa3d080
BW
2788xtensa_insnbuf_set_operand (xtensa_insnbuf slotbuf,
2789 xtensa_format fmt,
2790 int slot,
2791 xtensa_opcode opcode,
2792 int operand,
2793 uint32 value,
2794 const char *file,
2795 unsigned int line)
e0001a05 2796{
e0001a05
NC
2797 uint32 valbuf = value;
2798
43cd72b9 2799 if (xtensa_operand_encode (xtensa_default_isa, opcode, operand, &valbuf))
e0001a05 2800 {
43cd72b9
BW
2801 if (xtensa_operand_is_PCrelative (xtensa_default_isa, opcode, operand)
2802 == 1)
2803 as_bad_where ((char *) file, line,
3739860c 2804 _("operand %d of '%s' has out of range value '%u'"),
d7c531cd
BW
2805 operand + 1,
2806 xtensa_opcode_name (xtensa_default_isa, opcode),
2807 value);
43cd72b9
BW
2808 else
2809 as_bad_where ((char *) file, line,
d7c531cd
BW
2810 _("operand %d of '%s' has invalid value '%u'"),
2811 operand + 1,
2812 xtensa_opcode_name (xtensa_default_isa, opcode),
2813 value);
43cd72b9 2814 return;
e0001a05
NC
2815 }
2816
43cd72b9
BW
2817 xtensa_operand_set_field (xtensa_default_isa, opcode, operand, fmt, slot,
2818 slotbuf, valbuf);
e0001a05
NC
2819}
2820
2821
2822static uint32
7fa3d080
BW
2823xtensa_insnbuf_get_operand (xtensa_insnbuf slotbuf,
2824 xtensa_format fmt,
2825 int slot,
2826 xtensa_opcode opcode,
2827 int opnum)
e0001a05 2828{
43cd72b9
BW
2829 uint32 val = 0;
2830 (void) xtensa_operand_get_field (xtensa_default_isa, opcode, opnum,
2831 fmt, slot, slotbuf, &val);
2832 (void) xtensa_operand_decode (xtensa_default_isa, opcode, opnum, &val);
2833 return val;
e0001a05
NC
2834}
2835
e0001a05 2836\f
7fa3d080 2837/* Checks for rules from xtensa-relax tables. */
e0001a05 2838
7fa3d080
BW
2839/* The routine xg_instruction_matches_option_term must return TRUE
2840 when a given option term is true. The meaning of all of the option
19e8f41a 2841 terms is given interpretation by this function. */
e0001a05 2842
7fa3d080 2843static bfd_boolean
19e8f41a 2844xg_instruction_matches_option_term (TInsn *insn, const ReqOrOption *option)
e0001a05 2845{
7fa3d080
BW
2846 if (strcmp (option->option_name, "realnop") == 0
2847 || strncmp (option->option_name, "IsaUse", 6) == 0)
2848 {
2849 /* These conditions were evaluated statically when building the
2850 relaxation table. There's no need to reevaluate them now. */
2851 return TRUE;
2852 }
19e8f41a
BW
2853 else if (strcmp (option->option_name, "FREEREG") == 0)
2854 return insn->extra_arg.X_op == O_register;
7fa3d080
BW
2855 else
2856 {
2857 as_fatal (_("internal error: unknown option name '%s'"),
2858 option->option_name);
2859 }
e0001a05
NC
2860}
2861
2862
7fa3d080
BW
2863static bfd_boolean
2864xg_instruction_matches_or_options (TInsn *insn,
2865 const ReqOrOptionList *or_option)
e0001a05 2866{
7fa3d080
BW
2867 const ReqOrOption *option;
2868 /* Must match each of the AND terms. */
2869 for (option = or_option; option != NULL; option = option->next)
e0001a05 2870 {
7fa3d080
BW
2871 if (xg_instruction_matches_option_term (insn, option))
2872 return TRUE;
e0001a05 2873 }
7fa3d080 2874 return FALSE;
e0001a05
NC
2875}
2876
2877
7fa3d080
BW
2878static bfd_boolean
2879xg_instruction_matches_options (TInsn *insn, const ReqOptionList *options)
e0001a05 2880{
7fa3d080
BW
2881 const ReqOption *req_options;
2882 /* Must match each of the AND terms. */
2883 for (req_options = options;
2884 req_options != NULL;
2885 req_options = req_options->next)
e0001a05 2886 {
7fa3d080
BW
2887 /* Must match one of the OR clauses. */
2888 if (!xg_instruction_matches_or_options (insn,
2889 req_options->or_option_terms))
2890 return FALSE;
e0001a05 2891 }
7fa3d080 2892 return TRUE;
e0001a05
NC
2893}
2894
2895
7fa3d080 2896/* Return the transition rule that matches or NULL if none matches. */
e0001a05 2897
7fa3d080
BW
2898static bfd_boolean
2899xg_instruction_matches_rule (TInsn *insn, TransitionRule *rule)
e0001a05 2900{
7fa3d080 2901 PreconditionList *condition_l;
e0001a05 2902
7fa3d080
BW
2903 if (rule->opcode != insn->opcode)
2904 return FALSE;
e0001a05 2905
7fa3d080
BW
2906 for (condition_l = rule->conditions;
2907 condition_l != NULL;
2908 condition_l = condition_l->next)
e0001a05 2909 {
7fa3d080
BW
2910 expressionS *exp1;
2911 expressionS *exp2;
2912 Precondition *cond = condition_l->precond;
e0001a05 2913
7fa3d080 2914 switch (cond->typ)
e0001a05 2915 {
7fa3d080
BW
2916 case OP_CONSTANT:
2917 /* The expression must be the constant. */
9c2799c2 2918 gas_assert (cond->op_num < insn->ntok);
7fa3d080
BW
2919 exp1 = &insn->tok[cond->op_num];
2920 if (expr_is_const (exp1))
2921 {
2922 switch (cond->cmp)
2923 {
2924 case OP_EQUAL:
2925 if (get_expr_const (exp1) != cond->op_data)
2926 return FALSE;
2927 break;
2928 case OP_NOTEQUAL:
2929 if (get_expr_const (exp1) == cond->op_data)
2930 return FALSE;
2931 break;
2932 default:
2933 return FALSE;
2934 }
2935 }
2936 else if (expr_is_register (exp1))
2937 {
2938 switch (cond->cmp)
2939 {
2940 case OP_EQUAL:
2941 if (get_expr_register (exp1) != cond->op_data)
2942 return FALSE;
2943 break;
2944 case OP_NOTEQUAL:
2945 if (get_expr_register (exp1) == cond->op_data)
2946 return FALSE;
2947 break;
2948 default:
2949 return FALSE;
2950 }
2951 }
2952 else
2953 return FALSE;
2954 break;
2955
2956 case OP_OPERAND:
9c2799c2
NC
2957 gas_assert (cond->op_num < insn->ntok);
2958 gas_assert (cond->op_data < insn->ntok);
7fa3d080
BW
2959 exp1 = &insn->tok[cond->op_num];
2960 exp2 = &insn->tok[cond->op_data];
2961
2962 switch (cond->cmp)
2963 {
2964 case OP_EQUAL:
2965 if (!expr_is_equal (exp1, exp2))
2966 return FALSE;
2967 break;
2968 case OP_NOTEQUAL:
2969 if (expr_is_equal (exp1, exp2))
2970 return FALSE;
2971 break;
2972 }
2973 break;
2974
2975 case OP_LITERAL:
2976 case OP_LABEL:
2977 default:
2978 return FALSE;
2979 }
2980 }
2981 if (!xg_instruction_matches_options (insn, rule->options))
2982 return FALSE;
2983
2984 return TRUE;
2985}
2986
2987
2988static int
2989transition_rule_cmp (const TransitionRule *a, const TransitionRule *b)
2990{
2991 bfd_boolean a_greater = FALSE;
2992 bfd_boolean b_greater = FALSE;
2993
2994 ReqOptionList *l_a = a->options;
2995 ReqOptionList *l_b = b->options;
2996
2997 /* We only care if they both are the same except for
2998 a const16 vs. an l32r. */
2999
3000 while (l_a && l_b && ((l_a->next == NULL) == (l_b->next == NULL)))
3001 {
3002 ReqOrOptionList *l_or_a = l_a->or_option_terms;
3003 ReqOrOptionList *l_or_b = l_b->or_option_terms;
3004 while (l_or_a && l_or_b && ((l_a->next == NULL) == (l_b->next == NULL)))
3005 {
3006 if (l_or_a->is_true != l_or_b->is_true)
3007 return 0;
3008 if (strcmp (l_or_a->option_name, l_or_b->option_name) != 0)
3009 {
3010 /* This is the case we care about. */
3011 if (strcmp (l_or_a->option_name, "IsaUseConst16") == 0
3012 && strcmp (l_or_b->option_name, "IsaUseL32R") == 0)
3013 {
3014 if (prefer_const16)
3015 a_greater = TRUE;
3016 else
3017 b_greater = TRUE;
3018 }
3019 else if (strcmp (l_or_a->option_name, "IsaUseL32R") == 0
3020 && strcmp (l_or_b->option_name, "IsaUseConst16") == 0)
3021 {
3022 if (prefer_const16)
3023 b_greater = TRUE;
3024 else
3025 a_greater = TRUE;
3026 }
3027 else
3028 return 0;
3029 }
3030 l_or_a = l_or_a->next;
3031 l_or_b = l_or_b->next;
3032 }
3033 if (l_or_a || l_or_b)
3034 return 0;
3035
3036 l_a = l_a->next;
3037 l_b = l_b->next;
3038 }
3039 if (l_a || l_b)
3040 return 0;
3041
3042 /* Incomparable if the substitution was used differently in two cases. */
3043 if (a_greater && b_greater)
3044 return 0;
3045
3046 if (b_greater)
3047 return 1;
3048 if (a_greater)
3049 return -1;
3050
3051 return 0;
3052}
3053
3054
3055static TransitionRule *
3056xg_instruction_match (TInsn *insn)
3057{
3058 TransitionTable *table = xg_build_simplify_table (&transition_rule_cmp);
3059 TransitionList *l;
9c2799c2 3060 gas_assert (insn->opcode < table->num_opcodes);
7fa3d080
BW
3061
3062 /* Walk through all of the possible transitions. */
3063 for (l = table->table[insn->opcode]; l != NULL; l = l->next)
3064 {
3065 TransitionRule *rule = l->rule;
3066 if (xg_instruction_matches_rule (insn, rule))
3067 return rule;
3068 }
3069 return NULL;
3070}
3071
3072\f
3073/* Various Other Internal Functions. */
3074
3075static bfd_boolean
3076is_unique_insn_expansion (TransitionRule *r)
3077{
3078 if (!r->to_instr || r->to_instr->next != NULL)
3079 return FALSE;
3080 if (r->to_instr->typ != INSTR_INSTR)
3081 return FALSE;
3082 return TRUE;
3083}
3084
3085
84b08ed9
BW
3086/* Check if there is exactly one relaxation for INSN that converts it to
3087 another instruction of equal or larger size. If so, and if TARG is
3088 non-null, go ahead and generate the relaxed instruction into TARG. If
3089 NARROW_ONLY is true, then only consider relaxations that widen a narrow
3090 instruction, i.e., ignore relaxations that convert to an instruction of
3091 equal size. In some contexts where this function is used, only
c138bc38 3092 a single widening is allowed and the NARROW_ONLY argument is used to
84b08ed9
BW
3093 exclude cases like ADDI being "widened" to an ADDMI, which may
3094 later be relaxed to an ADDMI/ADDI pair. */
7fa3d080 3095
84b08ed9
BW
3096bfd_boolean
3097xg_is_single_relaxable_insn (TInsn *insn, TInsn *targ, bfd_boolean narrow_only)
7fa3d080
BW
3098{
3099 TransitionTable *table = xg_build_widen_table (&transition_rule_cmp);
3100 TransitionList *l;
84b08ed9 3101 TransitionRule *match = 0;
7fa3d080 3102
9c2799c2
NC
3103 gas_assert (insn->insn_type == ITYPE_INSN);
3104 gas_assert (insn->opcode < table->num_opcodes);
7fa3d080
BW
3105
3106 for (l = table->table[insn->opcode]; l != NULL; l = l->next)
3107 {
3108 TransitionRule *rule = l->rule;
3109
3110 if (xg_instruction_matches_rule (insn, rule)
84b08ed9
BW
3111 && is_unique_insn_expansion (rule)
3112 && (xg_get_single_size (insn->opcode) + (narrow_only ? 1 : 0)
3113 <= xg_get_single_size (rule->to_instr->opcode)))
7fa3d080 3114 {
84b08ed9
BW
3115 if (match)
3116 return FALSE;
3117 match = rule;
7fa3d080
BW
3118 }
3119 }
84b08ed9
BW
3120 if (!match)
3121 return FALSE;
3122
3123 if (targ)
3124 xg_build_to_insn (targ, insn, match->to_instr);
3125 return TRUE;
7fa3d080
BW
3126}
3127
3128
3129/* Return the maximum number of bytes this opcode can expand to. */
3130
3131static int
3132xg_get_max_insn_widen_size (xtensa_opcode opcode)
3133{
3134 TransitionTable *table = xg_build_widen_table (&transition_rule_cmp);
3135 TransitionList *l;
3136 int max_size = xg_get_single_size (opcode);
3137
9c2799c2 3138 gas_assert (opcode < table->num_opcodes);
7fa3d080
BW
3139
3140 for (l = table->table[opcode]; l != NULL; l = l->next)
3141 {
3142 TransitionRule *rule = l->rule;
3143 BuildInstr *build_list;
3144 int this_size = 0;
3145
3146 if (!rule)
3147 continue;
3148 build_list = rule->to_instr;
3149 if (is_unique_insn_expansion (rule))
3150 {
9c2799c2 3151 gas_assert (build_list->typ == INSTR_INSTR);
7fa3d080
BW
3152 this_size = xg_get_max_insn_widen_size (build_list->opcode);
3153 }
3154 else
3155 for (; build_list != NULL; build_list = build_list->next)
3156 {
3157 switch (build_list->typ)
3158 {
3159 case INSTR_INSTR:
3160 this_size += xg_get_single_size (build_list->opcode);
3161 break;
3162 case INSTR_LITERAL_DEF:
3163 case INSTR_LABEL_DEF:
e0001a05
NC
3164 default:
3165 break;
3166 }
3167 }
3168 if (this_size > max_size)
3169 max_size = this_size;
3170 }
3171 return max_size;
3172}
3173
3174
3175/* Return the maximum number of literal bytes this opcode can generate. */
3176
7fa3d080
BW
3177static int
3178xg_get_max_insn_widen_literal_size (xtensa_opcode opcode)
e0001a05 3179{
43cd72b9 3180 TransitionTable *table = xg_build_widen_table (&transition_rule_cmp);
e0001a05
NC
3181 TransitionList *l;
3182 int max_size = 0;
3183
9c2799c2 3184 gas_assert (opcode < table->num_opcodes);
e0001a05
NC
3185
3186 for (l = table->table[opcode]; l != NULL; l = l->next)
3187 {
3188 TransitionRule *rule = l->rule;
3189 BuildInstr *build_list;
3190 int this_size = 0;
3191
3192 if (!rule)
3193 continue;
3194 build_list = rule->to_instr;
3195 if (is_unique_insn_expansion (rule))
3196 {
9c2799c2 3197 gas_assert (build_list->typ == INSTR_INSTR);
e0001a05
NC
3198 this_size = xg_get_max_insn_widen_literal_size (build_list->opcode);
3199 }
3200 else
3201 for (; build_list != NULL; build_list = build_list->next)
3202 {
3203 switch (build_list->typ)
3204 {
3205 case INSTR_LITERAL_DEF:
43cd72b9 3206 /* Hard-coded 4-byte literal. */
e0001a05
NC
3207 this_size += 4;
3208 break;
3209 case INSTR_INSTR:
3210 case INSTR_LABEL_DEF:
3211 default:
3212 break;
3213 }
3214 }
3215 if (this_size > max_size)
3216 max_size = this_size;
3217 }
3218 return max_size;
3219}
3220
3221
7fa3d080
BW
3222static bfd_boolean
3223xg_is_relaxable_insn (TInsn *insn, int lateral_steps)
3224{
3225 int steps_taken = 0;
3226 TransitionTable *table = xg_build_widen_table (&transition_rule_cmp);
3227 TransitionList *l;
3228
9c2799c2
NC
3229 gas_assert (insn->insn_type == ITYPE_INSN);
3230 gas_assert (insn->opcode < table->num_opcodes);
7fa3d080
BW
3231
3232 for (l = table->table[insn->opcode]; l != NULL; l = l->next)
3233 {
3234 TransitionRule *rule = l->rule;
3235
3236 if (xg_instruction_matches_rule (insn, rule))
3237 {
3238 if (steps_taken == lateral_steps)
3239 return TRUE;
3240 steps_taken++;
3241 }
3242 }
3243 return FALSE;
3244}
3245
3246
3247static symbolS *
3248get_special_literal_symbol (void)
3249{
3250 static symbolS *sym = NULL;
3251
3252 if (sym == NULL)
3253 sym = symbol_find_or_make ("SPECIAL_LITERAL0\001");
3254 return sym;
3255}
3256
3257
3258static symbolS *
3259get_special_label_symbol (void)
3260{
3261 static symbolS *sym = NULL;
3262
3263 if (sym == NULL)
3264 sym = symbol_find_or_make ("SPECIAL_LABEL0\001");
3265 return sym;
3266}
3267
3268
3269static bfd_boolean
3270xg_valid_literal_expression (const expressionS *exp)
3271{
3272 switch (exp->X_op)
3273 {
3274 case O_constant:
3275 case O_symbol:
3276 case O_big:
3277 case O_uminus:
3278 case O_subtract:
3279 case O_pltrel:
1bbb5f21 3280 case O_pcrel:
28dbbc02
BW
3281 case O_tlsfunc:
3282 case O_tlsarg:
3283 case O_tpoff:
3284 case O_dtpoff:
7fa3d080
BW
3285 return TRUE;
3286 default:
3287 return FALSE;
3288 }
3289}
3290
3291
3292/* This will check to see if the value can be converted into the
3293 operand type. It will return TRUE if it does not fit. */
3294
3295static bfd_boolean
3296xg_check_operand (int32 value, xtensa_opcode opcode, int operand)
3297{
3298 uint32 valbuf = value;
3299 if (xtensa_operand_encode (xtensa_default_isa, opcode, operand, &valbuf))
3300 return TRUE;
3301 return FALSE;
3302}
3303
3304
3305/* Assumes: All immeds are constants. Check that all constants fit
3306 into their immeds; return FALSE if not. */
3307
3308static bfd_boolean
3309xg_immeds_fit (const TInsn *insn)
3310{
3311 xtensa_isa isa = xtensa_default_isa;
3312 int i;
3313
3314 int n = insn->ntok;
9c2799c2 3315 gas_assert (insn->insn_type == ITYPE_INSN);
7fa3d080
BW
3316 for (i = 0; i < n; ++i)
3317 {
91d6fa6a
NC
3318 const expressionS *exp = &insn->tok[i];
3319
7fa3d080
BW
3320 if (xtensa_operand_is_register (isa, insn->opcode, i) == 1)
3321 continue;
3322
91d6fa6a 3323 switch (exp->X_op)
7fa3d080
BW
3324 {
3325 case O_register:
3326 case O_constant:
91d6fa6a 3327 if (xg_check_operand (exp->X_add_number, insn->opcode, i))
7fa3d080
BW
3328 return FALSE;
3329 break;
3330
3331 default:
3332 /* The symbol should have a fixup associated with it. */
9c2799c2 3333 gas_assert (FALSE);
7fa3d080
BW
3334 break;
3335 }
3336 }
3337 return TRUE;
3338}
3339
3340
3341/* This should only be called after we have an initial
3342 estimate of the addresses. */
3343
3344static bfd_boolean
3345xg_symbolic_immeds_fit (const TInsn *insn,
3346 segT pc_seg,
3347 fragS *pc_frag,
3348 offsetT pc_offset,
3349 long stretch)
e0001a05 3350{
7fa3d080
BW
3351 xtensa_isa isa = xtensa_default_isa;
3352 symbolS *symbolP;
3353 fragS *sym_frag;
3354 offsetT target, pc;
3355 uint32 new_offset;
3356 int i;
3357 int n = insn->ntok;
e0001a05 3358
9c2799c2 3359 gas_assert (insn->insn_type == ITYPE_INSN);
e0001a05 3360
7fa3d080 3361 for (i = 0; i < n; ++i)
e0001a05 3362 {
91d6fa6a
NC
3363 const expressionS *exp = &insn->tok[i];
3364
7fa3d080
BW
3365 if (xtensa_operand_is_register (isa, insn->opcode, i) == 1)
3366 continue;
e0001a05 3367
91d6fa6a 3368 switch (exp->X_op)
e0001a05 3369 {
7fa3d080
BW
3370 case O_register:
3371 case O_constant:
91d6fa6a 3372 if (xg_check_operand (exp->X_add_number, insn->opcode, i))
7fa3d080
BW
3373 return FALSE;
3374 break;
e0001a05 3375
7fa3d080
BW
3376 case O_lo16:
3377 case O_hi16:
3378 /* Check for the worst case. */
3379 if (xg_check_operand (0xffff, insn->opcode, i))
3380 return FALSE;
3381 break;
e0001a05 3382
7fa3d080 3383 case O_symbol:
7c834684 3384 /* We only allow symbols for PC-relative references.
7fa3d080 3385 If pc_frag == 0, then we don't have frag locations yet. */
7c834684
BW
3386 if (pc_frag == 0
3387 || xtensa_operand_is_PCrelative (isa, insn->opcode, i) == 0)
7fa3d080 3388 return FALSE;
e0001a05 3389
8e6bc631
BW
3390 /* If it is a weak symbol or a symbol in a different section,
3391 it cannot be known to fit at assembly time. */
91d6fa6a
NC
3392 if (S_IS_WEAK (exp->X_add_symbol)
3393 || S_GET_SEGMENT (exp->X_add_symbol) != pc_seg)
7c834684 3394 {
8e6bc631 3395 /* For a direct call with --no-longcalls, be optimistic and
38f9cb7f
BW
3396 assume it will be in range. If the symbol is weak and
3397 undefined, it may remain undefined at link-time, in which
3398 case it will have a zero value and almost certainly be out
3399 of range for a direct call; thus, relax for undefined weak
3400 symbols even if longcalls is not enabled. */
8e6bc631 3401 if (is_direct_call_opcode (insn->opcode)
38f9cb7f 3402 && ! pc_frag->tc_frag_data.use_longcalls
91d6fa6a
NC
3403 && (! S_IS_WEAK (exp->X_add_symbol)
3404 || S_IS_DEFINED (exp->X_add_symbol)))
7c834684 3405 return TRUE;
7c834684 3406
8e6bc631
BW
3407 return FALSE;
3408 }
e0001a05 3409
91d6fa6a 3410 symbolP = exp->X_add_symbol;
7fa3d080 3411 sym_frag = symbol_get_frag (symbolP);
91d6fa6a 3412 target = S_GET_VALUE (symbolP) + exp->X_add_number;
7fa3d080 3413 pc = pc_frag->fr_address + pc_offset;
e0001a05 3414
7fa3d080
BW
3415 /* If frag has yet to be reached on this pass, assume it
3416 will move by STRETCH just as we did. If this is not so,
3417 it will be because some frag between grows, and that will
3418 force another pass. Beware zero-length frags. There
3419 should be a faster way to do this. */
3420
3421 if (stretch != 0
3422 && sym_frag->relax_marker != pc_frag->relax_marker
3423 && S_GET_SEGMENT (symbolP) == pc_seg)
3424 {
3425 target += stretch;
3426 }
c138bc38 3427
7fa3d080
BW
3428 new_offset = target;
3429 xtensa_operand_do_reloc (isa, insn->opcode, i, &new_offset, pc);
3430 if (xg_check_operand (new_offset, insn->opcode, i))
3431 return FALSE;
3432 break;
3433
3434 default:
3435 /* The symbol should have a fixup associated with it. */
3436 return FALSE;
3437 }
3438 }
3439
3440 return TRUE;
e0001a05
NC
3441}
3442
3443
43cd72b9 3444/* Return TRUE on success. */
e0001a05 3445
7fa3d080
BW
3446static bfd_boolean
3447xg_build_to_insn (TInsn *targ, TInsn *insn, BuildInstr *bi)
e0001a05
NC
3448{
3449 BuildOp *op;
3450 symbolS *sym;
3451
60242db2 3452 tinsn_init (targ);
b224e962
BW
3453 targ->debug_line = insn->debug_line;
3454 targ->loc_directive_seen = insn->loc_directive_seen;
e0001a05
NC
3455 switch (bi->typ)
3456 {
3457 case INSTR_INSTR:
3458 op = bi->ops;
3459 targ->opcode = bi->opcode;
3460 targ->insn_type = ITYPE_INSN;
3461 targ->is_specific_opcode = FALSE;
3462
3463 for (; op != NULL; op = op->next)
3464 {
3465 int op_num = op->op_num;
3466 int op_data = op->op_data;
3467
9c2799c2 3468 gas_assert (op->op_num < MAX_INSN_ARGS);
e0001a05
NC
3469
3470 if (targ->ntok <= op_num)
3471 targ->ntok = op_num + 1;
3472
3473 switch (op->typ)
3474 {
3475 case OP_CONSTANT:
3476 set_expr_const (&targ->tok[op_num], op_data);
3477 break;
3478 case OP_OPERAND:
9c2799c2 3479 gas_assert (op_data < insn->ntok);
e0001a05
NC
3480 copy_expr (&targ->tok[op_num], &insn->tok[op_data]);
3481 break;
19e8f41a
BW
3482 case OP_FREEREG:
3483 if (insn->extra_arg.X_op != O_register)
3484 return FALSE;
3485 copy_expr (&targ->tok[op_num], &insn->extra_arg);
3486 break;
e0001a05
NC
3487 case OP_LITERAL:
3488 sym = get_special_literal_symbol ();
3489 set_expr_symbol_offset (&targ->tok[op_num], sym, 0);
28dbbc02
BW
3490 if (insn->tok[op_data].X_op == O_tlsfunc
3491 || insn->tok[op_data].X_op == O_tlsarg)
19e8f41a 3492 copy_expr (&targ->extra_arg, &insn->tok[op_data]);
e0001a05
NC
3493 break;
3494 case OP_LABEL:
3495 sym = get_special_label_symbol ();
3496 set_expr_symbol_offset (&targ->tok[op_num], sym, 0);
3497 break;
43cd72b9
BW
3498 case OP_OPERAND_HI16U:
3499 case OP_OPERAND_LOW16U:
9c2799c2 3500 gas_assert (op_data < insn->ntok);
43cd72b9
BW
3501 if (expr_is_const (&insn->tok[op_data]))
3502 {
3503 long val;
3504 copy_expr (&targ->tok[op_num], &insn->tok[op_data]);
3505 val = xg_apply_userdef_op_fn (op->typ,
3506 targ->tok[op_num].
3507 X_add_number);
3508 targ->tok[op_num].X_add_number = val;
3509 }
3510 else
3511 {
3512 /* For const16 we can create relocations for these. */
3513 if (targ->opcode == XTENSA_UNDEFINED
3514 || (targ->opcode != xtensa_const16_opcode))
3515 return FALSE;
9c2799c2 3516 gas_assert (op_data < insn->ntok);
43cd72b9
BW
3517 /* Need to build a O_lo16 or O_hi16. */
3518 copy_expr (&targ->tok[op_num], &insn->tok[op_data]);
3519 if (targ->tok[op_num].X_op == O_symbol)
3520 {
3521 if (op->typ == OP_OPERAND_HI16U)
3522 targ->tok[op_num].X_op = O_hi16;
3523 else if (op->typ == OP_OPERAND_LOW16U)
3524 targ->tok[op_num].X_op = O_lo16;
3525 else
3526 return FALSE;
3527 }
3528 }
3529 break;
e0001a05
NC
3530 default:
3531 /* currently handles:
3532 OP_OPERAND_LOW8
3533 OP_OPERAND_HI24S
3534 OP_OPERAND_F32MINUS */
3535 if (xg_has_userdef_op_fn (op->typ))
3536 {
9c2799c2 3537 gas_assert (op_data < insn->ntok);
e0001a05
NC
3538 if (expr_is_const (&insn->tok[op_data]))
3539 {
3540 long val;
3541 copy_expr (&targ->tok[op_num], &insn->tok[op_data]);
3542 val = xg_apply_userdef_op_fn (op->typ,
3543 targ->tok[op_num].
3544 X_add_number);
3545 targ->tok[op_num].X_add_number = val;
3546 }
3547 else
3548 return FALSE; /* We cannot use a relocation for this. */
3549 break;
3550 }
9c2799c2 3551 gas_assert (0);
e0001a05
NC
3552 break;
3553 }
3554 }
3555 break;
3556
3557 case INSTR_LITERAL_DEF:
3558 op = bi->ops;
3559 targ->opcode = XTENSA_UNDEFINED;
3560 targ->insn_type = ITYPE_LITERAL;
3561 targ->is_specific_opcode = FALSE;
3562 for (; op != NULL; op = op->next)
3563 {
3564 int op_num = op->op_num;
3565 int op_data = op->op_data;
9c2799c2 3566 gas_assert (op->op_num < MAX_INSN_ARGS);
e0001a05
NC
3567
3568 if (targ->ntok <= op_num)
3569 targ->ntok = op_num + 1;
3570
3571 switch (op->typ)
3572 {
3573 case OP_OPERAND:
9c2799c2 3574 gas_assert (op_data < insn->ntok);
43cd72b9
BW
3575 /* We can only pass resolvable literals through. */
3576 if (!xg_valid_literal_expression (&insn->tok[op_data]))
3577 return FALSE;
e0001a05
NC
3578 copy_expr (&targ->tok[op_num], &insn->tok[op_data]);
3579 break;
3580 case OP_LITERAL:
3581 case OP_CONSTANT:
3582 case OP_LABEL:
3583 default:
9c2799c2 3584 gas_assert (0);
e0001a05
NC
3585 break;
3586 }
3587 }
3588 break;
3589
3590 case INSTR_LABEL_DEF:
3591 op = bi->ops;
3592 targ->opcode = XTENSA_UNDEFINED;
3593 targ->insn_type = ITYPE_LABEL;
3594 targ->is_specific_opcode = FALSE;
43cd72b9 3595 /* Literal with no ops is a label? */
9c2799c2 3596 gas_assert (op == NULL);
e0001a05
NC
3597 break;
3598
3599 default:
9c2799c2 3600 gas_assert (0);
e0001a05
NC
3601 }
3602
3603 return TRUE;
3604}
3605
3606
43cd72b9 3607/* Return TRUE on success. */
e0001a05 3608
7fa3d080
BW
3609static bfd_boolean
3610xg_build_to_stack (IStack *istack, TInsn *insn, BuildInstr *bi)
e0001a05
NC
3611{
3612 for (; bi != NULL; bi = bi->next)
3613 {
3614 TInsn *next_insn = istack_push_space (istack);
3615
3616 if (!xg_build_to_insn (next_insn, insn, bi))
3617 return FALSE;
3618 }
3619 return TRUE;
3620}
3621
3622
43cd72b9 3623/* Return TRUE on valid expansion. */
e0001a05 3624
7fa3d080
BW
3625static bfd_boolean
3626xg_expand_to_stack (IStack *istack, TInsn *insn, int lateral_steps)
e0001a05
NC
3627{
3628 int stack_size = istack->ninsn;
3629 int steps_taken = 0;
43cd72b9 3630 TransitionTable *table = xg_build_widen_table (&transition_rule_cmp);
e0001a05
NC
3631 TransitionList *l;
3632
9c2799c2
NC
3633 gas_assert (insn->insn_type == ITYPE_INSN);
3634 gas_assert (insn->opcode < table->num_opcodes);
e0001a05
NC
3635
3636 for (l = table->table[insn->opcode]; l != NULL; l = l->next)
3637 {
3638 TransitionRule *rule = l->rule;
3639
3640 if (xg_instruction_matches_rule (insn, rule))
3641 {
3642 if (lateral_steps == steps_taken)
3643 {
3644 int i;
3645
3646 /* This is it. Expand the rule to the stack. */
3647 if (!xg_build_to_stack (istack, insn, rule->to_instr))
3648 return FALSE;
3649
3650 /* Check to see if it fits. */
3651 for (i = stack_size; i < istack->ninsn; i++)
3652 {
91d6fa6a 3653 TInsn *tinsn = &istack->insn[i];
e0001a05 3654
91d6fa6a
NC
3655 if (tinsn->insn_type == ITYPE_INSN
3656 && !tinsn_has_symbolic_operands (tinsn)
3657 && !xg_immeds_fit (tinsn))
e0001a05
NC
3658 {
3659 istack->ninsn = stack_size;
3660 return FALSE;
3661 }
3662 }
3663 return TRUE;
3664 }
3665 steps_taken++;
3666 }
3667 }
3668 return FALSE;
3669}
3670
43cd72b9 3671\f
43cd72b9 3672/* Relax the assembly instruction at least "min_steps".
b81bf389
BW
3673 Return the number of steps taken.
3674
3675 For relaxation to correctly terminate, every relaxation chain must
3676 terminate in one of two ways:
3677
3678 1. If the chain from one instruction to the next consists entirely of
3679 single instructions, then the chain *must* handle all possible
3680 immediates without failing. It must not ever fail because an
3681 immediate is out of range. The MOVI.N -> MOVI -> L32R relaxation
3682 chain is one example. L32R loads 32 bits, and there cannot be an
3683 immediate larger than 32 bits, so it satisfies this condition.
3684 Single instruction relaxation chains are as defined by
3685 xg_is_single_relaxable_instruction.
3686
3687 2. Otherwise, the chain must end in a multi-instruction expansion: e.g.,
3688 BNEZ.N -> BNEZ -> BNEZ.W15 -> BENZ.N/J
3689
3690 Strictly speaking, in most cases you can violate condition 1 and be OK
3691 -- in particular when the last two instructions have the same single
3692 size. But nevertheless, you should guarantee the above two conditions.
3693
3694 We could fix this so that single-instruction expansions correctly
3695 terminate when they can't handle the range, but the error messages are
3696 worse, and it actually turns out that in every case but one (18-bit wide
3697 branches), you need a multi-instruction expansion to get the full range
3698 anyway. And because 18-bit branches are handled identically to 15-bit
3699 branches, there isn't any point in changing it. */
e0001a05 3700
7fa3d080
BW
3701static int
3702xg_assembly_relax (IStack *istack,
3703 TInsn *insn,
3704 segT pc_seg,
3705 fragS *pc_frag, /* if pc_frag == 0, not pc-relative */
3706 offsetT pc_offset, /* offset in fragment */
3707 int min_steps, /* minimum conversion steps */
3708 long stretch) /* number of bytes stretched so far */
e0001a05
NC
3709{
3710 int steps_taken = 0;
3711
b81bf389
BW
3712 /* Some of its immeds don't fit. Try to build a relaxed version.
3713 This may go through a couple of stages of single instruction
3714 transformations before we get there. */
e0001a05
NC
3715
3716 TInsn single_target;
3717 TInsn current_insn;
3718 int lateral_steps = 0;
3719 int istack_size = istack->ninsn;
3720
3721 if (xg_symbolic_immeds_fit (insn, pc_seg, pc_frag, pc_offset, stretch)
3722 && steps_taken >= min_steps)
3723 {
3724 istack_push (istack, insn);
3725 return steps_taken;
3726 }
43cd72b9 3727 current_insn = *insn;
e0001a05 3728
7c834684 3729 /* Walk through all of the single instruction expansions. */
84b08ed9 3730 while (xg_is_single_relaxable_insn (&current_insn, &single_target, FALSE))
e0001a05 3731 {
21af2bbd 3732 steps_taken++;
e0001a05
NC
3733 if (xg_symbolic_immeds_fit (&single_target, pc_seg, pc_frag, pc_offset,
3734 stretch))
3735 {
e0001a05
NC
3736 if (steps_taken >= min_steps)
3737 {
3738 istack_push (istack, &single_target);
3739 return steps_taken;
3740 }
3741 }
43cd72b9 3742 current_insn = single_target;
e0001a05
NC
3743 }
3744
3745 /* Now check for a multi-instruction expansion. */
3746 while (xg_is_relaxable_insn (&current_insn, lateral_steps))
3747 {
3748 if (xg_symbolic_immeds_fit (&current_insn, pc_seg, pc_frag, pc_offset,
3749 stretch))
3750 {
3751 if (steps_taken >= min_steps)
3752 {
3753 istack_push (istack, &current_insn);
3754 return steps_taken;
3755 }
3756 }
3757 steps_taken++;
3758 if (xg_expand_to_stack (istack, &current_insn, lateral_steps))
3759 {
3760 if (steps_taken >= min_steps)
3761 return steps_taken;
3762 }
3763 lateral_steps++;
3764 istack->ninsn = istack_size;
3765 }
3766
3767 /* It's not going to work -- use the original. */
3768 istack_push (istack, insn);
3769 return steps_taken;
3770}
3771
3772
7fa3d080
BW
3773static void
3774xg_finish_frag (char *last_insn,
3775 enum xtensa_relax_statesE frag_state,
3776 enum xtensa_relax_statesE slot0_state,
3777 int max_growth,
3778 bfd_boolean is_insn)
e0001a05
NC
3779{
3780 /* Finish off this fragment so that it has at LEAST the desired
3781 max_growth. If it doesn't fit in this fragment, close this one
3782 and start a new one. In either case, return a pointer to the
3783 beginning of the growth area. */
3784
3785 fragS *old_frag;
43cd72b9 3786
542f8b94 3787 frag_grow (max_growth);
e0001a05
NC
3788 old_frag = frag_now;
3789
3790 frag_now->fr_opcode = last_insn;
3791 if (is_insn)
3792 frag_now->tc_frag_data.is_insn = TRUE;
3793
3794 frag_var (rs_machine_dependent, max_growth, max_growth,
43cd72b9
BW
3795 frag_state, frag_now->fr_symbol, frag_now->fr_offset, last_insn);
3796
3797 old_frag->tc_frag_data.slot_subtypes[0] = slot0_state;
3798 xtensa_set_frag_assembly_state (frag_now);
e0001a05
NC
3799
3800 /* Just to make sure that we did not split it up. */
9c2799c2 3801 gas_assert (old_frag->fr_next == frag_now);
e0001a05
NC
3802}
3803
3804
7fa3d080
BW
3805/* Return TRUE if the target frag is one of the next non-empty frags. */
3806
3807static bfd_boolean
3808is_next_frag_target (const fragS *fragP, const fragS *target)
3809{
3810 if (fragP == NULL)
3811 return FALSE;
3812
3813 for (; fragP; fragP = fragP->fr_next)
3814 {
3815 if (fragP == target)
3816 return TRUE;
3817 if (fragP->fr_fix != 0)
3818 return FALSE;
3819 if (fragP->fr_type == rs_fill && fragP->fr_offset != 0)
3820 return FALSE;
3821 if ((fragP->fr_type == rs_align || fragP->fr_type == rs_align_code)
3822 && ((fragP->fr_address % (1 << fragP->fr_offset)) != 0))
3823 return FALSE;
3824 if (fragP->fr_type == rs_space)
3825 return FALSE;
3826 }
3827 return FALSE;
3828}
3829
3830
e0001a05 3831static bfd_boolean
7fa3d080 3832is_branch_jmp_to_next (TInsn *insn, fragS *fragP)
e0001a05
NC
3833{
3834 xtensa_isa isa = xtensa_default_isa;
3835 int i;
43cd72b9 3836 int num_ops = xtensa_opcode_num_operands (isa, insn->opcode);
e0001a05
NC
3837 int target_op = -1;
3838 symbolS *sym;
3839 fragS *target_frag;
3840
64b607e6
BW
3841 if (xtensa_opcode_is_branch (isa, insn->opcode) != 1
3842 && xtensa_opcode_is_jump (isa, insn->opcode) != 1)
e0001a05
NC
3843 return FALSE;
3844
3845 for (i = 0; i < num_ops; i++)
3846 {
43cd72b9 3847 if (xtensa_operand_is_PCrelative (isa, insn->opcode, i) == 1)
e0001a05
NC
3848 {
3849 target_op = i;
3850 break;
3851 }
3852 }
3853 if (target_op == -1)
3854 return FALSE;
3855
3856 if (insn->ntok <= target_op)
3857 return FALSE;
3858
3859 if (insn->tok[target_op].X_op != O_symbol)
3860 return FALSE;
3861
3862 sym = insn->tok[target_op].X_add_symbol;
3863 if (sym == NULL)
3864 return FALSE;
3865
3866 if (insn->tok[target_op].X_add_number != 0)
3867 return FALSE;
3868
3869 target_frag = symbol_get_frag (sym);
3870 if (target_frag == NULL)
3871 return FALSE;
3872
c138bc38 3873 if (is_next_frag_target (fragP->fr_next, target_frag)
e0001a05
NC
3874 && S_GET_VALUE (sym) == target_frag->fr_address)
3875 return TRUE;
3876
3877 return FALSE;
3878}
3879
3880
3881static void
7fa3d080 3882xg_add_branch_and_loop_targets (TInsn *insn)
e0001a05
NC
3883{
3884 xtensa_isa isa = xtensa_default_isa;
7fa3d080 3885 int num_ops = xtensa_opcode_num_operands (isa, insn->opcode);
43cd72b9 3886
7fa3d080
BW
3887 if (xtensa_opcode_is_loop (isa, insn->opcode) == 1)
3888 {
3889 int i = 1;
3890 if (xtensa_operand_is_PCrelative (isa, insn->opcode, i) == 1
3891 && insn->tok[i].X_op == O_symbol)
3892 symbol_get_tc (insn->tok[i].X_add_symbol)->is_loop_target = TRUE;
3893 return;
3894 }
e0001a05 3895
7fa3d080
BW
3896 if (xtensa_opcode_is_branch (isa, insn->opcode) == 1
3897 || xtensa_opcode_is_loop (isa, insn->opcode) == 1)
e0001a05 3898 {
7fa3d080
BW
3899 int i;
3900
3901 for (i = 0; i < insn->ntok && i < num_ops; i++)
3902 {
3903 if (xtensa_operand_is_PCrelative (isa, insn->opcode, i) == 1
3904 && insn->tok[i].X_op == O_symbol)
3905 {
3906 symbolS *sym = insn->tok[i].X_add_symbol;
3907 symbol_get_tc (sym)->is_branch_target = TRUE;
3908 if (S_IS_DEFINED (sym))
3909 symbol_get_frag (sym)->tc_frag_data.is_branch_target = TRUE;
3910 }
3911 }
e0001a05 3912 }
e0001a05
NC
3913}
3914
3915
43cd72b9 3916/* Return FALSE if no error. */
e0001a05 3917
7fa3d080
BW
3918static bfd_boolean
3919xg_build_token_insn (BuildInstr *instr_spec, TInsn *old_insn, TInsn *new_insn)
e0001a05
NC
3920{
3921 int num_ops = 0;
3922 BuildOp *b_op;
3923
3924 switch (instr_spec->typ)
3925 {
3926 case INSTR_INSTR:
3927 new_insn->insn_type = ITYPE_INSN;
3928 new_insn->opcode = instr_spec->opcode;
e0001a05
NC
3929 break;
3930 case INSTR_LITERAL_DEF:
3931 new_insn->insn_type = ITYPE_LITERAL;
3932 new_insn->opcode = XTENSA_UNDEFINED;
e0001a05
NC
3933 break;
3934 case INSTR_LABEL_DEF:
b224e962 3935 abort ();
e0001a05 3936 }
b224e962
BW
3937 new_insn->is_specific_opcode = FALSE;
3938 new_insn->debug_line = old_insn->debug_line;
3939 new_insn->loc_directive_seen = old_insn->loc_directive_seen;
e0001a05
NC
3940
3941 for (b_op = instr_spec->ops; b_op != NULL; b_op = b_op->next)
3942 {
3943 expressionS *exp;
3944 const expressionS *src_exp;
3945
3946 num_ops++;
3947 switch (b_op->typ)
3948 {
3949 case OP_CONSTANT:
3950 /* The expression must be the constant. */
9c2799c2 3951 gas_assert (b_op->op_num < MAX_INSN_ARGS);
e0001a05
NC
3952 exp = &new_insn->tok[b_op->op_num];
3953 set_expr_const (exp, b_op->op_data);
3954 break;
3955
3956 case OP_OPERAND:
9c2799c2
NC
3957 gas_assert (b_op->op_num < MAX_INSN_ARGS);
3958 gas_assert (b_op->op_data < (unsigned) old_insn->ntok);
e0001a05
NC
3959 src_exp = &old_insn->tok[b_op->op_data];
3960 exp = &new_insn->tok[b_op->op_num];
3961 copy_expr (exp, src_exp);
3962 break;
3963
3964 case OP_LITERAL:
3965 case OP_LABEL:
3966 as_bad (_("can't handle generation of literal/labels yet"));
9c2799c2 3967 gas_assert (0);
e0001a05
NC
3968
3969 default:
3970 as_bad (_("can't handle undefined OP TYPE"));
9c2799c2 3971 gas_assert (0);
e0001a05
NC
3972 }
3973 }
3974
3975 new_insn->ntok = num_ops;
3976 return FALSE;
3977}
3978
3979
43cd72b9 3980/* Return TRUE if it was simplified. */
e0001a05 3981
7fa3d080
BW
3982static bfd_boolean
3983xg_simplify_insn (TInsn *old_insn, TInsn *new_insn)
e0001a05 3984{
43cd72b9 3985 TransitionRule *rule;
e0001a05 3986 BuildInstr *insn_spec;
43cd72b9
BW
3987
3988 if (old_insn->is_specific_opcode || !density_supported)
3989 return FALSE;
3990
3991 rule = xg_instruction_match (old_insn);
e0001a05
NC
3992 if (rule == NULL)
3993 return FALSE;
3994
3995 insn_spec = rule->to_instr;
3996 /* There should only be one. */
9c2799c2
NC
3997 gas_assert (insn_spec != NULL);
3998 gas_assert (insn_spec->next == NULL);
e0001a05
NC
3999 if (insn_spec->next != NULL)
4000 return FALSE;
4001
4002 xg_build_token_insn (insn_spec, old_insn, new_insn);
4003
4004 return TRUE;
4005}
4006
4007
4008/* xg_expand_assembly_insn: (1) Simplify the instruction, i.e., l32i ->
4009 l32i.n. (2) Check the number of operands. (3) Place the instruction
7c834684
BW
4010 tokens into the stack or relax it and place multiple
4011 instructions/literals onto the stack. Return FALSE if no error. */
e0001a05
NC
4012
4013static bfd_boolean
7fa3d080 4014xg_expand_assembly_insn (IStack *istack, TInsn *orig_insn)
e0001a05
NC
4015{
4016 int noperands;
4017 TInsn new_insn;
7c834684
BW
4018 bfd_boolean do_expand;
4019
60242db2 4020 tinsn_init (&new_insn);
e0001a05 4021
43cd72b9
BW
4022 /* Narrow it if we can. xg_simplify_insn now does all the
4023 appropriate checking (e.g., for the density option). */
4024 if (xg_simplify_insn (orig_insn, &new_insn))
4025 orig_insn = &new_insn;
e0001a05 4026
43cd72b9
BW
4027 noperands = xtensa_opcode_num_operands (xtensa_default_isa,
4028 orig_insn->opcode);
e0001a05
NC
4029 if (orig_insn->ntok < noperands)
4030 {
992a06ee
AM
4031 as_bad (ngettext ("found %d operand for '%s': Expected %d",
4032 "found %d operands for '%s': Expected %d",
4033 orig_insn->ntok),
e0001a05
NC
4034 orig_insn->ntok,
4035 xtensa_opcode_name (xtensa_default_isa, orig_insn->opcode),
4036 noperands);
4037 return TRUE;
4038 }
4039 if (orig_insn->ntok > noperands)
992a06ee
AM
4040 as_warn (ngettext ("found %d operand for '%s': Expected %d",
4041 "found %d operands for '%s': Expected %d",
4042 orig_insn->ntok),
e0001a05
NC
4043 orig_insn->ntok,
4044 xtensa_opcode_name (xtensa_default_isa, orig_insn->opcode),
4045 noperands);
4046
43cd72b9 4047 /* If there are not enough operands, we will assert above. If there
e0001a05 4048 are too many, just cut out the extras here. */
e0001a05
NC
4049 orig_insn->ntok = noperands;
4050
e0001a05
NC
4051 if (tinsn_has_invalid_symbolic_operands (orig_insn))
4052 return TRUE;
4053
d12f9798
BW
4054 /* Special case for extui opcode which has constraints not handled
4055 by the ordinary operand encoding checks. The number of operands
4056 and related syntax issues have already been checked. */
4057 if (orig_insn->opcode == xtensa_extui_opcode)
4058 {
4059 int shiftimm = orig_insn->tok[2].X_add_number;
4060 int maskimm = orig_insn->tok[3].X_add_number;
4061 if (shiftimm + maskimm > 32)
4062 {
4063 as_bad (_("immediate operands sum to greater than 32"));
4064 return TRUE;
4065 }
4066 }
4067
7c834684
BW
4068 /* If the instruction will definitely need to be relaxed, it is better
4069 to expand it now for better scheduling. Decide whether to expand
4070 now.... */
4071 do_expand = (!orig_insn->is_specific_opcode && use_transform ());
4072
4073 /* Calls should be expanded to longcalls only in the backend relaxation
4074 so that the assembly scheduler will keep the L32R/CALLX instructions
4075 adjacent. */
4076 if (is_direct_call_opcode (orig_insn->opcode))
4077 do_expand = FALSE;
e0001a05
NC
4078
4079 if (tinsn_has_symbolic_operands (orig_insn))
4080 {
7c834684
BW
4081 /* The values of symbolic operands are not known yet, so only expand
4082 now if an operand is "complex" (e.g., difference of symbols) and
4083 will have to be stored as a literal regardless of the value. */
4084 if (!tinsn_has_complex_operands (orig_insn))
4085 do_expand = FALSE;
e0001a05 4086 }
7c834684
BW
4087 else if (xg_immeds_fit (orig_insn))
4088 do_expand = FALSE;
4089
4090 if (do_expand)
4091 xg_assembly_relax (istack, orig_insn, 0, 0, 0, 0, 0);
e0001a05 4092 else
7c834684 4093 istack_push (istack, orig_insn);
e0001a05 4094
e0001a05
NC
4095 return FALSE;
4096}
4097
4098
7fa3d080 4099/* Return TRUE if the section flags are marked linkonce
74869ac7
BW
4100 or the name is .gnu.linkonce.*. */
4101
4102static int linkonce_len = sizeof (".gnu.linkonce.") - 1;
7fa3d080
BW
4103
4104static bfd_boolean
4105get_is_linkonce_section (bfd *abfd ATTRIBUTE_UNUSED, segT sec)
4106{
4107 flagword flags, link_once_flags;
4108
4109 flags = bfd_get_section_flags (abfd, sec);
4110 link_once_flags = (flags & SEC_LINK_ONCE);
4111
4112 /* Flags might not be set yet. */
74869ac7
BW
4113 if (!link_once_flags
4114 && strncmp (segment_name (sec), ".gnu.linkonce.", linkonce_len) == 0)
4115 link_once_flags = SEC_LINK_ONCE;
7fa3d080 4116
7fa3d080
BW
4117 return (link_once_flags != 0);
4118}
4119
4120
4121static void
4122xtensa_add_literal_sym (symbolS *sym)
4123{
4124 sym_list *l;
4125
325801bd 4126 l = XNEW (sym_list);
7fa3d080
BW
4127 l->sym = sym;
4128 l->next = literal_syms;
4129 literal_syms = l;
4130}
4131
4132
4133static symbolS *
4134xtensa_create_literal_symbol (segT sec, fragS *frag)
4135{
4136 static int lit_num = 0;
4137 static char name[256];
4138 symbolS *symbolP;
4139
4140 sprintf (name, ".L_lit_sym%d", lit_num);
4141
4142 /* Create a local symbol. If it is in a linkonce section, we have to
4143 be careful to make sure that if it is used in a relocation that the
4144 symbol will be in the output file. */
4145 if (get_is_linkonce_section (stdoutput, sec))
4146 {
4147 symbolP = symbol_new (name, sec, 0, frag);
4148 S_CLEAR_EXTERNAL (symbolP);
4149 /* symbolP->local = 1; */
4150 }
4151 else
4152 symbolP = symbol_new (name, sec, 0, frag);
4153
4154 xtensa_add_literal_sym (symbolP);
4155
7fa3d080
BW
4156 lit_num++;
4157 return symbolP;
4158}
4159
4160
e0001a05
NC
4161/* Currently all literals that are generated here are 32-bit L32R targets. */
4162
7fa3d080
BW
4163static symbolS *
4164xg_assemble_literal (/* const */ TInsn *insn)
e0001a05
NC
4165{
4166 emit_state state;
4167 symbolS *lit_sym = NULL;
bbdd25a8 4168 bfd_reloc_code_real_type reloc;
1bbb5f21 4169 bfd_boolean pcrel = FALSE;
bbdd25a8 4170 char *p;
e0001a05
NC
4171
4172 /* size = 4 for L32R. It could easily be larger when we move to
4173 larger constants. Add a parameter later. */
4174 offsetT litsize = 4;
4175 offsetT litalign = 2; /* 2^2 = 4 */
4176 expressionS saved_loc;
43cd72b9
BW
4177 expressionS * emit_val;
4178
e0001a05
NC
4179 set_expr_symbol_offset (&saved_loc, frag_now->fr_symbol, frag_now_fix ());
4180
9c2799c2
NC
4181 gas_assert (insn->insn_type == ITYPE_LITERAL);
4182 gas_assert (insn->ntok == 1); /* must be only one token here */
e0001a05
NC
4183
4184 xtensa_switch_to_literal_fragment (&state);
4185
43cd72b9
BW
4186 emit_val = &insn->tok[0];
4187 if (emit_val->X_op == O_big)
4188 {
4189 int size = emit_val->X_add_number * CHARS_PER_LITTLENUM;
4190 if (size > litsize)
4191 {
4192 /* This happens when someone writes a "movi a2, big_number". */
c138bc38 4193 as_bad_where (frag_now->fr_file, frag_now->fr_line,
43cd72b9
BW
4194 _("invalid immediate"));
4195 xtensa_restore_emit_state (&state);
4196 return NULL;
4197 }
4198 }
4199
e0001a05
NC
4200 /* Force a 4-byte align here. Note that this opens a new frag, so all
4201 literals done with this function have a frag to themselves. That's
4202 important for the way text section literals work. */
4203 frag_align (litalign, 0, 0);
43cd72b9 4204 record_alignment (now_seg, litalign);
e0001a05 4205
bbdd25a8 4206 switch (emit_val->X_op)
43cd72b9 4207 {
1bbb5f21
BW
4208 case O_pcrel:
4209 pcrel = TRUE;
4210 /* fall through */
bbdd25a8 4211 case O_pltrel:
28dbbc02
BW
4212 case O_tlsfunc:
4213 case O_tlsarg:
4214 case O_tpoff:
4215 case O_dtpoff:
bbdd25a8 4216 p = frag_more (litsize);
43cd72b9 4217 xtensa_set_frag_assembly_state (frag_now);
28dbbc02 4218 reloc = map_operator_to_reloc (emit_val->X_op, TRUE);
43cd72b9
BW
4219 if (emit_val->X_add_symbol)
4220 emit_val->X_op = O_symbol;
4221 else
4222 emit_val->X_op = O_constant;
4223 fix_new_exp (frag_now, p - frag_now->fr_literal,
1bbb5f21 4224 litsize, emit_val, pcrel, reloc);
bbdd25a8
BW
4225 break;
4226
4227 default:
4228 emit_expr (emit_val, litsize);
4229 break;
43cd72b9 4230 }
e0001a05 4231
9c2799c2 4232 gas_assert (frag_now->tc_frag_data.literal_frag == NULL);
e0001a05
NC
4233 frag_now->tc_frag_data.literal_frag = get_literal_pool_location (now_seg);
4234 frag_now->fr_symbol = xtensa_create_literal_symbol (now_seg, frag_now);
4235 lit_sym = frag_now->fr_symbol;
e0001a05
NC
4236
4237 /* Go back. */
4238 xtensa_restore_emit_state (&state);
4239 return lit_sym;
4240}
4241
4242
4243static void
7fa3d080 4244xg_assemble_literal_space (/* const */ int size, int slot)
e0001a05
NC
4245{
4246 emit_state state;
43cd72b9 4247 /* We might have to do something about this alignment. It only
e0001a05
NC
4248 takes effect if something is placed here. */
4249 offsetT litalign = 2; /* 2^2 = 4 */
4250 fragS *lit_saved_frag;
4251
9c2799c2 4252 gas_assert (size % 4 == 0);
e0001a05
NC
4253
4254 xtensa_switch_to_literal_fragment (&state);
4255
4256 /* Force a 4-byte align here. */
4257 frag_align (litalign, 0, 0);
43cd72b9 4258 record_alignment (now_seg, litalign);
e0001a05 4259
542f8b94 4260 frag_grow (size);
e0001a05
NC
4261
4262 lit_saved_frag = frag_now;
4263 frag_now->tc_frag_data.literal_frag = get_literal_pool_location (now_seg);
e0001a05 4264 frag_now->fr_symbol = xtensa_create_literal_symbol (now_seg, frag_now);
43cd72b9 4265 xg_finish_frag (0, RELAX_LITERAL, 0, size, FALSE);
e0001a05
NC
4266
4267 /* Go back. */
4268 xtensa_restore_emit_state (&state);
43cd72b9 4269 frag_now->tc_frag_data.literal_frags[slot] = lit_saved_frag;
e0001a05
NC
4270}
4271
4272
e0001a05 4273/* Put in a fixup record based on the opcode.
43cd72b9 4274 Return TRUE on success. */
e0001a05 4275
7fa3d080
BW
4276static bfd_boolean
4277xg_add_opcode_fix (TInsn *tinsn,
4278 int opnum,
4279 xtensa_format fmt,
4280 int slot,
91d6fa6a 4281 expressionS *exp,
7fa3d080
BW
4282 fragS *fragP,
4283 offsetT offset)
43cd72b9
BW
4284{
4285 xtensa_opcode opcode = tinsn->opcode;
4286 bfd_reloc_code_real_type reloc;
4287 reloc_howto_type *howto;
4288 int fmt_length;
e0001a05
NC
4289 fixS *the_fix;
4290
43cd72b9
BW
4291 reloc = BFD_RELOC_NONE;
4292
4293 /* First try the special cases for "alternate" relocs. */
4294 if (opcode == xtensa_l32r_opcode)
4295 {
4296 if (fragP->tc_frag_data.use_absolute_literals)
4297 reloc = encode_alt_reloc (slot);
4298 }
4299 else if (opcode == xtensa_const16_opcode)
4300 {
91d6fa6a 4301 if (exp->X_op == O_lo16)
43cd72b9
BW
4302 {
4303 reloc = encode_reloc (slot);
91d6fa6a 4304 exp->X_op = O_symbol;
43cd72b9 4305 }
91d6fa6a 4306 else if (exp->X_op == O_hi16)
43cd72b9
BW
4307 {
4308 reloc = encode_alt_reloc (slot);
91d6fa6a 4309 exp->X_op = O_symbol;
43cd72b9
BW
4310 }
4311 }
4312
4313 if (opnum != get_relaxable_immed (opcode))
e0001a05 4314 {
43cd72b9 4315 as_bad (_("invalid relocation for operand %i of '%s'"),
431ad2d0 4316 opnum + 1, xtensa_opcode_name (xtensa_default_isa, opcode));
e0001a05
NC
4317 return FALSE;
4318 }
4319
43cd72b9
BW
4320 /* Handle erroneous "@h" and "@l" expressions here before they propagate
4321 into the symbol table where the generic portions of the assembler
4322 won't know what to do with them. */
91d6fa6a 4323 if (exp->X_op == O_lo16 || exp->X_op == O_hi16)
43cd72b9
BW
4324 {
4325 as_bad (_("invalid expression for operand %i of '%s'"),
431ad2d0 4326 opnum + 1, xtensa_opcode_name (xtensa_default_isa, opcode));
43cd72b9
BW
4327 return FALSE;
4328 }
4329
4330 /* Next try the generic relocs. */
4331 if (reloc == BFD_RELOC_NONE)
4332 reloc = encode_reloc (slot);
4333 if (reloc == BFD_RELOC_NONE)
4334 {
4335 as_bad (_("invalid relocation in instruction slot %i"), slot);
4336 return FALSE;
4337 }
e0001a05 4338
43cd72b9 4339 howto = bfd_reloc_type_lookup (stdoutput, reloc);
e0001a05
NC
4340 if (!howto)
4341 {
43cd72b9 4342 as_bad (_("undefined symbol for opcode \"%s\""),
e0001a05
NC
4343 xtensa_opcode_name (xtensa_default_isa, opcode));
4344 return FALSE;
4345 }
4346
43cd72b9 4347 fmt_length = xtensa_format_length (xtensa_default_isa, fmt);
91d6fa6a 4348 the_fix = fix_new_exp (fragP, offset, fmt_length, exp,
e0001a05 4349 howto->pc_relative, reloc);
d9740523 4350 the_fix->fx_no_overflow = 1;
91d6fa6a
NC
4351 the_fix->tc_fix_data.X_add_symbol = exp->X_add_symbol;
4352 the_fix->tc_fix_data.X_add_number = exp->X_add_number;
7fa3d080 4353 the_fix->tc_fix_data.slot = slot;
c138bc38 4354
7fa3d080
BW
4355 return TRUE;
4356}
4357
4358
4359static bfd_boolean
4360xg_emit_insn_to_buf (TInsn *tinsn,
7fa3d080
BW
4361 char *buf,
4362 fragS *fragP,
4363 offsetT offset,
4364 bfd_boolean build_fix)
4365{
4366 static xtensa_insnbuf insnbuf = NULL;
4367 bfd_boolean has_symbolic_immed = FALSE;
4368 bfd_boolean ok = TRUE;
b2d179be 4369
7fa3d080
BW
4370 if (!insnbuf)
4371 insnbuf = xtensa_insnbuf_alloc (xtensa_default_isa);
4372
4373 has_symbolic_immed = tinsn_to_insnbuf (tinsn, insnbuf);
4374 if (has_symbolic_immed && build_fix)
4375 {
4376 /* Add a fixup. */
b2d179be
BW
4377 xtensa_format fmt = xg_get_single_format (tinsn->opcode);
4378 int slot = xg_get_single_slot (tinsn->opcode);
7fa3d080
BW
4379 int opnum = get_relaxable_immed (tinsn->opcode);
4380 expressionS *exp = &tinsn->tok[opnum];
43cd72b9 4381
b2d179be 4382 if (!xg_add_opcode_fix (tinsn, opnum, fmt, slot, exp, fragP, offset))
7fa3d080
BW
4383 ok = FALSE;
4384 }
4385 fragP->tc_frag_data.is_insn = TRUE;
d77b99c9
BW
4386 xtensa_insnbuf_to_chars (xtensa_default_isa, insnbuf,
4387 (unsigned char *) buf, 0);
7fa3d080 4388 return ok;
e0001a05
NC
4389}
4390
4391
7fa3d080
BW
4392static void
4393xg_resolve_literals (TInsn *insn, symbolS *lit_sym)
e0001a05
NC
4394{
4395 symbolS *sym = get_special_literal_symbol ();
4396 int i;
4397 if (lit_sym == 0)
4398 return;
9c2799c2 4399 gas_assert (insn->insn_type == ITYPE_INSN);
e0001a05
NC
4400 for (i = 0; i < insn->ntok; i++)
4401 if (insn->tok[i].X_add_symbol == sym)
4402 insn->tok[i].X_add_symbol = lit_sym;
4403
4404}
4405
4406
7fa3d080
BW
4407static void
4408xg_resolve_labels (TInsn *insn, symbolS *label_sym)
e0001a05
NC
4409{
4410 symbolS *sym = get_special_label_symbol ();
4411 int i;
e0001a05
NC
4412 for (i = 0; i < insn->ntok; i++)
4413 if (insn->tok[i].X_add_symbol == sym)
4414 insn->tok[i].X_add_symbol = label_sym;
4415
4416}
4417
4418
43cd72b9 4419/* Return TRUE if the instruction can write to the specified
e0001a05
NC
4420 integer register. */
4421
4422static bfd_boolean
7fa3d080 4423is_register_writer (const TInsn *insn, const char *regset, int regnum)
e0001a05
NC
4424{
4425 int i;
4426 int num_ops;
4427 xtensa_isa isa = xtensa_default_isa;
4428
43cd72b9 4429 num_ops = xtensa_opcode_num_operands (isa, insn->opcode);
e0001a05
NC
4430
4431 for (i = 0; i < num_ops; i++)
4432 {
43cd72b9
BW
4433 char inout;
4434 inout = xtensa_operand_inout (isa, insn->opcode, i);
4435 if ((inout == 'o' || inout == 'm')
4436 && xtensa_operand_is_register (isa, insn->opcode, i) == 1)
e0001a05 4437 {
43cd72b9
BW
4438 xtensa_regfile opnd_rf =
4439 xtensa_operand_regfile (isa, insn->opcode, i);
4440 if (!strcmp (xtensa_regfile_shortname (isa, opnd_rf), regset))
e0001a05
NC
4441 {
4442 if ((insn->tok[i].X_op == O_register)
4443 && (insn->tok[i].X_add_number == regnum))
4444 return TRUE;
4445 }
4446 }
4447 }
4448 return FALSE;
4449}
4450
4451
4452static bfd_boolean
7fa3d080 4453is_bad_loopend_opcode (const TInsn *tinsn)
e0001a05
NC
4454{
4455 xtensa_opcode opcode = tinsn->opcode;
4456
4457 if (opcode == XTENSA_UNDEFINED)
4458 return FALSE;
4459
4460 if (opcode == xtensa_call0_opcode
4461 || opcode == xtensa_callx0_opcode
4462 || opcode == xtensa_call4_opcode
4463 || opcode == xtensa_callx4_opcode
4464 || opcode == xtensa_call8_opcode
4465 || opcode == xtensa_callx8_opcode
4466 || opcode == xtensa_call12_opcode
4467 || opcode == xtensa_callx12_opcode
4468 || opcode == xtensa_isync_opcode
4469 || opcode == xtensa_ret_opcode
4470 || opcode == xtensa_ret_n_opcode
4471 || opcode == xtensa_retw_opcode
4472 || opcode == xtensa_retw_n_opcode
43cd72b9
BW
4473 || opcode == xtensa_waiti_opcode
4474 || opcode == xtensa_rsr_lcount_opcode)
e0001a05 4475 return TRUE;
c138bc38 4476
e0001a05
NC
4477 return FALSE;
4478}
4479
4480
4481/* Labels that begin with ".Ln" or ".LM" are unaligned.
4482 This allows the debugger to add unaligned labels.
4483 Also, the assembler generates stabs labels that need
4484 not be aligned: FAKE_LABEL_NAME . {"F", "L", "endfunc"}. */
4485
7fa3d080
BW
4486static bfd_boolean
4487is_unaligned_label (symbolS *sym)
e0001a05
NC
4488{
4489 const char *name = S_GET_NAME (sym);
4490 static size_t fake_size = 0;
4491
4492 if (name
4493 && name[0] == '.'
4494 && name[1] == 'L' && (name[2] == 'n' || name[2] == 'M'))
4495 return TRUE;
4496
4497 /* FAKE_LABEL_NAME followed by "F", "L" or "endfunc" */
4498 if (fake_size == 0)
4499 fake_size = strlen (FAKE_LABEL_NAME);
4500
43cd72b9 4501 if (name
e0001a05
NC
4502 && strncmp (FAKE_LABEL_NAME, name, fake_size) == 0
4503 && (name[fake_size] == 'F'
4504 || name[fake_size] == 'L'
4505 || (name[fake_size] == 'e'
4506 && strncmp ("endfunc", name+fake_size, 7) == 0)))
4507 return TRUE;
4508
4509 return FALSE;
4510}
4511
4512
7fa3d080
BW
4513static fragS *
4514next_non_empty_frag (const fragS *fragP)
e0001a05
NC
4515{
4516 fragS *next_fragP = fragP->fr_next;
4517
c138bc38 4518 /* Sometimes an empty will end up here due storage allocation issues.
e0001a05
NC
4519 So we have to skip until we find something legit. */
4520 while (next_fragP && next_fragP->fr_fix == 0)
4521 next_fragP = next_fragP->fr_next;
4522
4523 if (next_fragP == NULL || next_fragP->fr_fix == 0)
4524 return NULL;
4525
4526 return next_fragP;
4527}
4528
4529
43cd72b9 4530static bfd_boolean
7fa3d080 4531next_frag_opcode_is_loop (const fragS *fragP, xtensa_opcode *opcode)
43cd72b9
BW
4532{
4533 xtensa_opcode out_opcode;
4534 const fragS *next_fragP = next_non_empty_frag (fragP);
4535
4536 if (next_fragP == NULL)
4537 return FALSE;
4538
4539 out_opcode = get_opcode_from_buf (next_fragP->fr_literal, 0);
4540 if (xtensa_opcode_is_loop (xtensa_default_isa, out_opcode) == 1)
4541 {
4542 *opcode = out_opcode;
4543 return TRUE;
4544 }
4545 return FALSE;
4546}
4547
4548
4549static int
7fa3d080 4550frag_format_size (const fragS *fragP)
43cd72b9 4551{
e0001a05
NC
4552 static xtensa_insnbuf insnbuf = NULL;
4553 xtensa_isa isa = xtensa_default_isa;
43cd72b9 4554 xtensa_format fmt;
c138bc38 4555 int fmt_size;
e0001a05
NC
4556
4557 if (!insnbuf)
4558 insnbuf = xtensa_insnbuf_alloc (isa);
4559
43cd72b9
BW
4560 if (fragP == NULL)
4561 return XTENSA_UNDEFINED;
4562
d77b99c9
BW
4563 xtensa_insnbuf_from_chars (isa, insnbuf,
4564 (unsigned char *) fragP->fr_literal, 0);
43cd72b9
BW
4565
4566 fmt = xtensa_format_decode (isa, insnbuf);
4567 if (fmt == XTENSA_UNDEFINED)
e0001a05 4568 return XTENSA_UNDEFINED;
43cd72b9
BW
4569 fmt_size = xtensa_format_length (isa, fmt);
4570
4571 /* If the next format won't be changing due to relaxation, just
4572 return the length of the first format. */
4573 if (fragP->fr_opcode != fragP->fr_literal)
4574 return fmt_size;
4575
c138bc38 4576 /* If during relaxation we have to pull an instruction out of a
43cd72b9
BW
4577 multi-slot instruction, we will return the more conservative
4578 number. This works because alignment on bigger instructions
4579 is more restrictive than alignment on smaller instructions.
4580 This is more conservative than we would like, but it happens
4581 infrequently. */
4582
4583 if (xtensa_format_num_slots (xtensa_default_isa, fmt) > 1)
4584 return fmt_size;
4585
4586 /* If we aren't doing one of our own relaxations or it isn't
4587 slot-based, then the insn size won't change. */
4588 if (fragP->fr_type != rs_machine_dependent)
4589 return fmt_size;
4590 if (fragP->fr_subtype != RELAX_SLOTS)
4591 return fmt_size;
4592
4593 /* If an instruction is about to grow, return the longer size. */
4594 if (fragP->tc_frag_data.slot_subtypes[0] == RELAX_IMMED_STEP1
b81bf389
BW
4595 || fragP->tc_frag_data.slot_subtypes[0] == RELAX_IMMED_STEP2
4596 || fragP->tc_frag_data.slot_subtypes[0] == RELAX_IMMED_STEP3)
def13efb
BW
4597 {
4598 /* For most frags at RELAX_IMMED_STEPX, with X > 0, the first
4599 instruction in the relaxed version is of length 3. (The case
4600 where we have to pull the instruction out of a FLIX bundle
4601 is handled conservatively above.) However, frags with opcodes
4602 that are expanding to wide branches end up having formats that
4603 are not determinable by the RELAX_IMMED_STEPX enumeration, and
4604 we can't tell directly what format the relaxer picked. This
4605 is a wart in the design of the relaxer that should someday be
4606 fixed, but would require major changes, or at least should
4607 be accompanied by major changes to make use of that data.
4608
4609 In any event, we can tell that we are expanding from a single-slot
19ef5f3d 4610 format to a wider one with the logic below. */
def13efb 4611
19ef5f3d
SA
4612 int i;
4613 int relaxed_size = fmt_size + fragP->tc_frag_data.text_expansion[0];
4614
4615 for (i = 0; i < xtensa_isa_num_formats (isa); i++)
4616 {
4617 if (relaxed_size == xtensa_format_length (isa, i))
4618 return relaxed_size;
4619 }
4620
4621 return 3;
def13efb 4622 }
c138bc38 4623
43cd72b9
BW
4624 if (fragP->tc_frag_data.slot_subtypes[0] == RELAX_NARROW)
4625 return 2 + fragP->tc_frag_data.text_expansion[0];
e0001a05 4626
43cd72b9 4627 return fmt_size;
e0001a05
NC
4628}
4629
4630
7fa3d080
BW
4631static int
4632next_frag_format_size (const fragS *fragP)
e0001a05 4633{
7fa3d080
BW
4634 const fragS *next_fragP = next_non_empty_frag (fragP);
4635 return frag_format_size (next_fragP);
e0001a05
NC
4636}
4637
4638
03aaa593
BW
4639/* In early Xtensa Processors, for reasons that are unclear, the ISA
4640 required two-byte instructions to be treated as three-byte instructions
4641 for loop instruction alignment. This restriction was removed beginning
4642 with Xtensa LX. Now the only requirement on loop instruction alignment
4643 is that the first instruction of the loop must appear at an address that
4644 does not cross a fetch boundary. */
4645
4646static int
4647get_loop_align_size (int insn_size)
4648{
4649 if (insn_size == XTENSA_UNDEFINED)
4650 return xtensa_fetch_width;
4651
4652 if (enforce_three_byte_loop_align && insn_size == 2)
4653 return 3;
4654
4655 return insn_size;
4656}
4657
4658
e0001a05
NC
4659/* If the next legit fragment is an end-of-loop marker,
4660 switch its state so it will instantiate a NOP. */
4661
4662static void
1d19a770 4663update_next_frag_state (fragS *fragP)
e0001a05
NC
4664{
4665 fragS *next_fragP = fragP->fr_next;
43cd72b9 4666 fragS *new_target = NULL;
e0001a05 4667
7b1cc377 4668 if (align_targets)
43cd72b9
BW
4669 {
4670 /* We are guaranteed there will be one of these... */
4671 while (!(next_fragP->fr_type == rs_machine_dependent
4672 && (next_fragP->fr_subtype == RELAX_MAYBE_UNREACHABLE
4673 || next_fragP->fr_subtype == RELAX_UNREACHABLE)))
4674 next_fragP = next_fragP->fr_next;
4675
9c2799c2 4676 gas_assert (next_fragP->fr_type == rs_machine_dependent
43cd72b9
BW
4677 && (next_fragP->fr_subtype == RELAX_MAYBE_UNREACHABLE
4678 || next_fragP->fr_subtype == RELAX_UNREACHABLE));
4679
4680 /* ...and one of these. */
4681 new_target = next_fragP->fr_next;
4682 while (!(new_target->fr_type == rs_machine_dependent
4683 && (new_target->fr_subtype == RELAX_MAYBE_DESIRE_ALIGN
4684 || new_target->fr_subtype == RELAX_DESIRE_ALIGN)))
4685 new_target = new_target->fr_next;
4686
9c2799c2 4687 gas_assert (new_target->fr_type == rs_machine_dependent
43cd72b9
BW
4688 && (new_target->fr_subtype == RELAX_MAYBE_DESIRE_ALIGN
4689 || new_target->fr_subtype == RELAX_DESIRE_ALIGN));
4690 }
43cd72b9 4691
1d19a770 4692 while (next_fragP && next_fragP->fr_fix == 0)
43cd72b9 4693 {
1d19a770
BW
4694 if (next_fragP->fr_type == rs_machine_dependent
4695 && next_fragP->fr_subtype == RELAX_LOOP_END)
43cd72b9 4696 {
1d19a770
BW
4697 next_fragP->fr_subtype = RELAX_LOOP_END_ADD_NOP;
4698 return;
e0001a05 4699 }
1d19a770
BW
4700
4701 next_fragP = next_fragP->fr_next;
e0001a05
NC
4702 }
4703}
4704
4705
4706static bfd_boolean
7fa3d080 4707next_frag_is_branch_target (const fragS *fragP)
e0001a05 4708{
43cd72b9 4709 /* Sometimes an empty will end up here due to storage allocation issues,
e0001a05
NC
4710 so we have to skip until we find something legit. */
4711 for (fragP = fragP->fr_next; fragP; fragP = fragP->fr_next)
4712 {
4713 if (fragP->tc_frag_data.is_branch_target)
4714 return TRUE;
4715 if (fragP->fr_fix != 0)
4716 break;
4717 }
4718 return FALSE;
4719}
4720
4721
4722static bfd_boolean
7fa3d080 4723next_frag_is_loop_target (const fragS *fragP)
e0001a05 4724{
c138bc38 4725 /* Sometimes an empty will end up here due storage allocation issues.
e0001a05
NC
4726 So we have to skip until we find something legit. */
4727 for (fragP = fragP->fr_next; fragP; fragP = fragP->fr_next)
4728 {
4729 if (fragP->tc_frag_data.is_loop_target)
4730 return TRUE;
4731 if (fragP->fr_fix != 0)
4732 break;
4733 }
4734 return FALSE;
4735}
4736
4737
3a1e9c4a
SA
4738/* As specified in the relaxation table, when a loop instruction is
4739 relaxed, there are 24 bytes between the loop instruction itself and
4740 the first instruction in the loop. */
4741
4742#define RELAXED_LOOP_INSN_BYTES 24
4743
e0001a05 4744static addressT
7fa3d080 4745next_frag_pre_opcode_bytes (const fragS *fragp)
e0001a05
NC
4746{
4747 const fragS *next_fragp = fragp->fr_next;
43cd72b9 4748 xtensa_opcode next_opcode;
e0001a05 4749
43cd72b9 4750 if (!next_frag_opcode_is_loop (fragp, &next_opcode))
e0001a05
NC
4751 return 0;
4752
43cd72b9
BW
4753 /* Sometimes an empty will end up here due to storage allocation issues,
4754 so we have to skip until we find something legit. */
e0001a05
NC
4755 while (next_fragp->fr_fix == 0)
4756 next_fragp = next_fragp->fr_next;
4757
4758 if (next_fragp->fr_type != rs_machine_dependent)
4759 return 0;
4760
4761 /* There is some implicit knowledge encoded in here.
4762 The LOOP instructions that are NOT RELAX_IMMED have
43cd72b9
BW
4763 been relaxed. Note that we can assume that the LOOP
4764 instruction is in slot 0 because loops aren't bundleable. */
4765 if (next_fragp->tc_frag_data.slot_subtypes[0] > RELAX_IMMED)
3a1e9c4a 4766 return get_expanded_loop_offset (next_opcode) + RELAXED_LOOP_INSN_BYTES;
e0001a05
NC
4767
4768 return 0;
4769}
4770
4771
4772/* Mark a location where we can later insert literal frags. Update
4773 the section's literal_pool_loc, so subsequent literals can be
4774 placed nearest to their use. */
4775
4776static void
7fa3d080 4777xtensa_mark_literal_pool_location (void)
e0001a05
NC
4778{
4779 /* Any labels pointing to the current location need
4780 to be adjusted to after the literal pool. */
4781 emit_state s;
e0001a05 4782 fragS *pool_location;
e0001a05 4783
1f2a7e38 4784 if (use_literal_section)
43cd72b9
BW
4785 return;
4786
dd49a749
BW
4787 /* We stash info in these frags so we can later move the literal's
4788 fixes into this frchain's fix list. */
e0001a05 4789 pool_location = frag_now;
dd49a749 4790 frag_now->tc_frag_data.lit_frchain = frchain_now;
c48aaca0 4791 frag_now->tc_frag_data.literal_frag = frag_now;
b46824bd
MF
4792 /* Just record this frag. */
4793 xtensa_maybe_create_literal_pool_frag (FALSE, FALSE);
dd49a749 4794 frag_variant (rs_machine_dependent, 0, 0,
e0001a05 4795 RELAX_LITERAL_POOL_BEGIN, NULL, 0, NULL);
43cd72b9 4796 xtensa_set_frag_assembly_state (frag_now);
dd49a749
BW
4797 frag_now->tc_frag_data.lit_seg = now_seg;
4798 frag_variant (rs_machine_dependent, 0, 0,
e0001a05 4799 RELAX_LITERAL_POOL_END, NULL, 0, NULL);
43cd72b9 4800 xtensa_set_frag_assembly_state (frag_now);
e0001a05
NC
4801
4802 /* Now put a frag into the literal pool that points to this location. */
4803 set_literal_pool_location (now_seg, pool_location);
43cd72b9
BW
4804 xtensa_switch_to_non_abs_literal_fragment (&s);
4805 frag_align (2, 0, 0);
4806 record_alignment (now_seg, 2);
e0001a05
NC
4807
4808 /* Close whatever frag is there. */
4809 frag_variant (rs_fill, 0, 0, 0, NULL, 0, NULL);
43cd72b9 4810 xtensa_set_frag_assembly_state (frag_now);
e0001a05
NC
4811 frag_now->tc_frag_data.literal_frag = pool_location;
4812 frag_variant (rs_fill, 0, 0, 0, NULL, 0, NULL);
4813 xtensa_restore_emit_state (&s);
43cd72b9 4814 xtensa_set_frag_assembly_state (frag_now);
e0001a05
NC
4815}
4816
4817
43cd72b9
BW
4818/* Build a nop of the correct size into tinsn. */
4819
4820static void
7fa3d080 4821build_nop (TInsn *tinsn, int size)
43cd72b9
BW
4822{
4823 tinsn_init (tinsn);
4824 switch (size)
4825 {
4826 case 2:
4827 tinsn->opcode = xtensa_nop_n_opcode;
4828 tinsn->ntok = 0;
4829 if (tinsn->opcode == XTENSA_UNDEFINED)
4830 as_fatal (_("opcode 'NOP.N' unavailable in this configuration"));
4831 break;
4832
4833 case 3:
4834 if (xtensa_nop_opcode == XTENSA_UNDEFINED)
4835 {
4836 tinsn->opcode = xtensa_or_opcode;
4837 set_expr_const (&tinsn->tok[0], 1);
4838 set_expr_const (&tinsn->tok[1], 1);
4839 set_expr_const (&tinsn->tok[2], 1);
4840 tinsn->ntok = 3;
4841 }
4842 else
4843 tinsn->opcode = xtensa_nop_opcode;
4844
9c2799c2 4845 gas_assert (tinsn->opcode != XTENSA_UNDEFINED);
43cd72b9
BW
4846 }
4847}
4848
4849
e0001a05
NC
4850/* Assemble a NOP of the requested size in the buffer. User must have
4851 allocated "buf" with at least "size" bytes. */
4852
7fa3d080 4853static void
d77b99c9 4854assemble_nop (int size, char *buf)
e0001a05
NC
4855{
4856 static xtensa_insnbuf insnbuf = NULL;
43cd72b9 4857 TInsn tinsn;
e0001a05 4858
43cd72b9 4859 build_nop (&tinsn, size);
e0001a05 4860
43cd72b9
BW
4861 if (!insnbuf)
4862 insnbuf = xtensa_insnbuf_alloc (xtensa_default_isa);
e0001a05 4863
43cd72b9 4864 tinsn_to_insnbuf (&tinsn, insnbuf);
d77b99c9
BW
4865 xtensa_insnbuf_to_chars (xtensa_default_isa, insnbuf,
4866 (unsigned char *) buf, 0);
e0001a05
NC
4867}
4868
4869
4870/* Return the number of bytes for the offset of the expanded loop
4871 instruction. This should be incorporated into the relaxation
4872 specification but is hard-coded here. This is used to auto-align
4873 the loop instruction. It is invalid to call this function if the
4874 configuration does not have loops or if the opcode is not a loop
4875 opcode. */
4876
4877static addressT
7fa3d080 4878get_expanded_loop_offset (xtensa_opcode opcode)
e0001a05
NC
4879{
4880 /* This is the OFFSET of the loop instruction in the expanded loop.
4881 This MUST correspond directly to the specification of the loop
4882 expansion. It will be validated on fragment conversion. */
9c2799c2 4883 gas_assert (opcode != XTENSA_UNDEFINED);
e0001a05
NC
4884 if (opcode == xtensa_loop_opcode)
4885 return 0;
4886 if (opcode == xtensa_loopnez_opcode)
4887 return 3;
4888 if (opcode == xtensa_loopgtz_opcode)
4889 return 6;
4890 as_fatal (_("get_expanded_loop_offset: invalid opcode"));
4891 return 0;
4892}
4893
4894
7fa3d080
BW
4895static fragS *
4896get_literal_pool_location (segT seg)
e0001a05 4897{
b46824bd
MF
4898 struct litpool_seg *lps = litpool_seg_list.next;
4899 struct litpool_frag *lpf;
4900 for ( ; lps && lps->seg->id != seg->id; lps = lps->next)
4901 ;
4902 if (lps)
4903 {
4904 for (lpf = lps->frag_list.prev; lpf->fragP; lpf = lpf->prev)
4905 { /* Skip "candidates" for now. */
4906 if (lpf->fragP->fr_subtype == RELAX_LITERAL_POOL_BEGIN &&
4907 lpf->priority == 1)
4908 return lpf->fragP;
4909 }
4910 /* Must convert a lower-priority pool. */
4911 for (lpf = lps->frag_list.prev; lpf->fragP; lpf = lpf->prev)
4912 {
4913 if (lpf->fragP->fr_subtype == RELAX_LITERAL_POOL_BEGIN)
4914 return lpf->fragP;
4915 }
4916 /* Still no match -- try for a low priority pool. */
4917 for (lpf = lps->frag_list.prev; lpf->fragP; lpf = lpf->prev)
4918 {
4919 if (lpf->fragP->fr_subtype == RELAX_LITERAL_POOL_CANDIDATE_BEGIN)
4920 return lpf->fragP;
4921 }
4922 }
e0001a05
NC
4923 return seg_info (seg)->tc_segment_info_data.literal_pool_loc;
4924}
4925
4926
4927static void
7fa3d080 4928set_literal_pool_location (segT seg, fragS *literal_pool_loc)
e0001a05
NC
4929{
4930 seg_info (seg)->tc_segment_info_data.literal_pool_loc = literal_pool_loc;
4931}
4932
43cd72b9
BW
4933
4934/* Set frag assembly state should be called when a new frag is
4935 opened and after a frag has been closed. */
4936
7fa3d080
BW
4937static void
4938xtensa_set_frag_assembly_state (fragS *fragP)
43cd72b9
BW
4939{
4940 if (!density_supported)
4941 fragP->tc_frag_data.is_no_density = TRUE;
4942
4943 /* This function is called from subsegs_finish, which is called
c138bc38 4944 after xtensa_end, so we can't use "use_transform" or
43cd72b9
BW
4945 "use_schedule" here. */
4946 if (!directive_state[directive_transform])
4947 fragP->tc_frag_data.is_no_transform = TRUE;
7c834684
BW
4948 if (directive_state[directive_longcalls])
4949 fragP->tc_frag_data.use_longcalls = TRUE;
43cd72b9
BW
4950 fragP->tc_frag_data.use_absolute_literals =
4951 directive_state[directive_absolute_literals];
4952 fragP->tc_frag_data.is_assembly_state_set = TRUE;
4953}
4954
4955
7fa3d080
BW
4956static bfd_boolean
4957relaxable_section (asection *sec)
43cd72b9 4958{
11ac2671
BW
4959 return ((sec->flags & SEC_DEBUGGING) == 0
4960 && strcmp (sec->name, ".eh_frame") != 0);
43cd72b9
BW
4961}
4962
4963
99ded152
BW
4964static void
4965xtensa_mark_frags_for_org (void)
4966{
4967 segT *seclist;
4968
4969 /* Walk over each fragment of all of the current segments. If we find
4970 a .org frag in any of the segments, mark all frags prior to it as
4971 "no transform", which will prevent linker optimizations from messing
4972 up the .org distance. This should be done after
4973 xtensa_find_unmarked_state_frags, because we don't want to worry here
4974 about that function trashing the data we save here. */
4975
4976 for (seclist = &stdoutput->sections;
4977 seclist && *seclist;
4978 seclist = &(*seclist)->next)
4979 {
4980 segT sec = *seclist;
4981 segment_info_type *seginfo;
4982 fragS *fragP;
4983 flagword flags;
4984 flags = bfd_get_section_flags (stdoutput, sec);
4985 if (flags & SEC_DEBUGGING)
4986 continue;
4987 if (!(flags & SEC_ALLOC))
4988 continue;
4989
4990 seginfo = seg_info (sec);
4991 if (seginfo && seginfo->frchainP)
4992 {
4993 fragS *last_fragP = seginfo->frchainP->frch_root;
4994 for (fragP = seginfo->frchainP->frch_root; fragP;
4995 fragP = fragP->fr_next)
4996 {
4997 /* cvt_frag_to_fill has changed the fr_type of org frags to
4998 rs_fill, so use the value as cached in rs_subtype here. */
4999 if (fragP->fr_subtype == RELAX_ORG)
5000 {
5001 while (last_fragP != fragP->fr_next)
5002 {
5003 last_fragP->tc_frag_data.is_no_transform = TRUE;
5004 last_fragP = last_fragP->fr_next;
5005 }
5006 }
5007 }
5008 }
5009 }
5010}
5011
5012
43cd72b9 5013static void
7fa3d080 5014xtensa_find_unmarked_state_frags (void)
43cd72b9
BW
5015{
5016 segT *seclist;
5017
5018 /* Walk over each fragment of all of the current segments. For each
5019 unmarked fragment, mark it with the same info as the previous
5020 fragment. */
5021 for (seclist = &stdoutput->sections;
5022 seclist && *seclist;
5023 seclist = &(*seclist)->next)
5024 {
5025 segT sec = *seclist;
5026 segment_info_type *seginfo;
5027 fragS *fragP;
5028 flagword flags;
5029 flags = bfd_get_section_flags (stdoutput, sec);
5030 if (flags & SEC_DEBUGGING)
5031 continue;
5032 if (!(flags & SEC_ALLOC))
5033 continue;
5034
5035 seginfo = seg_info (sec);
5036 if (seginfo && seginfo->frchainP)
5037 {
5038 fragS *last_fragP = 0;
5039 for (fragP = seginfo->frchainP->frch_root; fragP;
5040 fragP = fragP->fr_next)
5041 {
5042 if (fragP->fr_fix != 0
5043 && !fragP->tc_frag_data.is_assembly_state_set)
5044 {
5045 if (last_fragP == 0)
5046 {
5047 as_warn_where (fragP->fr_file, fragP->fr_line,
5048 _("assembly state not set for first frag in section %s"),
5049 sec->name);
5050 }
5051 else
5052 {
5053 fragP->tc_frag_data.is_assembly_state_set = TRUE;
5054 fragP->tc_frag_data.is_no_density =
5055 last_fragP->tc_frag_data.is_no_density;
5056 fragP->tc_frag_data.is_no_transform =
5057 last_fragP->tc_frag_data.is_no_transform;
7c834684
BW
5058 fragP->tc_frag_data.use_longcalls =
5059 last_fragP->tc_frag_data.use_longcalls;
43cd72b9
BW
5060 fragP->tc_frag_data.use_absolute_literals =
5061 last_fragP->tc_frag_data.use_absolute_literals;
5062 }
5063 }
5064 if (fragP->tc_frag_data.is_assembly_state_set)
5065 last_fragP = fragP;
5066 }
5067 }
5068 }
5069}
5070
5071
5072static void
7fa3d080
BW
5073xtensa_find_unaligned_branch_targets (bfd *abfd ATTRIBUTE_UNUSED,
5074 asection *sec,
5075 void *unused ATTRIBUTE_UNUSED)
43cd72b9
BW
5076{
5077 flagword flags = bfd_get_section_flags (abfd, sec);
5078 segment_info_type *seginfo = seg_info (sec);
5079 fragS *frag = seginfo->frchainP->frch_root;
c138bc38 5080
43cd72b9 5081 if (flags & SEC_CODE)
c138bc38 5082 {
43cd72b9
BW
5083 xtensa_isa isa = xtensa_default_isa;
5084 xtensa_insnbuf insnbuf = xtensa_insnbuf_alloc (isa);
5085 while (frag != NULL)
5086 {
5087 if (frag->tc_frag_data.is_branch_target)
5088 {
5089 int op_size;
664df4e4 5090 addressT branch_align, frag_addr;
43cd72b9
BW
5091 xtensa_format fmt;
5092
d77b99c9
BW
5093 xtensa_insnbuf_from_chars
5094 (isa, insnbuf, (unsigned char *) frag->fr_literal, 0);
43cd72b9
BW
5095 fmt = xtensa_format_decode (isa, insnbuf);
5096 op_size = xtensa_format_length (isa, fmt);
664df4e4
BW
5097 branch_align = 1 << branch_align_power (sec);
5098 frag_addr = frag->fr_address % branch_align;
5099 if (frag_addr + op_size > branch_align)
43cd72b9
BW
5100 as_warn_where (frag->fr_file, frag->fr_line,
5101 _("unaligned branch target: %d bytes at 0x%lx"),
dd49a749 5102 op_size, (long) frag->fr_address);
43cd72b9
BW
5103 }
5104 frag = frag->fr_next;
5105 }
5106 xtensa_insnbuf_free (isa, insnbuf);
5107 }
5108}
5109
5110
5111static void
7fa3d080
BW
5112xtensa_find_unaligned_loops (bfd *abfd ATTRIBUTE_UNUSED,
5113 asection *sec,
5114 void *unused ATTRIBUTE_UNUSED)
43cd72b9
BW
5115{
5116 flagword flags = bfd_get_section_flags (abfd, sec);
5117 segment_info_type *seginfo = seg_info (sec);
5118 fragS *frag = seginfo->frchainP->frch_root;
5119 xtensa_isa isa = xtensa_default_isa;
c138bc38 5120
43cd72b9 5121 if (flags & SEC_CODE)
c138bc38 5122 {
43cd72b9
BW
5123 xtensa_insnbuf insnbuf = xtensa_insnbuf_alloc (isa);
5124 while (frag != NULL)
5125 {
5126 if (frag->tc_frag_data.is_first_loop_insn)
5127 {
5128 int op_size;
d77b99c9 5129 addressT frag_addr;
43cd72b9
BW
5130 xtensa_format fmt;
5131
3c83b96e
SA
5132 if (frag->fr_fix == 0)
5133 frag = next_non_empty_frag (frag);
3739860c 5134
3c83b96e
SA
5135 if (frag)
5136 {
5137 xtensa_insnbuf_from_chars
5138 (isa, insnbuf, (unsigned char *) frag->fr_literal, 0);
5139 fmt = xtensa_format_decode (isa, insnbuf);
5140 op_size = xtensa_format_length (isa, fmt);
5141 frag_addr = frag->fr_address % xtensa_fetch_width;
3739860c 5142
3c83b96e
SA
5143 if (frag_addr + op_size > xtensa_fetch_width)
5144 as_warn_where (frag->fr_file, frag->fr_line,
5145 _("unaligned loop: %d bytes at 0x%lx"),
5146 op_size, (long) frag->fr_address);
5147 }
43cd72b9
BW
5148 }
5149 frag = frag->fr_next;
5150 }
5151 xtensa_insnbuf_free (isa, insnbuf);
5152 }
5153}
5154
5155
30f725a1
BW
5156static int
5157xg_apply_fix_value (fixS *fixP, valueT val)
43cd72b9
BW
5158{
5159 xtensa_isa isa = xtensa_default_isa;
5160 static xtensa_insnbuf insnbuf = NULL;
5161 static xtensa_insnbuf slotbuf = NULL;
5162 xtensa_format fmt;
5163 int slot;
5164 bfd_boolean alt_reloc;
5165 xtensa_opcode opcode;
5166 char *const fixpos = fixP->fx_frag->fr_literal + fixP->fx_where;
5167
1b6e95c2
BW
5168 if (decode_reloc (fixP->fx_r_type, &slot, &alt_reloc)
5169 || alt_reloc)
43cd72b9
BW
5170 as_fatal (_("unexpected fix"));
5171
5172 if (!insnbuf)
5173 {
5174 insnbuf = xtensa_insnbuf_alloc (isa);
5175 slotbuf = xtensa_insnbuf_alloc (isa);
5176 }
5177
d77b99c9 5178 xtensa_insnbuf_from_chars (isa, insnbuf, (unsigned char *) fixpos, 0);
43cd72b9
BW
5179 fmt = xtensa_format_decode (isa, insnbuf);
5180 if (fmt == XTENSA_UNDEFINED)
5181 as_fatal (_("undecodable fix"));
5182 xtensa_format_get_slot (isa, fmt, slot, insnbuf, slotbuf);
5183 opcode = xtensa_opcode_decode (isa, fmt, slot, slotbuf);
5184 if (opcode == XTENSA_UNDEFINED)
5185 as_fatal (_("undecodable fix"));
5186
5187 /* CONST16 immediates are not PC-relative, despite the fact that we
5188 reuse the normal PC-relative operand relocations for the low part
30f725a1 5189 of a CONST16 operand. */
43cd72b9 5190 if (opcode == xtensa_const16_opcode)
30f725a1 5191 return 0;
43cd72b9
BW
5192
5193 xtensa_insnbuf_set_operand (slotbuf, fmt, slot, opcode,
5194 get_relaxable_immed (opcode), val,
5195 fixP->fx_file, fixP->fx_line);
5196
5197 xtensa_format_set_slot (isa, fmt, slot, insnbuf, slotbuf);
d77b99c9 5198 xtensa_insnbuf_to_chars (isa, insnbuf, (unsigned char *) fixpos, 0);
30f725a1
BW
5199
5200 return 1;
43cd72b9
BW
5201}
5202
e0001a05
NC
5203\f
5204/* External Functions and Other GAS Hooks. */
5205
5206const char *
7fa3d080 5207xtensa_target_format (void)
e0001a05
NC
5208{
5209 return (target_big_endian ? "elf32-xtensa-be" : "elf32-xtensa-le");
5210}
5211
5212
5213void
7fa3d080 5214xtensa_file_arch_init (bfd *abfd)
e0001a05
NC
5215{
5216 bfd_set_private_flags (abfd, 0x100 | 0x200);
5217}
5218
5219
5220void
7fa3d080 5221md_number_to_chars (char *buf, valueT val, int n)
e0001a05
NC
5222{
5223 if (target_big_endian)
5224 number_to_chars_bigendian (buf, val, n);
5225 else
5226 number_to_chars_littleendian (buf, val, n);
5227}
5228
f7e16c2a
MF
5229static void
5230xg_init_global_config (void)
5231{
5232 target_big_endian = XCHAL_HAVE_BE;
5233
5234 density_supported = XCHAL_HAVE_DENSITY;
5235 absolute_literals_supported = XSHAL_USE_ABSOLUTE_LITERALS;
5236 xtensa_fetch_width = XCHAL_INST_FETCH_WIDTH;
5237
5238 directive_state[directive_density] = XCHAL_HAVE_DENSITY;
5239 directive_state[directive_absolute_literals] = XSHAL_USE_ABSOLUTE_LITERALS;
5240}
5241
5242void
5243xtensa_init (int argc ATTRIBUTE_UNUSED, char **argv ATTRIBUTE_UNUSED)
5244{
5245 xg_init_global_config ();
5246}
e0001a05
NC
5247
5248/* This function is called once, at assembler startup time. It should
5249 set up all the tables, etc. that the MD part of the assembler will
5250 need. */
5251
5252void
7fa3d080 5253md_begin (void)
e0001a05
NC
5254{
5255 segT current_section = now_seg;
5256 int current_subsec = now_subseg;
5257 xtensa_isa isa;
62af60e2 5258 int i;
e0001a05 5259
43cd72b9 5260 xtensa_default_isa = xtensa_isa_init (0, 0);
e0001a05 5261 isa = xtensa_default_isa;
e0001a05 5262
43cd72b9
BW
5263 linkrelax = 1;
5264
74869ac7 5265 /* Set up the literal sections. */
e0001a05 5266 memset (&default_lit_sections, 0, sizeof (default_lit_sections));
e0001a05
NC
5267
5268 subseg_set (current_section, current_subsec);
5269
5270 xtensa_addi_opcode = xtensa_opcode_lookup (isa, "addi");
5271 xtensa_addmi_opcode = xtensa_opcode_lookup (isa, "addmi");
5272 xtensa_call0_opcode = xtensa_opcode_lookup (isa, "call0");
5273 xtensa_call4_opcode = xtensa_opcode_lookup (isa, "call4");
5274 xtensa_call8_opcode = xtensa_opcode_lookup (isa, "call8");
5275 xtensa_call12_opcode = xtensa_opcode_lookup (isa, "call12");
5276 xtensa_callx0_opcode = xtensa_opcode_lookup (isa, "callx0");
5277 xtensa_callx4_opcode = xtensa_opcode_lookup (isa, "callx4");
5278 xtensa_callx8_opcode = xtensa_opcode_lookup (isa, "callx8");
5279 xtensa_callx12_opcode = xtensa_opcode_lookup (isa, "callx12");
43cd72b9 5280 xtensa_const16_opcode = xtensa_opcode_lookup (isa, "const16");
e0001a05 5281 xtensa_entry_opcode = xtensa_opcode_lookup (isa, "entry");
d12f9798 5282 xtensa_extui_opcode = xtensa_opcode_lookup (isa, "extui");
43cd72b9
BW
5283 xtensa_movi_opcode = xtensa_opcode_lookup (isa, "movi");
5284 xtensa_movi_n_opcode = xtensa_opcode_lookup (isa, "movi.n");
e0001a05 5285 xtensa_isync_opcode = xtensa_opcode_lookup (isa, "isync");
19e8f41a 5286 xtensa_j_opcode = xtensa_opcode_lookup (isa, "j");
e0001a05 5287 xtensa_jx_opcode = xtensa_opcode_lookup (isa, "jx");
43cd72b9 5288 xtensa_l32r_opcode = xtensa_opcode_lookup (isa, "l32r");
e0001a05
NC
5289 xtensa_loop_opcode = xtensa_opcode_lookup (isa, "loop");
5290 xtensa_loopnez_opcode = xtensa_opcode_lookup (isa, "loopnez");
5291 xtensa_loopgtz_opcode = xtensa_opcode_lookup (isa, "loopgtz");
43cd72b9 5292 xtensa_nop_opcode = xtensa_opcode_lookup (isa, "nop");
e0001a05
NC
5293 xtensa_nop_n_opcode = xtensa_opcode_lookup (isa, "nop.n");
5294 xtensa_or_opcode = xtensa_opcode_lookup (isa, "or");
5295 xtensa_ret_opcode = xtensa_opcode_lookup (isa, "ret");
5296 xtensa_ret_n_opcode = xtensa_opcode_lookup (isa, "ret.n");
5297 xtensa_retw_opcode = xtensa_opcode_lookup (isa, "retw");
5298 xtensa_retw_n_opcode = xtensa_opcode_lookup (isa, "retw.n");
43cd72b9 5299 xtensa_rsr_lcount_opcode = xtensa_opcode_lookup (isa, "rsr.lcount");
e0001a05 5300 xtensa_waiti_opcode = xtensa_opcode_lookup (isa, "waiti");
43cd72b9 5301
3739860c 5302 for (i = 0; i < xtensa_isa_num_formats (isa); i++)
62af60e2
SA
5303 {
5304 int format_slots = xtensa_format_num_slots (isa, i);
5305 if (format_slots > config_max_slots)
5306 config_max_slots = format_slots;
5307 }
5308
5309 xg_init_vinsn (&cur_vinsn);
5310
77cba8a3
BW
5311 xtensa_num_pipe_stages = xtensa_isa_num_pipe_stages (isa);
5312
43cd72b9
BW
5313 init_op_placement_info_table ();
5314
5315 /* Set up the assembly state. */
5316 if (!frag_now->tc_frag_data.is_assembly_state_set)
5317 xtensa_set_frag_assembly_state (frag_now);
5318}
5319
5320
5321/* TC_INIT_FIX_DATA hook */
5322
5323void
7fa3d080 5324xtensa_init_fix_data (fixS *x)
43cd72b9
BW
5325{
5326 x->tc_fix_data.slot = 0;
5327 x->tc_fix_data.X_add_symbol = NULL;
5328 x->tc_fix_data.X_add_number = 0;
e0001a05
NC
5329}
5330
5331
5332/* tc_frob_label hook */
5333
5334void
7fa3d080 5335xtensa_frob_label (symbolS *sym)
e0001a05 5336{
3ea38ac2
BW
5337 float freq;
5338
5339 if (cur_vinsn.inside_bundle)
5340 {
5341 as_bad (_("labels are not valid inside bundles"));
5342 return;
5343 }
5344
5345 freq = get_subseg_target_freq (now_seg, now_subseg);
7b1cc377 5346
43cd72b9
BW
5347 /* Since the label was already attached to a frag associated with the
5348 previous basic block, it now needs to be reset to the current frag. */
5349 symbol_set_frag (sym, frag_now);
5350 S_SET_VALUE (sym, (valueT) frag_now_fix ());
5351
82e7541d
BW
5352 if (generating_literals)
5353 xtensa_add_literal_sym (sym);
5354 else
5355 xtensa_add_insn_label (sym);
5356
7b1cc377
BW
5357 if (symbol_get_tc (sym)->is_loop_target)
5358 {
5359 if ((get_last_insn_flags (now_seg, now_subseg)
e0001a05 5360 & FLAG_IS_BAD_LOOPEND) != 0)
7b1cc377
BW
5361 as_bad (_("invalid last instruction for a zero-overhead loop"));
5362
5363 xtensa_set_frag_assembly_state (frag_now);
5364 frag_var (rs_machine_dependent, 4, 4, RELAX_LOOP_END,
5365 frag_now->fr_symbol, frag_now->fr_offset, NULL);
5366
5367 xtensa_set_frag_assembly_state (frag_now);
c3ea6048 5368 xtensa_move_labels (frag_now, 0);
07a53e5c 5369 }
e0001a05
NC
5370
5371 /* No target aligning in the absolute section. */
61846f28 5372 if (now_seg != absolute_section
61846f28 5373 && !is_unaligned_label (sym)
43cd72b9
BW
5374 && !generating_literals)
5375 {
43cd72b9
BW
5376 xtensa_set_frag_assembly_state (frag_now);
5377
b7afdeef
SA
5378 if (do_align_targets ())
5379 frag_var (rs_machine_dependent, 0, (int) freq,
5380 RELAX_DESIRE_ALIGN_IF_TARGET, frag_now->fr_symbol,
5381 frag_now->fr_offset, NULL);
5382 else
5383 frag_var (rs_fill, 0, 0, frag_now->fr_subtype,
5384 frag_now->fr_symbol, frag_now->fr_offset, NULL);
43cd72b9 5385 xtensa_set_frag_assembly_state (frag_now);
c3ea6048 5386 xtensa_move_labels (frag_now, 0);
43cd72b9
BW
5387 }
5388
5389 /* We need to mark the following properties even if we aren't aligning. */
5390
5391 /* If the label is already known to be a branch target, i.e., a
5392 forward branch, mark the frag accordingly. Backward branches
5393 are handled by xg_add_branch_and_loop_targets. */
5394 if (symbol_get_tc (sym)->is_branch_target)
5395 symbol_get_frag (sym)->tc_frag_data.is_branch_target = TRUE;
5396
5397 /* Loops only go forward, so they can be identified here. */
5398 if (symbol_get_tc (sym)->is_loop_target)
5399 symbol_get_frag (sym)->tc_frag_data.is_loop_target = TRUE;
07a53e5c
RH
5400
5401 dwarf2_emit_label (sym);
43cd72b9
BW
5402}
5403
5404
5405/* tc_unrecognized_line hook */
5406
5407int
7fa3d080 5408xtensa_unrecognized_line (int ch)
43cd72b9
BW
5409{
5410 switch (ch)
5411 {
5412 case '{' :
5413 if (cur_vinsn.inside_bundle == 0)
5414 {
5415 /* PR8110: Cannot emit line number info inside a FLIX bundle
5416 when using --gstabs. Temporarily disable debug info. */
5417 generate_lineno_debug ();
5418 if (debug_type == DEBUG_STABS)
5419 {
5420 xt_saved_debug_type = debug_type;
5421 debug_type = DEBUG_NONE;
5422 }
82e7541d 5423
43cd72b9
BW
5424 cur_vinsn.inside_bundle = 1;
5425 }
5426 else
5427 {
5428 as_bad (_("extra opening brace"));
5429 return 0;
5430 }
5431 break;
82e7541d 5432
43cd72b9
BW
5433 case '}' :
5434 if (cur_vinsn.inside_bundle)
5435 finish_vinsn (&cur_vinsn);
5436 else
5437 {
5438 as_bad (_("extra closing brace"));
5439 return 0;
5440 }
5441 break;
5442 default:
5443 as_bad (_("syntax error"));
5444 return 0;
e0001a05 5445 }
43cd72b9 5446 return 1;
e0001a05
NC
5447}
5448
5449
5450/* md_flush_pending_output hook */
5451
5452void
7fa3d080 5453xtensa_flush_pending_output (void)
e0001a05 5454{
a3582eee
BW
5455 /* This line fixes a bug where automatically generated gstabs info
5456 separates a function label from its entry instruction, ending up
5457 with the literal position between the function label and the entry
5458 instruction and crashing code. It only happens with --gstabs and
5459 --text-section-literals, and when several other obscure relaxation
5460 conditions are met. */
5461 if (outputting_stabs_line_debug)
5462 return;
5463
43cd72b9
BW
5464 if (cur_vinsn.inside_bundle)
5465 as_bad (_("missing closing brace"));
5466
e0001a05
NC
5467 /* If there is a non-zero instruction fragment, close it. */
5468 if (frag_now_fix () != 0 && frag_now->tc_frag_data.is_insn)
5469 {
5470 frag_wane (frag_now);
5471 frag_new (0);
43cd72b9 5472 xtensa_set_frag_assembly_state (frag_now);
e0001a05
NC
5473 }
5474 frag_now->tc_frag_data.is_insn = FALSE;
82e7541d
BW
5475
5476 xtensa_clear_insn_labels ();
e0001a05
NC
5477}
5478
5479
43cd72b9
BW
5480/* We had an error while parsing an instruction. The string might look
5481 like this: "insn arg1, arg2 }". If so, we need to see the closing
5482 brace and reset some fields. Otherwise, the vinsn never gets closed
5483 and the num_slots field will grow past the end of the array of slots,
5484 and bad things happen. */
5485
5486static void
7fa3d080 5487error_reset_cur_vinsn (void)
43cd72b9
BW
5488{
5489 if (cur_vinsn.inside_bundle)
5490 {
5491 if (*input_line_pointer == '}'
5492 || *(input_line_pointer - 1) == '}'
5493 || *(input_line_pointer - 2) == '}')
5494 xg_clear_vinsn (&cur_vinsn);
5495 }
5496}
5497
5498
e0001a05 5499void
7fa3d080 5500md_assemble (char *str)
e0001a05
NC
5501{
5502 xtensa_isa isa = xtensa_default_isa;
b224e962 5503 char *opname;
e0001a05
NC
5504 unsigned opnamelen;
5505 bfd_boolean has_underbar = FALSE;
43cd72b9 5506 char *arg_strings[MAX_INSN_ARGS];
e0001a05 5507 int num_args;
e0001a05 5508 TInsn orig_insn; /* Original instruction from the input. */
e0001a05 5509
e0001a05
NC
5510 tinsn_init (&orig_insn);
5511
5512 /* Split off the opcode. */
5513 opnamelen = strspn (str, "abcdefghijklmnopqrstuvwxyz_/0123456789.");
4ec9d7d5 5514 opname = xstrndup (str, opnamelen);
e0001a05
NC
5515
5516 num_args = tokenize_arguments (arg_strings, str + opnamelen);
5517 if (num_args == -1)
5518 {
5519 as_bad (_("syntax error"));
5520 return;
5521 }
5522
5523 if (xg_translate_idioms (&opname, &num_args, arg_strings))
5524 return;
5525
5526 /* Check for an underbar prefix. */
5527 if (*opname == '_')
5528 {
5529 has_underbar = TRUE;
5530 opname += 1;
5531 }
5532
5533 orig_insn.insn_type = ITYPE_INSN;
5534 orig_insn.ntok = 0;
43cd72b9 5535 orig_insn.is_specific_opcode = (has_underbar || !use_transform ());
e0001a05 5536 orig_insn.opcode = xtensa_opcode_lookup (isa, opname);
28dbbc02 5537
2b0f3761 5538 /* Special case: Check for "CALLXn.TLS" pseudo op. If found, grab its
28dbbc02
BW
5539 extra argument and set the opcode to "CALLXn". */
5540 if (orig_insn.opcode == XTENSA_UNDEFINED
5541 && strncasecmp (opname, "callx", 5) == 0)
5542 {
5543 unsigned long window_size;
5544 char *suffix;
5545
5546 window_size = strtoul (opname + 5, &suffix, 10);
5547 if (suffix != opname + 5
5548 && (window_size == 0
5549 || window_size == 4
5550 || window_size == 8
5551 || window_size == 12)
5552 && strcasecmp (suffix, ".tls") == 0)
5553 {
5554 switch (window_size)
5555 {
5556 case 0: orig_insn.opcode = xtensa_callx0_opcode; break;
5557 case 4: orig_insn.opcode = xtensa_callx4_opcode; break;
5558 case 8: orig_insn.opcode = xtensa_callx8_opcode; break;
5559 case 12: orig_insn.opcode = xtensa_callx12_opcode; break;
5560 }
5561
5562 if (num_args != 2)
5563 as_bad (_("wrong number of operands for '%s'"), opname);
5564 else
5565 {
5566 bfd_reloc_code_real_type reloc;
5567 char *old_input_line_pointer;
19e8f41a 5568 expressionS *tok = &orig_insn.extra_arg;
28dbbc02
BW
5569
5570 old_input_line_pointer = input_line_pointer;
5571 input_line_pointer = arg_strings[num_args - 1];
5572
87975d2a 5573 expression (tok);
28dbbc02
BW
5574 if (tok->X_op == O_symbol
5575 && ((reloc = xtensa_elf_suffix (&input_line_pointer, tok))
5576 == BFD_RELOC_XTENSA_TLS_CALL))
5577 tok->X_op = map_suffix_reloc_to_operator (reloc);
5578 else
5579 as_bad (_("bad relocation expression for '%s'"), opname);
5580
5581 input_line_pointer = old_input_line_pointer;
5582 num_args -= 1;
5583 }
5584 }
5585 }
5586
2b0f3761 5587 /* Special case: Check for "j.l" pseudo op. */
19e8f41a
BW
5588 if (orig_insn.opcode == XTENSA_UNDEFINED
5589 && strncasecmp (opname, "j.l", 3) == 0)
5590 {
5591 if (num_args != 2)
5592 as_bad (_("wrong number of operands for '%s'"), opname);
5593 else
5594 {
5595 char *old_input_line_pointer;
5596 expressionS *tok = &orig_insn.extra_arg;
5597
5598 old_input_line_pointer = input_line_pointer;
5599 input_line_pointer = arg_strings[num_args - 1];
5600
5601 expression_maybe_register (xtensa_jx_opcode, 0, tok);
5602 input_line_pointer = old_input_line_pointer;
5603
5604 num_args -= 1;
5605 orig_insn.opcode = xtensa_j_opcode;
5606 }
5607 }
5608
e0001a05
NC
5609 if (orig_insn.opcode == XTENSA_UNDEFINED)
5610 {
43cd72b9
BW
5611 xtensa_format fmt = xtensa_format_lookup (isa, opname);
5612 if (fmt == XTENSA_UNDEFINED)
5613 {
5614 as_bad (_("unknown opcode or format name '%s'"), opname);
5615 error_reset_cur_vinsn ();
5616 return;
5617 }
5618 if (!cur_vinsn.inside_bundle)
5619 {
5620 as_bad (_("format names only valid inside bundles"));
5621 error_reset_cur_vinsn ();
5622 return;
5623 }
5624 if (cur_vinsn.format != XTENSA_UNDEFINED)
5625 as_warn (_("multiple formats specified for one bundle; using '%s'"),
5626 opname);
5627 cur_vinsn.format = fmt;
5628 free (has_underbar ? opname - 1 : opname);
5629 error_reset_cur_vinsn ();
e0001a05
NC
5630 return;
5631 }
5632
e0001a05
NC
5633 /* Parse the arguments. */
5634 if (parse_arguments (&orig_insn, num_args, arg_strings))
5635 {
5636 as_bad (_("syntax error"));
43cd72b9 5637 error_reset_cur_vinsn ();
e0001a05
NC
5638 return;
5639 }
5640
5641 /* Free the opcode and argument strings, now that they've been parsed. */
5642 free (has_underbar ? opname - 1 : opname);
5643 opname = 0;
5644 while (num_args-- > 0)
5645 free (arg_strings[num_args]);
5646
43cd72b9
BW
5647 /* Get expressions for invisible operands. */
5648 if (get_invisible_operands (&orig_insn))
5649 {
5650 error_reset_cur_vinsn ();
5651 return;
5652 }
5653
e0001a05
NC
5654 /* Check for the right number and type of arguments. */
5655 if (tinsn_check_arguments (&orig_insn))
e0001a05 5656 {
43cd72b9
BW
5657 error_reset_cur_vinsn ();
5658 return;
e0001a05
NC
5659 }
5660
b224e962
BW
5661 /* Record the line number for each TInsn, because a FLIX bundle may be
5662 spread across multiple input lines and individual instructions may be
5663 moved around in some cases. */
5664 orig_insn.loc_directive_seen = dwarf2_loc_directive_seen;
5665 dwarf2_where (&orig_insn.debug_line);
5666 dwarf2_consume_line_info ();
c138bc38 5667
43cd72b9
BW
5668 xg_add_branch_and_loop_targets (&orig_insn);
5669
431ad2d0
BW
5670 /* Check that immediate value for ENTRY is >= 16. */
5671 if (orig_insn.opcode == xtensa_entry_opcode && orig_insn.ntok >= 3)
e0001a05 5672 {
431ad2d0
BW
5673 expressionS *exp = &orig_insn.tok[2];
5674 if (exp->X_op == O_constant && exp->X_add_number < 16)
5675 as_warn (_("entry instruction with stack decrement < 16"));
e0001a05
NC
5676 }
5677
e0001a05 5678 /* Finish it off:
43cd72b9
BW
5679 assemble_tokens (opcode, tok, ntok);
5680 expand the tokens from the orig_insn into the
5681 stack of instructions that will not expand
e0001a05 5682 unless required at relaxation time. */
e0001a05 5683
43cd72b9
BW
5684 if (!cur_vinsn.inside_bundle)
5685 emit_single_op (&orig_insn);
5686 else /* We are inside a bundle. */
e0001a05 5687 {
43cd72b9
BW
5688 cur_vinsn.slots[cur_vinsn.num_slots] = orig_insn;
5689 cur_vinsn.num_slots++;
5690 if (*input_line_pointer == '}'
5691 || *(input_line_pointer - 1) == '}'
5692 || *(input_line_pointer - 2) == '}')
5693 finish_vinsn (&cur_vinsn);
e0001a05
NC
5694 }
5695
43cd72b9
BW
5696 /* We've just emitted a new instruction so clear the list of labels. */
5697 xtensa_clear_insn_labels ();
a82c7d90
DW
5698
5699 xtensa_check_frag_count ();
e0001a05
NC
5700}
5701
5702
43cd72b9 5703/* HANDLE_ALIGN hook */
e0001a05 5704
43cd72b9
BW
5705/* For a .align directive, we mark the previous block with the alignment
5706 information. This will be placed in the object file in the
5707 property section corresponding to this section. */
e0001a05 5708
43cd72b9 5709void
7fa3d080 5710xtensa_handle_align (fragS *fragP)
43cd72b9
BW
5711{
5712 if (linkrelax
b08b5071 5713 && ! fragP->tc_frag_data.is_literal
43cd72b9
BW
5714 && (fragP->fr_type == rs_align
5715 || fragP->fr_type == rs_align_code)
43cd72b9
BW
5716 && fragP->fr_offset > 0
5717 && now_seg != bss_section)
e0001a05 5718 {
43cd72b9
BW
5719 fragP->tc_frag_data.is_align = TRUE;
5720 fragP->tc_frag_data.alignment = fragP->fr_offset;
e0001a05
NC
5721 }
5722
43cd72b9 5723 if (fragP->fr_type == rs_align_test)
e0001a05 5724 {
43cd72b9
BW
5725 int count;
5726 count = fragP->fr_next->fr_address - fragP->fr_address - fragP->fr_fix;
5727 if (count != 0)
c138bc38 5728 as_bad_where (fragP->fr_file, fragP->fr_line,
43cd72b9 5729 _("unaligned entry instruction"));
e0001a05 5730 }
99ded152
BW
5731
5732 if (linkrelax && fragP->fr_type == rs_org)
5733 fragP->fr_subtype = RELAX_ORG;
e0001a05 5734}
43cd72b9 5735
e0001a05
NC
5736
5737/* TC_FRAG_INIT hook */
5738
5739void
7fa3d080 5740xtensa_frag_init (fragS *frag)
e0001a05 5741{
43cd72b9 5742 xtensa_set_frag_assembly_state (frag);
e0001a05
NC
5743}
5744
5745
5746symbolS *
7fa3d080 5747md_undefined_symbol (char *name ATTRIBUTE_UNUSED)
e0001a05
NC
5748{
5749 return NULL;
5750}
5751
5752
5753/* Round up a section size to the appropriate boundary. */
5754
5755valueT
7fa3d080 5756md_section_align (segT segment ATTRIBUTE_UNUSED, valueT size)
e0001a05
NC
5757{
5758 return size; /* Byte alignment is fine. */
5759}
5760
5761
5762long
7fa3d080 5763md_pcrel_from (fixS *fixP)
e0001a05
NC
5764{
5765 char *insn_p;
5766 static xtensa_insnbuf insnbuf = NULL;
43cd72b9 5767 static xtensa_insnbuf slotbuf = NULL;
e0001a05 5768 int opnum;
43cd72b9 5769 uint32 opnd_value;
e0001a05 5770 xtensa_opcode opcode;
43cd72b9
BW
5771 xtensa_format fmt;
5772 int slot;
e0001a05
NC
5773 xtensa_isa isa = xtensa_default_isa;
5774 valueT addr = fixP->fx_where + fixP->fx_frag->fr_address;
43cd72b9 5775 bfd_boolean alt_reloc;
e0001a05 5776
e0001a05 5777 if (fixP->fx_r_type == BFD_RELOC_XTENSA_ASM_EXPAND)
30f725a1 5778 return 0;
e0001a05 5779
1bbb5f21
BW
5780 if (fixP->fx_r_type == BFD_RELOC_32_PCREL)
5781 return addr;
5782
e0001a05 5783 if (!insnbuf)
43cd72b9
BW
5784 {
5785 insnbuf = xtensa_insnbuf_alloc (isa);
5786 slotbuf = xtensa_insnbuf_alloc (isa);
5787 }
e0001a05
NC
5788
5789 insn_p = &fixP->fx_frag->fr_literal[fixP->fx_where];
d77b99c9 5790 xtensa_insnbuf_from_chars (isa, insnbuf, (unsigned char *) insn_p, 0);
43cd72b9
BW
5791 fmt = xtensa_format_decode (isa, insnbuf);
5792
5793 if (fmt == XTENSA_UNDEFINED)
5794 as_fatal (_("bad instruction format"));
5795
5796 if (decode_reloc (fixP->fx_r_type, &slot, &alt_reloc) != 0)
5797 as_fatal (_("invalid relocation"));
5798
5799 xtensa_format_get_slot (isa, fmt, slot, insnbuf, slotbuf);
5800 opcode = xtensa_opcode_decode (isa, fmt, slot, slotbuf);
5801
30f725a1
BW
5802 /* Check for "alternate" relocations (operand not specified). None
5803 of the current uses for these are really PC-relative. */
43cd72b9
BW
5804 if (alt_reloc || opcode == xtensa_const16_opcode)
5805 {
5806 if (opcode != xtensa_l32r_opcode
5807 && opcode != xtensa_const16_opcode)
5808 as_fatal (_("invalid relocation for '%s' instruction"),
5809 xtensa_opcode_name (isa, opcode));
30f725a1 5810 return 0;
e0001a05
NC
5811 }
5812
43cd72b9
BW
5813 opnum = get_relaxable_immed (opcode);
5814 opnd_value = 0;
5815 if (xtensa_operand_is_PCrelative (isa, opcode, opnum) != 1
5816 || xtensa_operand_do_reloc (isa, opcode, opnum, &opnd_value, addr))
e0001a05
NC
5817 {
5818 as_bad_where (fixP->fx_file,
5819 fixP->fx_line,
5820 _("invalid relocation for operand %d of '%s'"),
5821 opnum, xtensa_opcode_name (isa, opcode));
30f725a1 5822 return 0;
e0001a05 5823 }
43cd72b9
BW
5824 return 0 - opnd_value;
5825}
5826
5827
5828/* TC_FORCE_RELOCATION hook */
5829
5830int
7fa3d080 5831xtensa_force_relocation (fixS *fix)
43cd72b9
BW
5832{
5833 switch (fix->fx_r_type)
30f725a1
BW
5834 {
5835 case BFD_RELOC_XTENSA_ASM_EXPAND:
43cd72b9
BW
5836 case BFD_RELOC_XTENSA_SLOT0_ALT:
5837 case BFD_RELOC_XTENSA_SLOT1_ALT:
5838 case BFD_RELOC_XTENSA_SLOT2_ALT:
5839 case BFD_RELOC_XTENSA_SLOT3_ALT:
5840 case BFD_RELOC_XTENSA_SLOT4_ALT:
5841 case BFD_RELOC_XTENSA_SLOT5_ALT:
5842 case BFD_RELOC_XTENSA_SLOT6_ALT:
5843 case BFD_RELOC_XTENSA_SLOT7_ALT:
5844 case BFD_RELOC_XTENSA_SLOT8_ALT:
5845 case BFD_RELOC_XTENSA_SLOT9_ALT:
5846 case BFD_RELOC_XTENSA_SLOT10_ALT:
5847 case BFD_RELOC_XTENSA_SLOT11_ALT:
5848 case BFD_RELOC_XTENSA_SLOT12_ALT:
5849 case BFD_RELOC_XTENSA_SLOT13_ALT:
5850 case BFD_RELOC_XTENSA_SLOT14_ALT:
43cd72b9
BW
5851 return 1;
5852 default:
5853 break;
e0001a05
NC
5854 }
5855
43cd72b9
BW
5856 if (linkrelax && fix->fx_addsy
5857 && relaxable_section (S_GET_SEGMENT (fix->fx_addsy)))
5858 return 1;
5859
5860 return generic_force_reloc (fix);
5861}
5862
5863
30f725a1
BW
5864/* TC_VALIDATE_FIX_SUB hook */
5865
5866int
5867xtensa_validate_fix_sub (fixS *fix)
5868{
5869 segT add_symbol_segment, sub_symbol_segment;
5870
5871 /* The difference of two symbols should be resolved by the assembler when
5872 linkrelax is not set. If the linker may relax the section containing
5873 the symbols, then an Xtensa DIFF relocation must be generated so that
5874 the linker knows to adjust the difference value. */
5875 if (!linkrelax || fix->fx_addsy == NULL)
5876 return 0;
5877
5878 /* Make sure both symbols are in the same segment, and that segment is
5879 "normal" and relaxable. If the segment is not "normal", then the
5880 fix is not valid. If the segment is not "relaxable", then the fix
5881 should have been handled earlier. */
5882 add_symbol_segment = S_GET_SEGMENT (fix->fx_addsy);
5883 if (! SEG_NORMAL (add_symbol_segment) ||
5884 ! relaxable_section (add_symbol_segment))
5885 return 0;
5886 sub_symbol_segment = S_GET_SEGMENT (fix->fx_subsy);
5887 return (sub_symbol_segment == add_symbol_segment);
5888}
5889
5890
43cd72b9
BW
5891/* NO_PSEUDO_DOT hook */
5892
5893/* This function has nothing to do with pseudo dots, but this is the
5894 nearest macro to where the check needs to take place. FIXME: This
5895 seems wrong. */
5896
5897bfd_boolean
7fa3d080 5898xtensa_check_inside_bundle (void)
43cd72b9
BW
5899{
5900 if (cur_vinsn.inside_bundle && input_line_pointer[-1] == '.')
5901 as_bad (_("directives are not valid inside bundles"));
5902
5903 /* This function must always return FALSE because it is called via a
5904 macro that has nothing to do with bundling. */
5905 return FALSE;
e0001a05
NC
5906}
5907
5908
43cd72b9 5909/* md_elf_section_change_hook */
e0001a05
NC
5910
5911void
7fa3d080 5912xtensa_elf_section_change_hook (void)
e0001a05 5913{
43cd72b9
BW
5914 /* Set up the assembly state. */
5915 if (!frag_now->tc_frag_data.is_assembly_state_set)
5916 xtensa_set_frag_assembly_state (frag_now);
e0001a05
NC
5917}
5918
5919
5920/* tc_fix_adjustable hook */
5921
5922bfd_boolean
7fa3d080 5923xtensa_fix_adjustable (fixS *fixP)
e0001a05
NC
5924{
5925 /* We need the symbol name for the VTABLE entries. */
5926 if (fixP->fx_r_type == BFD_RELOC_VTABLE_INHERIT
5927 || fixP->fx_r_type == BFD_RELOC_VTABLE_ENTRY)
5928 return 0;
5929
5930 return 1;
5931}
5932
5933
6a7eedfe
BW
5934/* tc_symbol_new_hook */
5935
5936symbolS *expr_symbols = NULL;
5937
3739860c 5938void
6a7eedfe
BW
5939xtensa_symbol_new_hook (symbolS *sym)
5940{
fb227da0 5941 if (is_leb128_expr && S_GET_SEGMENT (sym) == expr_section)
6a7eedfe
BW
5942 {
5943 symbol_get_tc (sym)->next_expr_symbol = expr_symbols;
5944 expr_symbols = sym;
5945 }
5946}
5947
5948
e0001a05 5949void
55cf6793 5950md_apply_fix (fixS *fixP, valueT *valP, segT seg)
e0001a05 5951{
30f725a1 5952 char *const fixpos = fixP->fx_frag->fr_literal + fixP->fx_where;
d47d412e 5953 valueT val = 0;
30f725a1 5954
e7da6241
BW
5955 /* Subtracted symbols are only allowed for a few relocation types, and
5956 unless linkrelax is enabled, they should not make it to this point. */
5957 if (fixP->fx_subsy && !(linkrelax && (fixP->fx_r_type == BFD_RELOC_32
5958 || fixP->fx_r_type == BFD_RELOC_16
5959 || fixP->fx_r_type == BFD_RELOC_8)))
5960 as_bad_where (fixP->fx_file, fixP->fx_line, _("expression too complex"));
5961
30f725a1 5962 switch (fixP->fx_r_type)
e0001a05 5963 {
1bbb5f21 5964 case BFD_RELOC_32_PCREL:
30f725a1
BW
5965 case BFD_RELOC_32:
5966 case BFD_RELOC_16:
5967 case BFD_RELOC_8:
e7da6241 5968 if (fixP->fx_subsy)
30f725a1
BW
5969 {
5970 switch (fixP->fx_r_type)
5971 {
5972 case BFD_RELOC_8:
5973 fixP->fx_r_type = BFD_RELOC_XTENSA_DIFF8;
ea173078 5974 fixP->fx_signed = 0;
30f725a1
BW
5975 break;
5976 case BFD_RELOC_16:
5977 fixP->fx_r_type = BFD_RELOC_XTENSA_DIFF16;
ea173078 5978 fixP->fx_signed = 0;
30f725a1
BW
5979 break;
5980 case BFD_RELOC_32:
5981 fixP->fx_r_type = BFD_RELOC_XTENSA_DIFF32;
ea173078 5982 fixP->fx_signed = 0;
30f725a1
BW
5983 break;
5984 default:
5985 break;
5986 }
e0001a05 5987
30f725a1
BW
5988 val = (S_GET_VALUE (fixP->fx_addsy) + fixP->fx_offset
5989 - S_GET_VALUE (fixP->fx_subsy));
5990
5991 /* The difference value gets written out, and the DIFF reloc
5992 identifies the address of the subtracted symbol (i.e., the one
5993 with the lowest address). */
5994 *valP = val;
5995 fixP->fx_offset -= val;
5996 fixP->fx_subsy = NULL;
5997 }
5998 else if (! fixP->fx_addsy)
e0001a05 5999 {
30f725a1 6000 val = *valP;
e0001a05 6001 fixP->fx_done = 1;
30f725a1 6002 }
d47d412e
BW
6003 /* fall through */
6004
6005 case BFD_RELOC_XTENSA_PLT:
30f725a1
BW
6006 md_number_to_chars (fixpos, val, fixP->fx_size);
6007 fixP->fx_no_overflow = 0; /* Use the standard overflow check. */
6008 break;
e0001a05 6009
28dbbc02
BW
6010 case BFD_RELOC_XTENSA_TLSDESC_FN:
6011 case BFD_RELOC_XTENSA_TLSDESC_ARG:
6012 case BFD_RELOC_XTENSA_TLS_TPOFF:
6013 case BFD_RELOC_XTENSA_TLS_DTPOFF:
6014 S_SET_THREAD_LOCAL (fixP->fx_addsy);
6015 md_number_to_chars (fixpos, 0, fixP->fx_size);
6016 fixP->fx_no_overflow = 0; /* Use the standard overflow check. */
6017 break;
6018
30f725a1
BW
6019 case BFD_RELOC_XTENSA_SLOT0_OP:
6020 case BFD_RELOC_XTENSA_SLOT1_OP:
6021 case BFD_RELOC_XTENSA_SLOT2_OP:
6022 case BFD_RELOC_XTENSA_SLOT3_OP:
6023 case BFD_RELOC_XTENSA_SLOT4_OP:
6024 case BFD_RELOC_XTENSA_SLOT5_OP:
6025 case BFD_RELOC_XTENSA_SLOT6_OP:
6026 case BFD_RELOC_XTENSA_SLOT7_OP:
6027 case BFD_RELOC_XTENSA_SLOT8_OP:
6028 case BFD_RELOC_XTENSA_SLOT9_OP:
6029 case BFD_RELOC_XTENSA_SLOT10_OP:
6030 case BFD_RELOC_XTENSA_SLOT11_OP:
6031 case BFD_RELOC_XTENSA_SLOT12_OP:
6032 case BFD_RELOC_XTENSA_SLOT13_OP:
6033 case BFD_RELOC_XTENSA_SLOT14_OP:
6034 if (linkrelax)
6035 {
6036 /* Write the tentative value of a PC-relative relocation to a
6037 local symbol into the instruction. The value will be ignored
6038 by the linker, and it makes the object file disassembly
6039 readable when all branch targets are encoded in relocations. */
6040
9c2799c2 6041 gas_assert (fixP->fx_addsy);
20ee54e8 6042 if (S_GET_SEGMENT (fixP->fx_addsy) == seg
30f725a1
BW
6043 && !S_FORCE_RELOC (fixP->fx_addsy, 1))
6044 {
6045 val = (S_GET_VALUE (fixP->fx_addsy) + fixP->fx_offset
6046 - md_pcrel_from (fixP));
6047 (void) xg_apply_fix_value (fixP, val);
6048 }
6049 }
6050 else if (! fixP->fx_addsy)
6051 {
6052 val = *valP;
6053 if (xg_apply_fix_value (fixP, val))
6054 fixP->fx_done = 1;
6055 }
6056 break;
e0001a05 6057
30f725a1 6058 case BFD_RELOC_XTENSA_ASM_EXPAND:
28dbbc02
BW
6059 case BFD_RELOC_XTENSA_TLS_FUNC:
6060 case BFD_RELOC_XTENSA_TLS_ARG:
6061 case BFD_RELOC_XTENSA_TLS_CALL:
30f725a1
BW
6062 case BFD_RELOC_XTENSA_SLOT0_ALT:
6063 case BFD_RELOC_XTENSA_SLOT1_ALT:
6064 case BFD_RELOC_XTENSA_SLOT2_ALT:
6065 case BFD_RELOC_XTENSA_SLOT3_ALT:
6066 case BFD_RELOC_XTENSA_SLOT4_ALT:
6067 case BFD_RELOC_XTENSA_SLOT5_ALT:
6068 case BFD_RELOC_XTENSA_SLOT6_ALT:
6069 case BFD_RELOC_XTENSA_SLOT7_ALT:
6070 case BFD_RELOC_XTENSA_SLOT8_ALT:
6071 case BFD_RELOC_XTENSA_SLOT9_ALT:
6072 case BFD_RELOC_XTENSA_SLOT10_ALT:
6073 case BFD_RELOC_XTENSA_SLOT11_ALT:
6074 case BFD_RELOC_XTENSA_SLOT12_ALT:
6075 case BFD_RELOC_XTENSA_SLOT13_ALT:
6076 case BFD_RELOC_XTENSA_SLOT14_ALT:
6077 /* These all need to be resolved at link-time. Do nothing now. */
6078 break;
e0001a05 6079
30f725a1
BW
6080 case BFD_RELOC_VTABLE_INHERIT:
6081 case BFD_RELOC_VTABLE_ENTRY:
6082 fixP->fx_done = 0;
6083 break;
e0001a05 6084
30f725a1
BW
6085 default:
6086 as_bad (_("unhandled local relocation fix %s"),
6087 bfd_get_reloc_code_name (fixP->fx_r_type));
e0001a05
NC
6088 }
6089}
6090
6091
6d4af3c2 6092const char *
7fa3d080 6093md_atof (int type, char *litP, int *sizeP)
e0001a05 6094{
499ac353 6095 return ieee_md_atof (type, litP, sizeP, target_big_endian);
e0001a05
NC
6096}
6097
6098
6099int
7fa3d080 6100md_estimate_size_before_relax (fragS *fragP, segT seg ATTRIBUTE_UNUSED)
e0001a05 6101{
34e41783 6102 return total_frag_text_expansion (fragP);
e0001a05
NC
6103}
6104
6105
6106/* Translate internal representation of relocation info to BFD target
6107 format. */
6108
6109arelent *
30f725a1 6110tc_gen_reloc (asection *section ATTRIBUTE_UNUSED, fixS *fixp)
e0001a05
NC
6111{
6112 arelent *reloc;
6113
325801bd
TS
6114 reloc = XNEW (arelent);
6115 reloc->sym_ptr_ptr = XNEW (asymbol *);
e0001a05
NC
6116 *reloc->sym_ptr_ptr = symbol_get_bfdsym (fixp->fx_addsy);
6117 reloc->address = fixp->fx_frag->fr_address + fixp->fx_where;
6118
6119 /* Make sure none of our internal relocations make it this far.
6120 They'd better have been fully resolved by this point. */
9c2799c2 6121 gas_assert ((int) fixp->fx_r_type > 0);
e0001a05 6122
30f725a1 6123 reloc->addend = fixp->fx_offset;
43cd72b9 6124
e0001a05
NC
6125 reloc->howto = bfd_reloc_type_lookup (stdoutput, fixp->fx_r_type);
6126 if (reloc->howto == NULL)
6127 {
6128 as_bad_where (fixp->fx_file, fixp->fx_line,
6129 _("cannot represent `%s' relocation in object file"),
6130 bfd_get_reloc_code_name (fixp->fx_r_type));
43cd72b9
BW
6131 free (reloc->sym_ptr_ptr);
6132 free (reloc);
e0001a05
NC
6133 return NULL;
6134 }
6135
6136 if (!fixp->fx_pcrel != !reloc->howto->pc_relative)
1bbb5f21 6137 as_fatal (_("internal error; cannot generate `%s' relocation"),
43cd72b9 6138 bfd_get_reloc_code_name (fixp->fx_r_type));
e0001a05 6139
e0001a05
NC
6140 return reloc;
6141}
6142
7fa3d080
BW
6143\f
6144/* Checks for resource conflicts between instructions. */
6145
c138bc38
BW
6146/* The func unit stuff could be implemented as bit-vectors rather
6147 than the iterative approach here. If it ends up being too
7fa3d080
BW
6148 slow, we will switch it. */
6149
c138bc38 6150resource_table *
7fa3d080
BW
6151new_resource_table (void *data,
6152 int cycles,
6153 int nu,
6154 unit_num_copies_func uncf,
6155 opcode_num_units_func onuf,
6156 opcode_funcUnit_use_unit_func ouuf,
6157 opcode_funcUnit_use_stage_func ousf)
6158{
6159 int i;
325801bd 6160 resource_table *rt = XNEW (resource_table);
7fa3d080
BW
6161 rt->data = data;
6162 rt->cycles = cycles;
6163 rt->allocated_cycles = cycles;
6164 rt->num_units = nu;
6165 rt->unit_num_copies = uncf;
6166 rt->opcode_num_units = onuf;
6167 rt->opcode_unit_use = ouuf;
6168 rt->opcode_unit_stage = ousf;
6169
add39d23 6170 rt->units = XCNEWVEC (unsigned char *, cycles);
7fa3d080 6171 for (i = 0; i < cycles; i++)
add39d23 6172 rt->units[i] = XCNEWVEC (unsigned char, nu);
7fa3d080
BW
6173
6174 return rt;
6175}
6176
6177
c138bc38 6178void
7fa3d080
BW
6179clear_resource_table (resource_table *rt)
6180{
6181 int i, j;
6182 for (i = 0; i < rt->allocated_cycles; i++)
6183 for (j = 0; j < rt->num_units; j++)
6184 rt->units[i][j] = 0;
6185}
6186
6187
6188/* We never shrink it, just fake it into thinking so. */
6189
c138bc38 6190void
7fa3d080
BW
6191resize_resource_table (resource_table *rt, int cycles)
6192{
6193 int i, old_cycles;
6194
6195 rt->cycles = cycles;
6196 if (cycles <= rt->allocated_cycles)
6197 return;
6198
6199 old_cycles = rt->allocated_cycles;
6200 rt->allocated_cycles = cycles;
6201
325801bd 6202 rt->units = XRESIZEVEC (unsigned char *, rt->units, rt->allocated_cycles);
7fa3d080 6203 for (i = 0; i < old_cycles; i++)
325801bd 6204 rt->units[i] = XRESIZEVEC (unsigned char, rt->units[i], rt->num_units);
7fa3d080 6205 for (i = old_cycles; i < cycles; i++)
add39d23 6206 rt->units[i] = XCNEWVEC (unsigned char, rt->num_units);
7fa3d080
BW
6207}
6208
6209
c138bc38 6210bfd_boolean
7fa3d080
BW
6211resources_available (resource_table *rt, xtensa_opcode opcode, int cycle)
6212{
6213 int i;
6214 int uses = (rt->opcode_num_units) (rt->data, opcode);
6215
c138bc38 6216 for (i = 0; i < uses; i++)
7fa3d080
BW
6217 {
6218 xtensa_funcUnit unit = (rt->opcode_unit_use) (rt->data, opcode, i);
6219 int stage = (rt->opcode_unit_stage) (rt->data, opcode, i);
6220 int copies_in_use = rt->units[stage + cycle][unit];
6221 int copies = (rt->unit_num_copies) (rt->data, unit);
6222 if (copies_in_use >= copies)
6223 return FALSE;
6224 }
6225 return TRUE;
6226}
7fa3d080 6227
c138bc38
BW
6228
6229void
7fa3d080
BW
6230reserve_resources (resource_table *rt, xtensa_opcode opcode, int cycle)
6231{
6232 int i;
6233 int uses = (rt->opcode_num_units) (rt->data, opcode);
6234
c138bc38 6235 for (i = 0; i < uses; i++)
7fa3d080
BW
6236 {
6237 xtensa_funcUnit unit = (rt->opcode_unit_use) (rt->data, opcode, i);
6238 int stage = (rt->opcode_unit_stage) (rt->data, opcode, i);
c138bc38
BW
6239 /* Note that this allows resources to be oversubscribed. That's
6240 essential to the way the optional scheduler works.
7fa3d080
BW
6241 resources_available reports when a resource is over-subscribed,
6242 so it's easy to tell. */
6243 rt->units[stage + cycle][unit]++;
6244 }
6245}
6246
6247
c138bc38 6248void
7fa3d080
BW
6249release_resources (resource_table *rt, xtensa_opcode opcode, int cycle)
6250{
6251 int i;
6252 int uses = (rt->opcode_num_units) (rt->data, opcode);
6253
c138bc38 6254 for (i = 0; i < uses; i++)
7fa3d080
BW
6255 {
6256 xtensa_funcUnit unit = (rt->opcode_unit_use) (rt->data, opcode, i);
6257 int stage = (rt->opcode_unit_stage) (rt->data, opcode, i);
9c2799c2 6258 gas_assert (rt->units[stage + cycle][unit] > 0);
7fa3d080 6259 rt->units[stage + cycle][unit]--;
7fa3d080
BW
6260 }
6261}
c138bc38 6262
7fa3d080
BW
6263
6264/* Wrapper functions make parameterized resource reservation
6265 more convenient. */
6266
c138bc38 6267int
7fa3d080
BW
6268opcode_funcUnit_use_unit (void *data, xtensa_opcode opcode, int idx)
6269{
6270 xtensa_funcUnit_use *use = xtensa_opcode_funcUnit_use (data, opcode, idx);
c138bc38 6271 return use->unit;
7fa3d080
BW
6272}
6273
6274
c138bc38 6275int
7fa3d080
BW
6276opcode_funcUnit_use_stage (void *data, xtensa_opcode opcode, int idx)
6277{
6278 xtensa_funcUnit_use *use = xtensa_opcode_funcUnit_use (data, opcode, idx);
6279 return use->stage;
6280}
6281
6282
6283/* Note that this function does not check issue constraints, but
6284 solely whether the hardware is available to execute the given
c138bc38 6285 instructions together. It also doesn't check if the tinsns
7fa3d080 6286 write the same state, or access the same tieports. That is
a1ace8d8 6287 checked by check_t1_t2_reads_and_writes. */
7fa3d080
BW
6288
6289static bfd_boolean
6290resources_conflict (vliw_insn *vinsn)
6291{
6292 int i;
6293 static resource_table *rt = NULL;
6294
6295 /* This is the most common case by far. Optimize it. */
6296 if (vinsn->num_slots == 1)
6297 return FALSE;
43cd72b9 6298
c138bc38 6299 if (rt == NULL)
7fa3d080
BW
6300 {
6301 xtensa_isa isa = xtensa_default_isa;
6302 rt = new_resource_table
77cba8a3 6303 (isa, xtensa_num_pipe_stages,
7fa3d080
BW
6304 xtensa_isa_num_funcUnits (isa),
6305 (unit_num_copies_func) xtensa_funcUnit_num_copies,
6306 (opcode_num_units_func) xtensa_opcode_num_funcUnit_uses,
6307 opcode_funcUnit_use_unit,
6308 opcode_funcUnit_use_stage);
6309 }
43cd72b9 6310
7fa3d080 6311 clear_resource_table (rt);
43cd72b9 6312
7fa3d080
BW
6313 for (i = 0; i < vinsn->num_slots; i++)
6314 {
6315 if (!resources_available (rt, vinsn->slots[i].opcode, 0))
6316 return TRUE;
6317 reserve_resources (rt, vinsn->slots[i].opcode, 0);
6318 }
e0001a05 6319
7fa3d080
BW
6320 return FALSE;
6321}
e0001a05 6322
7fa3d080
BW
6323\f
6324/* finish_vinsn, emit_single_op and helper functions. */
e0001a05 6325
7fa3d080
BW
6326static bfd_boolean find_vinsn_conflicts (vliw_insn *);
6327static xtensa_format xg_find_narrowest_format (vliw_insn *);
7fa3d080 6328static void xg_assemble_vliw_tokens (vliw_insn *);
e0001a05
NC
6329
6330
43cd72b9
BW
6331/* We have reached the end of a bundle; emit into the frag. */
6332
e0001a05 6333static void
7fa3d080 6334finish_vinsn (vliw_insn *vinsn)
e0001a05 6335{
43cd72b9
BW
6336 IStack slotstack;
6337 int i;
bf3d1399 6338 int slots;
e0001a05 6339
43cd72b9 6340 if (find_vinsn_conflicts (vinsn))
a1ace8d8
BW
6341 {
6342 xg_clear_vinsn (vinsn);
6343 return;
6344 }
43cd72b9
BW
6345
6346 /* First, find a format that works. */
6347 if (vinsn->format == XTENSA_UNDEFINED)
6348 vinsn->format = xg_find_narrowest_format (vinsn);
6349
bf3d1399
AM
6350 slots = xtensa_format_num_slots (xtensa_default_isa, vinsn->format);
6351 if (slots > 1
19fc3723
SA
6352 && produce_flix == FLIX_NONE)
6353 {
6354 as_bad (_("The option \"--no-allow-flix\" prohibits multi-slot flix."));
6355 xg_clear_vinsn (vinsn);
6356 return;
6357 }
6358
43cd72b9
BW
6359 if (vinsn->format == XTENSA_UNDEFINED)
6360 {
3b4dbbbf 6361 as_bad (_("couldn't find a valid instruction format"));
43cd72b9
BW
6362 fprintf (stderr, _(" ops were: "));
6363 for (i = 0; i < vinsn->num_slots; i++)
6364 fprintf (stderr, _(" %s;"),
6365 xtensa_opcode_name (xtensa_default_isa,
6366 vinsn->slots[i].opcode));
6367 fprintf (stderr, _("\n"));
6368 xg_clear_vinsn (vinsn);
6369 return;
6370 }
6371
bf3d1399 6372 if (vinsn->num_slots != slots)
e0001a05 6373 {
bf3d1399
AM
6374 as_bad (_("mismatch for format '%s': #slots = %d, #opcodes = %d"),
6375 xtensa_format_name (xtensa_default_isa, vinsn->format),
6e98b342 6376 slots, vinsn->num_slots);
43cd72b9
BW
6377 xg_clear_vinsn (vinsn);
6378 return;
6379 }
e0001a05 6380
c138bc38 6381 if (resources_conflict (vinsn))
43cd72b9 6382 {
3b4dbbbf 6383 as_bad (_("illegal resource usage in bundle"));
43cd72b9
BW
6384 fprintf (stderr, " ops were: ");
6385 for (i = 0; i < vinsn->num_slots; i++)
6386 fprintf (stderr, " %s;",
6387 xtensa_opcode_name (xtensa_default_isa,
6388 vinsn->slots[i].opcode));
6389 fprintf (stderr, "\n");
6390 xg_clear_vinsn (vinsn);
6391 return;
6392 }
6393
6394 for (i = 0; i < vinsn->num_slots; i++)
6395 {
6396 if (vinsn->slots[i].opcode != XTENSA_UNDEFINED)
e0001a05 6397 {
43cd72b9
BW
6398 symbolS *lit_sym = NULL;
6399 int j;
6400 bfd_boolean e = FALSE;
6401 bfd_boolean saved_density = density_supported;
6402
6403 /* We don't want to narrow ops inside multi-slot bundles. */
6404 if (vinsn->num_slots > 1)
6405 density_supported = FALSE;
6406
6407 istack_init (&slotstack);
6408 if (vinsn->slots[i].opcode == xtensa_nop_opcode)
e0001a05 6409 {
43cd72b9
BW
6410 vinsn->slots[i].opcode =
6411 xtensa_format_slot_nop_opcode (xtensa_default_isa,
6412 vinsn->format, i);
6413 vinsn->slots[i].ntok = 0;
6414 }
e0001a05 6415
43cd72b9
BW
6416 if (xg_expand_assembly_insn (&slotstack, &vinsn->slots[i]))
6417 {
6418 e = TRUE;
6419 continue;
e0001a05 6420 }
e0001a05 6421
43cd72b9 6422 density_supported = saved_density;
e0001a05 6423
43cd72b9
BW
6424 if (e)
6425 {
6426 xg_clear_vinsn (vinsn);
6427 return;
6428 }
e0001a05 6429
0fa77c95 6430 for (j = 0; j < slotstack.ninsn; j++)
43cd72b9
BW
6431 {
6432 TInsn *insn = &slotstack.insn[j];
6433 if (insn->insn_type == ITYPE_LITERAL)
6434 {
9c2799c2 6435 gas_assert (lit_sym == NULL);
43cd72b9
BW
6436 lit_sym = xg_assemble_literal (insn);
6437 }
6438 else
6439 {
9c2799c2 6440 gas_assert (insn->insn_type == ITYPE_INSN);
43cd72b9
BW
6441 if (lit_sym)
6442 xg_resolve_literals (insn, lit_sym);
0fa77c95
BW
6443 if (j != slotstack.ninsn - 1)
6444 emit_single_op (insn);
43cd72b9
BW
6445 }
6446 }
6447
6448 if (vinsn->num_slots > 1)
6449 {
6450 if (opcode_fits_format_slot
6451 (slotstack.insn[slotstack.ninsn - 1].opcode,
6452 vinsn->format, i))
6453 {
6454 vinsn->slots[i] = slotstack.insn[slotstack.ninsn - 1];
6455 }
6456 else
6457 {
b2d179be 6458 emit_single_op (&slotstack.insn[slotstack.ninsn - 1]);
43cd72b9
BW
6459 if (vinsn->format == XTENSA_UNDEFINED)
6460 vinsn->slots[i].opcode = xtensa_nop_opcode;
6461 else
c138bc38 6462 vinsn->slots[i].opcode
43cd72b9
BW
6463 = xtensa_format_slot_nop_opcode (xtensa_default_isa,
6464 vinsn->format, i);
6465
6466 vinsn->slots[i].ntok = 0;
6467 }
6468 }
6469 else
6470 {
6471 vinsn->slots[0] = slotstack.insn[slotstack.ninsn - 1];
6472 vinsn->format = XTENSA_UNDEFINED;
6473 }
6474 }
6475 }
6476
6477 /* Now check resource conflicts on the modified bundle. */
c138bc38 6478 if (resources_conflict (vinsn))
43cd72b9 6479 {
3b4dbbbf 6480 as_bad (_("illegal resource usage in bundle"));
43cd72b9
BW
6481 fprintf (stderr, " ops were: ");
6482 for (i = 0; i < vinsn->num_slots; i++)
6483 fprintf (stderr, " %s;",
6484 xtensa_opcode_name (xtensa_default_isa,
6485 vinsn->slots[i].opcode));
6486 fprintf (stderr, "\n");
6487 xg_clear_vinsn (vinsn);
6488 return;
6489 }
6490
6491 /* First, find a format that works. */
6492 if (vinsn->format == XTENSA_UNDEFINED)
6493 vinsn->format = xg_find_narrowest_format (vinsn);
6494
6495 xg_assemble_vliw_tokens (vinsn);
6496
6497 xg_clear_vinsn (vinsn);
a82c7d90
DW
6498
6499 xtensa_check_frag_count ();
43cd72b9
BW
6500}
6501
6502
6503/* Given an vliw instruction, what conflicts are there in register
6504 usage and in writes to states and queues?
6505
6506 This function does two things:
6507 1. Reports an error when a vinsn contains illegal combinations
6508 of writes to registers states or queues.
6509 2. Marks individual tinsns as not relaxable if the combination
6510 contains antidependencies.
6511
6512 Job 2 handles things like swap semantics in instructions that need
6513 to be relaxed. For example,
6514
6515 addi a0, a1, 100000
6516
6517 normally would be relaxed to
6518
6519 l32r a0, some_label
6520 add a0, a1, a0
6521
6522 _but_, if the above instruction is bundled with an a0 reader, e.g.,
6523
6524 { addi a0, a1, 10000 ; add a2, a0, a4 ; }
6525
6526 then we can't relax it into
6527
6528 l32r a0, some_label
6529 { add a0, a1, a0 ; add a2, a0, a4 ; }
6530
6531 because the value of a0 is trashed before the second add can read it. */
6532
7fa3d080
BW
6533static char check_t1_t2_reads_and_writes (TInsn *, TInsn *);
6534
43cd72b9 6535static bfd_boolean
7fa3d080 6536find_vinsn_conflicts (vliw_insn *vinsn)
43cd72b9
BW
6537{
6538 int i, j;
6539 int branches = 0;
6540 xtensa_isa isa = xtensa_default_isa;
6541
9c2799c2 6542 gas_assert (!past_xtensa_end);
43cd72b9
BW
6543
6544 for (i = 0 ; i < vinsn->num_slots; i++)
6545 {
6546 TInsn *op1 = &vinsn->slots[i];
6547 if (op1->is_specific_opcode)
6548 op1->keep_wide = TRUE;
6549 else
6550 op1->keep_wide = FALSE;
6551 }
6552
6553 for (i = 0 ; i < vinsn->num_slots; i++)
6554 {
6555 TInsn *op1 = &vinsn->slots[i];
6556
6557 if (xtensa_opcode_is_branch (isa, op1->opcode) == 1)
6558 branches++;
6559
6560 for (j = 0; j < vinsn->num_slots; j++)
6561 {
6562 if (i != j)
6563 {
6564 TInsn *op2 = &vinsn->slots[j];
6565 char conflict_type = check_t1_t2_reads_and_writes (op1, op2);
6566 switch (conflict_type)
6567 {
6568 case 'c':
6569 as_bad (_("opcodes '%s' (slot %d) and '%s' (slot %d) write the same register"),
6570 xtensa_opcode_name (isa, op1->opcode), i,
6571 xtensa_opcode_name (isa, op2->opcode), j);
6572 return TRUE;
6573 case 'd':
6574 as_bad (_("opcodes '%s' (slot %d) and '%s' (slot %d) write the same state"),
6575 xtensa_opcode_name (isa, op1->opcode), i,
6576 xtensa_opcode_name (isa, op2->opcode), j);
6577 return TRUE;
6578 case 'e':
53dfbcc7 6579 as_bad (_("opcodes '%s' (slot %d) and '%s' (slot %d) write the same port"),
43cd72b9
BW
6580 xtensa_opcode_name (isa, op1->opcode), i,
6581 xtensa_opcode_name (isa, op2->opcode), j);
6582 return TRUE;
6583 case 'f':
53dfbcc7 6584 as_bad (_("opcodes '%s' (slot %d) and '%s' (slot %d) both have volatile port accesses"),
43cd72b9
BW
6585 xtensa_opcode_name (isa, op1->opcode), i,
6586 xtensa_opcode_name (isa, op2->opcode), j);
6587 return TRUE;
6588 default:
6589 /* Everything is OK. */
6590 break;
6591 }
6592 op2->is_specific_opcode = (op2->is_specific_opcode
6593 || conflict_type == 'a');
6594 }
6595 }
6596 }
6597
6598 if (branches > 1)
6599 {
6600 as_bad (_("multiple branches or jumps in the same bundle"));
6601 return TRUE;
6602 }
6603
6604 return FALSE;
6605}
6606
6607
a1ace8d8 6608/* Check how the state used by t1 and t2 relate.
43cd72b9
BW
6609 Cases found are:
6610
6611 case A: t1 reads a register t2 writes (an antidependency within a bundle)
6612 case B: no relationship between what is read and written (both could
6613 read the same reg though)
c138bc38 6614 case C: t1 writes a register t2 writes (a register conflict within a
43cd72b9
BW
6615 bundle)
6616 case D: t1 writes a state that t2 also writes
6617 case E: t1 writes a tie queue that t2 also writes
a1ace8d8 6618 case F: two volatile queue accesses
43cd72b9
BW
6619*/
6620
6621static char
7fa3d080 6622check_t1_t2_reads_and_writes (TInsn *t1, TInsn *t2)
43cd72b9
BW
6623{
6624 xtensa_isa isa = xtensa_default_isa;
6625 xtensa_regfile t1_regfile, t2_regfile;
6626 int t1_reg, t2_reg;
6627 int t1_base_reg, t1_last_reg;
6628 int t2_base_reg, t2_last_reg;
6629 char t1_inout, t2_inout;
6630 int i, j;
6631 char conflict = 'b';
6632 int t1_states;
6633 int t2_states;
6634 int t1_interfaces;
6635 int t2_interfaces;
6636 bfd_boolean t1_volatile = FALSE;
6637 bfd_boolean t2_volatile = FALSE;
6638
6639 /* Check registers. */
6640 for (j = 0; j < t2->ntok; j++)
6641 {
6642 if (xtensa_operand_is_register (isa, t2->opcode, j) != 1)
6643 continue;
6644
6645 t2_regfile = xtensa_operand_regfile (isa, t2->opcode, j);
6646 t2_base_reg = t2->tok[j].X_add_number;
6647 t2_last_reg = t2_base_reg + xtensa_operand_num_regs (isa, t2->opcode, j);
6648
6649 for (i = 0; i < t1->ntok; i++)
6650 {
6651 if (xtensa_operand_is_register (isa, t1->opcode, i) != 1)
6652 continue;
6653
6654 t1_regfile = xtensa_operand_regfile (isa, t1->opcode, i);
6655
6656 if (t1_regfile != t2_regfile)
6657 continue;
6658
6659 t1_inout = xtensa_operand_inout (isa, t1->opcode, i);
6660 t2_inout = xtensa_operand_inout (isa, t2->opcode, j);
6661
6662 if (xtensa_operand_is_known_reg (isa, t1->opcode, i) == 0
6663 || xtensa_operand_is_known_reg (isa, t2->opcode, j) == 0)
6664 {
6665 if (t1_inout == 'm' || t1_inout == 'o'
6666 || t2_inout == 'm' || t2_inout == 'o')
6667 {
6668 conflict = 'a';
6669 continue;
6670 }
6671 }
6672
6673 t1_base_reg = t1->tok[i].X_add_number;
6674 t1_last_reg = (t1_base_reg
6675 + xtensa_operand_num_regs (isa, t1->opcode, i));
6676
6677 for (t1_reg = t1_base_reg; t1_reg < t1_last_reg; t1_reg++)
6678 {
6679 for (t2_reg = t2_base_reg; t2_reg < t2_last_reg; t2_reg++)
6680 {
6681 if (t1_reg != t2_reg)
6682 continue;
6683
6684 if (t2_inout == 'i' && (t1_inout == 'm' || t1_inout == 'o'))
7fa3d080
BW
6685 {
6686 conflict = 'a';
6687 continue;
6688 }
43cd72b9 6689
7fa3d080
BW
6690 if (t1_inout == 'i' && (t2_inout == 'm' || t2_inout == 'o'))
6691 {
6692 conflict = 'a';
6693 continue;
6694 }
43cd72b9 6695
7fa3d080
BW
6696 if (t1_inout != 'i' && t2_inout != 'i')
6697 return 'c';
6698 }
6699 }
6700 }
6701 }
43cd72b9 6702
7fa3d080
BW
6703 /* Check states. */
6704 t1_states = xtensa_opcode_num_stateOperands (isa, t1->opcode);
6705 t2_states = xtensa_opcode_num_stateOperands (isa, t2->opcode);
6706 for (j = 0; j < t2_states; j++)
43cd72b9 6707 {
7fa3d080
BW
6708 xtensa_state t2_so = xtensa_stateOperand_state (isa, t2->opcode, j);
6709 t2_inout = xtensa_stateOperand_inout (isa, t2->opcode, j);
6710 for (i = 0; i < t1_states; i++)
6711 {
6712 xtensa_state t1_so = xtensa_stateOperand_state (isa, t1->opcode, i);
6713 t1_inout = xtensa_stateOperand_inout (isa, t1->opcode, i);
1fa3cd83 6714 if (t1_so != t2_so || xtensa_state_is_shared_or (isa, t1_so) == 1)
7fa3d080 6715 continue;
43cd72b9 6716
7fa3d080
BW
6717 if (t2_inout == 'i' && (t1_inout == 'm' || t1_inout == 'o'))
6718 {
6719 conflict = 'a';
6720 continue;
6721 }
c138bc38 6722
7fa3d080
BW
6723 if (t1_inout == 'i' && (t2_inout == 'm' || t2_inout == 'o'))
6724 {
6725 conflict = 'a';
6726 continue;
6727 }
c138bc38 6728
7fa3d080
BW
6729 if (t1_inout != 'i' && t2_inout != 'i')
6730 return 'd';
c138bc38 6731 }
7fa3d080 6732 }
43cd72b9 6733
7fa3d080
BW
6734 /* Check tieports. */
6735 t1_interfaces = xtensa_opcode_num_interfaceOperands (isa, t1->opcode);
6736 t2_interfaces = xtensa_opcode_num_interfaceOperands (isa, t2->opcode);
c138bc38 6737 for (j = 0; j < t2_interfaces; j++)
43cd72b9 6738 {
7fa3d080
BW
6739 xtensa_interface t2_int
6740 = xtensa_interfaceOperand_interface (isa, t2->opcode, j);
a1ace8d8
BW
6741 int t2_class = xtensa_interface_class_id (isa, t2_int);
6742
53dfbcc7 6743 t2_inout = xtensa_interface_inout (isa, t2_int);
a1ace8d8 6744 if (xtensa_interface_has_side_effect (isa, t2_int) == 1)
7fa3d080 6745 t2_volatile = TRUE;
a1ace8d8 6746
7fa3d080
BW
6747 for (i = 0; i < t1_interfaces; i++)
6748 {
6749 xtensa_interface t1_int
6750 = xtensa_interfaceOperand_interface (isa, t1->opcode, j);
2eccd1b4 6751 int t1_class = xtensa_interface_class_id (isa, t1_int);
a1ace8d8 6752
53dfbcc7 6753 t1_inout = xtensa_interface_inout (isa, t1_int);
a1ace8d8 6754 if (xtensa_interface_has_side_effect (isa, t1_int) == 1)
7fa3d080 6755 t1_volatile = TRUE;
a1ace8d8
BW
6756
6757 if (t1_volatile && t2_volatile && (t1_class == t2_class))
6758 return 'f';
c138bc38 6759
7fa3d080
BW
6760 if (t1_int != t2_int)
6761 continue;
c138bc38 6762
7fa3d080
BW
6763 if (t2_inout == 'i' && t1_inout == 'o')
6764 {
6765 conflict = 'a';
6766 continue;
6767 }
c138bc38 6768
7fa3d080
BW
6769 if (t1_inout == 'i' && t2_inout == 'o')
6770 {
6771 conflict = 'a';
6772 continue;
6773 }
c138bc38 6774
7fa3d080
BW
6775 if (t1_inout != 'i' && t2_inout != 'i')
6776 return 'e';
6777 }
43cd72b9 6778 }
c138bc38 6779
7fa3d080 6780 return conflict;
43cd72b9
BW
6781}
6782
6783
6784static xtensa_format
7fa3d080 6785xg_find_narrowest_format (vliw_insn *vinsn)
43cd72b9
BW
6786{
6787 /* Right now we assume that the ops within the vinsn are properly
6788 ordered for the slots that the programmer wanted them in. In
6789 other words, we don't rearrange the ops in hopes of finding a
6790 better format. The scheduler handles that. */
6791
6792 xtensa_isa isa = xtensa_default_isa;
6793 xtensa_format format;
43cd72b9
BW
6794 xtensa_opcode nop_opcode = xtensa_nop_opcode;
6795
65738a7d
BW
6796 if (vinsn->num_slots == 1)
6797 return xg_get_single_format (vinsn->slots[0].opcode);
6798
43cd72b9
BW
6799 for (format = 0; format < xtensa_isa_num_formats (isa); format++)
6800 {
d8392fd9
SA
6801 vliw_insn v_copy;
6802 xg_copy_vinsn (&v_copy, vinsn);
43cd72b9
BW
6803 if (xtensa_format_num_slots (isa, format) == v_copy.num_slots)
6804 {
6805 int slot;
6806 int fit = 0;
6807 for (slot = 0; slot < v_copy.num_slots; slot++)
6808 {
6809 if (v_copy.slots[slot].opcode == nop_opcode)
6810 {
6811 v_copy.slots[slot].opcode =
6812 xtensa_format_slot_nop_opcode (isa, format, slot);
6813 v_copy.slots[slot].ntok = 0;
6814 }
6815
6816 if (opcode_fits_format_slot (v_copy.slots[slot].opcode,
6817 format, slot))
6818 fit++;
7fa3d080 6819 else if (v_copy.num_slots > 1)
43cd72b9 6820 {
7fa3d080
BW
6821 TInsn widened;
6822 /* Try the widened version. */
6823 if (!v_copy.slots[slot].keep_wide
6824 && !v_copy.slots[slot].is_specific_opcode
84b08ed9
BW
6825 && xg_is_single_relaxable_insn (&v_copy.slots[slot],
6826 &widened, TRUE)
7fa3d080
BW
6827 && opcode_fits_format_slot (widened.opcode,
6828 format, slot))
43cd72b9 6829 {
7fa3d080
BW
6830 v_copy.slots[slot] = widened;
6831 fit++;
43cd72b9
BW
6832 }
6833 }
6834 }
6835 if (fit == v_copy.num_slots)
6836 {
d8392fd9 6837 xg_copy_vinsn (vinsn, &v_copy);
43cd72b9
BW
6838 xtensa_format_encode (isa, format, vinsn->insnbuf);
6839 vinsn->format = format;
6840 break;
6841 }
6842 }
6843 }
6844
6845 if (format == xtensa_isa_num_formats (isa))
6846 return XTENSA_UNDEFINED;
6847
6848 return format;
6849}
6850
6851
6852/* Return the additional space needed in a frag
6853 for possible relaxations of any ops in a VLIW insn.
6854 Also fill out the relaxations that might be required of
6855 each tinsn in the vinsn. */
6856
6857static int
e7da6241 6858relaxation_requirements (vliw_insn *vinsn, bfd_boolean *pfinish_frag)
43cd72b9 6859{
e7da6241 6860 bfd_boolean finish_frag = FALSE;
43cd72b9
BW
6861 int extra_space = 0;
6862 int slot;
6863
6864 for (slot = 0; slot < vinsn->num_slots; slot++)
6865 {
6866 TInsn *tinsn = &vinsn->slots[slot];
6867 if (!tinsn_has_symbolic_operands (tinsn))
6868 {
6869 /* A narrow instruction could be widened later to help
6870 alignment issues. */
84b08ed9 6871 if (xg_is_single_relaxable_insn (tinsn, 0, TRUE)
43cd72b9
BW
6872 && !tinsn->is_specific_opcode
6873 && vinsn->num_slots == 1)
6874 {
6875 /* Difference in bytes between narrow and wide insns... */
6876 extra_space += 1;
6877 tinsn->subtype = RELAX_NARROW;
43cd72b9
BW
6878 }
6879 }
6880 else
6881 {
b08b5071
BW
6882 if (workaround_b_j_loop_end
6883 && tinsn->opcode == xtensa_jx_opcode
43cd72b9
BW
6884 && use_transform ())
6885 {
6886 /* Add 2 of these. */
6887 extra_space += 3; /* for the nop size */
6888 tinsn->subtype = RELAX_ADD_NOP_IF_PRE_LOOP_END;
6889 }
c138bc38 6890
43cd72b9
BW
6891 /* Need to assemble it with space for the relocation. */
6892 if (xg_is_relaxable_insn (tinsn, 0)
6893 && !tinsn->is_specific_opcode)
6894 {
6895 int max_size = xg_get_max_insn_widen_size (tinsn->opcode);
6896 int max_literal_size =
6897 xg_get_max_insn_widen_literal_size (tinsn->opcode);
c138bc38 6898
43cd72b9 6899 tinsn->literal_space = max_literal_size;
c138bc38 6900
43cd72b9 6901 tinsn->subtype = RELAX_IMMED;
43cd72b9
BW
6902 extra_space += max_size;
6903 }
6904 else
6905 {
e7da6241
BW
6906 /* A fix record will be added for this instruction prior
6907 to relaxation, so make it end the frag. */
6908 finish_frag = TRUE;
43cd72b9
BW
6909 }
6910 }
6911 }
e7da6241 6912 *pfinish_frag = finish_frag;
43cd72b9
BW
6913 return extra_space;
6914}
6915
6916
6917static void
b2d179be 6918bundle_tinsn (TInsn *tinsn, vliw_insn *vinsn)
43cd72b9
BW
6919{
6920 xtensa_isa isa = xtensa_default_isa;
b2d179be 6921 int slot, chosen_slot;
43cd72b9 6922
b2d179be 6923 vinsn->format = xg_get_single_format (tinsn->opcode);
9c2799c2 6924 gas_assert (vinsn->format != XTENSA_UNDEFINED);
b2d179be 6925 vinsn->num_slots = xtensa_format_num_slots (isa, vinsn->format);
43cd72b9 6926
b2d179be
BW
6927 chosen_slot = xg_get_single_slot (tinsn->opcode);
6928 for (slot = 0; slot < vinsn->num_slots; slot++)
43cd72b9 6929 {
b2d179be
BW
6930 if (slot == chosen_slot)
6931 vinsn->slots[slot] = *tinsn;
6932 else
6933 {
6934 vinsn->slots[slot].opcode =
6935 xtensa_format_slot_nop_opcode (isa, vinsn->format, slot);
6936 vinsn->slots[slot].ntok = 0;
6937 vinsn->slots[slot].insn_type = ITYPE_INSN;
6938 }
43cd72b9 6939 }
43cd72b9
BW
6940}
6941
6942
6943static bfd_boolean
7fa3d080 6944emit_single_op (TInsn *orig_insn)
43cd72b9
BW
6945{
6946 int i;
6947 IStack istack; /* put instructions into here */
6948 symbolS *lit_sym = NULL;
6949 symbolS *label_sym = NULL;
6950
6951 istack_init (&istack);
6952
6953 /* Special-case for "movi aX, foo" which is guaranteed to need relaxing.
c138bc38
BW
6954 Because the scheduling and bundling characteristics of movi and
6955 l32r or const16 are so different, we can do much better if we relax
43cd72b9 6956 it prior to scheduling and bundling, rather than after. */
c138bc38 6957 if ((orig_insn->opcode == xtensa_movi_opcode
b08b5071
BW
6958 || orig_insn->opcode == xtensa_movi_n_opcode)
6959 && !cur_vinsn.inside_bundle
43cd72b9 6960 && (orig_insn->tok[1].X_op == O_symbol
28dbbc02
BW
6961 || orig_insn->tok[1].X_op == O_pltrel
6962 || orig_insn->tok[1].X_op == O_tlsfunc
6963 || orig_insn->tok[1].X_op == O_tlsarg
6964 || orig_insn->tok[1].X_op == O_tpoff
6965 || orig_insn->tok[1].X_op == O_dtpoff)
482fd9f9 6966 && !orig_insn->is_specific_opcode && use_transform ())
43cd72b9
BW
6967 xg_assembly_relax (&istack, orig_insn, now_seg, frag_now, 0, 1, 0);
6968 else
6969 if (xg_expand_assembly_insn (&istack, orig_insn))
6970 return TRUE;
6971
6972 for (i = 0; i < istack.ninsn; i++)
6973 {
6974 TInsn *insn = &istack.insn[i];
c138bc38 6975 switch (insn->insn_type)
43cd72b9
BW
6976 {
6977 case ITYPE_LITERAL:
9c2799c2 6978 gas_assert (lit_sym == NULL);
43cd72b9
BW
6979 lit_sym = xg_assemble_literal (insn);
6980 break;
6981 case ITYPE_LABEL:
6982 {
6983 static int relaxed_sym_idx = 0;
325801bd 6984 char *label = XNEWVEC (char, strlen (FAKE_LABEL_NAME) + 12);
43cd72b9
BW
6985 sprintf (label, "%s_rl_%x", FAKE_LABEL_NAME, relaxed_sym_idx++);
6986 colon (label);
9c2799c2 6987 gas_assert (label_sym == NULL);
43cd72b9 6988 label_sym = symbol_find_or_make (label);
9c2799c2 6989 gas_assert (label_sym);
43cd72b9
BW
6990 free (label);
6991 }
6992 break;
6993 case ITYPE_INSN:
b2d179be
BW
6994 {
6995 vliw_insn v;
6996 if (lit_sym)
6997 xg_resolve_literals (insn, lit_sym);
6998 if (label_sym)
6999 xg_resolve_labels (insn, label_sym);
7000 xg_init_vinsn (&v);
7001 bundle_tinsn (insn, &v);
7002 finish_vinsn (&v);
7003 xg_free_vinsn (&v);
7004 }
43cd72b9
BW
7005 break;
7006 default:
9c2799c2 7007 gas_assert (0);
43cd72b9
BW
7008 break;
7009 }
7010 }
7011 return FALSE;
7012}
7013
7014
34e41783
BW
7015static int
7016total_frag_text_expansion (fragS *fragP)
7017{
7018 int slot;
7019 int total_expansion = 0;
7020
62af60e2 7021 for (slot = 0; slot < config_max_slots; slot++)
34e41783
BW
7022 total_expansion += fragP->tc_frag_data.text_expansion[slot];
7023
7024 return total_expansion;
7025}
7026
7027
43cd72b9
BW
7028/* Emit a vliw instruction to the current fragment. */
7029
7fa3d080
BW
7030static void
7031xg_assemble_vliw_tokens (vliw_insn *vinsn)
43cd72b9 7032{
e7da6241 7033 bfd_boolean finish_frag;
43cd72b9
BW
7034 bfd_boolean is_jump = FALSE;
7035 bfd_boolean is_branch = FALSE;
7036 xtensa_isa isa = xtensa_default_isa;
43cd72b9
BW
7037 int insn_size;
7038 int extra_space;
7039 char *f = NULL;
7040 int slot;
b224e962
BW
7041 struct dwarf2_line_info debug_line;
7042 bfd_boolean loc_directive_seen = FALSE;
7043 TInsn *tinsn;
43cd72b9 7044
b224e962 7045 memset (&debug_line, 0, sizeof (struct dwarf2_line_info));
43cd72b9
BW
7046
7047 if (generating_literals)
7048 {
7049 static int reported = 0;
7050 if (reported < 4)
7051 as_bad_where (frag_now->fr_file, frag_now->fr_line,
7052 _("cannot assemble into a literal fragment"));
7053 if (reported == 3)
7054 as_bad (_("..."));
7055 reported++;
7056 return;
7057 }
7058
7059 if (frag_now_fix () != 0
b08b5071 7060 && (! frag_now->tc_frag_data.is_insn
43cd72b9 7061 || (vinsn_has_specific_opcodes (vinsn) && use_transform ())
28a0da39 7062 || (!use_transform ()) != frag_now->tc_frag_data.is_no_transform
7c834684
BW
7063 || (directive_state[directive_longcalls]
7064 != frag_now->tc_frag_data.use_longcalls)
43cd72b9
BW
7065 || (directive_state[directive_absolute_literals]
7066 != frag_now->tc_frag_data.use_absolute_literals)))
7067 {
7068 frag_wane (frag_now);
7069 frag_new (0);
7070 xtensa_set_frag_assembly_state (frag_now);
7071 }
7072
7073 if (workaround_a0_b_retw
7074 && vinsn->num_slots == 1
7075 && (get_last_insn_flags (now_seg, now_subseg) & FLAG_IS_A0_WRITER) != 0
7076 && xtensa_opcode_is_branch (isa, vinsn->slots[0].opcode) == 1
7077 && use_transform ())
7078 {
7079 has_a0_b_retw = TRUE;
7080
7081 /* Mark this fragment with the special RELAX_ADD_NOP_IF_A0_B_RETW.
7082 After the first assembly pass we will check all of them and
7083 add a nop if needed. */
7084 frag_now->tc_frag_data.is_insn = TRUE;
7085 frag_var (rs_machine_dependent, 4, 4,
7086 RELAX_ADD_NOP_IF_A0_B_RETW,
7087 frag_now->fr_symbol,
7088 frag_now->fr_offset,
7089 NULL);
7090 xtensa_set_frag_assembly_state (frag_now);
7091 frag_now->tc_frag_data.is_insn = TRUE;
7092 frag_var (rs_machine_dependent, 4, 4,
7093 RELAX_ADD_NOP_IF_A0_B_RETW,
7094 frag_now->fr_symbol,
7095 frag_now->fr_offset,
7096 NULL);
7097 xtensa_set_frag_assembly_state (frag_now);
7098 }
7099
b224e962 7100 for (slot = 0; slot < vinsn->num_slots; slot++)
43cd72b9 7101 {
b224e962
BW
7102 tinsn = &vinsn->slots[slot];
7103
43cd72b9 7104 /* See if the instruction implies an aligned section. */
b224e962 7105 if (xtensa_opcode_is_loop (isa, tinsn->opcode) == 1)
43cd72b9 7106 record_alignment (now_seg, 2);
c138bc38 7107
b224e962
BW
7108 /* Determine the best line number for debug info. */
7109 if ((tinsn->loc_directive_seen || !loc_directive_seen)
7110 && (tinsn->debug_line.filenum != debug_line.filenum
7111 || tinsn->debug_line.line < debug_line.line
7112 || tinsn->debug_line.column < debug_line.column))
7113 debug_line = tinsn->debug_line;
7114 if (tinsn->loc_directive_seen)
7115 loc_directive_seen = TRUE;
43cd72b9
BW
7116 }
7117
7118 /* Special cases for instructions that force an alignment... */
7119 /* None of these opcodes are bundle-able. */
7120 if (xtensa_opcode_is_loop (isa, vinsn->slots[0].opcode) == 1)
7121 {
d77b99c9 7122 int max_fill;
c138bc38 7123
05d58145
BW
7124 /* Remember the symbol that marks the end of the loop in the frag
7125 that marks the start of the loop. This way we can easily find
7126 the end of the loop at the beginning, without adding special code
7127 to mark the loop instructions themselves. */
7128 symbolS *target_sym = NULL;
7129 if (vinsn->slots[0].tok[1].X_op == O_symbol)
7130 target_sym = vinsn->slots[0].tok[1].X_add_symbol;
7131
43cd72b9
BW
7132 xtensa_set_frag_assembly_state (frag_now);
7133 frag_now->tc_frag_data.is_insn = TRUE;
c138bc38 7134
43cd72b9
BW
7135 max_fill = get_text_align_max_fill_size
7136 (get_text_align_power (xtensa_fetch_width),
7137 TRUE, frag_now->tc_frag_data.is_no_density);
7138
7139 if (use_transform ())
7140 frag_var (rs_machine_dependent, max_fill, max_fill,
05d58145 7141 RELAX_ALIGN_NEXT_OPCODE, target_sym, 0, NULL);
43cd72b9 7142 else
c138bc38 7143 frag_var (rs_machine_dependent, 0, 0,
05d58145 7144 RELAX_CHECK_ALIGN_NEXT_OPCODE, target_sym, 0, NULL);
43cd72b9 7145 xtensa_set_frag_assembly_state (frag_now);
43cd72b9
BW
7146 }
7147
b08b5071 7148 if (vinsn->slots[0].opcode == xtensa_entry_opcode
43cd72b9
BW
7149 && !vinsn->slots[0].is_specific_opcode)
7150 {
7151 xtensa_mark_literal_pool_location ();
c3ea6048 7152 xtensa_move_labels (frag_now, 0);
43cd72b9
BW
7153 frag_var (rs_align_test, 1, 1, 0, NULL, 2, NULL);
7154 }
7155
7156 if (vinsn->num_slots == 1)
7157 {
7158 if (workaround_a0_b_retw && use_transform ())
7159 set_last_insn_flags (now_seg, now_subseg, FLAG_IS_A0_WRITER,
7160 is_register_writer (&vinsn->slots[0], "a", 0));
7161
7162 set_last_insn_flags (now_seg, now_subseg, FLAG_IS_BAD_LOOPEND,
7163 is_bad_loopend_opcode (&vinsn->slots[0]));
7164 }
7165 else
7166 set_last_insn_flags (now_seg, now_subseg, FLAG_IS_BAD_LOOPEND, FALSE);
7167
7168 insn_size = xtensa_format_length (isa, vinsn->format);
7169
e7da6241 7170 extra_space = relaxation_requirements (vinsn, &finish_frag);
43cd72b9
BW
7171
7172 /* vinsn_to_insnbuf will produce the error. */
7173 if (vinsn->format != XTENSA_UNDEFINED)
7174 {
d77b99c9 7175 f = frag_more (insn_size + extra_space);
43cd72b9
BW
7176 xtensa_set_frag_assembly_state (frag_now);
7177 frag_now->tc_frag_data.is_insn = TRUE;
7178 }
7179
e7da6241 7180 vinsn_to_insnbuf (vinsn, f, frag_now, FALSE);
43cd72b9
BW
7181 if (vinsn->format == XTENSA_UNDEFINED)
7182 return;
7183
d77b99c9 7184 xtensa_insnbuf_to_chars (isa, vinsn->insnbuf, (unsigned char *) f, 0);
c138bc38 7185
b224e962
BW
7186 if (debug_type == DEBUG_DWARF2 || loc_directive_seen)
7187 dwarf2_gen_line_info (frag_now_fix () - (insn_size + extra_space),
7188 &debug_line);
43cd72b9
BW
7189
7190 for (slot = 0; slot < vinsn->num_slots; slot++)
7191 {
b224e962 7192 tinsn = &vinsn->slots[slot];
43cd72b9 7193 frag_now->tc_frag_data.slot_subtypes[slot] = tinsn->subtype;
7c834684 7194 frag_now->tc_frag_data.slot_symbols[slot] = tinsn->symbol;
7c834684 7195 frag_now->tc_frag_data.slot_offsets[slot] = tinsn->offset;
43cd72b9 7196 frag_now->tc_frag_data.literal_frags[slot] = tinsn->literal_frag;
b46824bd
MF
7197 if (tinsn->opcode == xtensa_l32r_opcode)
7198 {
7199 frag_now->tc_frag_data.literal_frags[slot] =
7200 tinsn->tok[1].X_add_symbol->sy_frag;
7201 }
43cd72b9
BW
7202 if (tinsn->literal_space != 0)
7203 xg_assemble_literal_space (tinsn->literal_space, slot);
19e8f41a 7204 frag_now->tc_frag_data.free_reg[slot] = tinsn->extra_arg;
43cd72b9
BW
7205
7206 if (tinsn->subtype == RELAX_NARROW)
9c2799c2 7207 gas_assert (vinsn->num_slots == 1);
43cd72b9
BW
7208 if (xtensa_opcode_is_jump (isa, tinsn->opcode) == 1)
7209 is_jump = TRUE;
7210 if (xtensa_opcode_is_branch (isa, tinsn->opcode) == 1)
7211 is_branch = TRUE;
7212
e7da6241
BW
7213 if (tinsn->subtype || tinsn->symbol || tinsn->offset
7214 || tinsn->literal_frag || is_jump || is_branch)
43cd72b9
BW
7215 finish_frag = TRUE;
7216 }
7217
7218 if (vinsn_has_specific_opcodes (vinsn) && use_transform ())
b08b5071 7219 frag_now->tc_frag_data.is_specific_opcode = TRUE;
43cd72b9
BW
7220
7221 if (finish_frag)
7222 {
7223 frag_variant (rs_machine_dependent,
7224 extra_space, extra_space, RELAX_SLOTS,
7225 frag_now->fr_symbol, frag_now->fr_offset, f);
7226 xtensa_set_frag_assembly_state (frag_now);
7227 }
7228
7229 /* Special cases for loops:
7230 close_loop_end should be inserted AFTER short_loop.
7231 Make sure that CLOSE loops are processed BEFORE short_loops
7232 when converting them. */
7233
7234 /* "short_loop": Add a NOP if the loop is < 4 bytes. */
64b607e6 7235 if (xtensa_opcode_is_loop (isa, vinsn->slots[0].opcode) == 1
43cd72b9
BW
7236 && !vinsn->slots[0].is_specific_opcode)
7237 {
7238 if (workaround_short_loop && use_transform ())
7239 {
7240 maybe_has_short_loop = TRUE;
7241 frag_now->tc_frag_data.is_insn = TRUE;
7242 frag_var (rs_machine_dependent, 4, 4,
7243 RELAX_ADD_NOP_IF_SHORT_LOOP,
7244 frag_now->fr_symbol, frag_now->fr_offset, NULL);
7245 frag_now->tc_frag_data.is_insn = TRUE;
7246 frag_var (rs_machine_dependent, 4, 4,
7247 RELAX_ADD_NOP_IF_SHORT_LOOP,
7248 frag_now->fr_symbol, frag_now->fr_offset, NULL);
7249 }
7250
7251 /* "close_loop_end": Add up to 12 bytes of NOPs to keep a
7252 loop at least 12 bytes away from another loop's end. */
7253 if (workaround_close_loop_end && use_transform ())
7254 {
7255 maybe_has_close_loop_end = TRUE;
7256 frag_now->tc_frag_data.is_insn = TRUE;
7257 frag_var (rs_machine_dependent, 12, 12,
7258 RELAX_ADD_NOP_IF_CLOSE_LOOP_END,
7259 frag_now->fr_symbol, frag_now->fr_offset, NULL);
7260 }
7261 }
7262
7263 if (use_transform ())
7264 {
7265 if (is_jump)
7266 {
9c2799c2 7267 gas_assert (finish_frag);
43cd72b9 7268 frag_var (rs_machine_dependent,
1beeb686 7269 xtensa_fetch_width, xtensa_fetch_width,
43cd72b9
BW
7270 RELAX_UNREACHABLE,
7271 frag_now->fr_symbol, frag_now->fr_offset, NULL);
7272 xtensa_set_frag_assembly_state (frag_now);
a82c7d90 7273 xtensa_maybe_create_trampoline_frag ();
b46824bd
MF
7274 /* Always create one here. */
7275 xtensa_maybe_create_literal_pool_frag (TRUE, FALSE);
43cd72b9 7276 }
7b1cc377 7277 else if (is_branch && do_align_targets ())
43cd72b9 7278 {
9c2799c2 7279 gas_assert (finish_frag);
43cd72b9 7280 frag_var (rs_machine_dependent,
1beeb686 7281 xtensa_fetch_width, xtensa_fetch_width,
43cd72b9
BW
7282 RELAX_MAYBE_UNREACHABLE,
7283 frag_now->fr_symbol, frag_now->fr_offset, NULL);
7284 xtensa_set_frag_assembly_state (frag_now);
7285 frag_var (rs_machine_dependent,
7286 0, 0,
7287 RELAX_MAYBE_DESIRE_ALIGN,
7288 frag_now->fr_symbol, frag_now->fr_offset, NULL);
7289 xtensa_set_frag_assembly_state (frag_now);
7290 }
7291 }
7292
7293 /* Now, if the original opcode was a call... */
7294 if (do_align_targets ()
7295 && xtensa_opcode_is_call (isa, vinsn->slots[0].opcode) == 1)
7296 {
b08b5071 7297 float freq = get_subseg_total_freq (now_seg, now_subseg);
43cd72b9
BW
7298 frag_now->tc_frag_data.is_insn = TRUE;
7299 frag_var (rs_machine_dependent, 4, (int) freq, RELAX_DESIRE_ALIGN,
7300 frag_now->fr_symbol, frag_now->fr_offset, NULL);
7301 xtensa_set_frag_assembly_state (frag_now);
7302 }
7303
7304 if (vinsn_has_specific_opcodes (vinsn) && use_transform ())
7305 {
7306 frag_wane (frag_now);
7307 frag_new (0);
7308 xtensa_set_frag_assembly_state (frag_now);
7309 }
7310}
7311
7312\f
7fa3d080
BW
7313/* xtensa_end and helper functions. */
7314
7315static void xtensa_cleanup_align_frags (void);
7316static void xtensa_fix_target_frags (void);
7317static void xtensa_mark_narrow_branches (void);
7318static void xtensa_mark_zcl_first_insns (void);
6a7eedfe 7319static void xtensa_mark_difference_of_two_symbols (void);
7fa3d080
BW
7320static void xtensa_fix_a0_b_retw_frags (void);
7321static void xtensa_fix_b_j_loop_end_frags (void);
7322static void xtensa_fix_close_loop_end_frags (void);
7323static void xtensa_fix_short_loop_frags (void);
7324static void xtensa_sanity_check (void);
2caa7ca0 7325static void xtensa_add_config_info (void);
7fa3d080 7326
43cd72b9 7327void
7fa3d080 7328xtensa_end (void)
43cd72b9
BW
7329{
7330 directive_balance ();
7331 xtensa_flush_pending_output ();
7332
7333 past_xtensa_end = TRUE;
7334
7335 xtensa_move_literals ();
7336
7337 xtensa_reorder_segments ();
7338 xtensa_cleanup_align_frags ();
7339 xtensa_fix_target_frags ();
7340 if (workaround_a0_b_retw && has_a0_b_retw)
7341 xtensa_fix_a0_b_retw_frags ();
7342 if (workaround_b_j_loop_end)
7343 xtensa_fix_b_j_loop_end_frags ();
7344
7345 /* "close_loop_end" should be processed BEFORE "short_loop". */
7346 if (workaround_close_loop_end && maybe_has_close_loop_end)
7347 xtensa_fix_close_loop_end_frags ();
7348
7349 if (workaround_short_loop && maybe_has_short_loop)
7350 xtensa_fix_short_loop_frags ();
03aaa593
BW
7351 if (align_targets)
7352 xtensa_mark_narrow_branches ();
43cd72b9
BW
7353 xtensa_mark_zcl_first_insns ();
7354
7355 xtensa_sanity_check ();
2caa7ca0
BW
7356
7357 xtensa_add_config_info ();
a82c7d90
DW
7358
7359 xtensa_check_frag_count ();
43cd72b9
BW
7360}
7361
148d6384
MF
7362struct trampoline_chain_entry
7363{
7364 symbolS *sym;
7365 addressT offset;
7366};
7367
7368/* Trampoline chain for a given (sym, offset) pair is a sorted array
7369 of locations of trampoline jumps leading there. Jumps are represented
7370 as pairs (sym, offset): trampoline frag symbol and offset of the jump
7371 inside the frag. */
7372struct trampoline_chain
7373{
7374 struct trampoline_chain_entry target;
7375 struct trampoline_chain_entry *entry;
7376 size_t n_entries;
7377 size_t n_max;
7378 bfd_boolean needs_sorting;
7379};
7380
7381struct trampoline_chain_index
7382{
7383 struct trampoline_chain *entry;
7384 size_t n_entries;
7385 size_t n_max;
7386 bfd_boolean needs_sorting;
7387};
7388
fe6c2f1b
MF
7389struct trampoline_index
7390{
7391 fragS **entry;
7392 size_t n_entries;
7393 size_t n_max;
7394};
43cd72b9 7395
a82c7d90
DW
7396struct trampoline_seg
7397{
7398 struct trampoline_seg *next;
7399 asection *seg;
148d6384 7400 /* Trampolines ordered by their frag fr_address */
fe6c2f1b 7401 struct trampoline_index index;
148d6384
MF
7402 /* Known trampoline chains ordered by (sym, offset) pair */
7403 struct trampoline_chain_index chain_index;
a82c7d90
DW
7404};
7405
7406static struct trampoline_seg trampoline_seg_list;
7407#define J_RANGE (128 * 1024)
fe6c2f1b 7408#define J_MARGIN 4096
a82c7d90
DW
7409
7410static int unreachable_count = 0;
7411
7412
7413static void
7414xtensa_maybe_create_trampoline_frag (void)
7415{
7416 if (!use_trampolines)
7417 return;
7418
7419 /* We create an area for possible trampolines every 10 unreachable frags.
7420 These are preferred over the ones not preceded by an unreachable frag,
7421 because we don't have to jump around them. This function is called after
7422 each RELAX_UNREACHABLE frag is created. */
7423
7424 if (++unreachable_count > 10)
7425 {
7426 xtensa_create_trampoline_frag (FALSE);
7427 clear_frag_count ();
7428 unreachable_count = 0;
7429 }
7430}
7431
7432static void
7433xtensa_check_frag_count (void)
7434{
7435 if (!use_trampolines || frag_now->tc_frag_data.is_no_transform)
7436 return;
7437
7438 /* We create an area for possible trampolines every 8000 frags or so. This
7439 is an estimate based on the max range of a "j" insn (+/-128K) divided
7440 by a typical frag byte count (16), minus a few for safety. This function
7441 is called after each source line is processed. */
7442
7443 if (get_frag_count () > 8000)
7444 {
7445 xtensa_create_trampoline_frag (TRUE);
7446 clear_frag_count ();
7447 unreachable_count = 0;
7448 }
b46824bd
MF
7449
7450 /* We create an area for a possible literal pool every N (default 5000)
7451 frags or so. */
7452 xtensa_maybe_create_literal_pool_frag (TRUE, TRUE);
a82c7d90
DW
7453}
7454
7455static xtensa_insnbuf trampoline_buf = NULL;
7456static xtensa_insnbuf trampoline_slotbuf = NULL;
7457
b46824bd
MF
7458static xtensa_insnbuf litpool_buf = NULL;
7459static xtensa_insnbuf litpool_slotbuf = NULL;
7460
a82c7d90
DW
7461#define TRAMPOLINE_FRAG_SIZE 3000
7462
1c2649f5
MF
7463static struct trampoline_seg *
7464find_trampoline_seg (asection *seg)
7465{
7466 struct trampoline_seg *ts = trampoline_seg_list.next;
407e1140
MF
7467 static struct trampoline_seg *mr;
7468
7469 if (mr && mr->seg == seg)
7470 return mr;
1c2649f5
MF
7471
7472 for ( ; ts; ts = ts->next)
7473 {
7474 if (ts->seg == seg)
407e1140
MF
7475 {
7476 mr = ts;
7477 return ts;
7478 }
1c2649f5
MF
7479 }
7480
7481 return NULL;
7482}
7483
fe6c2f1b
MF
7484static size_t xg_find_trampoline (const struct trampoline_index *idx,
7485 addressT addr)
7486{
7487 size_t a = 0;
7488 size_t b = idx->n_entries;
7489
7490 while (b - a > 1)
7491 {
7492 size_t c = (a + b) / 2;
7493
7494 if (idx->entry[c]->fr_address <= addr)
7495 a = c;
7496 else
7497 b = c;
7498 }
7499 return a;
7500}
7501
7502static void xg_add_trampoline_to_index (struct trampoline_index *idx,
7503 fragS *fragP)
7504{
7505 if (idx->n_entries == idx->n_max)
7506 {
7507 idx->n_max = (idx->n_entries + 1) * 2;
7508 idx->entry = xrealloc (idx->entry,
7509 sizeof (*idx->entry) * idx->n_max);
7510 }
7511 idx->entry[idx->n_entries] = fragP;
7512 ++idx->n_entries;
7513}
7514
7515static void xg_remove_trampoline_from_index (struct trampoline_index *idx,
7516 size_t i)
7517{
7518 gas_assert (i < idx->n_entries);
7519 memmove (idx->entry + i, idx->entry + i + 1,
7520 (idx->n_entries - i - 1) * sizeof (*idx->entry));
7521 --idx->n_entries;
7522}
7523
7524static void xg_add_trampoline_to_seg (struct trampoline_seg *ts,
7525 fragS *fragP)
7526{
7527 xg_add_trampoline_to_index (&ts->index, fragP);
7528}
1c2649f5 7529
a82c7d90
DW
7530static void
7531xtensa_create_trampoline_frag (bfd_boolean needs_jump_around)
7532{
7533 /* Emit a frag where we can place intermediate jump instructions,
7534 in case we need to jump farther than 128K bytes.
7535 Each jump instruction takes three bytes.
7536 We allocate enough for 1000 trampolines in each frag.
7537 If that's not enough, oh well. */
7538
1c2649f5 7539 struct trampoline_seg *ts = find_trampoline_seg (now_seg);
a82c7d90
DW
7540 char *varP;
7541 fragS *fragP;
7542 int size = TRAMPOLINE_FRAG_SIZE;
7543
a82c7d90
DW
7544 if (ts == NULL)
7545 {
add39d23 7546 ts = XCNEW(struct trampoline_seg);
a82c7d90
DW
7547 ts->next = trampoline_seg_list.next;
7548 trampoline_seg_list.next = ts;
7549 ts->seg = now_seg;
7550 }
7551
7552 frag_wane (frag_now);
7553 frag_new (0);
7554 xtensa_set_frag_assembly_state (frag_now);
7555 varP = frag_var (rs_machine_dependent, size, size, RELAX_TRAMPOLINE, NULL, 0, NULL);
7556 fragP = (fragS *)(varP - SIZEOF_STRUCT_FRAG);
7557 if (trampoline_buf == NULL)
7558 {
7559 trampoline_buf = xtensa_insnbuf_alloc (xtensa_default_isa);
7560 trampoline_slotbuf = xtensa_insnbuf_alloc (xtensa_default_isa);
7561 }
46888d71 7562 fragP->tc_frag_data.needs_jump_around = needs_jump_around;
fe6c2f1b 7563 xg_add_trampoline_to_seg (ts, fragP);
a82c7d90
DW
7564}
7565
fe6c2f1b
MF
7566static bfd_boolean xg_is_trampoline_frag_full (const fragS *fragP)
7567{
7568 return fragP->fr_var < 3;
7569}
a82c7d90 7570
148d6384
MF
7571static int xg_order_trampoline_chain_entry (const void *a, const void *b)
7572{
7573 const struct trampoline_chain_entry *pa = a;
7574 const struct trampoline_chain_entry *pb = b;
7575
7576 if (pa->sym == pb->sym ||
7577 S_GET_VALUE (pa->sym) == S_GET_VALUE (pb->sym))
7578 if (pa->offset == pb->offset)
7579 return 0;
7580 else
7581 return pa->offset < pb->offset ? -1 : 1;
7582 else
7583 return S_GET_VALUE (pa->sym) < S_GET_VALUE (pb->sym) ? -1 : 1;
7584}
7585
7586static void xg_sort_trampoline_chain (struct trampoline_chain *tc)
7587{
7588 qsort (tc->entry, tc->n_entries, sizeof (*tc->entry),
7589 xg_order_trampoline_chain_entry);
7590 tc->needs_sorting = FALSE;
7591}
7592
7593/* Find entry index in the given chain with maximal address <= source. */
7594static size_t xg_find_chain_entry (struct trampoline_chain *tc,
7595 addressT source)
7596{
7597 size_t a = 0;
7598 size_t b = tc->n_entries;
7599
7600 if (tc->needs_sorting)
7601 xg_sort_trampoline_chain (tc);
7602
7603 while (b - a > 1)
7604 {
7605 size_t c = (a + b) / 2;
7606 struct trampoline_chain_entry *e = tc->entry + c;
7607
7608 if (S_GET_VALUE(e->sym) + e->offset <= source)
7609 a = c;
7610 else
7611 b = c;
7612 }
7613 return a;
7614}
7615
7616/* Find the best jump target for the source in the given trampoline chain.
7617 The best jump target is the one that results in the shortest path to the
7618 final target, it's the location of the jump closest to the final target,
7619 but within the J_RANGE - J_MARGIN from the source. */
7620static struct trampoline_chain_entry *
7621xg_get_best_chain_entry (struct trampoline_chain *tc, addressT source)
7622{
7623 addressT target = S_GET_VALUE(tc->target.sym) + tc->target.offset;
7624 size_t i = xg_find_chain_entry (tc, source);
7625 struct trampoline_chain_entry *e = tc->entry + i;
7626 int step = target < source ? -1 : 1;
7627 addressT chained_target;
7628 offsetT off;
7629
7630 if (target > source &&
7631 S_GET_VALUE(e->sym) + e->offset <= source &&
7632 i + 1 < tc->n_entries)
7633 ++i;
7634
7635 while (i + step < tc->n_entries)
7636 {
7637 struct trampoline_chain_entry *next = tc->entry + i + step;
7638
7639 chained_target = S_GET_VALUE(next->sym) + next->offset;
7640 off = source - chained_target;
7641
7642 if (labs (off) >= J_RANGE - J_MARGIN)
7643 break;
7644
7645 i += step;
7646 }
7647
7648 e = tc->entry + i;
7649 chained_target = S_GET_VALUE(e->sym) + e->offset;
7650 off = source - chained_target;
7651
7652 if (labs (off) < J_MARGIN ||
7653 labs (off) >= J_RANGE - J_MARGIN)
7654 return &tc->target;
7655 return tc->entry + i;
7656}
7657
7658static int xg_order_trampoline_chain (const void *a, const void *b)
7659{
10af2a65
MF
7660 const struct trampoline_chain *_pa = a;
7661 const struct trampoline_chain *_pb = b;
7662 const struct trampoline_chain_entry *pa = &_pa->target;
7663 const struct trampoline_chain_entry *pb = &_pb->target;
7664 symbolS *s1 = pa->sym;
7665 symbolS *s2 = pb->sym;
7666
7667 if (s1->sy_flags.sy_local_symbol
7668 && local_symbol_converted_p ((struct local_symbol *) s1))
7669 s1 = local_symbol_get_real_symbol ((struct local_symbol *) s1);
7670
7671 if (s2->sy_flags.sy_local_symbol
7672 && local_symbol_converted_p ((struct local_symbol *) s2))
7673 s2 = local_symbol_get_real_symbol ((struct local_symbol *) s2);
7674
7675 if (s1 == s2)
7676 if (pa->offset == pb->offset)
7677 return 0;
7678 else
7679 return pa->offset < pb->offset ? -1 : 1;
7680 else
7681 return s1 < s2 ? -1 : 1;
148d6384
MF
7682}
7683
7684static struct trampoline_chain *
7685xg_get_trampoline_chain (struct trampoline_seg *ts,
7686 symbolS *sym,
7687 addressT offset)
7688{
7689 struct trampoline_chain_index *idx = &ts->chain_index;
7690 struct trampoline_chain c;
7691
7692 if (idx->needs_sorting)
7693 {
7694 qsort (idx->entry, idx->n_entries, sizeof (*idx->entry),
7695 xg_order_trampoline_chain);
7696 idx->needs_sorting = FALSE;
7697 }
7698 c.target.sym = sym;
7699 c.target.offset = offset;
7700 return bsearch (&c, idx->entry, idx->n_entries,
7701 sizeof (struct trampoline_chain),
7702 xg_order_trampoline_chain);
7703}
7704
7705/* Find trampoline chain in the given trampoline segment that is going
7706 to the *sym + *offset. If found, replace *sym and *offset with the
7707 best jump target in that chain. */
7708static struct trampoline_chain *
7709xg_find_best_eq_target (struct trampoline_seg *ts,
7710 addressT source, symbolS **sym,
7711 addressT *offset)
7712{
7713 struct trampoline_chain *tc = xg_get_trampoline_chain (ts, *sym, *offset);
7714
7715 if (tc)
7716 {
7717 struct trampoline_chain_entry *e = xg_get_best_chain_entry (tc, source);
7718
7719 *sym = e->sym;
7720 *offset = e->offset;
7721 }
7722 return tc;
7723}
7724
7725static void xg_add_location_to_chain (struct trampoline_chain *tc,
7726 symbolS *sym, addressT offset)
7727{
7728 struct trampoline_chain_entry *e;
7729
7730 if (tc->n_entries == tc->n_max)
7731 {
7732 tc->n_max = (tc->n_max + 1) * 2;
7733 tc->entry = xrealloc (tc->entry, sizeof (*tc->entry) * tc->n_max);
7734 }
7735 e = tc->entry + tc->n_entries;
7736 e->sym = sym;
7737 e->offset = offset;
7738 ++tc->n_entries;
7739 tc->needs_sorting = TRUE;
7740}
7741
7742static struct trampoline_chain *
7743xg_create_trampoline_chain (struct trampoline_seg *ts,
7744 symbolS *sym, addressT offset)
7745{
7746 struct trampoline_chain_index *idx = &ts->chain_index;
7747 struct trampoline_chain *tc;
7748
7749 if (idx->n_entries == idx->n_max)
7750 {
7751 idx->n_max = (idx->n_max + 1) * 2;
7752 idx->entry = xrealloc (idx->entry,
7753 sizeof (*idx->entry) * idx->n_max);
7754 }
7755
7756 tc = idx->entry + idx->n_entries;
7757 tc->target.sym = sym;
7758 tc->target.offset = offset;
7759 tc->entry = NULL;
7760 tc->n_entries = 0;
7761 tc->n_max = 0;
7762 xg_add_location_to_chain (tc, sym, offset);
7763
7764 ++idx->n_entries;
7765 idx->needs_sorting = TRUE;
7766
7767 return tc;
7768}
7769
a82c7d90
DW
7770void dump_trampolines (void);
7771
7772void
7773dump_trampolines (void)
7774{
7775 struct trampoline_seg *ts = trampoline_seg_list.next;
7776
7777 for ( ; ts; ts = ts->next)
7778 {
fe6c2f1b 7779 size_t i;
a82c7d90
DW
7780 asection *seg = ts->seg;
7781
7782 if (seg == NULL)
7783 continue;
7784 fprintf(stderr, "SECTION %s\n", seg->name);
fe6c2f1b
MF
7785
7786 for (i = 0; i < ts->index.n_entries; ++i)
a82c7d90 7787 {
fe6c2f1b
MF
7788 fragS *tf = ts->index.entry[i];
7789
a82c7d90 7790 fprintf(stderr, " 0x%08x: fix=%d, jump_around=%s\n",
46888d71
MF
7791 (int)tf->fr_address, (int)tf->fr_fix,
7792 tf->tc_frag_data.needs_jump_around ? "T" : "F");
a82c7d90
DW
7793 }
7794 }
7795}
7796
b46824bd
MF
7797static void dump_litpools (void) __attribute__ ((unused));
7798
7799static void
7800dump_litpools (void)
7801{
7802 struct litpool_seg *lps = litpool_seg_list.next;
7803 struct litpool_frag *lpf;
7804
7805 for ( ; lps ; lps = lps->next )
7806 {
7807 printf("litpool seg %s\n", lps->seg->name);
7808 for ( lpf = lps->frag_list.next; lpf->fragP; lpf = lpf->next )
7809 {
7810 fragS *litfrag = lpf->fragP->fr_next;
7811 int count = 0;
7812 while (litfrag && litfrag->fr_subtype != RELAX_LITERAL_POOL_END)
7813 {
7814 if (litfrag->fr_fix == 4)
7815 count++;
7816 litfrag = litfrag->fr_next;
7817 }
7818 printf(" %ld <%d:%d> (%d) [%d]: ",
7819 lpf->addr, lpf->priority, lpf->original_priority,
7820 lpf->fragP->fr_line, count);
7821 //dump_frag(lpf->fragP);
7822 }
7823 }
7824}
7825
7826static void
7827xtensa_maybe_create_literal_pool_frag (bfd_boolean create,
7828 bfd_boolean only_if_needed)
7829{
7830 struct litpool_seg *lps = litpool_seg_list.next;
7831 fragS *fragP;
7832 struct litpool_frag *lpf;
7833 bfd_boolean needed = FALSE;
7834
7835 if (use_literal_section || !auto_litpools)
7836 return;
7837
7838 for ( ; lps ; lps = lps->next )
7839 {
7840 if (lps->seg == now_seg)
7841 break;
7842 }
7843
7844 if (lps == NULL)
7845 {
add39d23 7846 lps = XCNEW (struct litpool_seg);
b46824bd
MF
7847 lps->next = litpool_seg_list.next;
7848 litpool_seg_list.next = lps;
7849 lps->seg = now_seg;
7850 lps->frag_list.next = &lps->frag_list;
7851 lps->frag_list.prev = &lps->frag_list;
947fa914
MF
7852 /* Put candidate literal pool at the beginning of every section,
7853 so that even when section starts with literal load there's a
7854 literal pool available. */
7855 lps->frag_count = auto_litpool_limit;
b46824bd
MF
7856 }
7857
7858 lps->frag_count++;
7859
7860 if (create)
7861 {
7862 if (only_if_needed)
7863 {
7864 if (past_xtensa_end || !use_transform() ||
7865 frag_now->tc_frag_data.is_no_transform)
7866 {
7867 return;
7868 }
7869 if (auto_litpool_limit <= 0)
7870 {
7871 /* Don't create a litpool based only on frag count. */
7872 return;
7873 }
7874 else if (lps->frag_count > auto_litpool_limit)
7875 {
7876 needed = TRUE;
7877 }
7878 else
7879 {
7880 return;
7881 }
7882 }
7883 else
7884 {
7885 needed = TRUE;
7886 }
7887 }
7888
7889 if (needed)
7890 {
7891 int size = (only_if_needed) ? 3 : 0; /* Space for a "j" insn. */
7892 /* Create a potential site for a literal pool. */
7893 frag_wane (frag_now);
7894 frag_new (0);
7895 xtensa_set_frag_assembly_state (frag_now);
7896 fragP = frag_now;
7897 fragP->tc_frag_data.lit_frchain = frchain_now;
7898 fragP->tc_frag_data.literal_frag = fragP;
7899 frag_var (rs_machine_dependent, size, size,
7900 (only_if_needed) ?
7901 RELAX_LITERAL_POOL_CANDIDATE_BEGIN :
7902 RELAX_LITERAL_POOL_BEGIN,
7903 NULL, 0, NULL);
7904 frag_now->tc_frag_data.lit_seg = now_seg;
7905 frag_variant (rs_machine_dependent, 0, 0,
7906 RELAX_LITERAL_POOL_END, NULL, 0, NULL);
7907 xtensa_set_frag_assembly_state (frag_now);
7908 }
7909 else
7910 {
7911 /* RELAX_LITERAL_POOL_BEGIN frag is being created;
7912 just record it here. */
7913 fragP = frag_now;
7914 }
7915
325801bd 7916 lpf = XNEW (struct litpool_frag);
b46824bd
MF
7917 /* Insert at tail of circular list. */
7918 lpf->addr = 0;
7919 lps->frag_list.prev->next = lpf;
7920 lpf->next = &lps->frag_list;
7921 lpf->prev = lps->frag_list.prev;
7922 lps->frag_list.prev = lpf;
7923 lpf->fragP = fragP;
7924 lpf->priority = (needed) ? (only_if_needed) ? 3 : 2 : 1;
7925 lpf->original_priority = lpf->priority;
cd665a94 7926 lpf->literal_count = 0;
b46824bd
MF
7927
7928 lps->frag_count = 0;
7929}
7930
43cd72b9 7931static void
7fa3d080 7932xtensa_cleanup_align_frags (void)
43cd72b9
BW
7933{
7934 frchainS *frchP;
c9049d30 7935 asection *s;
43cd72b9 7936
c9049d30
AM
7937 for (s = stdoutput->sections; s; s = s->next)
7938 for (frchP = seg_info (s)->frchainP; frchP; frchP = frchP->frch_next)
7939 {
7940 fragS *fragP;
7941 /* Walk over all of the fragments in a subsection. */
7942 for (fragP = frchP->frch_root; fragP; fragP = fragP->fr_next)
7943 {
7944 if ((fragP->fr_type == rs_align
7945 || fragP->fr_type == rs_align_code
7946 || (fragP->fr_type == rs_machine_dependent
7947 && (fragP->fr_subtype == RELAX_DESIRE_ALIGN
7948 || fragP->fr_subtype == RELAX_DESIRE_ALIGN_IF_TARGET)))
7949 && fragP->fr_fix == 0)
7950 {
7951 fragS *next = fragP->fr_next;
7952
7953 while (next
7954 && next->fr_fix == 0
7955 && next->fr_type == rs_machine_dependent
7956 && next->fr_subtype == RELAX_DESIRE_ALIGN_IF_TARGET)
7957 {
7958 frag_wane (next);
7959 next = next->fr_next;
7960 }
7961 }
7962 /* If we don't widen branch targets, then they
7963 will be easier to align. */
7964 if (fragP->tc_frag_data.is_branch_target
7965 && fragP->fr_opcode == fragP->fr_literal
7966 && fragP->fr_type == rs_machine_dependent
7967 && fragP->fr_subtype == RELAX_SLOTS
7968 && fragP->tc_frag_data.slot_subtypes[0] == RELAX_NARROW)
7969 frag_wane (fragP);
7970 if (fragP->fr_type == rs_machine_dependent
7971 && fragP->fr_subtype == RELAX_UNREACHABLE)
7972 fragP->tc_frag_data.is_unreachable = TRUE;
7973 }
7974 }
43cd72b9
BW
7975}
7976
7977
7978/* Re-process all of the fragments looking to convert all of the
7979 RELAX_DESIRE_ALIGN_IF_TARGET fragments. If there is a branch
7980 target in the next fragment, convert this to RELAX_DESIRE_ALIGN.
7b1cc377 7981 Otherwise, convert to a .fill 0. */
7fa3d080 7982
43cd72b9 7983static void
7fa3d080 7984xtensa_fix_target_frags (void)
e0001a05
NC
7985{
7986 frchainS *frchP;
c9049d30 7987 asection *s;
e0001a05
NC
7988
7989 /* When this routine is called, all of the subsections are still intact
7990 so we walk over subsections instead of sections. */
c9049d30
AM
7991 for (s = stdoutput->sections; s; s = s->next)
7992 for (frchP = seg_info (s)->frchainP; frchP; frchP = frchP->frch_next)
7993 {
7994 fragS *fragP;
e0001a05 7995
c9049d30
AM
7996 /* Walk over all of the fragments in a subsection. */
7997 for (fragP = frchP->frch_root; fragP; fragP = fragP->fr_next)
7998 {
7999 if (fragP->fr_type == rs_machine_dependent
8000 && fragP->fr_subtype == RELAX_DESIRE_ALIGN_IF_TARGET)
8001 {
8002 if (next_frag_is_branch_target (fragP))
8003 fragP->fr_subtype = RELAX_DESIRE_ALIGN;
8004 else
8005 frag_wane (fragP);
8006 }
8007 }
8008 }
e0001a05
NC
8009}
8010
8011
7fa3d080
BW
8012static bfd_boolean is_narrow_branch_guaranteed_in_range (fragS *, TInsn *);
8013
43cd72b9 8014static void
7fa3d080 8015xtensa_mark_narrow_branches (void)
43cd72b9
BW
8016{
8017 frchainS *frchP;
c9049d30 8018 asection *s;
43cd72b9 8019
c9049d30
AM
8020 for (s = stdoutput->sections; s; s = s->next)
8021 for (frchP = seg_info (s)->frchainP; frchP; frchP = frchP->frch_next)
8022 {
8023 fragS *fragP;
8024 /* Walk over all of the fragments in a subsection. */
8025 for (fragP = frchP->frch_root; fragP; fragP = fragP->fr_next)
8026 {
8027 if (fragP->fr_type == rs_machine_dependent
8028 && fragP->fr_subtype == RELAX_SLOTS
8029 && fragP->tc_frag_data.slot_subtypes[0] == RELAX_IMMED)
8030 {
8031 vliw_insn vinsn;
8032
8033 vinsn_from_chars (&vinsn, fragP->fr_opcode);
8034 tinsn_immed_from_frag (&vinsn.slots[0], fragP, 0);
8035
8036 if (vinsn.num_slots == 1
8037 && xtensa_opcode_is_branch (xtensa_default_isa,
64b607e6 8038 vinsn.slots[0].opcode) == 1
c9049d30
AM
8039 && xg_get_single_size (vinsn.slots[0].opcode) == 2
8040 && is_narrow_branch_guaranteed_in_range (fragP,
8041 &vinsn.slots[0]))
8042 {
8043 fragP->fr_subtype = RELAX_SLOTS;
8044 fragP->tc_frag_data.slot_subtypes[0] = RELAX_NARROW;
8045 fragP->tc_frag_data.is_aligning_branch = 1;
8046 }
8047 }
8048 }
8049 }
43cd72b9
BW
8050}
8051
8052
8053/* A branch is typically widened only when its target is out of
8054 range. However, we would like to widen them to align a subsequent
8055 branch target when possible.
8056
8057 Because the branch relaxation code is so convoluted, the optimal solution
8058 (combining the two cases) is difficult to get right in all circumstances.
8059 We therefore go with an "almost as good" solution, where we only
8060 use for alignment narrow branches that definitely will not expand to a
8061 jump and a branch. These functions find and mark these cases. */
8062
a67517f4
BW
8063/* The range in bytes of BNEZ.N and BEQZ.N. The target operand is encoded
8064 as PC + 4 + imm6, where imm6 is a 6-bit immediate ranging from 0 to 63.
8065 We start counting beginning with the frag after the 2-byte branch, so the
8066 maximum offset is (4 - 2) + 63 = 65. */
8067#define MAX_IMMED6 65
43cd72b9 8068
d77b99c9 8069static offsetT unrelaxed_frag_max_size (fragS *);
7fa3d080 8070
43cd72b9 8071static bfd_boolean
7fa3d080 8072is_narrow_branch_guaranteed_in_range (fragS *fragP, TInsn *tinsn)
43cd72b9 8073{
91d6fa6a
NC
8074 const expressionS *exp = &tinsn->tok[1];
8075 symbolS *symbolP = exp->X_add_symbol;
8076 offsetT max_distance = exp->X_add_number;
e7da6241
BW
8077 fragS *target_frag;
8078
91d6fa6a 8079 if (exp->X_op != O_symbol)
e7da6241
BW
8080 return FALSE;
8081
8082 target_frag = symbol_get_frag (symbolP);
8083
43cd72b9
BW
8084 max_distance += (S_GET_VALUE (symbolP) - target_frag->fr_address);
8085 if (is_branch_jmp_to_next (tinsn, fragP))
8086 return FALSE;
8087
8088 /* The branch doesn't branch over it's own frag,
8089 but over the subsequent ones. */
8090 fragP = fragP->fr_next;
8091 while (fragP != NULL && fragP != target_frag && max_distance <= MAX_IMMED6)
8092 {
8093 max_distance += unrelaxed_frag_max_size (fragP);
8094 fragP = fragP->fr_next;
8095 }
8096 if (max_distance <= MAX_IMMED6 && fragP == target_frag)
8097 return TRUE;
e0001a05
NC
8098 return FALSE;
8099}
8100
8101
43cd72b9 8102static void
7fa3d080 8103xtensa_mark_zcl_first_insns (void)
43cd72b9
BW
8104{
8105 frchainS *frchP;
c9049d30 8106 asection *s;
43cd72b9 8107
c9049d30
AM
8108 for (s = stdoutput->sections; s; s = s->next)
8109 for (frchP = seg_info (s)->frchainP; frchP; frchP = frchP->frch_next)
8110 {
8111 fragS *fragP;
8112 /* Walk over all of the fragments in a subsection. */
8113 for (fragP = frchP->frch_root; fragP; fragP = fragP->fr_next)
8114 {
8115 if (fragP->fr_type == rs_machine_dependent
8116 && (fragP->fr_subtype == RELAX_ALIGN_NEXT_OPCODE
8117 || fragP->fr_subtype == RELAX_CHECK_ALIGN_NEXT_OPCODE))
8118 {
8119 /* Find the loop frag. */
3a1e9c4a 8120 fragS *loop_frag = next_non_empty_frag (fragP);
c9049d30 8121 /* Find the first insn frag. */
3a1e9c4a
SA
8122 fragS *targ_frag = next_non_empty_frag (loop_frag);
8123
8124 /* Handle a corner case that comes up in hardware
8125 diagnostics. The original assembly looks like this:
3739860c 8126
3a1e9c4a
SA
8127 loop aX, LabelA
8128 <empty_frag>--not found by next_non_empty_frag
8129 loop aY, LabelB
8130
8131 Depending on the start address, the assembler may or
8132 may not change it to look something like this:
8133
8134 loop aX, LabelA
8135 nop--frag isn't empty anymore
8136 loop aY, LabelB
8137
8138 So set up to check the alignment of the nop if it
8139 exists */
8140 while (loop_frag != targ_frag)
8141 {
8142 if (loop_frag->fr_type == rs_machine_dependent
8143 && (loop_frag->fr_subtype == RELAX_ALIGN_NEXT_OPCODE
3739860c 8144 || loop_frag->fr_subtype
3a1e9c4a
SA
8145 == RELAX_CHECK_ALIGN_NEXT_OPCODE))
8146 targ_frag = loop_frag;
8147 else
8148 loop_frag = loop_frag->fr_next;
8149 }
c9049d30
AM
8150
8151 /* Of course, sometimes (mostly for toy test cases) a
8152 zero-cost loop instruction is the last in a section. */
8153 if (targ_frag)
8154 {
8155 targ_frag->tc_frag_data.is_first_loop_insn = TRUE;
8156 /* Do not widen a frag that is the first instruction of a
8157 zero-cost loop. It makes that loop harder to align. */
8158 if (targ_frag->fr_type == rs_machine_dependent
8159 && targ_frag->fr_subtype == RELAX_SLOTS
8160 && (targ_frag->tc_frag_data.slot_subtypes[0]
8161 == RELAX_NARROW))
8162 {
8163 if (targ_frag->tc_frag_data.is_aligning_branch)
8164 targ_frag->tc_frag_data.slot_subtypes[0] = RELAX_IMMED;
8165 else
8166 {
8167 frag_wane (targ_frag);
8168 targ_frag->tc_frag_data.slot_subtypes[0] = 0;
8169 }
8170 }
8171 }
8172 if (fragP->fr_subtype == RELAX_CHECK_ALIGN_NEXT_OPCODE)
8173 frag_wane (fragP);
8174 }
8175 }
8176 }
43cd72b9
BW
8177}
8178
8179
fb227da0
BW
8180/* When a difference-of-symbols expression is encoded as a uleb128 or
8181 sleb128 value, the linker is unable to adjust that value to account for
8182 link-time relaxation. Mark all the code between such symbols so that
8183 its size cannot be changed by linker relaxation. */
3739860c 8184
6a7eedfe
BW
8185static void
8186xtensa_mark_difference_of_two_symbols (void)
8187{
8188 symbolS *expr_sym;
8189
3739860c 8190 for (expr_sym = expr_symbols; expr_sym;
6a7eedfe
BW
8191 expr_sym = symbol_get_tc (expr_sym)->next_expr_symbol)
8192 {
91d6fa6a 8193 expressionS *exp = symbol_get_value_expression (expr_sym);
6a7eedfe 8194
91d6fa6a 8195 if (exp->X_op == O_subtract)
6a7eedfe 8196 {
91d6fa6a
NC
8197 symbolS *left = exp->X_add_symbol;
8198 symbolS *right = exp->X_op_symbol;
3739860c 8199
6a7eedfe
BW
8200 /* Difference of two symbols not in the same section
8201 are handled with relocations in the linker. */
8202 if (S_GET_SEGMENT (left) == S_GET_SEGMENT (right))
8203 {
8204 fragS *start;
8205 fragS *end;
983f90e3 8206 fragS *walk;
6a7eedfe 8207
3739860c 8208 if (symbol_get_frag (left)->fr_address
6a7eedfe
BW
8209 <= symbol_get_frag (right)->fr_address)
8210 {
8211 start = symbol_get_frag (left);
8212 end = symbol_get_frag (right);
8213 }
8214 else
8215 {
8216 start = symbol_get_frag (right);
8217 end = symbol_get_frag (left);
8218 }
983f90e3
SA
8219
8220 if (start->tc_frag_data.no_transform_end != NULL)
8221 walk = start->tc_frag_data.no_transform_end;
8222 else
8223 walk = start;
3739860c 8224 do
6a7eedfe 8225 {
983f90e3
SA
8226 walk->tc_frag_data.is_no_transform = 1;
8227 walk = walk->fr_next;
6a7eedfe 8228 }
983f90e3
SA
8229 while (walk && walk->fr_address < end->fr_address);
8230
8231 start->tc_frag_data.no_transform_end = walk;
6a7eedfe
BW
8232 }
8233 }
8234 }
8235}
8236
8237
e0001a05
NC
8238/* Re-process all of the fragments looking to convert all of the
8239 RELAX_ADD_NOP_IF_A0_B_RETW. If the next instruction is a
8240 conditional branch or a retw/retw.n, convert this frag to one that
8241 will generate a NOP. In any case close it off with a .fill 0. */
8242
7fa3d080
BW
8243static bfd_boolean next_instrs_are_b_retw (fragS *);
8244
e0001a05 8245static void
7fa3d080 8246xtensa_fix_a0_b_retw_frags (void)
e0001a05
NC
8247{
8248 frchainS *frchP;
c9049d30 8249 asection *s;
e0001a05
NC
8250
8251 /* When this routine is called, all of the subsections are still intact
8252 so we walk over subsections instead of sections. */
c9049d30
AM
8253 for (s = stdoutput->sections; s; s = s->next)
8254 for (frchP = seg_info (s)->frchainP; frchP; frchP = frchP->frch_next)
8255 {
8256 fragS *fragP;
e0001a05 8257
c9049d30
AM
8258 /* Walk over all of the fragments in a subsection. */
8259 for (fragP = frchP->frch_root; fragP; fragP = fragP->fr_next)
8260 {
8261 if (fragP->fr_type == rs_machine_dependent
8262 && fragP->fr_subtype == RELAX_ADD_NOP_IF_A0_B_RETW)
8263 {
8264 if (next_instrs_are_b_retw (fragP))
8265 {
8266 if (fragP->tc_frag_data.is_no_transform)
8267 as_bad (_("instruction sequence (write a0, branch, retw) may trigger hardware errata"));
8268 else
8269 relax_frag_add_nop (fragP);
8270 }
8271 frag_wane (fragP);
8272 }
8273 }
8274 }
e0001a05
NC
8275}
8276
8277
7fa3d080
BW
8278static bfd_boolean
8279next_instrs_are_b_retw (fragS *fragP)
e0001a05
NC
8280{
8281 xtensa_opcode opcode;
43cd72b9 8282 xtensa_format fmt;
e0001a05
NC
8283 const fragS *next_fragP = next_non_empty_frag (fragP);
8284 static xtensa_insnbuf insnbuf = NULL;
43cd72b9 8285 static xtensa_insnbuf slotbuf = NULL;
e0001a05
NC
8286 xtensa_isa isa = xtensa_default_isa;
8287 int offset = 0;
43cd72b9
BW
8288 int slot;
8289 bfd_boolean branch_seen = FALSE;
e0001a05
NC
8290
8291 if (!insnbuf)
43cd72b9
BW
8292 {
8293 insnbuf = xtensa_insnbuf_alloc (isa);
8294 slotbuf = xtensa_insnbuf_alloc (isa);
8295 }
e0001a05
NC
8296
8297 if (next_fragP == NULL)
8298 return FALSE;
8299
8300 /* Check for the conditional branch. */
d77b99c9
BW
8301 xtensa_insnbuf_from_chars
8302 (isa, insnbuf, (unsigned char *) &next_fragP->fr_literal[offset], 0);
43cd72b9
BW
8303 fmt = xtensa_format_decode (isa, insnbuf);
8304 if (fmt == XTENSA_UNDEFINED)
8305 return FALSE;
8306
8307 for (slot = 0; slot < xtensa_format_num_slots (isa, fmt); slot++)
8308 {
8309 xtensa_format_get_slot (isa, fmt, slot, insnbuf, slotbuf);
8310 opcode = xtensa_opcode_decode (isa, fmt, slot, slotbuf);
8311
8312 branch_seen = (branch_seen
8313 || xtensa_opcode_is_branch (isa, opcode) == 1);
8314 }
e0001a05 8315
43cd72b9 8316 if (!branch_seen)
e0001a05
NC
8317 return FALSE;
8318
43cd72b9 8319 offset += xtensa_format_length (isa, fmt);
e0001a05
NC
8320 if (offset == next_fragP->fr_fix)
8321 {
8322 next_fragP = next_non_empty_frag (next_fragP);
8323 offset = 0;
8324 }
43cd72b9 8325
e0001a05
NC
8326 if (next_fragP == NULL)
8327 return FALSE;
8328
8329 /* Check for the retw/retw.n. */
d77b99c9
BW
8330 xtensa_insnbuf_from_chars
8331 (isa, insnbuf, (unsigned char *) &next_fragP->fr_literal[offset], 0);
43cd72b9
BW
8332 fmt = xtensa_format_decode (isa, insnbuf);
8333
8334 /* Because RETW[.N] is not bundleable, a VLIW bundle here means that we
8335 have no problems. */
8336 if (fmt == XTENSA_UNDEFINED
8337 || xtensa_format_num_slots (isa, fmt) != 1)
8338 return FALSE;
8339
8340 xtensa_format_get_slot (isa, fmt, 0, insnbuf, slotbuf);
8341 opcode = xtensa_opcode_decode (isa, fmt, 0, slotbuf);
e0001a05 8342
b08b5071 8343 if (opcode == xtensa_retw_opcode || opcode == xtensa_retw_n_opcode)
e0001a05 8344 return TRUE;
43cd72b9 8345
e0001a05
NC
8346 return FALSE;
8347}
8348
8349
8350/* Re-process all of the fragments looking to convert all of the
8351 RELAX_ADD_NOP_IF_PRE_LOOP_END. If there is one instruction and a
8352 loop end label, convert this frag to one that will generate a NOP.
8353 In any case close it off with a .fill 0. */
8354
7fa3d080
BW
8355static bfd_boolean next_instr_is_loop_end (fragS *);
8356
e0001a05 8357static void
7fa3d080 8358xtensa_fix_b_j_loop_end_frags (void)
e0001a05
NC
8359{
8360 frchainS *frchP;
c9049d30 8361 asection *s;
e0001a05
NC
8362
8363 /* When this routine is called, all of the subsections are still intact
8364 so we walk over subsections instead of sections. */
c9049d30
AM
8365 for (s = stdoutput->sections; s; s = s->next)
8366 for (frchP = seg_info (s)->frchainP; frchP; frchP = frchP->frch_next)
8367 {
8368 fragS *fragP;
e0001a05 8369
c9049d30
AM
8370 /* Walk over all of the fragments in a subsection. */
8371 for (fragP = frchP->frch_root; fragP; fragP = fragP->fr_next)
8372 {
8373 if (fragP->fr_type == rs_machine_dependent
8374 && fragP->fr_subtype == RELAX_ADD_NOP_IF_PRE_LOOP_END)
8375 {
8376 if (next_instr_is_loop_end (fragP))
8377 {
8378 if (fragP->tc_frag_data.is_no_transform)
8379 as_bad (_("branching or jumping to a loop end may trigger hardware errata"));
8380 else
8381 relax_frag_add_nop (fragP);
8382 }
8383 frag_wane (fragP);
8384 }
8385 }
8386 }
e0001a05
NC
8387}
8388
8389
7fa3d080
BW
8390static bfd_boolean
8391next_instr_is_loop_end (fragS *fragP)
e0001a05
NC
8392{
8393 const fragS *next_fragP;
8394
8395 if (next_frag_is_loop_target (fragP))
8396 return FALSE;
8397
8398 next_fragP = next_non_empty_frag (fragP);
8399 if (next_fragP == NULL)
8400 return FALSE;
8401
8402 if (!next_frag_is_loop_target (next_fragP))
8403 return FALSE;
8404
8405 /* If the size is >= 3 then there is more than one instruction here.
8406 The hardware bug will not fire. */
8407 if (next_fragP->fr_fix > 3)
8408 return FALSE;
8409
8410 return TRUE;
8411}
8412
8413
8414/* Re-process all of the fragments looking to convert all of the
8415 RELAX_ADD_NOP_IF_CLOSE_LOOP_END. If there is an loop end that is
8416 not MY loop's loop end within 12 bytes, add enough nops here to
8417 make it at least 12 bytes away. In any case close it off with a
8418 .fill 0. */
8419
d77b99c9 8420static offsetT min_bytes_to_other_loop_end
05d58145 8421 (fragS *, fragS *, offsetT);
7fa3d080 8422
e0001a05 8423static void
7fa3d080 8424xtensa_fix_close_loop_end_frags (void)
e0001a05
NC
8425{
8426 frchainS *frchP;
c9049d30 8427 asection *s;
e0001a05
NC
8428
8429 /* When this routine is called, all of the subsections are still intact
8430 so we walk over subsections instead of sections. */
c9049d30
AM
8431 for (s = stdoutput->sections; s; s = s->next)
8432 for (frchP = seg_info (s)->frchainP; frchP; frchP = frchP->frch_next)
8433 {
8434 fragS *fragP;
e0001a05 8435
c9049d30 8436 fragS *current_target = NULL;
e0001a05 8437
c9049d30
AM
8438 /* Walk over all of the fragments in a subsection. */
8439 for (fragP = frchP->frch_root; fragP; fragP = fragP->fr_next)
8440 {
8441 if (fragP->fr_type == rs_machine_dependent
8442 && ((fragP->fr_subtype == RELAX_ALIGN_NEXT_OPCODE)
8443 || (fragP->fr_subtype == RELAX_CHECK_ALIGN_NEXT_OPCODE)))
05d58145 8444 current_target = symbol_get_frag (fragP->fr_symbol);
e0001a05 8445
c9049d30
AM
8446 if (current_target
8447 && fragP->fr_type == rs_machine_dependent
8448 && fragP->fr_subtype == RELAX_ADD_NOP_IF_CLOSE_LOOP_END)
8449 {
8450 offsetT min_bytes;
8451 int bytes_added = 0;
e0001a05
NC
8452
8453#define REQUIRED_LOOP_DIVIDING_BYTES 12
c9049d30
AM
8454 /* Max out at 12. */
8455 min_bytes = min_bytes_to_other_loop_end
8456 (fragP->fr_next, current_target, REQUIRED_LOOP_DIVIDING_BYTES);
8457
8458 if (min_bytes < REQUIRED_LOOP_DIVIDING_BYTES)
8459 {
8460 if (fragP->tc_frag_data.is_no_transform)
8461 as_bad (_("loop end too close to another loop end may trigger hardware errata"));
8462 else
8463 {
8464 while (min_bytes + bytes_added
8465 < REQUIRED_LOOP_DIVIDING_BYTES)
8466 {
8467 int length = 3;
8468
8469 if (fragP->fr_var < length)
8470 as_fatal (_("fr_var %lu < length %d"),
8471 (long) fragP->fr_var, length);
8472 else
8473 {
8474 assemble_nop (length,
8475 fragP->fr_literal + fragP->fr_fix);
8476 fragP->fr_fix += length;
8477 fragP->fr_var -= length;
8478 }
8479 bytes_added += length;
8480 }
8481 }
8482 }
8483 frag_wane (fragP);
8484 }
9c2799c2 8485 gas_assert (fragP->fr_type != rs_machine_dependent
c9049d30
AM
8486 || fragP->fr_subtype != RELAX_ADD_NOP_IF_CLOSE_LOOP_END);
8487 }
8488 }
e0001a05
NC
8489}
8490
8491
d77b99c9 8492static offsetT unrelaxed_frag_min_size (fragS *);
7fa3d080 8493
d77b99c9 8494static offsetT
7fa3d080
BW
8495min_bytes_to_other_loop_end (fragS *fragP,
8496 fragS *current_target,
d77b99c9 8497 offsetT max_size)
e0001a05 8498{
d77b99c9 8499 offsetT offset = 0;
e0001a05
NC
8500 fragS *current_fragP;
8501
8502 for (current_fragP = fragP;
8503 current_fragP;
8504 current_fragP = current_fragP->fr_next)
8505 {
8506 if (current_fragP->tc_frag_data.is_loop_target
8507 && current_fragP != current_target)
05d58145 8508 return offset;
e0001a05
NC
8509
8510 offset += unrelaxed_frag_min_size (current_fragP);
8511
05d58145 8512 if (offset >= max_size)
e0001a05
NC
8513 return max_size;
8514 }
8515 return max_size;
8516}
8517
8518
d77b99c9 8519static offsetT
7fa3d080 8520unrelaxed_frag_min_size (fragS *fragP)
e0001a05 8521{
d77b99c9 8522 offsetT size = fragP->fr_fix;
e0001a05 8523
d77b99c9 8524 /* Add fill size. */
e0001a05
NC
8525 if (fragP->fr_type == rs_fill)
8526 size += fragP->fr_offset;
8527
8528 return size;
8529}
8530
8531
d77b99c9 8532static offsetT
7fa3d080 8533unrelaxed_frag_max_size (fragS *fragP)
43cd72b9 8534{
d77b99c9 8535 offsetT size = fragP->fr_fix;
43cd72b9
BW
8536 switch (fragP->fr_type)
8537 {
8538 case 0:
c138bc38 8539 /* Empty frags created by the obstack allocation scheme
43cd72b9
BW
8540 end up with type 0. */
8541 break;
8542 case rs_fill:
8543 case rs_org:
8544 case rs_space:
8545 size += fragP->fr_offset;
8546 break;
8547 case rs_align:
8548 case rs_align_code:
8549 case rs_align_test:
8550 case rs_leb128:
8551 case rs_cfa:
8552 case rs_dwarf2dbg:
8553 /* No further adjustments needed. */
8554 break;
8555 case rs_machine_dependent:
8556 if (fragP->fr_subtype != RELAX_DESIRE_ALIGN)
8557 size += fragP->fr_var;
8558 break;
8559 default:
8560 /* We had darn well better know how big it is. */
9c2799c2 8561 gas_assert (0);
43cd72b9
BW
8562 break;
8563 }
8564
8565 return size;
8566}
8567
8568
e0001a05
NC
8569/* Re-process all of the fragments looking to convert all
8570 of the RELAX_ADD_NOP_IF_SHORT_LOOP. If:
8571
8572 A)
8573 1) the instruction size count to the loop end label
8574 is too short (<= 2 instructions),
8575 2) loop has a jump or branch in it
8576
8577 or B)
43cd72b9 8578 1) workaround_all_short_loops is TRUE
e0001a05
NC
8579 2) The generating loop was a 'loopgtz' or 'loopnez'
8580 3) the instruction size count to the loop end label is too short
8581 (<= 2 instructions)
8582 then convert this frag (and maybe the next one) to generate a NOP.
8583 In any case close it off with a .fill 0. */
8584
d77b99c9 8585static int count_insns_to_loop_end (fragS *, bfd_boolean, int);
7fa3d080
BW
8586static bfd_boolean branch_before_loop_end (fragS *);
8587
e0001a05 8588static void
7fa3d080 8589xtensa_fix_short_loop_frags (void)
e0001a05
NC
8590{
8591 frchainS *frchP;
c9049d30 8592 asection *s;
e0001a05
NC
8593
8594 /* When this routine is called, all of the subsections are still intact
8595 so we walk over subsections instead of sections. */
c9049d30
AM
8596 for (s = stdoutput->sections; s; s = s->next)
8597 for (frchP = seg_info (s)->frchainP; frchP; frchP = frchP->frch_next)
8598 {
8599 fragS *fragP;
c9049d30 8600 xtensa_opcode current_opcode = XTENSA_UNDEFINED;
e0001a05 8601
c9049d30
AM
8602 /* Walk over all of the fragments in a subsection. */
8603 for (fragP = frchP->frch_root; fragP; fragP = fragP->fr_next)
8604 {
8605 if (fragP->fr_type == rs_machine_dependent
8606 && ((fragP->fr_subtype == RELAX_ALIGN_NEXT_OPCODE)
8607 || (fragP->fr_subtype == RELAX_CHECK_ALIGN_NEXT_OPCODE)))
8608 {
8609 TInsn t_insn;
8610 fragS *loop_frag = next_non_empty_frag (fragP);
8611 tinsn_from_chars (&t_insn, loop_frag->fr_opcode, 0);
c9049d30 8612 current_opcode = t_insn.opcode;
9c2799c2 8613 gas_assert (xtensa_opcode_is_loop (xtensa_default_isa,
64b607e6 8614 current_opcode) == 1);
c9049d30 8615 }
e0001a05 8616
c9049d30
AM
8617 if (fragP->fr_type == rs_machine_dependent
8618 && fragP->fr_subtype == RELAX_ADD_NOP_IF_SHORT_LOOP)
8619 {
8620 if (count_insns_to_loop_end (fragP->fr_next, TRUE, 3) < 3
8621 && (branch_before_loop_end (fragP->fr_next)
8622 || (workaround_all_short_loops
8623 && current_opcode != XTENSA_UNDEFINED
8624 && current_opcode != xtensa_loop_opcode)))
8625 {
8626 if (fragP->tc_frag_data.is_no_transform)
8627 as_bad (_("loop containing less than three instructions may trigger hardware errata"));
8628 else
8629 relax_frag_add_nop (fragP);
8630 }
8631 frag_wane (fragP);
8632 }
8633 }
8634 }
e0001a05
NC
8635}
8636
8637
d77b99c9 8638static int unrelaxed_frag_min_insn_count (fragS *);
7fa3d080 8639
d77b99c9 8640static int
7fa3d080
BW
8641count_insns_to_loop_end (fragS *base_fragP,
8642 bfd_boolean count_relax_add,
d77b99c9 8643 int max_count)
e0001a05
NC
8644{
8645 fragS *fragP = NULL;
d77b99c9 8646 int insn_count = 0;
e0001a05
NC
8647
8648 fragP = base_fragP;
8649
8650 for (; fragP && !fragP->tc_frag_data.is_loop_target; fragP = fragP->fr_next)
8651 {
8652 insn_count += unrelaxed_frag_min_insn_count (fragP);
8653 if (insn_count >= max_count)
8654 return max_count;
8655
8656 if (count_relax_add)
8657 {
8658 if (fragP->fr_type == rs_machine_dependent
8659 && fragP->fr_subtype == RELAX_ADD_NOP_IF_SHORT_LOOP)
8660 {
8661 /* In order to add the appropriate number of
8662 NOPs, we count an instruction for downstream
8663 occurrences. */
8664 insn_count++;
8665 if (insn_count >= max_count)
8666 return max_count;
8667 }
8668 }
8669 }
8670 return insn_count;
8671}
8672
8673
d77b99c9 8674static int
7fa3d080 8675unrelaxed_frag_min_insn_count (fragS *fragP)
e0001a05 8676{
43cd72b9
BW
8677 xtensa_isa isa = xtensa_default_isa;
8678 static xtensa_insnbuf insnbuf = NULL;
d77b99c9 8679 int insn_count = 0;
e0001a05
NC
8680 int offset = 0;
8681
8682 if (!fragP->tc_frag_data.is_insn)
8683 return insn_count;
8684
43cd72b9
BW
8685 if (!insnbuf)
8686 insnbuf = xtensa_insnbuf_alloc (isa);
8687
e0001a05
NC
8688 /* Decode the fixed instructions. */
8689 while (offset < fragP->fr_fix)
8690 {
43cd72b9
BW
8691 xtensa_format fmt;
8692
d77b99c9
BW
8693 xtensa_insnbuf_from_chars
8694 (isa, insnbuf, (unsigned char *) fragP->fr_literal + offset, 0);
43cd72b9
BW
8695 fmt = xtensa_format_decode (isa, insnbuf);
8696
8697 if (fmt == XTENSA_UNDEFINED)
e0001a05
NC
8698 {
8699 as_fatal (_("undecodable instruction in instruction frag"));
8700 return insn_count;
8701 }
43cd72b9 8702 offset += xtensa_format_length (isa, fmt);
e0001a05
NC
8703 insn_count++;
8704 }
8705
8706 return insn_count;
8707}
8708
8709
7fa3d080
BW
8710static bfd_boolean unrelaxed_frag_has_b_j (fragS *);
8711
43cd72b9 8712static bfd_boolean
7fa3d080 8713branch_before_loop_end (fragS *base_fragP)
e0001a05
NC
8714{
8715 fragS *fragP;
8716
8717 for (fragP = base_fragP;
8718 fragP && !fragP->tc_frag_data.is_loop_target;
8719 fragP = fragP->fr_next)
8720 {
8721 if (unrelaxed_frag_has_b_j (fragP))
8722 return TRUE;
8723 }
8724 return FALSE;
8725}
8726
8727
43cd72b9 8728static bfd_boolean
7fa3d080 8729unrelaxed_frag_has_b_j (fragS *fragP)
e0001a05 8730{
43cd72b9
BW
8731 static xtensa_insnbuf insnbuf = NULL;
8732 xtensa_isa isa = xtensa_default_isa;
e0001a05
NC
8733 int offset = 0;
8734
8735 if (!fragP->tc_frag_data.is_insn)
8736 return FALSE;
8737
43cd72b9
BW
8738 if (!insnbuf)
8739 insnbuf = xtensa_insnbuf_alloc (isa);
8740
e0001a05
NC
8741 /* Decode the fixed instructions. */
8742 while (offset < fragP->fr_fix)
8743 {
43cd72b9
BW
8744 xtensa_format fmt;
8745 int slot;
8746
d77b99c9
BW
8747 xtensa_insnbuf_from_chars
8748 (isa, insnbuf, (unsigned char *) fragP->fr_literal + offset, 0);
43cd72b9
BW
8749 fmt = xtensa_format_decode (isa, insnbuf);
8750 if (fmt == XTENSA_UNDEFINED)
8751 return FALSE;
8752
8753 for (slot = 0; slot < xtensa_format_num_slots (isa, fmt); slot++)
e0001a05 8754 {
43cd72b9
BW
8755 xtensa_opcode opcode =
8756 get_opcode_from_buf (fragP->fr_literal + offset, slot);
8757 if (xtensa_opcode_is_branch (isa, opcode) == 1
8758 || xtensa_opcode_is_jump (isa, opcode) == 1)
8759 return TRUE;
e0001a05 8760 }
43cd72b9 8761 offset += xtensa_format_length (isa, fmt);
e0001a05
NC
8762 }
8763 return FALSE;
8764}
8765
8766
8767/* Checks to be made after initial assembly but before relaxation. */
8768
7fa3d080
BW
8769static bfd_boolean is_empty_loop (const TInsn *, fragS *);
8770static bfd_boolean is_local_forward_loop (const TInsn *, fragS *);
8771
e0001a05 8772static void
7fa3d080 8773xtensa_sanity_check (void)
e0001a05 8774{
3b4dbbbf 8775 const char *file_name;
d77b99c9 8776 unsigned line;
e0001a05 8777 frchainS *frchP;
c9049d30 8778 asection *s;
e0001a05 8779
3b4dbbbf 8780 file_name = as_where (&line);
c9049d30
AM
8781 for (s = stdoutput->sections; s; s = s->next)
8782 for (frchP = seg_info (s)->frchainP; frchP; frchP = frchP->frch_next)
8783 {
8784 fragS *fragP;
e0001a05 8785
c9049d30
AM
8786 /* Walk over all of the fragments in a subsection. */
8787 for (fragP = frchP->frch_root; fragP; fragP = fragP->fr_next)
8788 {
c9049d30 8789 if (fragP->fr_type == rs_machine_dependent
3739860c 8790 && fragP->fr_subtype == RELAX_SLOTS
a7284bf1 8791 && fragP->tc_frag_data.slot_subtypes[0] == RELAX_IMMED)
c9049d30
AM
8792 {
8793 static xtensa_insnbuf insnbuf = NULL;
8794 TInsn t_insn;
8795
8796 if (fragP->fr_opcode != NULL)
8797 {
8798 if (!insnbuf)
8799 insnbuf = xtensa_insnbuf_alloc (xtensa_default_isa);
8800 tinsn_from_chars (&t_insn, fragP->fr_opcode, 0);
8801 tinsn_immed_from_frag (&t_insn, fragP, 0);
8802
8803 if (xtensa_opcode_is_loop (xtensa_default_isa,
8804 t_insn.opcode) == 1)
8805 {
8806 if (is_empty_loop (&t_insn, fragP))
8807 {
8808 new_logical_line (fragP->fr_file, fragP->fr_line);
8809 as_bad (_("invalid empty loop"));
8810 }
8811 if (!is_local_forward_loop (&t_insn, fragP))
8812 {
8813 new_logical_line (fragP->fr_file, fragP->fr_line);
8814 as_bad (_("loop target does not follow "
8815 "loop instruction in section"));
8816 }
8817 }
8818 }
8819 }
8820 }
8821 }
e0001a05
NC
8822 new_logical_line (file_name, line);
8823}
8824
8825
8826#define LOOP_IMMED_OPN 1
8827
43cd72b9 8828/* Return TRUE if the loop target is the next non-zero fragment. */
e0001a05 8829
7fa3d080
BW
8830static bfd_boolean
8831is_empty_loop (const TInsn *insn, fragS *fragP)
e0001a05 8832{
91d6fa6a 8833 const expressionS *exp;
e0001a05
NC
8834 symbolS *symbolP;
8835 fragS *next_fragP;
8836
8837 if (insn->insn_type != ITYPE_INSN)
8838 return FALSE;
8839
43cd72b9 8840 if (xtensa_opcode_is_loop (xtensa_default_isa, insn->opcode) != 1)
e0001a05
NC
8841 return FALSE;
8842
8843 if (insn->ntok <= LOOP_IMMED_OPN)
8844 return FALSE;
8845
91d6fa6a 8846 exp = &insn->tok[LOOP_IMMED_OPN];
e0001a05 8847
91d6fa6a 8848 if (exp->X_op != O_symbol)
e0001a05
NC
8849 return FALSE;
8850
91d6fa6a 8851 symbolP = exp->X_add_symbol;
e0001a05
NC
8852 if (!symbolP)
8853 return FALSE;
8854
8855 if (symbol_get_frag (symbolP) == NULL)
8856 return FALSE;
8857
8858 if (S_GET_VALUE (symbolP) != 0)
8859 return FALSE;
8860
8861 /* Walk through the zero-size fragments from this one. If we find
8862 the target fragment, then this is a zero-size loop. */
43cd72b9 8863
e0001a05
NC
8864 for (next_fragP = fragP->fr_next;
8865 next_fragP != NULL;
8866 next_fragP = next_fragP->fr_next)
8867 {
8868 if (next_fragP == symbol_get_frag (symbolP))
8869 return TRUE;
8870 if (next_fragP->fr_fix != 0)
8871 return FALSE;
8872 }
8873 return FALSE;
8874}
8875
8876
7fa3d080
BW
8877static bfd_boolean
8878is_local_forward_loop (const TInsn *insn, fragS *fragP)
e0001a05 8879{
91d6fa6a 8880 const expressionS *exp;
e0001a05
NC
8881 symbolS *symbolP;
8882 fragS *next_fragP;
8883
8884 if (insn->insn_type != ITYPE_INSN)
8885 return FALSE;
8886
64b607e6 8887 if (xtensa_opcode_is_loop (xtensa_default_isa, insn->opcode) != 1)
e0001a05
NC
8888 return FALSE;
8889
8890 if (insn->ntok <= LOOP_IMMED_OPN)
8891 return FALSE;
8892
91d6fa6a 8893 exp = &insn->tok[LOOP_IMMED_OPN];
e0001a05 8894
91d6fa6a 8895 if (exp->X_op != O_symbol)
e0001a05
NC
8896 return FALSE;
8897
91d6fa6a 8898 symbolP = exp->X_add_symbol;
e0001a05
NC
8899 if (!symbolP)
8900 return FALSE;
8901
8902 if (symbol_get_frag (symbolP) == NULL)
8903 return FALSE;
8904
8905 /* Walk through fragments until we find the target.
8906 If we do not find the target, then this is an invalid loop. */
43cd72b9 8907
e0001a05
NC
8908 for (next_fragP = fragP->fr_next;
8909 next_fragP != NULL;
8910 next_fragP = next_fragP->fr_next)
43cd72b9
BW
8911 {
8912 if (next_fragP == symbol_get_frag (symbolP))
8913 return TRUE;
8914 }
e0001a05
NC
8915
8916 return FALSE;
8917}
8918
2caa7ca0
BW
8919
8920#define XTINFO_NAME "Xtensa_Info"
8921#define XTINFO_NAMESZ 12
8922#define XTINFO_TYPE 1
8923
8924static void
8925xtensa_add_config_info (void)
8926{
8927 asection *info_sec;
8928 char *data, *p;
8929 int sz;
8930
8931 info_sec = subseg_new (".xtensa.info", 0);
8932 bfd_set_section_flags (stdoutput, info_sec, SEC_HAS_CONTENTS | SEC_READONLY);
8933
325801bd 8934 data = XNEWVEC (char, 100);
2caa7ca0
BW
8935 sprintf (data, "USE_ABSOLUTE_LITERALS=%d\nABI=%d\n",
8936 XSHAL_USE_ABSOLUTE_LITERALS, XSHAL_ABI);
8937 sz = strlen (data) + 1;
8938
8939 /* Add enough null terminators to pad to a word boundary. */
8940 do
8941 data[sz++] = 0;
8942 while ((sz & 3) != 0);
8943
8944 /* Follow the standard note section layout:
8945 First write the length of the name string. */
8946 p = frag_more (4);
8947 md_number_to_chars (p, (valueT) XTINFO_NAMESZ, 4);
8948
8949 /* Next comes the length of the "descriptor", i.e., the actual data. */
8950 p = frag_more (4);
8951 md_number_to_chars (p, (valueT) sz, 4);
8952
8953 /* Write the note type. */
8954 p = frag_more (4);
8955 md_number_to_chars (p, (valueT) XTINFO_TYPE, 4);
8956
8957 /* Write the name field. */
8958 p = frag_more (XTINFO_NAMESZ);
8959 memcpy (p, XTINFO_NAME, XTINFO_NAMESZ);
8960
8961 /* Finally, write the descriptor. */
8962 p = frag_more (sz);
8963 memcpy (p, data, sz);
8964
8965 free (data);
8966}
8967
e0001a05
NC
8968\f
8969/* Alignment Functions. */
8970
d77b99c9
BW
8971static int
8972get_text_align_power (unsigned target_size)
e0001a05 8973{
03aaa593
BW
8974 if (target_size <= 4)
8975 return 2;
19ef5f3d
SA
8976
8977 if (target_size <= 8)
8978 return 3;
8979
8980 if (target_size <= 16)
8981 return 4;
8982
8983 if (target_size <= 32)
8984 return 5;
8985
8986 if (target_size <= 64)
8987 return 6;
8988
8989 if (target_size <= 128)
8990 return 7;
8991
8992 if (target_size <= 256)
8993 return 8;
8994
8995 if (target_size <= 512)
8996 return 9;
8997
8998 if (target_size <= 1024)
8999 return 10;
9000
9001 gas_assert (0);
9002 return 0;
e0001a05
NC
9003}
9004
9005
d77b99c9 9006static int
7fa3d080
BW
9007get_text_align_max_fill_size (int align_pow,
9008 bfd_boolean use_nops,
9009 bfd_boolean use_no_density)
e0001a05
NC
9010{
9011 if (!use_nops)
9012 return (1 << align_pow);
9013 if (use_no_density)
9014 return 3 * (1 << align_pow);
9015
9016 return 1 + (1 << align_pow);
9017}
9018
9019
d77b99c9
BW
9020/* Calculate the minimum bytes of fill needed at "address" to align a
9021 target instruction of size "target_size" so that it does not cross a
9022 power-of-two boundary specified by "align_pow". If "use_nops" is FALSE,
9023 the fill can be an arbitrary number of bytes. Otherwise, the space must
9024 be filled by NOP instructions. */
e0001a05 9025
d77b99c9 9026static int
7fa3d080
BW
9027get_text_align_fill_size (addressT address,
9028 int align_pow,
9029 int target_size,
9030 bfd_boolean use_nops,
9031 bfd_boolean use_no_density)
e0001a05 9032{
d77b99c9
BW
9033 addressT alignment, fill, fill_limit, fill_step;
9034 bfd_boolean skip_one = FALSE;
e0001a05 9035
d77b99c9 9036 alignment = (1 << align_pow);
9c2799c2 9037 gas_assert (target_size > 0 && alignment >= (addressT) target_size);
c138bc38 9038
e0001a05
NC
9039 if (!use_nops)
9040 {
d77b99c9
BW
9041 fill_limit = alignment;
9042 fill_step = 1;
e0001a05 9043 }
d77b99c9 9044 else if (!use_no_density)
e0001a05 9045 {
d77b99c9
BW
9046 /* Combine 2- and 3-byte NOPs to fill anything larger than one. */
9047 fill_limit = alignment * 2;
9048 fill_step = 1;
9049 skip_one = TRUE;
e0001a05
NC
9050 }
9051 else
9052 {
d77b99c9
BW
9053 /* Fill with 3-byte NOPs -- can only fill multiples of 3. */
9054 fill_limit = alignment * 3;
9055 fill_step = 3;
9056 }
e0001a05 9057
d77b99c9
BW
9058 /* Try all fill sizes until finding one that works. */
9059 for (fill = 0; fill < fill_limit; fill += fill_step)
9060 {
9061 if (skip_one && fill == 1)
9062 continue;
9063 if ((address + fill) >> align_pow
9064 == (address + fill + target_size - 1) >> align_pow)
9065 return fill;
e0001a05 9066 }
9c2799c2 9067 gas_assert (0);
e0001a05
NC
9068 return 0;
9069}
9070
9071
664df4e4
BW
9072static int
9073branch_align_power (segT sec)
9074{
19ef5f3d
SA
9075 /* If the Xtensa processor has a fetch width of X, and
9076 the section is aligned to at least that boundary, then a branch
9077 target need only fit within that aligned block of memory to avoid
9078 a stall. Otherwise, try to fit branch targets within 4-byte
9079 aligned blocks (which may be insufficient, e.g., if the section
9080 has no alignment, but it's good enough). */
9081 int fetch_align = get_text_align_power(xtensa_fetch_width);
9082 int sec_align = get_recorded_alignment (sec);
9083
9084 if (sec_align >= fetch_align)
9085 return fetch_align;
664df4e4
BW
9086
9087 return 2;
9088}
9089
9090
e0001a05
NC
9091/* This will assert if it is not possible. */
9092
d77b99c9
BW
9093static int
9094get_text_align_nop_count (offsetT fill_size, bfd_boolean use_no_density)
e0001a05 9095{
d77b99c9
BW
9096 int count = 0;
9097
e0001a05
NC
9098 if (use_no_density)
9099 {
9c2799c2 9100 gas_assert (fill_size % 3 == 0);
e0001a05
NC
9101 return (fill_size / 3);
9102 }
9103
9c2799c2 9104 gas_assert (fill_size != 1); /* Bad argument. */
e0001a05
NC
9105
9106 while (fill_size > 1)
9107 {
d77b99c9 9108 int insn_size = 3;
e0001a05
NC
9109 if (fill_size == 2 || fill_size == 4)
9110 insn_size = 2;
9111 fill_size -= insn_size;
9112 count++;
9113 }
9c2799c2 9114 gas_assert (fill_size != 1); /* Bad algorithm. */
e0001a05
NC
9115 return count;
9116}
9117
9118
d77b99c9
BW
9119static int
9120get_text_align_nth_nop_size (offsetT fill_size,
9121 int n,
7fa3d080 9122 bfd_boolean use_no_density)
e0001a05 9123{
d77b99c9 9124 int count = 0;
e0001a05
NC
9125
9126 if (use_no_density)
9127 return 3;
9128
9c2799c2 9129 gas_assert (fill_size != 1); /* Bad argument. */
d77b99c9 9130
e0001a05
NC
9131 while (fill_size > 1)
9132 {
d77b99c9 9133 int insn_size = 3;
e0001a05
NC
9134 if (fill_size == 2 || fill_size == 4)
9135 insn_size = 2;
9136 fill_size -= insn_size;
9137 count++;
9138 if (n + 1 == count)
9139 return insn_size;
9140 }
9c2799c2 9141 gas_assert (0);
e0001a05
NC
9142 return 0;
9143}
9144
9145
9146/* For the given fragment, find the appropriate address
9147 for it to begin at if we are using NOPs to align it. */
9148
9149static addressT
7fa3d080 9150get_noop_aligned_address (fragS *fragP, addressT address)
e0001a05 9151{
43cd72b9
BW
9152 /* The rule is: get next fragment's FIRST instruction. Find
9153 the smallest number of bytes that need to be added to
9154 ensure that the next fragment's FIRST instruction will fit
9155 in a single word.
c138bc38 9156
43cd72b9
BW
9157 E.G., 2 bytes : 0, 1, 2 mod 4
9158 3 bytes: 0, 1 mod 4
c138bc38 9159
43cd72b9
BW
9160 If the FIRST instruction MIGHT be relaxed,
9161 assume that it will become a 3-byte instruction.
c138bc38 9162
43cd72b9
BW
9163 Note again here that LOOP instructions are not bundleable,
9164 and this relaxation only applies to LOOP opcodes. */
c138bc38 9165
d77b99c9 9166 int fill_size = 0;
43cd72b9
BW
9167 int first_insn_size;
9168 int loop_insn_size;
9169 addressT pre_opcode_bytes;
d77b99c9 9170 int align_power;
43cd72b9
BW
9171 fragS *first_insn;
9172 xtensa_opcode opcode;
9173 bfd_boolean is_loop;
e0001a05 9174
9c2799c2
NC
9175 gas_assert (fragP->fr_type == rs_machine_dependent);
9176 gas_assert (fragP->fr_subtype == RELAX_ALIGN_NEXT_OPCODE);
e0001a05 9177
43cd72b9
BW
9178 /* Find the loop frag. */
9179 first_insn = next_non_empty_frag (fragP);
9180 /* Now find the first insn frag. */
9181 first_insn = next_non_empty_frag (first_insn);
e0001a05 9182
43cd72b9 9183 is_loop = next_frag_opcode_is_loop (fragP, &opcode);
9c2799c2 9184 gas_assert (is_loop);
43cd72b9 9185 loop_insn_size = xg_get_single_size (opcode);
e0001a05 9186
43cd72b9
BW
9187 pre_opcode_bytes = next_frag_pre_opcode_bytes (fragP);
9188 pre_opcode_bytes += loop_insn_size;
e0001a05 9189
43cd72b9
BW
9190 /* For loops, the alignment depends on the size of the
9191 instruction following the loop, not the LOOP instruction. */
e0001a05 9192
43cd72b9 9193 if (first_insn == NULL)
03aaa593
BW
9194 first_insn_size = xtensa_fetch_width;
9195 else
9196 first_insn_size = get_loop_align_size (frag_format_size (first_insn));
e0001a05 9197
43cd72b9 9198 /* If it was 8, then we'll need a larger alignment for the section. */
d77b99c9
BW
9199 align_power = get_text_align_power (first_insn_size);
9200 record_alignment (now_seg, align_power);
c138bc38 9201
43cd72b9 9202 fill_size = get_text_align_fill_size
d77b99c9
BW
9203 (address + pre_opcode_bytes, align_power, first_insn_size, TRUE,
9204 fragP->tc_frag_data.is_no_density);
e0001a05
NC
9205
9206 return address + fill_size;
9207}
9208
9209
43cd72b9
BW
9210/* 3 mechanisms for relaxing an alignment:
9211
9212 Align to a power of 2.
9213 Align so the next fragment's instruction does not cross a word boundary.
9214 Align the current instruction so that if the next instruction
9215 were 3 bytes, it would not cross a word boundary.
9216
e0001a05
NC
9217 We can align with:
9218
43cd72b9
BW
9219 zeros - This is easy; always insert zeros.
9220 nops - 3-byte and 2-byte instructions
9221 2 - 2-byte nop
9222 3 - 3-byte nop
9223 4 - 2 2-byte nops
9224 >=5 : 3-byte instruction + fn (n-3)
e0001a05
NC
9225 widening - widen previous instructions. */
9226
d77b99c9
BW
9227static offsetT
9228get_aligned_diff (fragS *fragP, addressT address, offsetT *max_diff)
e0001a05 9229{
43cd72b9
BW
9230 addressT target_address, loop_insn_offset;
9231 int target_size;
9232 xtensa_opcode loop_opcode;
9233 bfd_boolean is_loop;
d77b99c9
BW
9234 int align_power;
9235 offsetT opt_diff;
5f9084e9 9236 offsetT branch_align;
def13efb 9237 fragS *loop_frag;
e0001a05 9238
9c2799c2 9239 gas_assert (fragP->fr_type == rs_machine_dependent);
43cd72b9 9240 switch (fragP->fr_subtype)
e0001a05 9241 {
43cd72b9
BW
9242 case RELAX_DESIRE_ALIGN:
9243 target_size = next_frag_format_size (fragP);
9244 if (target_size == XTENSA_UNDEFINED)
9245 target_size = 3;
664df4e4
BW
9246 align_power = branch_align_power (now_seg);
9247 branch_align = 1 << align_power;
0e5cd789
BW
9248 /* Don't count on the section alignment being as large as the target. */
9249 if (target_size > branch_align)
9250 target_size = branch_align;
d77b99c9 9251 opt_diff = get_text_align_fill_size (address, align_power,
43cd72b9
BW
9252 target_size, FALSE, FALSE);
9253
664df4e4
BW
9254 *max_diff = (opt_diff + branch_align
9255 - (target_size + ((address + opt_diff) % branch_align)));
9c2799c2 9256 gas_assert (*max_diff >= opt_diff);
43cd72b9 9257 return opt_diff;
e0001a05 9258
43cd72b9 9259 case RELAX_ALIGN_NEXT_OPCODE:
def13efb
BW
9260 /* The next non-empty frag after this one holds the LOOP instruction
9261 that needs to be aligned. The required alignment depends on the
9262 size of the next non-empty frag after the loop frag, i.e., the
9263 first instruction in the loop. */
9264 loop_frag = next_non_empty_frag (fragP);
9265 target_size = get_loop_align_size (next_frag_format_size (loop_frag));
43cd72b9
BW
9266 loop_insn_offset = 0;
9267 is_loop = next_frag_opcode_is_loop (fragP, &loop_opcode);
9c2799c2 9268 gas_assert (is_loop);
43cd72b9
BW
9269
9270 /* If the loop has been expanded then the LOOP instruction
9271 could be at an offset from this fragment. */
def13efb 9272 if (loop_frag->tc_frag_data.slot_subtypes[0] != RELAX_IMMED)
43cd72b9
BW
9273 loop_insn_offset = get_expanded_loop_offset (loop_opcode);
9274
43cd72b9
BW
9275 /* In an ideal world, which is what we are shooting for here,
9276 we wouldn't need to use any NOPs immediately prior to the
9277 LOOP instruction. If this approach fails, relax_frag_loop_align
9278 will call get_noop_aligned_address. */
9279 target_address =
9280 address + loop_insn_offset + xg_get_single_size (loop_opcode);
def13efb 9281 align_power = get_text_align_power (target_size);
d77b99c9 9282 opt_diff = get_text_align_fill_size (target_address, align_power,
43cd72b9
BW
9283 target_size, FALSE, FALSE);
9284
9285 *max_diff = xtensa_fetch_width
9286 - ((target_address + opt_diff) % xtensa_fetch_width)
9287 - target_size + opt_diff;
9c2799c2 9288 gas_assert (*max_diff >= opt_diff);
43cd72b9 9289 return opt_diff;
e0001a05 9290
43cd72b9
BW
9291 default:
9292 break;
e0001a05 9293 }
9c2799c2 9294 gas_assert (0);
43cd72b9 9295 return 0;
e0001a05
NC
9296}
9297
9298\f
9299/* md_relax_frag Hook and Helper Functions. */
9300
7fa3d080
BW
9301static long relax_frag_loop_align (fragS *, long);
9302static long relax_frag_for_align (fragS *, long);
9303static long relax_frag_immed
9304 (segT, fragS *, long, int, xtensa_format, int, int *, bfd_boolean);
9305
fe6c2f1b
MF
9306/* Get projected address for the first fulcrum on a path from source to
9307 target. */
9308static addressT xg_get_fulcrum (addressT source, addressT target)
b76f99d7 9309{
fe6c2f1b
MF
9310 offsetT delta = target - source;
9311 int n;
b76f99d7 9312
fe6c2f1b
MF
9313 n = (labs (delta) + J_RANGE - J_MARGIN - 1) / (J_RANGE - J_MARGIN);
9314 return source + delta / n;
9315}
b76f99d7 9316
fe6c2f1b
MF
9317/* Given trampoline index, source and target of a jump find the best
9318 candidate trampoline for the first fulcrum. The best trampoline is
9319 the one in the reach of "j' instruction from the source, closest to
9320 the projected fulcrum address, and preferrably w/o a jump around or
9321 with already initialized jump around. */
9322static size_t xg_find_best_trampoline (struct trampoline_index *idx,
9323 addressT source, addressT target)
b76f99d7 9324{
fe6c2f1b
MF
9325 addressT fulcrum = xg_get_fulcrum (source, target);
9326 size_t dist = 0;
9327 size_t best = -1;
9328 size_t base_tr = xg_find_trampoline (idx, fulcrum);
9329 int checked = 1;
b76f99d7 9330
fe6c2f1b
MF
9331 /* Check trampoline frags around the base_tr to find the best. */
9332 for (dist = 0; checked; ++dist)
b76f99d7 9333 {
fe6c2f1b
MF
9334 int i;
9335 size_t tr = base_tr - dist;
9336
9337 checked = 0;
9338
9339 /* Trampolines are checked in the following order:
9340 base_tr, base_tr + 1, base_tr - 1, base_tr + 2, base_tr - 2 */
9341 for (i = 0; i < 2; ++i, tr = base_tr + dist + 1)
9342 if (tr < idx->n_entries)
9343 {
9344 fragS *trampoline_frag = idx->entry[tr];
9345 offsetT off;
9346
9347 /* Don't check trampolines outside source - target interval. */
9348 if ((trampoline_frag->fr_address < source &&
9349 trampoline_frag->fr_address < target) ||
9350 (trampoline_frag->fr_address > source &&
9351 trampoline_frag->fr_address > target))
9352 continue;
9353
db5d5ad1
MF
9354 /* Don't choose trampoline that contains the source. */
9355 if (source >= trampoline_frag->fr_address
9356 && source <= trampoline_frag->fr_address +
9357 trampoline_frag->fr_fix)
9358 continue;
9359
fe6c2f1b
MF
9360 off = trampoline_frag->fr_address - fulcrum;
9361 /* Stop if some trampoline is found and the search is more than
9362 J_RANGE / 4 from the projected fulcrum. A trampoline w/o jump
9363 around is nice, but it shouldn't have much overhead. */
9364 if (best < idx->n_entries && labs (off) > J_RANGE / 4)
9365 return best;
9366
9367 off = trampoline_frag->fr_address - source;
9368 if (labs (off) < J_RANGE - J_MARGIN)
9369 {
9370 ++checked;
9371 /* Stop if a trampoline w/o jump around is found or initialized
9372 trampoline with jump around is found. */
9373 if (!trampoline_frag->tc_frag_data.needs_jump_around ||
9374 trampoline_frag->fr_fix)
9375 return tr;
9376 else if (best >= idx->n_entries)
9377 best = tr;
9378 }
9379 }
b76f99d7 9380 }
fe6c2f1b
MF
9381
9382 if (best < idx->n_entries)
9383 return best;
9384 else
9385 as_fatal (_("cannot find suitable trampoline"));
b76f99d7
MF
9386}
9387
fe6c2f1b
MF
9388static fixS *xg_relax_fixup (struct trampoline_index *idx, fixS *fixP)
9389{
9390 symbolS *s = fixP->fx_addsy;
9391 addressT source = fixP->fx_frag->fr_address;
9392 addressT target = S_GET_VALUE (s) + fixP->fx_offset;
9393 size_t tr = xg_find_best_trampoline (idx, source, target);
9394 fragS *trampoline_frag = idx->entry[tr];
9395 fixS *newfixP;
9396
9397 init_trampoline_frag (trampoline_frag);
9398 newfixP = xg_append_jump (trampoline_frag,
9399 fixP->fx_addsy, fixP->fx_offset);
9400
9401 /* Adjust the fixup for the original "j" instruction to
9402 point to the newly added jump. */
9403 fixP->fx_addsy = trampoline_frag->fr_symbol;
9404 fixP->fx_offset = trampoline_frag->fr_fix - 3;
9405 fixP->tc_fix_data.X_add_symbol = trampoline_frag->fr_symbol;
9406 fixP->tc_fix_data.X_add_number = trampoline_frag->fr_fix - 3;
9407
9408 trampoline_frag->tc_frag_data.relax_seen = FALSE;
9409
9410 if (xg_is_trampoline_frag_full (trampoline_frag))
9411 xg_remove_trampoline_from_index (idx, tr);
9412
9413 return newfixP;
9414}
9415
9416static bfd_boolean xg_is_relaxable_fixup (fixS *fixP)
b76f99d7
MF
9417{
9418 xtensa_isa isa = xtensa_default_isa;
fe6c2f1b
MF
9419 addressT addr = fixP->fx_frag->fr_address;
9420 addressT target;
9421 offsetT delta;
b76f99d7
MF
9422 symbolS *s = fixP->fx_addsy;
9423 int slot;
9424 xtensa_format fmt;
9425 xtensa_opcode opcode;
9426
9427 if (fixP->fx_r_type < BFD_RELOC_XTENSA_SLOT0_OP ||
9428 fixP->fx_r_type > BFD_RELOC_XTENSA_SLOT14_OP)
9429 return FALSE;
fe6c2f1b
MF
9430
9431 target = S_GET_VALUE (s) + fixP->fx_offset;
b76f99d7
MF
9432 delta = target - addr;
9433
fe6c2f1b 9434 if (labs (delta) < J_RANGE - J_MARGIN)
b76f99d7
MF
9435 return FALSE;
9436
9437 xtensa_insnbuf_from_chars (isa, trampoline_buf,
9438 (unsigned char *) fixP->fx_frag->fr_literal +
9439 fixP->fx_where, 0);
9440 fmt = xtensa_format_decode (isa, trampoline_buf);
9441 gas_assert (fmt != XTENSA_UNDEFINED);
9442 slot = fixP->tc_fix_data.slot;
9443 xtensa_format_get_slot (isa, fmt, slot, trampoline_buf, trampoline_slotbuf);
9444 opcode = xtensa_opcode_decode (isa, fmt, slot, trampoline_slotbuf);
fe6c2f1b 9445 return opcode == xtensa_j_opcode;
b76f99d7
MF
9446}
9447
fe6c2f1b 9448static void xg_relax_fixups (struct trampoline_seg *ts)
b76f99d7 9449{
fe6c2f1b
MF
9450 struct trampoline_index *idx = &ts->index;
9451 segment_info_type *seginfo = seg_info (now_seg);
9452 fixS *fx;
b76f99d7 9453
fe6c2f1b 9454 for (fx = seginfo->fix_root; fx; fx = fx->fx_next)
b76f99d7 9455 {
fe6c2f1b 9456 fixS *fixP = fx;
148d6384
MF
9457 struct trampoline_chain *tc = NULL;
9458
9459 if (xg_is_relaxable_fixup (fixP))
9460 {
9461 tc = xg_find_best_eq_target (ts, fixP->fx_frag->fr_address,
9462 &fixP->fx_addsy, &fixP->fx_offset);
9463 if (!tc)
9464 tc = xg_create_trampoline_chain (ts, fixP->fx_addsy,
9465 fixP->fx_offset);
9466 gas_assert (tc);
9467 }
b76f99d7 9468
fe6c2f1b 9469 while (xg_is_relaxable_fixup (fixP))
148d6384
MF
9470 {
9471 fixP = xg_relax_fixup (idx, fixP);
9472 xg_add_location_to_chain (tc, fixP->fx_frag->fr_symbol,
9473 fixP->fx_where);
9474 }
b76f99d7 9475 }
b76f99d7 9476}
7fa3d080 9477
fe6c2f1b
MF
9478/* Given a trampoline frag relax all jumps that might want to use this
9479 trampoline. Only do real work once per relaxation cycle, when
9480 xg_relax_trampoline is called for the first trampoline in the now_seg.
9481 Don't use stretch, don't update new_stretch: place fulcrums with a
9482 slack to tolerate code movement. In the worst case if a jump between
9483 two trampolines wouldn't reach the next relaxation pass will fix it. */
9484static void xg_relax_trampoline (fragS *fragP, long stretch ATTRIBUTE_UNUSED,
9485 long *new_stretch ATTRIBUTE_UNUSED)
120bc8b8 9486{
fe6c2f1b 9487 struct trampoline_seg *ts = find_trampoline_seg (now_seg);
120bc8b8 9488
fe6c2f1b
MF
9489 if (ts->index.n_entries && ts->index.entry[0] == fragP)
9490 xg_relax_fixups (ts);
120bc8b8
MF
9491}
9492
e0001a05
NC
9493/* Return the number of bytes added to this fragment, given that the
9494 input has been stretched already by "stretch". */
9495
9496long
7fa3d080 9497xtensa_relax_frag (fragS *fragP, long stretch, int *stretched_p)
e0001a05 9498{
43cd72b9 9499 xtensa_isa isa = xtensa_default_isa;
e0001a05
NC
9500 int unreported = fragP->tc_frag_data.unreported_expansion;
9501 long new_stretch = 0;
3b4dbbbf 9502 const char *file_name;
d77b99c9
BW
9503 unsigned line;
9504 int lit_size;
43cd72b9
BW
9505 static xtensa_insnbuf vbuf = NULL;
9506 int slot, num_slots;
9507 xtensa_format fmt;
e0001a05 9508
3b4dbbbf 9509 file_name = as_where (&line);
e0001a05
NC
9510 new_logical_line (fragP->fr_file, fragP->fr_line);
9511
9512 fragP->tc_frag_data.unreported_expansion = 0;
9513
9514 switch (fragP->fr_subtype)
9515 {
9516 case RELAX_ALIGN_NEXT_OPCODE:
9517 /* Always convert. */
43cd72b9
BW
9518 if (fragP->tc_frag_data.relax_seen)
9519 new_stretch = relax_frag_loop_align (fragP, stretch);
e0001a05
NC
9520 break;
9521
9522 case RELAX_LOOP_END:
9523 /* Do nothing. */
9524 break;
9525
9526 case RELAX_LOOP_END_ADD_NOP:
9527 /* Add a NOP and switch to .fill 0. */
9528 new_stretch = relax_frag_add_nop (fragP);
43cd72b9 9529 frag_wane (fragP);
e0001a05
NC
9530 break;
9531
9532 case RELAX_DESIRE_ALIGN:
43cd72b9 9533 /* Do nothing. The narrowing before this frag will either align
e0001a05
NC
9534 it or not. */
9535 break;
9536
9537 case RELAX_LITERAL:
9538 case RELAX_LITERAL_FINAL:
9539 return 0;
9540
9541 case RELAX_LITERAL_NR:
9542 lit_size = 4;
9543 fragP->fr_subtype = RELAX_LITERAL_FINAL;
9c2799c2 9544 gas_assert (unreported == lit_size);
e0001a05
NC
9545 memset (&fragP->fr_literal[fragP->fr_fix], 0, 4);
9546 fragP->fr_var -= lit_size;
9547 fragP->fr_fix += lit_size;
9548 new_stretch = 4;
9549 break;
9550
43cd72b9
BW
9551 case RELAX_SLOTS:
9552 if (vbuf == NULL)
9553 vbuf = xtensa_insnbuf_alloc (isa);
9554
d77b99c9
BW
9555 xtensa_insnbuf_from_chars
9556 (isa, vbuf, (unsigned char *) fragP->fr_opcode, 0);
43cd72b9
BW
9557 fmt = xtensa_format_decode (isa, vbuf);
9558 num_slots = xtensa_format_num_slots (isa, fmt);
e0001a05 9559
43cd72b9
BW
9560 for (slot = 0; slot < num_slots; slot++)
9561 {
9562 switch (fragP->tc_frag_data.slot_subtypes[slot])
9563 {
9564 case RELAX_NARROW:
9565 if (fragP->tc_frag_data.relax_seen)
9566 new_stretch += relax_frag_for_align (fragP, stretch);
9567 break;
9568
9569 case RELAX_IMMED:
9570 case RELAX_IMMED_STEP1:
9571 case RELAX_IMMED_STEP2:
b81bf389 9572 case RELAX_IMMED_STEP3:
43cd72b9
BW
9573 /* Place the immediate. */
9574 new_stretch += relax_frag_immed
9575 (now_seg, fragP, stretch,
9576 fragP->tc_frag_data.slot_subtypes[slot] - RELAX_IMMED,
9577 fmt, slot, stretched_p, FALSE);
9578 break;
9579
9580 default:
9581 /* This is OK; see the note in xg_assemble_vliw_tokens. */
9582 break;
9583 }
9584 }
e0001a05
NC
9585 break;
9586
9587 case RELAX_LITERAL_POOL_BEGIN:
b46824bd
MF
9588 if (fragP->fr_var != 0)
9589 {
9590 /* We have a converted "candidate" literal pool;
9591 assemble a jump around it. */
9592 TInsn insn;
9593 if (!litpool_slotbuf)
9594 {
9595 litpool_buf = xtensa_insnbuf_alloc (isa);
9596 litpool_slotbuf = xtensa_insnbuf_alloc (isa);
9597 }
9598 new_stretch += 3;
9599 fragP->tc_frag_data.relax_seen = FALSE; /* Need another pass. */
9600 fragP->tc_frag_data.is_insn = TRUE;
9601 tinsn_init (&insn);
9602 insn.insn_type = ITYPE_INSN;
9603 insn.opcode = xtensa_j_opcode;
9604 insn.ntok = 1;
9605 set_expr_symbol_offset (&insn.tok[0], fragP->fr_symbol,
9606 fragP->fr_fix);
9607 fmt = xg_get_single_format (xtensa_j_opcode);
9608 tinsn_to_slotbuf (fmt, 0, &insn, litpool_slotbuf);
9609 xtensa_format_set_slot (isa, fmt, 0, litpool_buf, litpool_slotbuf);
9610 xtensa_insnbuf_to_chars (isa, litpool_buf,
9611 (unsigned char *)fragP->fr_literal +
9612 fragP->fr_fix, 3);
9613 fragP->fr_fix += 3;
9614 fragP->fr_var -= 3;
9615 /* Add a fix-up. */
9616 fix_new (fragP, 0, 3, fragP->fr_symbol, 0, TRUE,
9617 BFD_RELOC_XTENSA_SLOT0_OP);
9618 }
9619 break;
9620
e0001a05 9621 case RELAX_LITERAL_POOL_END:
b46824bd 9622 case RELAX_LITERAL_POOL_CANDIDATE_BEGIN:
43cd72b9
BW
9623 case RELAX_MAYBE_UNREACHABLE:
9624 case RELAX_MAYBE_DESIRE_ALIGN:
e0001a05
NC
9625 /* No relaxation required. */
9626 break;
9627
43cd72b9
BW
9628 case RELAX_FILL_NOP:
9629 case RELAX_UNREACHABLE:
9630 if (fragP->tc_frag_data.relax_seen)
9631 new_stretch += relax_frag_for_align (fragP, stretch);
9632 break;
9633
a82c7d90
DW
9634 case RELAX_TRAMPOLINE:
9635 if (fragP->tc_frag_data.relax_seen)
120bc8b8 9636 xg_relax_trampoline (fragP, stretch, &new_stretch);
a82c7d90
DW
9637 break;
9638
e0001a05
NC
9639 default:
9640 as_bad (_("bad relaxation state"));
9641 }
9642
43cd72b9 9643 /* Tell gas we need another relaxation pass. */
c138bc38 9644 if (! fragP->tc_frag_data.relax_seen)
43cd72b9
BW
9645 {
9646 fragP->tc_frag_data.relax_seen = TRUE;
9647 *stretched_p = 1;
9648 }
9649
e0001a05
NC
9650 new_logical_line (file_name, line);
9651 return new_stretch;
9652}
9653
9654
9655static long
7fa3d080 9656relax_frag_loop_align (fragS *fragP, long stretch)
e0001a05
NC
9657{
9658 addressT old_address, old_next_address, old_size;
9659 addressT new_address, new_next_address, new_size;
9660 addressT growth;
9661
43cd72b9
BW
9662 /* All the frags with relax_frag_for_alignment prior to this one in the
9663 section have been done, hopefully eliminating the need for a NOP here.
9664 But, this will put it in if necessary. */
e0001a05
NC
9665
9666 /* Calculate the old address of this fragment and the next fragment. */
9667 old_address = fragP->fr_address - stretch;
9668 old_next_address = (fragP->fr_address - stretch + fragP->fr_fix +
43cd72b9 9669 fragP->tc_frag_data.text_expansion[0]);
e0001a05
NC
9670 old_size = old_next_address - old_address;
9671
9672 /* Calculate the new address of this fragment and the next fragment. */
9673 new_address = fragP->fr_address;
9674 new_next_address =
9675 get_noop_aligned_address (fragP, fragP->fr_address + fragP->fr_fix);
9676 new_size = new_next_address - new_address;
9677
9678 growth = new_size - old_size;
9679
9680 /* Fix up the text_expansion field and return the new growth. */
43cd72b9 9681 fragP->tc_frag_data.text_expansion[0] += growth;
e0001a05
NC
9682 return growth;
9683}
9684
9685
43cd72b9 9686/* Add a NOP instruction. */
e0001a05
NC
9687
9688static long
7fa3d080 9689relax_frag_add_nop (fragS *fragP)
e0001a05 9690{
e0001a05 9691 char *nop_buf = fragP->fr_literal + fragP->fr_fix;
43cd72b9
BW
9692 int length = fragP->tc_frag_data.is_no_density ? 3 : 2;
9693 assemble_nop (length, nop_buf);
e0001a05 9694 fragP->tc_frag_data.is_insn = TRUE;
e0001a05 9695
e0001a05
NC
9696 if (fragP->fr_var < length)
9697 {
dd49a749 9698 as_fatal (_("fr_var (%ld) < length (%d)"), (long) fragP->fr_var, length);
e0001a05
NC
9699 return 0;
9700 }
9701
9702 fragP->fr_fix += length;
9703 fragP->fr_var -= length;
e0001a05
NC
9704 return length;
9705}
9706
9707
7fa3d080
BW
9708static long future_alignment_required (fragS *, long);
9709
e0001a05 9710static long
7fa3d080 9711relax_frag_for_align (fragS *fragP, long stretch)
e0001a05 9712{
43cd72b9
BW
9713 /* Overview of the relaxation procedure for alignment:
9714 We can widen with NOPs or by widening instructions or by filling
9715 bytes after jump instructions. Find the opportune places and widen
9716 them if necessary. */
9717
9718 long stretch_me;
9719 long diff;
e0001a05 9720
9c2799c2 9721 gas_assert (fragP->fr_subtype == RELAX_FILL_NOP
43cd72b9
BW
9722 || fragP->fr_subtype == RELAX_UNREACHABLE
9723 || (fragP->fr_subtype == RELAX_SLOTS
9724 && fragP->tc_frag_data.slot_subtypes[0] == RELAX_NARROW));
9725
9726 stretch_me = future_alignment_required (fragP, stretch);
9727 diff = stretch_me - fragP->tc_frag_data.text_expansion[0];
9728 if (diff == 0)
9729 return 0;
e0001a05 9730
43cd72b9 9731 if (diff < 0)
e0001a05 9732 {
43cd72b9
BW
9733 /* We expanded on a previous pass. Can we shrink now? */
9734 long shrink = fragP->tc_frag_data.text_expansion[0] - stretch_me;
9735 if (shrink <= stretch && stretch > 0)
e0001a05 9736 {
43cd72b9
BW
9737 fragP->tc_frag_data.text_expansion[0] = stretch_me;
9738 return -shrink;
e0001a05
NC
9739 }
9740 return 0;
9741 }
9742
43cd72b9
BW
9743 /* Below here, diff > 0. */
9744 fragP->tc_frag_data.text_expansion[0] = stretch_me;
e0001a05 9745
43cd72b9 9746 return diff;
e0001a05
NC
9747}
9748
9749
43cd72b9
BW
9750/* Return the address of the next frag that should be aligned.
9751
9752 By "address" we mean the address it _would_ be at if there
9753 is no action taken to align it between here and the target frag.
9754 In other words, if no narrows and no fill nops are used between
9755 here and the frag to align, _even_if_ some of the frags we use
9756 to align targets have already expanded on a previous relaxation
9757 pass.
9758
9759 Also, count each frag that may be used to help align the target.
9760
9761 Return 0 if there are no frags left in the chain that need to be
9762 aligned. */
9763
9764static addressT
7fa3d080
BW
9765find_address_of_next_align_frag (fragS **fragPP,
9766 int *wide_nops,
9767 int *narrow_nops,
9768 int *widens,
9769 bfd_boolean *paddable)
e0001a05 9770{
43cd72b9
BW
9771 fragS *fragP = *fragPP;
9772 addressT address = fragP->fr_address;
9773
9774 /* Do not reset the counts to 0. */
e0001a05
NC
9775
9776 while (fragP)
9777 {
9778 /* Limit this to a small search. */
b5e4a23d 9779 if (*widens >= (int) xtensa_fetch_width)
43cd72b9
BW
9780 {
9781 *fragPP = fragP;
9782 return 0;
9783 }
e0001a05
NC
9784 address += fragP->fr_fix;
9785
43cd72b9
BW
9786 if (fragP->fr_type == rs_fill)
9787 address += fragP->fr_offset * fragP->fr_var;
9788 else if (fragP->fr_type == rs_machine_dependent)
e0001a05 9789 {
e0001a05
NC
9790 switch (fragP->fr_subtype)
9791 {
43cd72b9
BW
9792 case RELAX_UNREACHABLE:
9793 *paddable = TRUE;
9794 break;
9795
9796 case RELAX_FILL_NOP:
9797 (*wide_nops)++;
9798 if (!fragP->tc_frag_data.is_no_density)
9799 (*narrow_nops)++;
9800 break;
9801
9802 case RELAX_SLOTS:
9803 if (fragP->tc_frag_data.slot_subtypes[0] == RELAX_NARROW)
9804 {
9805 (*widens)++;
9806 break;
9807 }
5bb3703f 9808 address += total_frag_text_expansion (fragP);
e0001a05
NC
9809 break;
9810
9811 case RELAX_IMMED:
43cd72b9 9812 address += fragP->tc_frag_data.text_expansion[0];
e0001a05
NC
9813 break;
9814
9815 case RELAX_ALIGN_NEXT_OPCODE:
9816 case RELAX_DESIRE_ALIGN:
43cd72b9
BW
9817 *fragPP = fragP;
9818 return address;
9819
9820 case RELAX_MAYBE_UNREACHABLE:
9821 case RELAX_MAYBE_DESIRE_ALIGN:
9822 /* Do nothing. */
e0001a05
NC
9823 break;
9824
9825 default:
43cd72b9
BW
9826 /* Just punt if we don't know the type. */
9827 *fragPP = fragP;
9828 return 0;
e0001a05 9829 }
43cd72b9 9830 }
c138bc38 9831 else
43cd72b9
BW
9832 {
9833 /* Just punt if we don't know the type. */
9834 *fragPP = fragP;
9835 return 0;
9836 }
9837 fragP = fragP->fr_next;
9838 }
9839
9840 *fragPP = fragP;
9841 return 0;
9842}
9843
9844
7fa3d080
BW
9845static long bytes_to_stretch (fragS *, int, int, int, int);
9846
43cd72b9 9847static long
7fa3d080 9848future_alignment_required (fragS *fragP, long stretch ATTRIBUTE_UNUSED)
43cd72b9
BW
9849{
9850 fragS *this_frag = fragP;
9851 long address;
9852 int num_widens = 0;
9853 int wide_nops = 0;
9854 int narrow_nops = 0;
9855 bfd_boolean paddable = FALSE;
9856 offsetT local_opt_diff;
9857 offsetT opt_diff;
9858 offsetT max_diff;
9859 int stretch_amount = 0;
9860 int local_stretch_amount;
9861 int global_stretch_amount;
9862
7fa3d080
BW
9863 address = find_address_of_next_align_frag
9864 (&fragP, &wide_nops, &narrow_nops, &num_widens, &paddable);
43cd72b9 9865
b5e4a23d
BW
9866 if (!address)
9867 {
9868 if (this_frag->tc_frag_data.is_aligning_branch)
9869 this_frag->tc_frag_data.slot_subtypes[0] = RELAX_IMMED;
9870 else
9871 frag_wane (this_frag);
9872 }
9873 else
43cd72b9
BW
9874 {
9875 local_opt_diff = get_aligned_diff (fragP, address, &max_diff);
9876 opt_diff = local_opt_diff;
9c2799c2
NC
9877 gas_assert (opt_diff >= 0);
9878 gas_assert (max_diff >= opt_diff);
c138bc38 9879 if (max_diff == 0)
43cd72b9 9880 return 0;
d2a033cd 9881
43cd72b9
BW
9882 if (fragP)
9883 fragP = fragP->fr_next;
9884
9885 while (fragP && opt_diff < max_diff && address)
9886 {
9887 /* We only use these to determine if we can exit early
c138bc38 9888 because there will be plenty of ways to align future
43cd72b9 9889 align frags. */
d77b99c9 9890 int glob_widens = 0;
43cd72b9
BW
9891 int dnn = 0;
9892 int dw = 0;
9893 bfd_boolean glob_pad = 0;
7fa3d080
BW
9894 address = find_address_of_next_align_frag
9895 (&fragP, &glob_widens, &dnn, &dw, &glob_pad);
43cd72b9 9896 /* If there is a padable portion, then skip. */
664df4e4 9897 if (glob_pad || glob_widens >= (1 << branch_align_power (now_seg)))
b5e4a23d 9898 address = 0;
43cd72b9 9899
c138bc38 9900 if (address)
43cd72b9
BW
9901 {
9902 offsetT next_m_diff;
9903 offsetT next_o_diff;
9904
9905 /* Downrange frags haven't had stretch added to them yet. */
9906 address += stretch;
9907
9908 /* The address also includes any text expansion from this
9909 frag in a previous pass, but we don't want that. */
9910 address -= this_frag->tc_frag_data.text_expansion[0];
9911
9912 /* Assume we are going to move at least opt_diff. In
9913 reality, we might not be able to, but assuming that
9914 we will helps catch cases where moving opt_diff pushes
9915 the next target from aligned to unaligned. */
9916 address += opt_diff;
9917
9918 next_o_diff = get_aligned_diff (fragP, address, &next_m_diff);
9919
9920 /* Now cleanup for the adjustments to address. */
9921 next_o_diff += opt_diff;
9922 next_m_diff += opt_diff;
9923 if (next_o_diff <= max_diff && next_o_diff > opt_diff)
9924 opt_diff = next_o_diff;
9925 if (next_m_diff < max_diff)
9926 max_diff = next_m_diff;
9927 fragP = fragP->fr_next;
9928 }
9929 }
d2a033cd 9930
43cd72b9
BW
9931 /* If there are enough wideners in between, do it. */
9932 if (paddable)
9933 {
9934 if (this_frag->fr_subtype == RELAX_UNREACHABLE)
9935 {
1beeb686 9936 gas_assert (opt_diff <= (signed) xtensa_fetch_width);
43cd72b9
BW
9937 return opt_diff;
9938 }
9939 return 0;
9940 }
c138bc38 9941 local_stretch_amount
43cd72b9
BW
9942 = bytes_to_stretch (this_frag, wide_nops, narrow_nops,
9943 num_widens, local_opt_diff);
c138bc38
BW
9944 global_stretch_amount
9945 = bytes_to_stretch (this_frag, wide_nops, narrow_nops,
43cd72b9 9946 num_widens, opt_diff);
c138bc38
BW
9947 /* If the condition below is true, then the frag couldn't
9948 stretch the correct amount for the global case, so we just
9949 optimize locally. We'll rely on the subsequent frags to get
43cd72b9
BW
9950 the correct alignment in the global case. */
9951 if (global_stretch_amount < local_stretch_amount)
9952 stretch_amount = local_stretch_amount;
9953 else
9954 stretch_amount = global_stretch_amount;
d2a033cd 9955
43cd72b9
BW
9956 if (this_frag->fr_subtype == RELAX_SLOTS
9957 && this_frag->tc_frag_data.slot_subtypes[0] == RELAX_NARROW)
9c2799c2 9958 gas_assert (stretch_amount <= 1);
43cd72b9
BW
9959 else if (this_frag->fr_subtype == RELAX_FILL_NOP)
9960 {
9961 if (this_frag->tc_frag_data.is_no_density)
9c2799c2 9962 gas_assert (stretch_amount == 3 || stretch_amount == 0);
43cd72b9 9963 else
9c2799c2 9964 gas_assert (stretch_amount <= 3);
43cd72b9
BW
9965 }
9966 }
9967 return stretch_amount;
9968}
9969
9970
9971/* The idea: widen everything you can to get a target or loop aligned,
9972 then start using NOPs.
9973
43cd72b9
BW
9974 wide_nops = the number of wide NOPs available for aligning
9975 narrow_nops = the number of narrow NOPs available for aligning
9976 (a subset of wide_nops)
9977 widens = the number of narrow instructions that should be widened
9978
43cd72b9
BW
9979*/
9980
9981static long
7fa3d080
BW
9982bytes_to_stretch (fragS *this_frag,
9983 int wide_nops,
9984 int narrow_nops,
9985 int num_widens,
9986 int desired_diff)
43cd72b9 9987{
19ef5f3d
SA
9988 int nops_needed;
9989 int nop_bytes;
9990 int extra_bytes;
43cd72b9
BW
9991 int bytes_short = desired_diff - num_widens;
9992
3739860c 9993 gas_assert (desired_diff >= 0
1beeb686 9994 && desired_diff < (signed) xtensa_fetch_width);
43cd72b9
BW
9995 if (desired_diff == 0)
9996 return 0;
c138bc38 9997
9c2799c2 9998 gas_assert (wide_nops > 0 || num_widens > 0);
e0001a05 9999
43cd72b9
BW
10000 /* Always prefer widening to NOP-filling. */
10001 if (bytes_short < 0)
10002 {
10003 /* There are enough RELAX_NARROW frags after this one
10004 to align the target without widening this frag in any way. */
10005 return 0;
10006 }
c138bc38 10007
43cd72b9
BW
10008 if (bytes_short == 0)
10009 {
10010 /* Widen every narrow between here and the align target
10011 and the align target will be properly aligned. */
10012 if (this_frag->fr_subtype == RELAX_FILL_NOP)
10013 return 0;
10014 else
10015 return 1;
10016 }
c138bc38 10017
43cd72b9
BW
10018 /* From here we will need at least one NOP to get an alignment.
10019 However, we may not be able to align at all, in which case,
10020 don't widen. */
19ef5f3d
SA
10021 nops_needed = desired_diff / 3;
10022
10023 /* If there aren't enough nops, don't widen. */
10024 if (nops_needed > wide_nops)
10025 return 0;
10026
10027 /* First try it with all wide nops. */
10028 nop_bytes = nops_needed * 3;
10029 extra_bytes = desired_diff - nop_bytes;
10030
10031 if (nop_bytes + num_widens >= desired_diff)
43cd72b9 10032 {
19ef5f3d
SA
10033 if (this_frag->fr_subtype == RELAX_FILL_NOP)
10034 return 3;
10035 else if (num_widens == extra_bytes)
10036 return 1;
10037 return 0;
e0001a05 10038 }
19ef5f3d
SA
10039
10040 /* Add a narrow nop. */
10041 nops_needed++;
10042 nop_bytes += 2;
10043 extra_bytes -= 2;
10044 if (narrow_nops == 0 || nops_needed > wide_nops)
10045 return 0;
10046
10047 if (nop_bytes + num_widens >= desired_diff && extra_bytes >= 0)
43cd72b9 10048 {
19ef5f3d
SA
10049 if (this_frag->fr_subtype == RELAX_FILL_NOP)
10050 return !this_frag->tc_frag_data.is_no_density ? 2 : 3;
10051 else if (num_widens == extra_bytes)
10052 return 1;
10053 return 0;
10054 }
e0001a05 10055
19ef5f3d
SA
10056 /* Replace a wide nop with a narrow nop--we can get here if
10057 extra_bytes was negative in the previous conditional. */
10058 if (narrow_nops == 1)
10059 return 0;
10060 nop_bytes--;
10061 extra_bytes++;
10062 if (nop_bytes + num_widens >= desired_diff)
10063 {
10064 if (this_frag->fr_subtype == RELAX_FILL_NOP)
10065 return !this_frag->tc_frag_data.is_no_density ? 2 : 3;
10066 else if (num_widens == extra_bytes)
10067 return 1;
10068 return 0;
43cd72b9 10069 }
19ef5f3d
SA
10070
10071 /* If we can't satisfy any of the above cases, then we can't align
10072 using padding or fill nops. */
43cd72b9 10073 return 0;
e0001a05
NC
10074}
10075
10076
46888d71 10077static fragS *
76a493ab 10078xg_find_best_trampoline_for_tinsn (TInsn *tinsn, fragS *fragP)
a82c7d90 10079{
76a493ab
MF
10080 symbolS *sym = tinsn->tok[0].X_add_symbol;
10081 addressT source = fragP->fr_address;
10082 addressT target = S_GET_VALUE (sym) + tinsn->tok[0].X_add_number;
a82c7d90 10083 struct trampoline_seg *ts = find_trampoline_seg (now_seg);
fe6c2f1b 10084 size_t i;
a82c7d90 10085
76a493ab
MF
10086 if (!ts || !ts->index.n_entries)
10087 return NULL;
a82c7d90 10088
76a493ab 10089 i = xg_find_best_trampoline (&ts->index, source, target);
a82c7d90 10090
76a493ab 10091 return ts->index.entry[i];
a82c7d90
DW
10092}
10093
10094
fe6c2f1b
MF
10095/* Append jump to sym + offset to the end of the trampoline frag fragP.
10096 Adjust fragP's jump around if it's present. Adjust fragP's fr_fix/fr_var
10097 and finish the frag if it's full (but don't remove it from the trampoline
10098 frag index). Return fixup for the newly created jump. */
46888d71 10099static fixS *xg_append_jump (fragS *fragP, symbolS *sym, offsetT offset)
fec68fb1
MF
10100{
10101 fixS *fixP;
10102 TInsn insn;
10103 xtensa_format fmt;
10104 xtensa_isa isa = xtensa_default_isa;
10105
10106 gas_assert (fragP->fr_var >= 3);
10107 tinsn_init (&insn);
10108 insn.insn_type = ITYPE_INSN;
10109 insn.opcode = xtensa_j_opcode;
10110 insn.ntok = 1;
10111 set_expr_symbol_offset (&insn.tok[0], sym, offset);
10112 fmt = xg_get_single_format (xtensa_j_opcode);
10113 tinsn_to_slotbuf (fmt, 0, &insn, trampoline_slotbuf);
10114 xtensa_format_set_slot (isa, fmt, 0, trampoline_buf, trampoline_slotbuf);
10115 xtensa_insnbuf_to_chars (isa, trampoline_buf,
10116 (unsigned char *)fragP->fr_literal + fragP->fr_fix, 3);
10117 fixP = fix_new (fragP, fragP->fr_fix, 3, sym, offset, TRUE,
10118 BFD_RELOC_XTENSA_SLOT0_OP);
10119 fixP->tc_fix_data.slot = 0;
10120
10121 fragP->fr_fix += 3;
10122 fragP->fr_var -= 3;
10123
10124 /* Adjust the jump around this trampoline (if present). */
46888d71
MF
10125 if (fragP->tc_frag_data.jump_around_fix)
10126 fragP->tc_frag_data.jump_around_fix->fx_offset += 3;
fec68fb1 10127
fe6c2f1b
MF
10128 /* Do we have room for more? */
10129 if (xg_is_trampoline_frag_full (fragP))
10130 {
10131 frag_wane (fragP);
10132 fragP->fr_subtype = 0;
10133 }
10134
fec68fb1
MF
10135 return fixP;
10136}
10137
a82c7d90
DW
10138
10139static int
46888d71 10140init_trampoline_frag (fragS *fp)
a82c7d90 10141{
a82c7d90
DW
10142 int growth = 0;
10143
10144 if (fp->fr_fix == 0)
10145 {
10146 symbolS *lsym;
10147 char label[10 + 2 * sizeof(fp)];
a82c7d90 10148
fec68fb1 10149 sprintf (label, ".L0_TR_%p", fp);
a82c7d90
DW
10150 lsym = (symbolS *)local_symbol_make (label, now_seg, 0, fp);
10151 fp->fr_symbol = lsym;
46888d71 10152 if (fp->tc_frag_data.needs_jump_around)
a82c7d90 10153 {
46888d71 10154 fp->tc_frag_data.jump_around_fix = xg_append_jump (fp, lsym, 3);
a82c7d90 10155 growth = 3;
a82c7d90
DW
10156 }
10157 }
10158 return growth;
10159}
10160
a82c7d90 10161static int
148d6384 10162xg_get_single_symbol_slot (fragS *fragP)
a82c7d90 10163{
148d6384
MF
10164 int i;
10165 int slot = -1;
24e5b4e6
MF
10166
10167 for (i = 0; i < MAX_SLOTS; ++i)
148d6384 10168 if (fragP->tc_frag_data.slot_symbols[i])
24e5b4e6
MF
10169 {
10170 gas_assert (slot == -1);
10171 slot = i;
10172 }
10173
10174 gas_assert (slot >= 0 && slot < MAX_SLOTS);
a82c7d90 10175
148d6384
MF
10176 return slot;
10177}
10178
10179static fixS *
10180add_jump_to_trampoline (fragS *tramp, fragS *origfrag)
10181{
10182 int slot = xg_get_single_symbol_slot (origfrag);
10183 fixS *fixP;
10184
a82c7d90 10185 /* Assemble a jump to the target label in the trampoline frag. */
148d6384
MF
10186 fixP = xg_append_jump (tramp,
10187 origfrag->tc_frag_data.slot_symbols[slot],
10188 origfrag->tc_frag_data.slot_offsets[slot]);
fec68fb1 10189
a82c7d90 10190 /* Modify the original j to point here. */
fec68fb1 10191 origfrag->tc_frag_data.slot_symbols[slot] = tramp->fr_symbol;
24e5b4e6 10192 origfrag->tc_frag_data.slot_offsets[slot] = tramp->fr_fix - 3;
fec68fb1 10193
a82c7d90 10194 /* If trampoline is full, remove it from the list. */
fe6c2f1b
MF
10195 if (xg_is_trampoline_frag_full (tramp))
10196 {
10197 struct trampoline_seg *ts = find_trampoline_seg (now_seg);
10198 size_t tr = xg_find_trampoline (&ts->index, tramp->fr_address);
10199
10200 gas_assert (ts->index.entry[tr] == tramp);
10201 xg_remove_trampoline_from_index (&ts->index, tr);
10202 }
a82c7d90 10203
148d6384 10204 return fixP;
a82c7d90
DW
10205}
10206
10207
e0001a05 10208static long
7fa3d080
BW
10209relax_frag_immed (segT segP,
10210 fragS *fragP,
10211 long stretch,
10212 int min_steps,
10213 xtensa_format fmt,
10214 int slot,
10215 int *stretched_p,
10216 bfd_boolean estimate_only)
e0001a05 10217{
43cd72b9 10218 TInsn tinsn;
e0001a05
NC
10219 int old_size;
10220 bfd_boolean negatable_branch = FALSE;
10221 bfd_boolean branch_jmp_to_next = FALSE;
def13efb 10222 bfd_boolean from_wide_insn = FALSE;
43cd72b9 10223 xtensa_isa isa = xtensa_default_isa;
e0001a05
NC
10224 IStack istack;
10225 offsetT frag_offset;
10226 int num_steps;
e0001a05 10227 int num_text_bytes, num_literal_bytes;
2276bc20 10228 int literal_diff, total_text_diff, this_text_diff;
e0001a05 10229
9c2799c2 10230 gas_assert (fragP->fr_opcode != NULL);
e0001a05 10231
b5e4a23d
BW
10232 xg_clear_vinsn (&cur_vinsn);
10233 vinsn_from_chars (&cur_vinsn, fragP->fr_opcode);
b2d179be 10234 if (cur_vinsn.num_slots > 1)
def13efb 10235 from_wide_insn = TRUE;
43cd72b9 10236
b5e4a23d 10237 tinsn = cur_vinsn.slots[slot];
43cd72b9 10238 tinsn_immed_from_frag (&tinsn, fragP, slot);
e0001a05 10239
64b607e6 10240 if (estimate_only && xtensa_opcode_is_loop (isa, tinsn.opcode) == 1)
43cd72b9 10241 return 0;
e0001a05 10242
b08b5071 10243 if (workaround_b_j_loop_end && ! fragP->tc_frag_data.is_no_transform)
43cd72b9 10244 branch_jmp_to_next = is_branch_jmp_to_next (&tinsn, fragP);
e0001a05 10245
43cd72b9 10246 negatable_branch = (xtensa_opcode_is_branch (isa, tinsn.opcode) == 1);
e0001a05 10247
43cd72b9 10248 old_size = xtensa_format_length (isa, fmt);
e0001a05
NC
10249
10250 /* Special case: replace a branch to the next instruction with a NOP.
10251 This is required to work around a hardware bug in T1040.0 and also
10252 serves as an optimization. */
10253
10254 if (branch_jmp_to_next
10255 && ((old_size == 2) || (old_size == 3))
10256 && !next_frag_is_loop_target (fragP))
10257 return 0;
10258
10259 /* Here is the fun stuff: Get the immediate field from this
10260 instruction. If it fits, we are done. If not, find the next
10261 instruction sequence that fits. */
10262
10263 frag_offset = fragP->fr_opcode - fragP->fr_literal;
10264 istack_init (&istack);
43cd72b9 10265 num_steps = xg_assembly_relax (&istack, &tinsn, segP, fragP, frag_offset,
e0001a05 10266 min_steps, stretch);
9c2799c2 10267 gas_assert (num_steps >= min_steps && num_steps <= RELAX_IMMED_MAXSTEPS);
e0001a05 10268
43cd72b9 10269 fragP->tc_frag_data.slot_subtypes[slot] = (int) RELAX_IMMED + num_steps;
e0001a05
NC
10270
10271 /* Figure out the number of bytes needed. */
e0001a05 10272 num_literal_bytes = get_num_stack_literal_bytes (&istack);
2276bc20
BW
10273 literal_diff
10274 = num_literal_bytes - fragP->tc_frag_data.literal_expansion[slot];
43cd72b9 10275 num_text_bytes = get_num_stack_text_bytes (&istack);
def13efb
BW
10276
10277 if (from_wide_insn)
43cd72b9 10278 {
2276bc20
BW
10279 int first = 0;
10280 while (istack.insn[first].opcode == XTENSA_UNDEFINED)
10281 first++;
10282
43cd72b9
BW
10283 num_text_bytes += old_size;
10284 if (opcode_fits_format_slot (istack.insn[first].opcode, fmt, slot))
10285 num_text_bytes -= xg_get_single_size (istack.insn[first].opcode);
2276bc20
BW
10286 else
10287 {
10288 /* The first instruction in the relaxed sequence will go after
10289 the current wide instruction, and thus its symbolic immediates
10290 might not fit. */
3739860c 10291
2276bc20 10292 istack_init (&istack);
3739860c 10293 num_steps = xg_assembly_relax (&istack, &tinsn, segP, fragP,
2276bc20
BW
10294 frag_offset + old_size,
10295 min_steps, stretch + old_size);
9c2799c2 10296 gas_assert (num_steps >= min_steps && num_steps <= RELAX_IMMED_MAXSTEPS);
2276bc20 10297
3739860c 10298 fragP->tc_frag_data.slot_subtypes[slot]
2276bc20
BW
10299 = (int) RELAX_IMMED + num_steps;
10300
10301 num_literal_bytes = get_num_stack_literal_bytes (&istack);
3739860c 10302 literal_diff
2276bc20 10303 = num_literal_bytes - fragP->tc_frag_data.literal_expansion[slot];
3739860c 10304
2276bc20
BW
10305 num_text_bytes = get_num_stack_text_bytes (&istack) + old_size;
10306 }
43cd72b9 10307 }
def13efb 10308
43cd72b9
BW
10309 total_text_diff = num_text_bytes - old_size;
10310 this_text_diff = total_text_diff - fragP->tc_frag_data.text_expansion[slot];
e0001a05
NC
10311
10312 /* It MUST get larger. If not, we could get an infinite loop. */
9c2799c2
NC
10313 gas_assert (num_text_bytes >= 0);
10314 gas_assert (literal_diff >= 0);
10315 gas_assert (total_text_diff >= 0);
e0001a05 10316
43cd72b9
BW
10317 fragP->tc_frag_data.text_expansion[slot] = total_text_diff;
10318 fragP->tc_frag_data.literal_expansion[slot] = num_literal_bytes;
9c2799c2
NC
10319 gas_assert (fragP->tc_frag_data.text_expansion[slot] >= 0);
10320 gas_assert (fragP->tc_frag_data.literal_expansion[slot] >= 0);
e0001a05
NC
10321
10322 /* Find the associated expandable literal for this. */
10323 if (literal_diff != 0)
10324 {
2276bc20 10325 fragS *lit_fragP = fragP->tc_frag_data.literal_frags[slot];
e0001a05
NC
10326 if (lit_fragP)
10327 {
9c2799c2 10328 gas_assert (literal_diff == 4);
e0001a05
NC
10329 lit_fragP->tc_frag_data.unreported_expansion += literal_diff;
10330
10331 /* We expect that the literal section state has NOT been
10332 modified yet. */
9c2799c2 10333 gas_assert (lit_fragP->fr_type == rs_machine_dependent
e0001a05
NC
10334 && lit_fragP->fr_subtype == RELAX_LITERAL);
10335 lit_fragP->fr_subtype = RELAX_LITERAL_NR;
10336
10337 /* We need to mark this section for another iteration
10338 of relaxation. */
10339 (*stretched_p)++;
10340 }
10341 }
10342
43cd72b9 10343 if (negatable_branch && istack.ninsn > 1)
1d19a770 10344 update_next_frag_state (fragP);
e0001a05 10345
a82c7d90
DW
10346 /* If last insn is a jump, and it cannot reach its target, try to find a trampoline. */
10347 if (istack.ninsn > 2 &&
10348 istack.insn[istack.ninsn - 1].insn_type == ITYPE_LABEL &&
10349 istack.insn[istack.ninsn - 2].insn_type == ITYPE_INSN &&
10350 istack.insn[istack.ninsn - 2].opcode == xtensa_j_opcode)
10351 {
10352 TInsn *jinsn = &istack.insn[istack.ninsn - 2];
148d6384
MF
10353 struct trampoline_seg *ts = find_trampoline_seg (segP);
10354 struct trampoline_chain *tc = NULL;
10355
10356 if (ts &&
10357 !xg_symbolic_immeds_fit (jinsn, segP, fragP, fragP->fr_offset,
10358 total_text_diff))
10359 {
10360 int s = xg_get_single_symbol_slot (fragP);
10361 addressT offset = fragP->tc_frag_data.slot_offsets[s];
10362
10363 tc = xg_find_best_eq_target (ts, fragP->fr_address,
10364 &fragP->tc_frag_data.slot_symbols[s],
10365 &offset);
10366
10367 if (!tc)
10368 tc = xg_create_trampoline_chain (ts,
10369 fragP->tc_frag_data.slot_symbols[s],
10370 offset);
10371 fragP->tc_frag_data.slot_offsets[s] = offset;
10372 tinsn_immed_from_frag (jinsn, fragP, s);
10373 }
a82c7d90 10374
148d6384
MF
10375 if (!xg_symbolic_immeds_fit (jinsn, segP, fragP, fragP->fr_offset,
10376 total_text_diff))
a82c7d90 10377 {
76a493ab 10378 fragS *tf = xg_find_best_trampoline_for_tinsn (jinsn, fragP);
a82c7d90
DW
10379
10380 if (tf)
10381 {
148d6384
MF
10382 fixS *fixP;
10383
10384 this_text_diff += init_trampoline_frag (tf) + 3;
10385 fixP = add_jump_to_trampoline (tf, fragP);
10386 xg_add_location_to_chain (tc, fixP->fx_frag->fr_symbol,
10387 fixP->fx_where);
10388 fragP->tc_frag_data.relax_seen = FALSE;
a82c7d90
DW
10389 }
10390 else
10391 {
10392 /* If target symbol is undefined, assume it will reach once linked. */
10393 expressionS *exp = &istack.insn[istack.ninsn - 2].tok[0];
10394
10395 if (exp->X_op == O_symbol && S_IS_DEFINED (exp->X_add_symbol))
10396 {
10397 as_bad_where (fragP->fr_file, fragP->fr_line,
10398 _("jump target out of range; no usable trampoline found"));
10399 }
10400 }
10401 }
10402 }
10403
43cd72b9 10404 return this_text_diff;
e0001a05
NC
10405}
10406
10407\f
10408/* md_convert_frag Hook and Helper Functions. */
10409
7fa3d080
BW
10410static void convert_frag_align_next_opcode (fragS *);
10411static void convert_frag_narrow (segT, fragS *, xtensa_format, int);
10412static void convert_frag_fill_nop (fragS *);
10413static void convert_frag_immed (segT, fragS *, int, xtensa_format, int);
10414
e0001a05 10415void
7fa3d080 10416md_convert_frag (bfd *abfd ATTRIBUTE_UNUSED, segT sec, fragS *fragp)
e0001a05 10417{
43cd72b9
BW
10418 static xtensa_insnbuf vbuf = NULL;
10419 xtensa_isa isa = xtensa_default_isa;
10420 int slot;
10421 int num_slots;
10422 xtensa_format fmt;
3b4dbbbf 10423 const char *file_name;
d77b99c9 10424 unsigned line;
e0001a05 10425
3b4dbbbf 10426 file_name = as_where (&line);
e0001a05
NC
10427 new_logical_line (fragp->fr_file, fragp->fr_line);
10428
10429 switch (fragp->fr_subtype)
10430 {
10431 case RELAX_ALIGN_NEXT_OPCODE:
10432 /* Always convert. */
10433 convert_frag_align_next_opcode (fragp);
10434 break;
10435
10436 case RELAX_DESIRE_ALIGN:
10437 /* Do nothing. If not aligned already, too bad. */
10438 break;
10439
43cd72b9
BW
10440 case RELAX_LITERAL:
10441 case RELAX_LITERAL_FINAL:
10442 break;
10443
10444 case RELAX_SLOTS:
10445 if (vbuf == NULL)
10446 vbuf = xtensa_insnbuf_alloc (isa);
10447
d77b99c9
BW
10448 xtensa_insnbuf_from_chars
10449 (isa, vbuf, (unsigned char *) fragp->fr_opcode, 0);
43cd72b9
BW
10450 fmt = xtensa_format_decode (isa, vbuf);
10451 num_slots = xtensa_format_num_slots (isa, fmt);
10452
10453 for (slot = 0; slot < num_slots; slot++)
10454 {
10455 switch (fragp->tc_frag_data.slot_subtypes[slot])
10456 {
10457 case RELAX_NARROW:
10458 convert_frag_narrow (sec, fragp, fmt, slot);
10459 break;
10460
10461 case RELAX_IMMED:
10462 case RELAX_IMMED_STEP1:
10463 case RELAX_IMMED_STEP2:
b81bf389 10464 case RELAX_IMMED_STEP3:
43cd72b9
BW
10465 /* Place the immediate. */
10466 convert_frag_immed
10467 (sec, fragp,
10468 fragp->tc_frag_data.slot_subtypes[slot] - RELAX_IMMED,
10469 fmt, slot);
10470 break;
10471
10472 default:
10473 /* This is OK because some slots could have
10474 relaxations and others have none. */
10475 break;
10476 }
10477 }
10478 break;
10479
10480 case RELAX_UNREACHABLE:
10481 memset (&fragp->fr_literal[fragp->fr_fix], 0, fragp->fr_var);
10482 fragp->fr_fix += fragp->tc_frag_data.text_expansion[0];
10483 fragp->fr_var -= fragp->tc_frag_data.text_expansion[0];
10484 frag_wane (fragp);
e0001a05
NC
10485 break;
10486
43cd72b9
BW
10487 case RELAX_MAYBE_UNREACHABLE:
10488 case RELAX_MAYBE_DESIRE_ALIGN:
10489 frag_wane (fragp);
e0001a05
NC
10490 break;
10491
43cd72b9
BW
10492 case RELAX_FILL_NOP:
10493 convert_frag_fill_nop (fragp);
e0001a05
NC
10494 break;
10495
10496 case RELAX_LITERAL_NR:
10497 if (use_literal_section)
10498 {
10499 /* This should have been handled during relaxation. When
10500 relaxing a code segment, literals sometimes need to be
10501 added to the corresponding literal segment. If that
10502 literal segment has already been relaxed, then we end up
10503 in this situation. Marking the literal segments as data
10504 would make this happen less often (since GAS always relaxes
10505 code before data), but we could still get into trouble if
10506 there are instructions in a segment that is not marked as
10507 containing code. Until we can implement a better solution,
10508 cheat and adjust the addresses of all the following frags.
10509 This could break subsequent alignments, but the linker's
10510 literal coalescing will do that anyway. */
10511
10512 fragS *f;
10513 fragp->fr_subtype = RELAX_LITERAL_FINAL;
9c2799c2 10514 gas_assert (fragp->tc_frag_data.unreported_expansion == 4);
e0001a05
NC
10515 memset (&fragp->fr_literal[fragp->fr_fix], 0, 4);
10516 fragp->fr_var -= 4;
10517 fragp->fr_fix += 4;
10518 for (f = fragp->fr_next; f; f = f->fr_next)
10519 f->fr_address += 4;
10520 }
10521 else
10522 as_bad (_("invalid relaxation fragment result"));
10523 break;
a82c7d90
DW
10524
10525 case RELAX_TRAMPOLINE:
10526 break;
e0001a05
NC
10527 }
10528
10529 fragp->fr_var = 0;
10530 new_logical_line (file_name, line);
10531}
10532
10533
7fa3d080
BW
10534static void
10535convert_frag_align_next_opcode (fragS *fragp)
e0001a05
NC
10536{
10537 char *nop_buf; /* Location for Writing. */
e0001a05
NC
10538 bfd_boolean use_no_density = fragp->tc_frag_data.is_no_density;
10539 addressT aligned_address;
d77b99c9
BW
10540 offsetT fill_size;
10541 int nop, nop_count;
e0001a05
NC
10542
10543 aligned_address = get_noop_aligned_address (fragp, fragp->fr_address +
10544 fragp->fr_fix);
10545 fill_size = aligned_address - (fragp->fr_address + fragp->fr_fix);
10546 nop_count = get_text_align_nop_count (fill_size, use_no_density);
10547 nop_buf = fragp->fr_literal + fragp->fr_fix;
10548
d77b99c9 10549 for (nop = 0; nop < nop_count; nop++)
e0001a05 10550 {
d77b99c9
BW
10551 int nop_size;
10552 nop_size = get_text_align_nth_nop_size (fill_size, nop, use_no_density);
e0001a05
NC
10553
10554 assemble_nop (nop_size, nop_buf);
10555 nop_buf += nop_size;
10556 }
10557
10558 fragp->fr_fix += fill_size;
10559 fragp->fr_var -= fill_size;
10560}
10561
10562
10563static void
7fa3d080 10564convert_frag_narrow (segT segP, fragS *fragP, xtensa_format fmt, int slot)
e0001a05 10565{
43cd72b9 10566 TInsn tinsn, single_target;
84b08ed9 10567 int size, old_size, diff;
e0001a05
NC
10568 offsetT frag_offset;
10569
9c2799c2 10570 gas_assert (slot == 0);
43cd72b9
BW
10571 tinsn_from_chars (&tinsn, fragP->fr_opcode, 0);
10572
b5e4a23d 10573 if (fragP->tc_frag_data.is_aligning_branch == 1)
43cd72b9 10574 {
9c2799c2 10575 gas_assert (fragP->tc_frag_data.text_expansion[0] == 1
43cd72b9
BW
10576 || fragP->tc_frag_data.text_expansion[0] == 0);
10577 convert_frag_immed (segP, fragP, fragP->tc_frag_data.text_expansion[0],
10578 fmt, slot);
10579 return;
10580 }
10581
10582 if (fragP->tc_frag_data.text_expansion[0] == 0)
e0001a05
NC
10583 {
10584 /* No conversion. */
10585 fragP->fr_var = 0;
10586 return;
10587 }
10588
9c2799c2 10589 gas_assert (fragP->fr_opcode != NULL);
e0001a05 10590
43cd72b9
BW
10591 /* Frags in this relaxation state should only contain
10592 single instruction bundles. */
10593 tinsn_immed_from_frag (&tinsn, fragP, 0);
e0001a05
NC
10594
10595 /* Just convert it to a wide form.... */
10596 size = 0;
43cd72b9 10597 old_size = xg_get_single_size (tinsn.opcode);
e0001a05
NC
10598
10599 tinsn_init (&single_target);
10600 frag_offset = fragP->fr_opcode - fragP->fr_literal;
10601
84b08ed9 10602 if (! xg_is_single_relaxable_insn (&tinsn, &single_target, FALSE))
43cd72b9
BW
10603 {
10604 as_bad (_("unable to widen instruction"));
10605 return;
10606 }
10607
10608 size = xg_get_single_size (single_target.opcode);
b2d179be
BW
10609 xg_emit_insn_to_buf (&single_target, fragP->fr_opcode, fragP,
10610 frag_offset, TRUE);
e0001a05
NC
10611
10612 diff = size - old_size;
9c2799c2
NC
10613 gas_assert (diff >= 0);
10614 gas_assert (diff <= fragP->fr_var);
e0001a05
NC
10615 fragP->fr_var -= diff;
10616 fragP->fr_fix += diff;
10617
10618 /* clean it up */
10619 fragP->fr_var = 0;
10620}
10621
10622
10623static void
7fa3d080 10624convert_frag_fill_nop (fragS *fragP)
43cd72b9
BW
10625{
10626 char *loc = &fragP->fr_literal[fragP->fr_fix];
10627 int size = fragP->tc_frag_data.text_expansion[0];
9c2799c2 10628 gas_assert ((unsigned) size == (fragP->fr_next->fr_address
43cd72b9
BW
10629 - fragP->fr_address - fragP->fr_fix));
10630 if (size == 0)
10631 {
10632 /* No conversion. */
10633 fragP->fr_var = 0;
10634 return;
10635 }
10636 assemble_nop (size, loc);
10637 fragP->tc_frag_data.is_insn = TRUE;
10638 fragP->fr_var -= size;
10639 fragP->fr_fix += size;
10640 frag_wane (fragP);
10641}
10642
10643
7fa3d080
BW
10644static fixS *fix_new_exp_in_seg
10645 (segT, subsegT, fragS *, int, int, expressionS *, int,
10646 bfd_reloc_code_real_type);
10647static void convert_frag_immed_finish_loop (segT, fragS *, TInsn *);
10648
43cd72b9 10649static void
7fa3d080
BW
10650convert_frag_immed (segT segP,
10651 fragS *fragP,
10652 int min_steps,
10653 xtensa_format fmt,
10654 int slot)
e0001a05
NC
10655{
10656 char *immed_instr = fragP->fr_opcode;
43cd72b9 10657 TInsn orig_tinsn;
e0001a05 10658 bfd_boolean expanded = FALSE;
e0001a05 10659 bfd_boolean branch_jmp_to_next = FALSE;
43cd72b9 10660 char *fr_opcode = fragP->fr_opcode;
43cd72b9 10661 xtensa_isa isa = xtensa_default_isa;
def13efb 10662 bfd_boolean from_wide_insn = FALSE;
43cd72b9
BW
10663 int bytes;
10664 bfd_boolean is_loop;
e0001a05 10665
9c2799c2 10666 gas_assert (fr_opcode != NULL);
e0001a05 10667
b5e4a23d 10668 xg_clear_vinsn (&cur_vinsn);
e0001a05 10669
b5e4a23d 10670 vinsn_from_chars (&cur_vinsn, fr_opcode);
b2d179be 10671 if (cur_vinsn.num_slots > 1)
def13efb 10672 from_wide_insn = TRUE;
e0001a05 10673
b5e4a23d 10674 orig_tinsn = cur_vinsn.slots[slot];
43cd72b9
BW
10675 tinsn_immed_from_frag (&orig_tinsn, fragP, slot);
10676
10677 is_loop = xtensa_opcode_is_loop (xtensa_default_isa, orig_tinsn.opcode) == 1;
e0001a05 10678
b08b5071 10679 if (workaround_b_j_loop_end && ! fragP->tc_frag_data.is_no_transform)
43cd72b9 10680 branch_jmp_to_next = is_branch_jmp_to_next (&orig_tinsn, fragP);
e0001a05
NC
10681
10682 if (branch_jmp_to_next && !next_frag_is_loop_target (fragP))
10683 {
10684 /* Conversion just inserts a NOP and marks the fix as completed. */
43cd72b9
BW
10685 bytes = xtensa_format_length (isa, fmt);
10686 if (bytes >= 4)
10687 {
b5e4a23d
BW
10688 cur_vinsn.slots[slot].opcode =
10689 xtensa_format_slot_nop_opcode (isa, cur_vinsn.format, slot);
10690 cur_vinsn.slots[slot].ntok = 0;
43cd72b9
BW
10691 }
10692 else
10693 {
10694 bytes += fragP->tc_frag_data.text_expansion[0];
9c2799c2 10695 gas_assert (bytes == 2 || bytes == 3);
b5e4a23d 10696 build_nop (&cur_vinsn.slots[0], bytes);
43cd72b9
BW
10697 fragP->fr_fix += fragP->tc_frag_data.text_expansion[0];
10698 }
e7da6241 10699 vinsn_to_insnbuf (&cur_vinsn, fr_opcode, frag_now, TRUE);
d77b99c9 10700 xtensa_insnbuf_to_chars
b5e4a23d 10701 (isa, cur_vinsn.insnbuf, (unsigned char *) fr_opcode, 0);
e0001a05
NC
10702 fragP->fr_var = 0;
10703 }
7c834684 10704 else
e0001a05 10705 {
43cd72b9
BW
10706 /* Here is the fun stuff: Get the immediate field from this
10707 instruction. If it fits, we're done. If not, find the next
10708 instruction sequence that fits. */
10709
e0001a05
NC
10710 IStack istack;
10711 int i;
10712 symbolS *lit_sym = NULL;
10713 int total_size = 0;
43cd72b9 10714 int target_offset = 0;
e0001a05
NC
10715 int old_size;
10716 int diff;
10717 symbolS *gen_label = NULL;
10718 offsetT frag_offset;
43cd72b9 10719 bfd_boolean first = TRUE;
e0001a05 10720
43cd72b9 10721 /* It does not fit. Find something that does and
e0001a05 10722 convert immediately. */
43cd72b9 10723 frag_offset = fr_opcode - fragP->fr_literal;
e0001a05 10724 istack_init (&istack);
43cd72b9 10725 xg_assembly_relax (&istack, &orig_tinsn,
e0001a05
NC
10726 segP, fragP, frag_offset, min_steps, 0);
10727
43cd72b9 10728 old_size = xtensa_format_length (isa, fmt);
e0001a05
NC
10729
10730 /* Assemble this right inline. */
10731
10732 /* First, create the mapping from a label name to the REAL label. */
43cd72b9 10733 target_offset = 0;
e0001a05
NC
10734 for (i = 0; i < istack.ninsn; i++)
10735 {
43cd72b9 10736 TInsn *tinsn = &istack.insn[i];
e0001a05
NC
10737 fragS *lit_frag;
10738
43cd72b9 10739 switch (tinsn->insn_type)
e0001a05
NC
10740 {
10741 case ITYPE_LITERAL:
10742 if (lit_sym != NULL)
10743 as_bad (_("multiple literals in expansion"));
10744 /* First find the appropriate space in the literal pool. */
43cd72b9 10745 lit_frag = fragP->tc_frag_data.literal_frags[slot];
e0001a05
NC
10746 if (lit_frag == NULL)
10747 as_bad (_("no registered fragment for literal"));
43cd72b9 10748 if (tinsn->ntok != 1)
e0001a05
NC
10749 as_bad (_("number of literal tokens != 1"));
10750
10751 /* Set the literal symbol and add a fixup. */
10752 lit_sym = lit_frag->fr_symbol;
10753 break;
10754
10755 case ITYPE_LABEL:
43cd72b9
BW
10756 if (align_targets && !is_loop)
10757 {
10758 fragS *unreach = fragP->fr_next;
10759 while (!(unreach->fr_type == rs_machine_dependent
10760 && (unreach->fr_subtype == RELAX_MAYBE_UNREACHABLE
10761 || unreach->fr_subtype == RELAX_UNREACHABLE)))
10762 {
10763 unreach = unreach->fr_next;
10764 }
10765
9c2799c2 10766 gas_assert (unreach->fr_type == rs_machine_dependent
43cd72b9
BW
10767 && (unreach->fr_subtype == RELAX_MAYBE_UNREACHABLE
10768 || unreach->fr_subtype == RELAX_UNREACHABLE));
10769
10770 target_offset += unreach->tc_frag_data.text_expansion[0];
10771 }
9c2799c2 10772 gas_assert (gen_label == NULL);
e0001a05 10773 gen_label = symbol_new (FAKE_LABEL_NAME, now_seg,
43cd72b9
BW
10774 fr_opcode - fragP->fr_literal
10775 + target_offset, fragP);
e0001a05
NC
10776 break;
10777
10778 case ITYPE_INSN:
def13efb 10779 if (first && from_wide_insn)
43cd72b9
BW
10780 {
10781 target_offset += xtensa_format_length (isa, fmt);
10782 first = FALSE;
10783 if (!opcode_fits_format_slot (tinsn->opcode, fmt, slot))
10784 target_offset += xg_get_single_size (tinsn->opcode);
10785 }
10786 else
10787 target_offset += xg_get_single_size (tinsn->opcode);
e0001a05
NC
10788 break;
10789 }
10790 }
10791
10792 total_size = 0;
43cd72b9 10793 first = TRUE;
e0001a05
NC
10794 for (i = 0; i < istack.ninsn; i++)
10795 {
43cd72b9 10796 TInsn *tinsn = &istack.insn[i];
e0001a05
NC
10797 fragS *lit_frag;
10798 int size;
10799 segT target_seg;
43cd72b9 10800 bfd_reloc_code_real_type reloc_type;
e0001a05 10801
43cd72b9 10802 switch (tinsn->insn_type)
e0001a05
NC
10803 {
10804 case ITYPE_LITERAL:
43cd72b9
BW
10805 lit_frag = fragP->tc_frag_data.literal_frags[slot];
10806 /* Already checked. */
9c2799c2
NC
10807 gas_assert (lit_frag != NULL);
10808 gas_assert (lit_sym != NULL);
10809 gas_assert (tinsn->ntok == 1);
43cd72b9 10810 /* Add a fixup. */
e0001a05 10811 target_seg = S_GET_SEGMENT (lit_sym);
9c2799c2 10812 gas_assert (target_seg);
28dbbc02 10813 reloc_type = map_operator_to_reloc (tinsn->tok[0].X_op, TRUE);
e0001a05 10814 fix_new_exp_in_seg (target_seg, 0, lit_frag, 0, 4,
43cd72b9 10815 &tinsn->tok[0], FALSE, reloc_type);
e0001a05
NC
10816 break;
10817
10818 case ITYPE_LABEL:
10819 break;
10820
10821 case ITYPE_INSN:
43cd72b9
BW
10822 xg_resolve_labels (tinsn, gen_label);
10823 xg_resolve_literals (tinsn, lit_sym);
def13efb 10824 if (from_wide_insn && first)
43cd72b9
BW
10825 {
10826 first = FALSE;
10827 if (opcode_fits_format_slot (tinsn->opcode, fmt, slot))
10828 {
b5e4a23d 10829 cur_vinsn.slots[slot] = *tinsn;
43cd72b9
BW
10830 }
10831 else
10832 {
b5e4a23d 10833 cur_vinsn.slots[slot].opcode =
43cd72b9 10834 xtensa_format_slot_nop_opcode (isa, fmt, slot);
b5e4a23d 10835 cur_vinsn.slots[slot].ntok = 0;
43cd72b9 10836 }
b5e4a23d
BW
10837 vinsn_to_insnbuf (&cur_vinsn, immed_instr, fragP, TRUE);
10838 xtensa_insnbuf_to_chars (isa, cur_vinsn.insnbuf,
d77b99c9 10839 (unsigned char *) immed_instr, 0);
43cd72b9
BW
10840 fragP->tc_frag_data.is_insn = TRUE;
10841 size = xtensa_format_length (isa, fmt);
10842 if (!opcode_fits_format_slot (tinsn->opcode, fmt, slot))
10843 {
43cd72b9 10844 xg_emit_insn_to_buf
b2d179be 10845 (tinsn, immed_instr + size, fragP,
43cd72b9
BW
10846 immed_instr - fragP->fr_literal + size, TRUE);
10847 size += xg_get_single_size (tinsn->opcode);
10848 }
10849 }
10850 else
10851 {
43cd72b9 10852 size = xg_get_single_size (tinsn->opcode);
b2d179be 10853 xg_emit_insn_to_buf (tinsn, immed_instr, fragP,
43cd72b9 10854 immed_instr - fragP->fr_literal, TRUE);
43cd72b9 10855 }
e0001a05 10856 immed_instr += size;
43cd72b9 10857 total_size += size;
e0001a05
NC
10858 break;
10859 }
10860 }
10861
10862 diff = total_size - old_size;
9c2799c2 10863 gas_assert (diff >= 0);
e0001a05
NC
10864 if (diff != 0)
10865 expanded = TRUE;
9c2799c2 10866 gas_assert (diff <= fragP->fr_var);
e0001a05
NC
10867 fragP->fr_var -= diff;
10868 fragP->fr_fix += diff;
10869 }
10870
e0001a05 10871 /* Check for undefined immediates in LOOP instructions. */
43cd72b9 10872 if (is_loop)
e0001a05
NC
10873 {
10874 symbolS *sym;
43cd72b9 10875 sym = orig_tinsn.tok[1].X_add_symbol;
e0001a05
NC
10876 if (sym != NULL && !S_IS_DEFINED (sym))
10877 {
10878 as_bad (_("unresolved loop target symbol: %s"), S_GET_NAME (sym));
10879 return;
10880 }
43cd72b9 10881 sym = orig_tinsn.tok[1].X_op_symbol;
e0001a05
NC
10882 if (sym != NULL && !S_IS_DEFINED (sym))
10883 {
10884 as_bad (_("unresolved loop target symbol: %s"), S_GET_NAME (sym));
10885 return;
10886 }
10887 }
10888
43cd72b9
BW
10889 if (expanded && xtensa_opcode_is_loop (isa, orig_tinsn.opcode) == 1)
10890 convert_frag_immed_finish_loop (segP, fragP, &orig_tinsn);
e0001a05 10891
43cd72b9 10892 if (expanded && is_direct_call_opcode (orig_tinsn.opcode))
e0001a05
NC
10893 {
10894 /* Add an expansion note on the expanded instruction. */
10895 fix_new_exp_in_seg (now_seg, 0, fragP, fr_opcode - fragP->fr_literal, 4,
43cd72b9 10896 &orig_tinsn.tok[0], TRUE,
e0001a05 10897 BFD_RELOC_XTENSA_ASM_EXPAND);
e0001a05
NC
10898 }
10899}
10900
10901
10902/* Add a new fix expression into the desired segment. We have to
10903 switch to that segment to do this. */
10904
10905static fixS *
7fa3d080
BW
10906fix_new_exp_in_seg (segT new_seg,
10907 subsegT new_subseg,
10908 fragS *frag,
10909 int where,
10910 int size,
10911 expressionS *exp,
10912 int pcrel,
10913 bfd_reloc_code_real_type r_type)
e0001a05
NC
10914{
10915 fixS *new_fix;
10916 segT seg = now_seg;
10917 subsegT subseg = now_subseg;
43cd72b9 10918
9c2799c2 10919 gas_assert (new_seg != 0);
e0001a05
NC
10920 subseg_set (new_seg, new_subseg);
10921
e0001a05
NC
10922 new_fix = fix_new_exp (frag, where, size, exp, pcrel, r_type);
10923 subseg_set (seg, subseg);
10924 return new_fix;
10925}
10926
10927
43cd72b9
BW
10928/* Relax a loop instruction so that it can span loop >256 bytes.
10929
10930 loop as, .L1
10931 .L0:
10932 rsr as, LEND
10933 wsr as, LBEG
10934 addi as, as, lo8 (label-.L1)
10935 addmi as, as, mid8 (label-.L1)
10936 wsr as, LEND
10937 isync
10938 rsr as, LCOUNT
10939 addi as, as, 1
10940 .L1:
10941 <<body>>
10942 label:
10943*/
e0001a05
NC
10944
10945static void
7fa3d080 10946convert_frag_immed_finish_loop (segT segP, fragS *fragP, TInsn *tinsn)
e0001a05
NC
10947{
10948 TInsn loop_insn;
10949 TInsn addi_insn;
10950 TInsn addmi_insn;
10951 unsigned long target;
10952 static xtensa_insnbuf insnbuf = NULL;
10953 unsigned int loop_length, loop_length_hi, loop_length_lo;
10954 xtensa_isa isa = xtensa_default_isa;
10955 addressT loop_offset;
10956 addressT addi_offset = 9;
10957 addressT addmi_offset = 12;
43cd72b9 10958 fragS *next_fragP;
d77b99c9 10959 int target_count;
e0001a05
NC
10960
10961 if (!insnbuf)
10962 insnbuf = xtensa_insnbuf_alloc (isa);
10963
10964 /* Get the loop offset. */
43cd72b9 10965 loop_offset = get_expanded_loop_offset (tinsn->opcode);
e0001a05 10966
43cd72b9
BW
10967 /* Validate that there really is a LOOP at the loop_offset. Because
10968 loops are not bundleable, we can assume that the instruction will be
10969 in slot 0. */
10970 tinsn_from_chars (&loop_insn, fragP->fr_opcode + loop_offset, 0);
10971 tinsn_immed_from_frag (&loop_insn, fragP, 0);
10972
9c2799c2 10973 gas_assert (xtensa_opcode_is_loop (isa, loop_insn.opcode) == 1);
e0001a05
NC
10974 addi_offset += loop_offset;
10975 addmi_offset += loop_offset;
10976
9c2799c2 10977 gas_assert (tinsn->ntok == 2);
b08b5071
BW
10978 if (tinsn->tok[1].X_op == O_constant)
10979 target = tinsn->tok[1].X_add_number;
10980 else if (tinsn->tok[1].X_op == O_symbol)
10981 {
10982 /* Find the fragment. */
10983 symbolS *sym = tinsn->tok[1].X_add_symbol;
9c2799c2 10984 gas_assert (S_GET_SEGMENT (sym) == segP
b08b5071
BW
10985 || S_GET_SEGMENT (sym) == absolute_section);
10986 target = (S_GET_VALUE (sym) + tinsn->tok[1].X_add_number);
10987 }
10988 else
10989 {
10990 as_bad (_("invalid expression evaluation type %d"), tinsn->tok[1].X_op);
10991 target = 0;
10992 }
e0001a05 10993
e0001a05
NC
10994 loop_length = target - (fragP->fr_address + fragP->fr_fix);
10995 loop_length_hi = loop_length & ~0x0ff;
10996 loop_length_lo = loop_length & 0x0ff;
10997 if (loop_length_lo >= 128)
10998 {
10999 loop_length_lo -= 256;
11000 loop_length_hi += 256;
11001 }
11002
43cd72b9 11003 /* Because addmi sign-extends the immediate, 'loop_length_hi' can be at most
e0001a05
NC
11004 32512. If the loop is larger than that, then we just fail. */
11005 if (loop_length_hi > 32512)
11006 as_bad_where (fragP->fr_file, fragP->fr_line,
11007 _("loop too long for LOOP instruction"));
11008
43cd72b9 11009 tinsn_from_chars (&addi_insn, fragP->fr_opcode + addi_offset, 0);
9c2799c2 11010 gas_assert (addi_insn.opcode == xtensa_addi_opcode);
e0001a05 11011
43cd72b9 11012 tinsn_from_chars (&addmi_insn, fragP->fr_opcode + addmi_offset, 0);
9c2799c2 11013 gas_assert (addmi_insn.opcode == xtensa_addmi_opcode);
e0001a05
NC
11014
11015 set_expr_const (&addi_insn.tok[2], loop_length_lo);
11016 tinsn_to_insnbuf (&addi_insn, insnbuf);
43cd72b9 11017
e0001a05 11018 fragP->tc_frag_data.is_insn = TRUE;
d77b99c9
BW
11019 xtensa_insnbuf_to_chars
11020 (isa, insnbuf, (unsigned char *) fragP->fr_opcode + addi_offset, 0);
e0001a05
NC
11021
11022 set_expr_const (&addmi_insn.tok[2], loop_length_hi);
11023 tinsn_to_insnbuf (&addmi_insn, insnbuf);
d77b99c9
BW
11024 xtensa_insnbuf_to_chars
11025 (isa, insnbuf, (unsigned char *) fragP->fr_opcode + addmi_offset, 0);
43cd72b9
BW
11026
11027 /* Walk through all of the frags from here to the loop end
11028 and mark them as no_transform to keep them from being modified
11029 by the linker. If we ever have a relocation for the
11030 addi/addmi of the difference of two symbols we can remove this. */
11031
11032 target_count = 0;
11033 for (next_fragP = fragP; next_fragP != NULL;
11034 next_fragP = next_fragP->fr_next)
11035 {
b08b5071 11036 next_fragP->tc_frag_data.is_no_transform = TRUE;
43cd72b9
BW
11037 if (next_fragP->tc_frag_data.is_loop_target)
11038 target_count++;
11039 if (target_count == 2)
11040 break;
11041 }
e0001a05
NC
11042}
11043
b08b5071
BW
11044\f
11045/* A map that keeps information on a per-subsegment basis. This is
11046 maintained during initial assembly, but is invalid once the
11047 subsegments are smashed together. I.E., it cannot be used during
11048 the relaxation. */
e0001a05 11049
b08b5071 11050typedef struct subseg_map_struct
e0001a05 11051{
b08b5071
BW
11052 /* the key */
11053 segT seg;
11054 subsegT subseg;
e0001a05 11055
b08b5071
BW
11056 /* the data */
11057 unsigned flags;
11058 float total_freq; /* fall-through + branch target frequency */
11059 float target_freq; /* branch target frequency alone */
11060
11061 struct subseg_map_struct *next;
11062} subseg_map;
e0001a05 11063
e0001a05 11064
e0001a05
NC
11065static subseg_map *sseg_map = NULL;
11066
43cd72b9 11067static subseg_map *
7fa3d080 11068get_subseg_info (segT seg, subsegT subseg)
e0001a05
NC
11069{
11070 subseg_map *subseg_e;
11071
11072 for (subseg_e = sseg_map; subseg_e; subseg_e = subseg_e->next)
e0001a05 11073 {
43cd72b9 11074 if (seg == subseg_e->seg && subseg == subseg_e->subseg)
b08b5071 11075 break;
e0001a05 11076 }
b08b5071
BW
11077 return subseg_e;
11078}
11079
11080
11081static subseg_map *
11082add_subseg_info (segT seg, subsegT subseg)
11083{
325801bd 11084 subseg_map *subseg_e = XNEW (subseg_map);
43cd72b9
BW
11085 memset (subseg_e, 0, sizeof (subseg_map));
11086 subseg_e->seg = seg;
11087 subseg_e->subseg = subseg;
11088 subseg_e->flags = 0;
11089 /* Start off considering every branch target very important. */
b08b5071
BW
11090 subseg_e->target_freq = 1.0;
11091 subseg_e->total_freq = 1.0;
43cd72b9
BW
11092 subseg_e->next = sseg_map;
11093 sseg_map = subseg_e;
43cd72b9
BW
11094 return subseg_e;
11095}
e0001a05 11096
7fa3d080
BW
11097
11098static unsigned
11099get_last_insn_flags (segT seg, subsegT subseg)
11100{
11101 subseg_map *subseg_e = get_subseg_info (seg, subseg);
b08b5071
BW
11102 if (subseg_e)
11103 return subseg_e->flags;
11104 return 0;
7fa3d080
BW
11105}
11106
11107
43cd72b9 11108static void
7fa3d080
BW
11109set_last_insn_flags (segT seg,
11110 subsegT subseg,
11111 unsigned fl,
11112 bfd_boolean val)
43cd72b9
BW
11113{
11114 subseg_map *subseg_e = get_subseg_info (seg, subseg);
b08b5071
BW
11115 if (! subseg_e)
11116 subseg_e = add_subseg_info (seg, subseg);
e0001a05
NC
11117 if (val)
11118 subseg_e->flags |= fl;
11119 else
11120 subseg_e->flags &= ~fl;
11121}
11122
b08b5071
BW
11123
11124static float
11125get_subseg_total_freq (segT seg, subsegT subseg)
11126{
11127 subseg_map *subseg_e = get_subseg_info (seg, subseg);
11128 if (subseg_e)
11129 return subseg_e->total_freq;
11130 return 1.0;
11131}
11132
11133
11134static float
11135get_subseg_target_freq (segT seg, subsegT subseg)
11136{
11137 subseg_map *subseg_e = get_subseg_info (seg, subseg);
11138 if (subseg_e)
11139 return subseg_e->target_freq;
11140 return 1.0;
11141}
11142
11143
11144static void
11145set_subseg_freq (segT seg, subsegT subseg, float total_f, float target_f)
11146{
11147 subseg_map *subseg_e = get_subseg_info (seg, subseg);
11148 if (! subseg_e)
11149 subseg_e = add_subseg_info (seg, subseg);
11150 subseg_e->total_freq = total_f;
11151 subseg_e->target_freq = target_f;
11152}
11153
e0001a05
NC
11154\f
11155/* Segment Lists and emit_state Stuff. */
11156
e0001a05 11157static void
7fa3d080 11158xtensa_move_seg_list_to_beginning (seg_list *head)
e0001a05
NC
11159{
11160 head = head->next;
11161 while (head)
11162 {
11163 segT literal_section = head->seg;
11164
11165 /* Move the literal section to the front of the section list. */
9c2799c2 11166 gas_assert (literal_section);
69852798
AM
11167 if (literal_section != stdoutput->sections)
11168 {
11169 bfd_section_list_remove (stdoutput, literal_section);
11170 bfd_section_list_prepend (stdoutput, literal_section);
11171 }
e0001a05
NC
11172 head = head->next;
11173 }
11174}
11175
11176
7fa3d080
BW
11177static void mark_literal_frags (seg_list *);
11178
947fa914
MF
11179static void
11180xg_promote_candidate_litpool (struct litpool_seg *lps,
11181 struct litpool_frag *lp)
11182{
11183 fragS *poolbeg;
11184 fragS *poolend;
11185 symbolS *lsym;
11186 char label[10 + 2 * sizeof (fragS *)];
11187
11188 poolbeg = lp->fragP;
11189 lp->priority = 1;
11190 poolbeg->fr_subtype = RELAX_LITERAL_POOL_BEGIN;
11191 poolend = poolbeg->fr_next;
11192 gas_assert (poolend->fr_type == rs_machine_dependent &&
11193 poolend->fr_subtype == RELAX_LITERAL_POOL_END);
11194 /* Create a local symbol pointing to the
11195 end of the pool. */
11196 sprintf (label, ".L0_LT_%p", poolbeg);
11197 lsym = (symbolS *)local_symbol_make (label, lps->seg,
11198 0, poolend);
11199 poolbeg->fr_symbol = lsym;
11200 /* Rest is done in xtensa_relax_frag. */
11201}
11202
cd665a94
MF
11203static struct litpool_frag *xg_find_litpool (struct litpool_seg *lps,
11204 struct litpool_frag *lpf,
11205 addressT addr)
11206{
11207 struct litpool_frag *lp = lpf->prev;
11208
11209 gas_assert (lp->fragP);
11210
11211 while (lp->fragP->fr_subtype == RELAX_LITERAL_POOL_CANDIDATE_BEGIN)
11212 {
11213 lp = lp->prev;
11214 if (lp->fragP == NULL)
11215 {
11216 /* End of list; have to bite the bullet.
11217 Take the nearest. */
11218 lp = lpf->prev;
11219 break;
11220 }
11221 /* Does it (conservatively) reach? */
11222 if (addr - lp->addr <= 128 * 1024)
11223 {
11224 if (lp->fragP->fr_subtype == RELAX_LITERAL_POOL_BEGIN &&
11225 lp->literal_count < MAX_POOL_LITERALS)
11226 {
11227 /* Found a good one. */
11228 break;
11229 }
11230 else if (lp->prev->fragP &&
11231 addr - lp->prev->addr > 128 * 1024 &&
11232 lp->prev->literal_count < MAX_POOL_LITERALS)
11233 {
11234 /* This is still a "candidate" but the next one
11235 will be too far away, so revert to the nearest
11236 one, convert it and add the jump around. */
11237 lp = lpf->prev;
11238 break;
11239 }
11240 }
11241 }
11242
11243 if (lp->literal_count >= MAX_POOL_LITERALS)
11244 {
11245 lp = lpf->prev;
11246 while (lp && lp->fragP && lp->literal_count >= MAX_POOL_LITERALS)
11247 {
11248 lp = lp->prev;
11249 }
11250 gas_assert (lp);
11251 }
11252
11253 gas_assert (lp && lp->fragP && lp->literal_count < MAX_POOL_LITERALS);
11254 ++lp->literal_count;
11255
11256 /* Convert candidate and add the jump around. */
11257 if (lp->fragP->fr_subtype == RELAX_LITERAL_POOL_CANDIDATE_BEGIN)
11258 xg_promote_candidate_litpool (lps, lp);
11259
11260 return lp;
11261}
11262
7fa3d080
BW
11263static void
11264xtensa_move_literals (void)
e0001a05
NC
11265{
11266 seg_list *segment;
11267 frchainS *frchain_from, *frchain_to;
87975d2a 11268 fragS *search_frag, *next_frag, *literal_pool, *insert_after;
e0001a05
NC
11269 fragS **frag_splice;
11270 emit_state state;
11271 segT dest_seg;
11272 fixS *fix, *next_fix, **fix_splice;
82e7541d 11273 sym_list *lit;
b46824bd 11274 struct litpool_seg *lps;
4111950f
MF
11275 const char *init_name = INIT_SECTION_NAME;
11276 const char *fini_name = FINI_SECTION_NAME;
11277 int init_name_len = strlen(init_name);
11278 int fini_name_len = strlen(fini_name);
e0001a05 11279
a7877748 11280 mark_literal_frags (literal_head->next);
e0001a05
NC
11281
11282 if (use_literal_section)
11283 return;
11284
b46824bd
MF
11285 /* Assign addresses (rough estimates) to the potential literal pool locations
11286 and create new ones if the gaps are too large. */
11287
11288 for (lps = litpool_seg_list.next; lps; lps = lps->next)
11289 {
11290 frchainS *frchP = seg_info (lps->seg)->frchainP;
11291 struct litpool_frag *lpf = lps->frag_list.next;
11292 addressT addr = 0;
11293
11294 for ( ; frchP; frchP = frchP->frch_next)
11295 {
11296 fragS *fragP;
11297 for (fragP = frchP->frch_root; fragP; fragP = fragP->fr_next)
11298 {
11299 if (lpf && fragP == lpf->fragP)
11300 {
11301 gas_assert(fragP->fr_type == rs_machine_dependent &&
11302 (fragP->fr_subtype == RELAX_LITERAL_POOL_BEGIN ||
11303 fragP->fr_subtype == RELAX_LITERAL_POOL_CANDIDATE_BEGIN));
11304 /* Found a litpool location. */
11305 lpf->addr = addr;
11306 lpf = lpf->next;
11307 }
11308 if (fragP->fr_type == rs_machine_dependent &&
11309 fragP->fr_subtype == RELAX_SLOTS)
11310 {
11311 int slot;
11312 for (slot = 0; slot < MAX_SLOTS; slot++)
11313 {
11314 if (fragP->tc_frag_data.literal_frags[slot])
11315 {
11316 /* L32R; point its literal to the nearest litpool
11317 preferring non-"candidate" positions to avoid
11318 the jump-around. */
11319 fragS *litfrag = fragP->tc_frag_data.literal_frags[slot];
947fa914 11320
cd665a94 11321 if (!litfrag->tc_frag_data.literal_frag)
b46824bd 11322 {
cd665a94
MF
11323 struct litpool_frag *lp;
11324
11325 lp = xg_find_litpool (lps, lpf, addr);
b46824bd
MF
11326 /* Take earliest use of this literal to avoid
11327 forward refs. */
11328 litfrag->tc_frag_data.literal_frag = lp->fragP;
11329 }
11330 }
11331 }
11332 }
11333 addr += fragP->fr_fix;
11334 if (fragP->fr_type == rs_fill)
11335 addr += fragP->fr_offset;
11336 }
11337 }
11338 }
11339
74869ac7 11340 for (segment = literal_head->next; segment; segment = segment->next)
e0001a05 11341 {
4111950f
MF
11342 const char *seg_name = segment_name (segment->seg);
11343
74869ac7 11344 /* Keep the literals for .init and .fini in separate sections. */
4111950f
MF
11345 if ((!memcmp (seg_name, init_name, init_name_len) &&
11346 !strcmp (seg_name + init_name_len, ".literal")) ||
11347 (!memcmp (seg_name, fini_name, fini_name_len) &&
11348 !strcmp (seg_name + fini_name_len, ".literal")))
74869ac7
BW
11349 continue;
11350
e0001a05
NC
11351 frchain_from = seg_info (segment->seg)->frchainP;
11352 search_frag = frchain_from->frch_root;
11353 literal_pool = NULL;
11354 frchain_to = NULL;
11355 frag_splice = &(frchain_from->frch_root);
11356
4de0562a 11357 while (search_frag && !search_frag->tc_frag_data.literal_frag)
e0001a05 11358 {
9c2799c2 11359 gas_assert (search_frag->fr_fix == 0
e0001a05
NC
11360 || search_frag->fr_type == rs_align);
11361 search_frag = search_frag->fr_next;
11362 }
11363
4de0562a
MF
11364 if (!search_frag)
11365 {
11366 search_frag = frchain_from->frch_root;
11367 as_bad_where (search_frag->fr_file, search_frag->fr_line,
11368 _("literal pool location required for text-section-literals; specify with .literal_position"));
11369 continue;
11370 }
11371
9c2799c2 11372 gas_assert (search_frag->tc_frag_data.literal_frag->fr_subtype
e0001a05
NC
11373 == RELAX_LITERAL_POOL_BEGIN);
11374 xtensa_switch_section_emit_state (&state, segment->seg, 0);
11375
11376 /* Make sure that all the frags in this series are closed, and
11377 that there is at least one left over of zero-size. This
11378 prevents us from making a segment with an frchain without any
11379 frags in it. */
11380 frag_variant (rs_fill, 0, 0, 0, NULL, 0, NULL);
43cd72b9 11381 xtensa_set_frag_assembly_state (frag_now);
e0001a05 11382 frag_variant (rs_fill, 0, 0, 0, NULL, 0, NULL);
43cd72b9 11383 xtensa_set_frag_assembly_state (frag_now);
e0001a05 11384
43cd72b9 11385 while (search_frag != frag_now)
e0001a05
NC
11386 {
11387 next_frag = search_frag->fr_next;
e0001a05
NC
11388 if (search_frag->tc_frag_data.literal_frag)
11389 {
11390 literal_pool = search_frag->tc_frag_data.literal_frag;
9c2799c2 11391 gas_assert (literal_pool->fr_subtype == RELAX_LITERAL_POOL_BEGIN);
dd49a749 11392 frchain_to = literal_pool->tc_frag_data.lit_frchain;
9c2799c2 11393 gas_assert (frchain_to);
e0001a05 11394 }
b46824bd
MF
11395
11396 if (search_frag->fr_type == rs_fill && search_frag->fr_fix == 0)
11397 {
11398 /* Skip empty fill frags. */
11399 *frag_splice = next_frag;
11400 search_frag = next_frag;
11401 continue;
11402 }
11403
11404 if (search_frag->fr_type == rs_align)
11405 {
11406 /* Skip alignment frags, because the pool as a whole will be
11407 aligned if used, and we don't want to force alignment if the
11408 pool is unused. */
11409 *frag_splice = next_frag;
11410 search_frag = next_frag;
11411 continue;
11412 }
11413
11414 /* First, move the frag out of the literal section and
11415 to the appropriate place. */
11416
33eaf5de 11417 /* Insert an alignment frag at start of pool. */
b46824bd
MF
11418 if (literal_pool->fr_next->fr_type == rs_machine_dependent &&
11419 literal_pool->fr_next->fr_subtype == RELAX_LITERAL_POOL_END)
11420 {
11421 segT pool_seg = literal_pool->fr_next->tc_frag_data.lit_seg;
11422 emit_state prev_state;
11423 fragS *prev_frag;
11424 fragS *align_frag;
11425 xtensa_switch_section_emit_state (&prev_state, pool_seg, 0);
11426 prev_frag = frag_now;
11427 frag_variant (rs_fill, 0, 0, 0, NULL, 0, NULL);
11428 align_frag = frag_now;
11429 frag_align (2, 0, 0);
11430 /* Splice it into the right place. */
11431 prev_frag->fr_next = align_frag->fr_next;
11432 align_frag->fr_next = literal_pool->fr_next;
11433 literal_pool->fr_next = align_frag;
11434 /* Insert after this one. */
11435 literal_pool->tc_frag_data.literal_frag = align_frag;
11436 xtensa_restore_emit_state (&prev_state);
11437 }
c48aaca0 11438 insert_after = literal_pool->tc_frag_data.literal_frag;
dd49a749 11439 dest_seg = insert_after->fr_next->tc_frag_data.lit_seg;
b46824bd
MF
11440 /* Skip align frag. */
11441 if (insert_after->fr_next->fr_type == rs_align)
11442 {
11443 insert_after = insert_after->fr_next;
11444 }
43cd72b9 11445
e0001a05
NC
11446 *frag_splice = next_frag;
11447 search_frag->fr_next = insert_after->fr_next;
11448 insert_after->fr_next = search_frag;
11449 search_frag->tc_frag_data.lit_seg = dest_seg;
c48aaca0 11450 literal_pool->tc_frag_data.literal_frag = search_frag;
e0001a05
NC
11451
11452 /* Now move any fixups associated with this frag to the
11453 right section. */
11454 fix = frchain_from->fix_root;
11455 fix_splice = &(frchain_from->fix_root);
11456 while (fix)
11457 {
11458 next_fix = fix->fx_next;
11459 if (fix->fx_frag == search_frag)
11460 {
11461 *fix_splice = next_fix;
11462 fix->fx_next = frchain_to->fix_root;
11463 frchain_to->fix_root = fix;
11464 if (frchain_to->fix_tail == NULL)
11465 frchain_to->fix_tail = fix;
11466 }
11467 else
11468 fix_splice = &(fix->fx_next);
11469 fix = next_fix;
11470 }
11471 search_frag = next_frag;
11472 }
11473
11474 if (frchain_from->fix_root != NULL)
11475 {
11476 frchain_from = seg_info (segment->seg)->frchainP;
11477 as_warn (_("fixes not all moved from %s"), segment->seg->name);
11478
9c2799c2 11479 gas_assert (frchain_from->fix_root == NULL);
e0001a05
NC
11480 }
11481 frchain_from->fix_tail = NULL;
11482 xtensa_restore_emit_state (&state);
e0001a05
NC
11483 }
11484
82e7541d
BW
11485 /* Now fix up the SEGMENT value for all the literal symbols. */
11486 for (lit = literal_syms; lit; lit = lit->next)
11487 {
11488 symbolS *lit_sym = lit->sym;
91d6fa6a
NC
11489 segT dseg = symbol_get_frag (lit_sym)->tc_frag_data.lit_seg;
11490 if (dseg)
11491 S_SET_SEGMENT (lit_sym, dseg);
82e7541d 11492 }
e0001a05
NC
11493}
11494
11495
a7877748
BW
11496/* Walk over all the frags for segments in a list and mark them as
11497 containing literals. As clunky as this is, we can't rely on frag_var
11498 and frag_variant to get called in all situations. */
11499
11500static void
7fa3d080 11501mark_literal_frags (seg_list *segment)
a7877748
BW
11502{
11503 frchainS *frchain_from;
11504 fragS *search_frag;
11505
11506 while (segment)
11507 {
11508 frchain_from = seg_info (segment->seg)->frchainP;
11509 search_frag = frchain_from->frch_root;
c138bc38 11510 while (search_frag)
a7877748
BW
11511 {
11512 search_frag->tc_frag_data.is_literal = TRUE;
11513 search_frag = search_frag->fr_next;
11514 }
11515 segment = segment->next;
11516 }
11517}
11518
11519
e0001a05 11520static void
7fa3d080 11521xtensa_reorder_seg_list (seg_list *head, segT after)
e0001a05
NC
11522{
11523 /* Move all of the sections in the section list to come
11524 after "after" in the gnu segment list. */
11525
11526 head = head->next;
11527 while (head)
11528 {
11529 segT literal_section = head->seg;
11530
11531 /* Move the literal section after "after". */
9c2799c2 11532 gas_assert (literal_section);
e0001a05
NC
11533 if (literal_section != after)
11534 {
69852798
AM
11535 bfd_section_list_remove (stdoutput, literal_section);
11536 bfd_section_list_insert_after (stdoutput, after, literal_section);
e0001a05
NC
11537 }
11538
11539 head = head->next;
11540 }
11541}
11542
11543
11544/* Push all the literal segments to the end of the gnu list. */
11545
7fa3d080
BW
11546static void
11547xtensa_reorder_segments (void)
e0001a05
NC
11548{
11549 segT sec;
b08b5071 11550 segT last_sec = 0;
e0001a05
NC
11551 int old_count = 0;
11552 int new_count = 0;
11553
11554 for (sec = stdoutput->sections; sec != NULL; sec = sec->next)
b08b5071
BW
11555 {
11556 last_sec = sec;
11557 old_count++;
11558 }
e0001a05
NC
11559
11560 /* Now that we have the last section, push all the literal
11561 sections to the end. */
e0001a05 11562 xtensa_reorder_seg_list (literal_head, last_sec);
e0001a05
NC
11563
11564 /* Now perform the final error check. */
11565 for (sec = stdoutput->sections; sec != NULL; sec = sec->next)
11566 new_count++;
9c2799c2 11567 gas_assert (new_count == old_count);
e0001a05
NC
11568}
11569
11570
e0001a05
NC
11571/* Change the emit state (seg, subseg, and frag related stuff) to the
11572 correct location. Return a emit_state which can be passed to
11573 xtensa_restore_emit_state to return to current fragment. */
11574
7fa3d080
BW
11575static void
11576xtensa_switch_to_literal_fragment (emit_state *result)
43cd72b9
BW
11577{
11578 if (directive_state[directive_absolute_literals])
11579 {
74869ac7
BW
11580 segT lit4_seg = cache_literal_section (TRUE);
11581 xtensa_switch_section_emit_state (result, lit4_seg, 0);
43cd72b9
BW
11582 }
11583 else
11584 xtensa_switch_to_non_abs_literal_fragment (result);
11585
11586 /* Do a 4-byte align here. */
11587 frag_align (2, 0, 0);
11588 record_alignment (now_seg, 2);
11589}
11590
11591
7fa3d080
BW
11592static void
11593xtensa_switch_to_non_abs_literal_fragment (emit_state *result)
e0001a05 11594{
e0001a05 11595 fragS *pool_location = get_literal_pool_location (now_seg);
74869ac7 11596 segT lit_seg;
c138bc38 11597 bfd_boolean is_init =
e0001a05 11598 (now_seg && !strcmp (segment_name (now_seg), INIT_SECTION_NAME));
c138bc38 11599 bfd_boolean is_fini =
e0001a05 11600 (now_seg && !strcmp (segment_name (now_seg), FINI_SECTION_NAME));
e0001a05 11601
43cd72b9
BW
11602 if (pool_location == NULL
11603 && !use_literal_section
e0001a05
NC
11604 && !is_init && ! is_fini)
11605 {
b46824bd
MF
11606 if (!auto_litpools)
11607 {
11608 as_bad (_("literal pool location required for text-section-literals; specify with .literal_position"));
11609 }
947fa914
MF
11610 xtensa_maybe_create_literal_pool_frag (TRUE, TRUE);
11611 pool_location = get_literal_pool_location (now_seg);
e0001a05
NC
11612 }
11613
74869ac7
BW
11614 lit_seg = cache_literal_section (FALSE);
11615 xtensa_switch_section_emit_state (result, lit_seg, 0);
e0001a05 11616
43cd72b9
BW
11617 if (!use_literal_section
11618 && !is_init && !is_fini
11619 && get_literal_pool_location (now_seg) != pool_location)
e0001a05
NC
11620 {
11621 /* Close whatever frag is there. */
11622 frag_variant (rs_fill, 0, 0, 0, NULL, 0, NULL);
43cd72b9 11623 xtensa_set_frag_assembly_state (frag_now);
e0001a05
NC
11624 frag_now->tc_frag_data.literal_frag = pool_location;
11625 frag_variant (rs_fill, 0, 0, 0, NULL, 0, NULL);
43cd72b9 11626 xtensa_set_frag_assembly_state (frag_now);
e0001a05 11627 }
e0001a05
NC
11628}
11629
11630
11631/* Call this function before emitting data into the literal section.
11632 This is a helper function for xtensa_switch_to_literal_fragment.
11633 This is similar to a .section new_now_seg subseg. */
11634
7fa3d080
BW
11635static void
11636xtensa_switch_section_emit_state (emit_state *state,
11637 segT new_now_seg,
11638 subsegT new_now_subseg)
e0001a05
NC
11639{
11640 state->name = now_seg->name;
11641 state->now_seg = now_seg;
11642 state->now_subseg = now_subseg;
11643 state->generating_literals = generating_literals;
11644 generating_literals++;
2b0210eb 11645 subseg_set (new_now_seg, new_now_subseg);
e0001a05
NC
11646}
11647
11648
11649/* Use to restore the emitting into the normal place. */
11650
7fa3d080
BW
11651static void
11652xtensa_restore_emit_state (emit_state *state)
e0001a05
NC
11653{
11654 generating_literals = state->generating_literals;
2b0210eb 11655 subseg_set (state->now_seg, state->now_subseg);
e0001a05
NC
11656}
11657
11658
74869ac7 11659/* Predicate function used to look up a section in a particular group. */
e0001a05 11660
74869ac7
BW
11661static bfd_boolean
11662match_section_group (bfd *abfd ATTRIBUTE_UNUSED, asection *sec, void *inf)
e0001a05 11663{
74869ac7
BW
11664 const char *gname = inf;
11665 const char *group_name = elf_group_name (sec);
3739860c 11666
74869ac7
BW
11667 return (group_name == gname
11668 || (group_name != NULL
11669 && gname != NULL
11670 && strcmp (group_name, gname) == 0));
11671}
e0001a05 11672
e0001a05 11673
74869ac7
BW
11674/* Get the literal section to be used for the current text section.
11675 The result may be cached in the default_lit_sections structure. */
11676
11677static segT
11678cache_literal_section (bfd_boolean use_abs_literals)
11679{
11680 const char *text_name, *group_name = 0;
b9bb4a93
TS
11681 const char *base_name, *suffix;
11682 char *name;
74869ac7
BW
11683 segT *pcached;
11684 segT seg, current_section;
11685 int current_subsec;
11686 bfd_boolean linkonce = FALSE;
11687
11688 /* Save the current section/subsection. */
11689 current_section = now_seg;
11690 current_subsec = now_subseg;
11691
11692 /* Clear the cached values if they are no longer valid. */
11693 if (now_seg != default_lit_sections.current_text_seg)
b08b5071 11694 {
74869ac7
BW
11695 default_lit_sections.current_text_seg = now_seg;
11696 default_lit_sections.lit_seg = NULL;
11697 default_lit_sections.lit4_seg = NULL;
11698 }
11699
11700 /* Check if the literal section is already cached. */
11701 if (use_abs_literals)
11702 pcached = &default_lit_sections.lit4_seg;
11703 else
11704 pcached = &default_lit_sections.lit_seg;
11705
11706 if (*pcached)
11707 return *pcached;
3739860c 11708
74869ac7
BW
11709 text_name = default_lit_sections.lit_prefix;
11710 if (! text_name || ! *text_name)
11711 {
11712 text_name = segment_name (current_section);
11713 group_name = elf_group_name (current_section);
11714 linkonce = (current_section->flags & SEC_LINK_ONCE) != 0;
11715 }
11716
11717 base_name = use_abs_literals ? ".lit4" : ".literal";
11718 if (group_name)
11719 {
4ec9d7d5 11720 name = concat (base_name, ".", group_name, (char *) NULL);
74869ac7
BW
11721 }
11722 else if (strncmp (text_name, ".gnu.linkonce.", linkonce_len) == 0)
11723 {
11724 suffix = strchr (text_name + linkonce_len, '.');
11725
4ec9d7d5
TS
11726 name = concat (".gnu.linkonce", base_name, suffix ? suffix : "",
11727 (char *) NULL);
74869ac7
BW
11728 linkonce = TRUE;
11729 }
11730 else
11731 {
a89c407e
SA
11732 /* If the section name begins or ends with ".text", then replace
11733 that portion instead of appending an additional suffix. */
74869ac7 11734 size_t len = strlen (text_name);
a89c407e
SA
11735 if (len >= 5
11736 && (strcmp (text_name + len - 5, ".text") == 0
11737 || strncmp (text_name, ".text", 5) == 0))
74869ac7
BW
11738 len -= 5;
11739
add39d23 11740 name = XNEWVEC (char, len + strlen (base_name) + 1);
a89c407e
SA
11741 if (strncmp (text_name, ".text", 5) == 0)
11742 {
11743 strcpy (name, base_name);
11744 strcat (name, text_name + 5);
11745 }
11746 else
11747 {
11748 strcpy (name, text_name);
11749 strcpy (name + len, base_name);
11750 }
b08b5071 11751 }
e0001a05 11752
74869ac7
BW
11753 /* Canonicalize section names to allow renaming literal sections.
11754 The group name, if any, came from the current text section and
11755 has already been canonicalized. */
11756 name = tc_canonicalize_symbol_name (name);
11757
11758 seg = bfd_get_section_by_name_if (stdoutput, name, match_section_group,
11759 (void *) group_name);
11760 if (! seg)
e0001a05 11761 {
74869ac7
BW
11762 flagword flags;
11763
11764 seg = subseg_force_new (name, 0);
11765
11766 if (! use_abs_literals)
b08b5071 11767 {
74869ac7 11768 /* Add the newly created literal segment to the list. */
325801bd 11769 seg_list *n = XNEW (seg_list);
b08b5071 11770 n->seg = seg;
74869ac7
BW
11771 n->next = literal_head->next;
11772 literal_head->next = n;
b08b5071 11773 }
74869ac7
BW
11774
11775 flags = (SEC_HAS_CONTENTS | SEC_READONLY | SEC_ALLOC | SEC_LOAD
11776 | (linkonce ? (SEC_LINK_ONCE | SEC_LINK_DUPLICATES_DISCARD) : 0)
11777 | (use_abs_literals ? SEC_DATA : SEC_CODE));
11778
11779 elf_group_name (seg) = group_name;
11780
11781 bfd_set_section_flags (stdoutput, seg, flags);
b08b5071 11782 bfd_set_section_alignment (stdoutput, seg, 2);
e0001a05
NC
11783 }
11784
74869ac7 11785 *pcached = seg;
b08b5071 11786 subseg_set (current_section, current_subsec);
74869ac7 11787 return seg;
e0001a05
NC
11788}
11789
43cd72b9
BW
11790\f
11791/* Property Tables Stuff. */
11792
7fa3d080
BW
11793#define XTENSA_INSN_SEC_NAME ".xt.insn"
11794#define XTENSA_LIT_SEC_NAME ".xt.lit"
11795#define XTENSA_PROP_SEC_NAME ".xt.prop"
11796
11797typedef bfd_boolean (*frag_predicate) (const fragS *);
11798typedef void (*frag_flags_fn) (const fragS *, frag_flags *);
11799
b08b5071 11800static bfd_boolean get_frag_is_literal (const fragS *);
7fa3d080
BW
11801static void xtensa_create_property_segments
11802 (frag_predicate, frag_predicate, const char *, xt_section_type);
11803static void xtensa_create_xproperty_segments
11804 (frag_flags_fn, const char *, xt_section_type);
532f93bd 11805static bfd_boolean exclude_section_from_property_tables (segT);
7fa3d080
BW
11806static bfd_boolean section_has_property (segT, frag_predicate);
11807static bfd_boolean section_has_xproperty (segT, frag_flags_fn);
11808static void add_xt_block_frags
542f8b94 11809 (segT, xtensa_block_info **, frag_predicate, frag_predicate);
7fa3d080
BW
11810static bfd_boolean xtensa_frag_flags_is_empty (const frag_flags *);
11811static void xtensa_frag_flags_init (frag_flags *);
11812static void get_frag_property_flags (const fragS *, frag_flags *);
2f1bf5c1 11813static flagword frag_flags_to_number (const frag_flags *);
542f8b94 11814static void add_xt_prop_frags (segT, xtensa_block_info **, frag_flags_fn);
7fa3d080
BW
11815
11816/* Set up property tables after relaxation. */
11817
11818void
11819xtensa_post_relax_hook (void)
11820{
11821 xtensa_move_seg_list_to_beginning (literal_head);
7fa3d080
BW
11822
11823 xtensa_find_unmarked_state_frags ();
99ded152 11824 xtensa_mark_frags_for_org ();
6a7eedfe 11825 xtensa_mark_difference_of_two_symbols ();
7fa3d080 11826
b29757dc
BW
11827 xtensa_create_property_segments (get_frag_is_literal,
11828 NULL,
11829 XTENSA_LIT_SEC_NAME,
11830 xt_literal_sec);
7fa3d080
BW
11831 xtensa_create_xproperty_segments (get_frag_property_flags,
11832 XTENSA_PROP_SEC_NAME,
11833 xt_prop_sec);
11834
11835 if (warn_unaligned_branch_targets)
11836 bfd_map_over_sections (stdoutput, xtensa_find_unaligned_branch_targets, 0);
11837 bfd_map_over_sections (stdoutput, xtensa_find_unaligned_loops, 0);
11838}
11839
11840
43cd72b9
BW
11841/* This function is only meaningful after xtensa_move_literals. */
11842
11843static bfd_boolean
7fa3d080 11844get_frag_is_literal (const fragS *fragP)
43cd72b9 11845{
9c2799c2 11846 gas_assert (fragP != NULL);
43cd72b9
BW
11847 return fragP->tc_frag_data.is_literal;
11848}
11849
11850
43cd72b9 11851static void
7fa3d080
BW
11852xtensa_create_property_segments (frag_predicate property_function,
11853 frag_predicate end_property_function,
11854 const char *section_name_base,
11855 xt_section_type sec_type)
43cd72b9
BW
11856{
11857 segT *seclist;
11858
11859 /* Walk over all of the current segments.
11860 Walk over each fragment
11861 For each non-empty fragment,
11862 Build a property record (append where possible). */
11863
11864 for (seclist = &stdoutput->sections;
11865 seclist && *seclist;
11866 seclist = &(*seclist)->next)
11867 {
11868 segT sec = *seclist;
43cd72b9 11869
532f93bd 11870 if (exclude_section_from_property_tables (sec))
43cd72b9
BW
11871 continue;
11872
11873 if (section_has_property (sec, property_function))
11874 {
542f8b94
BW
11875 segment_info_type *xt_seg_info;
11876 xtensa_block_info **xt_blocks;
51c8ebc1 11877 segT prop_sec = xtensa_make_property_section (sec, section_name_base);
542f8b94
BW
11878
11879 prop_sec->output_section = prop_sec;
11880 subseg_set (prop_sec, 0);
11881 xt_seg_info = seg_info (prop_sec);
11882 xt_blocks = &xt_seg_info->tc_segment_info_data.blocks[sec_type];
11883
43cd72b9 11884 /* Walk over all of the frchains here and add new sections. */
542f8b94 11885 add_xt_block_frags (sec, xt_blocks, property_function,
43cd72b9
BW
11886 end_property_function);
11887 }
11888 }
11889
11890 /* Now we fill them out.... */
11891
11892 for (seclist = &stdoutput->sections;
11893 seclist && *seclist;
11894 seclist = &(*seclist)->next)
11895 {
11896 segment_info_type *seginfo;
11897 xtensa_block_info *block;
11898 segT sec = *seclist;
11899
11900 seginfo = seg_info (sec);
11901 block = seginfo->tc_segment_info_data.blocks[sec_type];
11902
11903 if (block)
11904 {
11905 xtensa_block_info *cur_block;
43cd72b9 11906 int num_recs = 0;
d77b99c9 11907 bfd_size_type rec_size;
43cd72b9
BW
11908
11909 for (cur_block = block; cur_block; cur_block = cur_block->next)
11910 num_recs++;
11911
11912 rec_size = num_recs * 8;
11913 bfd_set_section_size (stdoutput, sec, rec_size);
11914
43cd72b9
BW
11915 if (num_recs)
11916 {
43cd72b9 11917 char *frag_data;
542f8b94 11918 int i;
43cd72b9 11919
542f8b94
BW
11920 subseg_set (sec, 0);
11921 frag_data = frag_more (rec_size);
43cd72b9 11922 cur_block = block;
43cd72b9
BW
11923 for (i = 0; i < num_recs; i++)
11924 {
542f8b94 11925 fixS *fix;
e0001a05 11926
43cd72b9 11927 /* Write the fixup. */
9c2799c2 11928 gas_assert (cur_block);
542f8b94
BW
11929 fix = fix_new (frag_now, i * 8, 4,
11930 section_symbol (cur_block->sec),
11931 cur_block->offset,
11932 FALSE, BFD_RELOC_32);
11933 fix->fx_file = "<internal>";
43cd72b9 11934 fix->fx_line = 0;
e0001a05 11935
43cd72b9 11936 /* Write the length. */
542f8b94 11937 md_number_to_chars (&frag_data[4 + i * 8],
43cd72b9
BW
11938 cur_block->size, 4);
11939 cur_block = cur_block->next;
11940 }
542f8b94
BW
11941 frag_wane (frag_now);
11942 frag_new (0);
11943 frag_wane (frag_now);
43cd72b9
BW
11944 }
11945 }
11946 }
e0001a05
NC
11947}
11948
11949
7fa3d080
BW
11950static void
11951xtensa_create_xproperty_segments (frag_flags_fn flag_fn,
11952 const char *section_name_base,
11953 xt_section_type sec_type)
e0001a05
NC
11954{
11955 segT *seclist;
11956
11957 /* Walk over all of the current segments.
43cd72b9
BW
11958 Walk over each fragment.
11959 For each fragment that has instructions,
11960 build an instruction record (append where possible). */
e0001a05
NC
11961
11962 for (seclist = &stdoutput->sections;
11963 seclist && *seclist;
11964 seclist = &(*seclist)->next)
11965 {
11966 segT sec = *seclist;
43cd72b9 11967
532f93bd 11968 if (exclude_section_from_property_tables (sec))
43cd72b9
BW
11969 continue;
11970
11971 if (section_has_xproperty (sec, flag_fn))
e0001a05 11972 {
542f8b94
BW
11973 segment_info_type *xt_seg_info;
11974 xtensa_block_info **xt_blocks;
51c8ebc1 11975 segT prop_sec = xtensa_make_property_section (sec, section_name_base);
542f8b94
BW
11976
11977 prop_sec->output_section = prop_sec;
11978 subseg_set (prop_sec, 0);
11979 xt_seg_info = seg_info (prop_sec);
11980 xt_blocks = &xt_seg_info->tc_segment_info_data.blocks[sec_type];
11981
e0001a05 11982 /* Walk over all of the frchains here and add new sections. */
542f8b94 11983 add_xt_prop_frags (sec, xt_blocks, flag_fn);
e0001a05
NC
11984 }
11985 }
11986
11987 /* Now we fill them out.... */
11988
11989 for (seclist = &stdoutput->sections;
11990 seclist && *seclist;
11991 seclist = &(*seclist)->next)
11992 {
11993 segment_info_type *seginfo;
11994 xtensa_block_info *block;
11995 segT sec = *seclist;
43cd72b9 11996
e0001a05
NC
11997 seginfo = seg_info (sec);
11998 block = seginfo->tc_segment_info_data.blocks[sec_type];
11999
12000 if (block)
12001 {
12002 xtensa_block_info *cur_block;
43cd72b9 12003 int num_recs = 0;
d77b99c9 12004 bfd_size_type rec_size;
e0001a05
NC
12005
12006 for (cur_block = block; cur_block; cur_block = cur_block->next)
12007 num_recs++;
12008
43cd72b9 12009 rec_size = num_recs * (8 + 4);
e0001a05 12010 bfd_set_section_size (stdoutput, sec, rec_size);
43cd72b9
BW
12011 /* elf_section_data (sec)->this_hdr.sh_entsize = 12; */
12012
e0001a05
NC
12013 if (num_recs)
12014 {
e0001a05 12015 char *frag_data;
542f8b94 12016 int i;
e0001a05 12017
542f8b94
BW
12018 subseg_set (sec, 0);
12019 frag_data = frag_more (rec_size);
e0001a05 12020 cur_block = block;
e0001a05
NC
12021 for (i = 0; i < num_recs; i++)
12022 {
542f8b94 12023 fixS *fix;
e0001a05
NC
12024
12025 /* Write the fixup. */
9c2799c2 12026 gas_assert (cur_block);
542f8b94
BW
12027 fix = fix_new (frag_now, i * 12, 4,
12028 section_symbol (cur_block->sec),
12029 cur_block->offset,
12030 FALSE, BFD_RELOC_32);
12031 fix->fx_file = "<internal>";
e0001a05
NC
12032 fix->fx_line = 0;
12033
12034 /* Write the length. */
542f8b94 12035 md_number_to_chars (&frag_data[4 + i * 12],
e0001a05 12036 cur_block->size, 4);
542f8b94 12037 md_number_to_chars (&frag_data[8 + i * 12],
43cd72b9 12038 frag_flags_to_number (&cur_block->flags),
2f1bf5c1 12039 sizeof (flagword));
e0001a05
NC
12040 cur_block = cur_block->next;
12041 }
542f8b94
BW
12042 frag_wane (frag_now);
12043 frag_new (0);
12044 frag_wane (frag_now);
e0001a05
NC
12045 }
12046 }
12047 }
12048}
12049
12050
532f93bd
BW
12051static bfd_boolean
12052exclude_section_from_property_tables (segT sec)
12053{
12054 flagword flags = bfd_get_section_flags (stdoutput, sec);
12055
12056 /* Sections that don't contribute to the memory footprint are excluded. */
12057 if ((flags & SEC_DEBUGGING)
12058 || !(flags & SEC_ALLOC)
12059 || (flags & SEC_MERGE))
12060 return TRUE;
12061
12062 /* Linker cie and fde optimizations mess up property entries for
12063 eh_frame sections, but there is nothing inside them relevant to
12064 property tables anyway. */
12065 if (strcmp (sec->name, ".eh_frame") == 0)
12066 return TRUE;
12067
12068 return FALSE;
12069}
12070
12071
7fa3d080
BW
12072static bfd_boolean
12073section_has_property (segT sec, frag_predicate property_function)
e0001a05
NC
12074{
12075 segment_info_type *seginfo = seg_info (sec);
12076 fragS *fragP;
12077
12078 if (seginfo && seginfo->frchainP)
12079 {
12080 for (fragP = seginfo->frchainP->frch_root; fragP; fragP = fragP->fr_next)
12081 {
12082 if (property_function (fragP)
12083 && (fragP->fr_type != rs_fill || fragP->fr_fix != 0))
12084 return TRUE;
12085 }
12086 }
12087 return FALSE;
12088}
12089
12090
7fa3d080
BW
12091static bfd_boolean
12092section_has_xproperty (segT sec, frag_flags_fn property_function)
43cd72b9
BW
12093{
12094 segment_info_type *seginfo = seg_info (sec);
12095 fragS *fragP;
12096
12097 if (seginfo && seginfo->frchainP)
12098 {
12099 for (fragP = seginfo->frchainP->frch_root; fragP; fragP = fragP->fr_next)
12100 {
12101 frag_flags prop_flags;
12102 property_function (fragP, &prop_flags);
12103 if (!xtensa_frag_flags_is_empty (&prop_flags))
12104 return TRUE;
12105 }
12106 }
12107 return FALSE;
12108}
12109
12110
e0001a05
NC
12111/* Two types of block sections exist right now: literal and insns. */
12112
7fa3d080
BW
12113static void
12114add_xt_block_frags (segT sec,
7fa3d080
BW
12115 xtensa_block_info **xt_block,
12116 frag_predicate property_function,
12117 frag_predicate end_property_function)
e0001a05 12118{
e0001a05
NC
12119 fragS *fragP;
12120
e0001a05
NC
12121 /* Build it if needed. */
12122 while (*xt_block != NULL)
12123 xt_block = &(*xt_block)->next;
12124 /* We are either at NULL at the beginning or at the end. */
12125
12126 /* Walk through the frags. */
542f8b94 12127 if (seg_info (sec)->frchainP)
e0001a05 12128 {
542f8b94 12129 for (fragP = seg_info (sec)->frchainP->frch_root;
e0001a05
NC
12130 fragP;
12131 fragP = fragP->fr_next)
12132 {
12133 if (property_function (fragP)
12134 && (fragP->fr_type != rs_fill || fragP->fr_fix != 0))
12135 {
12136 if (*xt_block != NULL)
12137 {
12138 if ((*xt_block)->offset + (*xt_block)->size
12139 == fragP->fr_address)
12140 (*xt_block)->size += fragP->fr_fix;
12141 else
12142 xt_block = &((*xt_block)->next);
12143 }
12144 if (*xt_block == NULL)
12145 {
325801bd 12146 xtensa_block_info *new_block = XNEW (xtensa_block_info);
43cd72b9
BW
12147 new_block->sec = sec;
12148 new_block->offset = fragP->fr_address;
12149 new_block->size = fragP->fr_fix;
12150 new_block->next = NULL;
12151 xtensa_frag_flags_init (&new_block->flags);
12152 *xt_block = new_block;
12153 }
12154 if (end_property_function
12155 && end_property_function (fragP))
12156 {
12157 xt_block = &((*xt_block)->next);
12158 }
12159 }
12160 }
12161 }
12162}
12163
12164
12165/* Break the encapsulation of add_xt_prop_frags here. */
12166
7fa3d080
BW
12167static bfd_boolean
12168xtensa_frag_flags_is_empty (const frag_flags *prop_flags)
43cd72b9
BW
12169{
12170 if (prop_flags->is_literal
12171 || prop_flags->is_insn
12172 || prop_flags->is_data
12173 || prop_flags->is_unreachable)
12174 return FALSE;
12175 return TRUE;
12176}
12177
12178
7fa3d080
BW
12179static void
12180xtensa_frag_flags_init (frag_flags *prop_flags)
43cd72b9
BW
12181{
12182 memset (prop_flags, 0, sizeof (frag_flags));
12183}
12184
12185
7fa3d080
BW
12186static void
12187get_frag_property_flags (const fragS *fragP, frag_flags *prop_flags)
43cd72b9
BW
12188{
12189 xtensa_frag_flags_init (prop_flags);
12190 if (fragP->tc_frag_data.is_literal)
12191 prop_flags->is_literal = TRUE;
99ded152
BW
12192 if (fragP->tc_frag_data.is_specific_opcode
12193 || fragP->tc_frag_data.is_no_transform)
1f7efbae
BW
12194 {
12195 prop_flags->is_no_transform = TRUE;
12196 if (xtensa_frag_flags_is_empty (prop_flags))
12197 prop_flags->is_data = TRUE;
12198 }
43cd72b9 12199 if (fragP->tc_frag_data.is_unreachable)
7fa3d080 12200 prop_flags->is_unreachable = TRUE;
43cd72b9
BW
12201 else if (fragP->tc_frag_data.is_insn)
12202 {
12203 prop_flags->is_insn = TRUE;
12204 if (fragP->tc_frag_data.is_loop_target)
12205 prop_flags->insn.is_loop_target = TRUE;
12206 if (fragP->tc_frag_data.is_branch_target)
12207 prop_flags->insn.is_branch_target = TRUE;
43cd72b9
BW
12208 if (fragP->tc_frag_data.is_no_density)
12209 prop_flags->insn.is_no_density = TRUE;
12210 if (fragP->tc_frag_data.use_absolute_literals)
12211 prop_flags->insn.is_abslit = TRUE;
12212 }
12213 if (fragP->tc_frag_data.is_align)
12214 {
12215 prop_flags->is_align = TRUE;
12216 prop_flags->alignment = fragP->tc_frag_data.alignment;
12217 if (xtensa_frag_flags_is_empty (prop_flags))
12218 prop_flags->is_data = TRUE;
12219 }
12220}
12221
12222
2f1bf5c1 12223static flagword
7fa3d080 12224frag_flags_to_number (const frag_flags *prop_flags)
43cd72b9 12225{
2f1bf5c1 12226 flagword num = 0;
43cd72b9
BW
12227 if (prop_flags->is_literal)
12228 num |= XTENSA_PROP_LITERAL;
12229 if (prop_flags->is_insn)
12230 num |= XTENSA_PROP_INSN;
12231 if (prop_flags->is_data)
12232 num |= XTENSA_PROP_DATA;
12233 if (prop_flags->is_unreachable)
12234 num |= XTENSA_PROP_UNREACHABLE;
12235 if (prop_flags->insn.is_loop_target)
12236 num |= XTENSA_PROP_INSN_LOOP_TARGET;
12237 if (prop_flags->insn.is_branch_target)
12238 {
12239 num |= XTENSA_PROP_INSN_BRANCH_TARGET;
12240 num = SET_XTENSA_PROP_BT_ALIGN (num, prop_flags->insn.bt_align_priority);
12241 }
12242
12243 if (prop_flags->insn.is_no_density)
12244 num |= XTENSA_PROP_INSN_NO_DENSITY;
99ded152
BW
12245 if (prop_flags->is_no_transform)
12246 num |= XTENSA_PROP_NO_TRANSFORM;
43cd72b9
BW
12247 if (prop_flags->insn.is_no_reorder)
12248 num |= XTENSA_PROP_INSN_NO_REORDER;
12249 if (prop_flags->insn.is_abslit)
12250 num |= XTENSA_PROP_INSN_ABSLIT;
12251
12252 if (prop_flags->is_align)
12253 {
12254 num |= XTENSA_PROP_ALIGN;
12255 num = SET_XTENSA_PROP_ALIGNMENT (num, prop_flags->alignment);
12256 }
12257
12258 return num;
12259}
12260
12261
12262static bfd_boolean
7fa3d080
BW
12263xtensa_frag_flags_combinable (const frag_flags *prop_flags_1,
12264 const frag_flags *prop_flags_2)
43cd72b9
BW
12265{
12266 /* Cannot combine with an end marker. */
12267
12268 if (prop_flags_1->is_literal != prop_flags_2->is_literal)
12269 return FALSE;
12270 if (prop_flags_1->is_insn != prop_flags_2->is_insn)
12271 return FALSE;
12272 if (prop_flags_1->is_data != prop_flags_2->is_data)
12273 return FALSE;
12274
12275 if (prop_flags_1->is_insn)
12276 {
12277 /* Properties of the beginning of the frag. */
12278 if (prop_flags_2->insn.is_loop_target)
12279 return FALSE;
12280 if (prop_flags_2->insn.is_branch_target)
12281 return FALSE;
12282 if (prop_flags_1->insn.is_no_density !=
12283 prop_flags_2->insn.is_no_density)
12284 return FALSE;
99ded152
BW
12285 if (prop_flags_1->is_no_transform !=
12286 prop_flags_2->is_no_transform)
43cd72b9
BW
12287 return FALSE;
12288 if (prop_flags_1->insn.is_no_reorder !=
12289 prop_flags_2->insn.is_no_reorder)
12290 return FALSE;
12291 if (prop_flags_1->insn.is_abslit !=
12292 prop_flags_2->insn.is_abslit)
12293 return FALSE;
12294 }
12295
12296 if (prop_flags_1->is_align)
12297 return FALSE;
12298
12299 return TRUE;
12300}
12301
12302
7fa3d080
BW
12303static bfd_vma
12304xt_block_aligned_size (const xtensa_block_info *xt_block)
43cd72b9
BW
12305{
12306 bfd_vma end_addr;
d77b99c9 12307 unsigned align_bits;
43cd72b9
BW
12308
12309 if (!xt_block->flags.is_align)
12310 return xt_block->size;
12311
12312 end_addr = xt_block->offset + xt_block->size;
12313 align_bits = xt_block->flags.alignment;
12314 end_addr = ((end_addr + ((1 << align_bits) -1)) >> align_bits) << align_bits;
12315 return end_addr - xt_block->offset;
12316}
12317
12318
12319static bfd_boolean
7fa3d080
BW
12320xtensa_xt_block_combine (xtensa_block_info *xt_block,
12321 const xtensa_block_info *xt_block_2)
43cd72b9
BW
12322{
12323 if (xt_block->sec != xt_block_2->sec)
12324 return FALSE;
12325 if (xt_block->offset + xt_block_aligned_size (xt_block)
12326 != xt_block_2->offset)
12327 return FALSE;
12328
12329 if (xt_block_2->size == 0
12330 && (!xt_block_2->flags.is_unreachable
12331 || xt_block->flags.is_unreachable))
12332 {
12333 if (xt_block_2->flags.is_align
12334 && xt_block->flags.is_align)
12335 {
12336 /* Nothing needed. */
12337 if (xt_block->flags.alignment >= xt_block_2->flags.alignment)
12338 return TRUE;
12339 }
12340 else
12341 {
12342 if (xt_block_2->flags.is_align)
12343 {
12344 /* Push alignment to previous entry. */
12345 xt_block->flags.is_align = xt_block_2->flags.is_align;
12346 xt_block->flags.alignment = xt_block_2->flags.alignment;
12347 }
12348 return TRUE;
12349 }
12350 }
12351 if (!xtensa_frag_flags_combinable (&xt_block->flags,
12352 &xt_block_2->flags))
12353 return FALSE;
12354
12355 xt_block->size += xt_block_2->size;
12356
12357 if (xt_block_2->flags.is_align)
12358 {
12359 xt_block->flags.is_align = TRUE;
12360 xt_block->flags.alignment = xt_block_2->flags.alignment;
12361 }
12362
12363 return TRUE;
12364}
12365
12366
7fa3d080
BW
12367static void
12368add_xt_prop_frags (segT sec,
7fa3d080
BW
12369 xtensa_block_info **xt_block,
12370 frag_flags_fn property_function)
43cd72b9 12371{
43cd72b9
BW
12372 fragS *fragP;
12373
43cd72b9
BW
12374 /* Build it if needed. */
12375 while (*xt_block != NULL)
12376 {
12377 xt_block = &(*xt_block)->next;
12378 }
12379 /* We are either at NULL at the beginning or at the end. */
12380
12381 /* Walk through the frags. */
542f8b94 12382 if (seg_info (sec)->frchainP)
43cd72b9 12383 {
542f8b94 12384 for (fragP = seg_info (sec)->frchainP->frch_root; fragP;
43cd72b9
BW
12385 fragP = fragP->fr_next)
12386 {
12387 xtensa_block_info tmp_block;
12388 tmp_block.sec = sec;
12389 tmp_block.offset = fragP->fr_address;
12390 tmp_block.size = fragP->fr_fix;
12391 tmp_block.next = NULL;
12392 property_function (fragP, &tmp_block.flags);
12393
12394 if (!xtensa_frag_flags_is_empty (&tmp_block.flags))
12395 /* && fragP->fr_fix != 0) */
12396 {
12397 if ((*xt_block) == NULL
12398 || !xtensa_xt_block_combine (*xt_block, &tmp_block))
12399 {
12400 xtensa_block_info *new_block;
12401 if ((*xt_block) != NULL)
12402 xt_block = &(*xt_block)->next;
325801bd 12403 new_block = XNEW (xtensa_block_info);
43cd72b9
BW
12404 *new_block = tmp_block;
12405 *xt_block = new_block;
12406 }
12407 }
12408 }
12409 }
12410}
12411
12412\f
12413/* op_placement_info_table */
12414
12415/* op_placement_info makes it easier to determine which
12416 ops can go in which slots. */
12417
12418static void
7fa3d080 12419init_op_placement_info_table (void)
43cd72b9
BW
12420{
12421 xtensa_isa isa = xtensa_default_isa;
12422 xtensa_insnbuf ibuf = xtensa_insnbuf_alloc (isa);
12423 xtensa_opcode opcode;
12424 xtensa_format fmt;
12425 int slot;
12426 int num_opcodes = xtensa_isa_num_opcodes (isa);
12427
325801bd 12428 op_placement_table = XNEWVEC (op_placement_info, num_opcodes);
9c2799c2 12429 gas_assert (xtensa_isa_num_formats (isa) < MAX_FORMATS);
43cd72b9
BW
12430
12431 for (opcode = 0; opcode < num_opcodes; opcode++)
12432 {
12433 op_placement_info *opi = &op_placement_table[opcode];
12434 /* FIXME: Make tinsn allocation dynamic. */
51add5c3 12435 if (xtensa_opcode_num_operands (isa, opcode) > MAX_INSN_ARGS)
43cd72b9 12436 as_fatal (_("too many operands in instruction"));
43cd72b9
BW
12437 opi->narrowest = XTENSA_UNDEFINED;
12438 opi->narrowest_size = 0x7F;
b2d179be 12439 opi->narrowest_slot = 0;
43cd72b9
BW
12440 opi->formats = 0;
12441 opi->num_formats = 0;
12442 opi->issuef = 0;
12443 for (fmt = 0; fmt < xtensa_isa_num_formats (isa); fmt++)
12444 {
12445 opi->slots[fmt] = 0;
12446 for (slot = 0; slot < xtensa_format_num_slots (isa, fmt); slot++)
12447 {
12448 if (xtensa_opcode_encode (isa, fmt, slot, ibuf, opcode) == 0)
12449 {
12450 int fmt_length = xtensa_format_length (isa, fmt);
12451 opi->issuef++;
12452 set_bit (fmt, opi->formats);
12453 set_bit (slot, opi->slots[fmt]);
a02728c8
BW
12454 if (fmt_length < opi->narrowest_size
12455 || (fmt_length == opi->narrowest_size
12456 && (xtensa_format_num_slots (isa, fmt)
12457 < xtensa_format_num_slots (isa,
12458 opi->narrowest))))
43cd72b9
BW
12459 {
12460 opi->narrowest = fmt;
12461 opi->narrowest_size = fmt_length;
b2d179be 12462 opi->narrowest_slot = slot;
43cd72b9 12463 }
e0001a05
NC
12464 }
12465 }
43cd72b9
BW
12466 if (opi->formats)
12467 opi->num_formats++;
e0001a05
NC
12468 }
12469 }
43cd72b9
BW
12470 xtensa_insnbuf_free (isa, ibuf);
12471}
12472
12473
12474bfd_boolean
7fa3d080 12475opcode_fits_format_slot (xtensa_opcode opcode, xtensa_format fmt, int slot)
43cd72b9
BW
12476{
12477 return bit_is_set (slot, op_placement_table[opcode].slots[fmt]);
12478}
12479
12480
12481/* If the opcode is available in a single slot format, return its size. */
12482
7fa3d080
BW
12483static int
12484xg_get_single_size (xtensa_opcode opcode)
43cd72b9 12485{
b2d179be 12486 return op_placement_table[opcode].narrowest_size;
43cd72b9
BW
12487}
12488
12489
7fa3d080
BW
12490static xtensa_format
12491xg_get_single_format (xtensa_opcode opcode)
43cd72b9 12492{
b2d179be
BW
12493 return op_placement_table[opcode].narrowest;
12494}
12495
12496
12497static int
12498xg_get_single_slot (xtensa_opcode opcode)
12499{
12500 return op_placement_table[opcode].narrowest_slot;
e0001a05
NC
12501}
12502
12503\f
12504/* Instruction Stack Functions (from "xtensa-istack.h"). */
12505
12506void
7fa3d080 12507istack_init (IStack *stack)
e0001a05 12508{
e0001a05
NC
12509 stack->ninsn = 0;
12510}
12511
12512
12513bfd_boolean
7fa3d080 12514istack_empty (IStack *stack)
e0001a05
NC
12515{
12516 return (stack->ninsn == 0);
12517}
12518
12519
12520bfd_boolean
7fa3d080 12521istack_full (IStack *stack)
e0001a05
NC
12522{
12523 return (stack->ninsn == MAX_ISTACK);
12524}
12525
12526
12527/* Return a pointer to the top IStack entry.
43cd72b9 12528 It is an error to call this if istack_empty () is TRUE. */
e0001a05
NC
12529
12530TInsn *
7fa3d080 12531istack_top (IStack *stack)
e0001a05
NC
12532{
12533 int rec = stack->ninsn - 1;
9c2799c2 12534 gas_assert (!istack_empty (stack));
e0001a05
NC
12535 return &stack->insn[rec];
12536}
12537
12538
12539/* Add a new TInsn to an IStack.
43cd72b9 12540 It is an error to call this if istack_full () is TRUE. */
e0001a05
NC
12541
12542void
7fa3d080 12543istack_push (IStack *stack, TInsn *insn)
e0001a05
NC
12544{
12545 int rec = stack->ninsn;
9c2799c2 12546 gas_assert (!istack_full (stack));
43cd72b9 12547 stack->insn[rec] = *insn;
e0001a05
NC
12548 stack->ninsn++;
12549}
12550
12551
12552/* Clear space for the next TInsn on the IStack and return a pointer
43cd72b9 12553 to it. It is an error to call this if istack_full () is TRUE. */
e0001a05
NC
12554
12555TInsn *
7fa3d080 12556istack_push_space (IStack *stack)
e0001a05
NC
12557{
12558 int rec = stack->ninsn;
12559 TInsn *insn;
9c2799c2 12560 gas_assert (!istack_full (stack));
e0001a05 12561 insn = &stack->insn[rec];
60242db2 12562 tinsn_init (insn);
e0001a05
NC
12563 stack->ninsn++;
12564 return insn;
12565}
12566
12567
12568/* Remove the last pushed instruction. It is an error to call this if
43cd72b9 12569 istack_empty () returns TRUE. */
e0001a05
NC
12570
12571void
7fa3d080 12572istack_pop (IStack *stack)
e0001a05
NC
12573{
12574 int rec = stack->ninsn - 1;
9c2799c2 12575 gas_assert (!istack_empty (stack));
e0001a05 12576 stack->ninsn--;
60242db2 12577 tinsn_init (&stack->insn[rec]);
e0001a05
NC
12578}
12579
12580\f
12581/* TInsn functions. */
12582
12583void
7fa3d080 12584tinsn_init (TInsn *dst)
e0001a05
NC
12585{
12586 memset (dst, 0, sizeof (TInsn));
12587}
12588
12589
43cd72b9 12590/* Return TRUE if ANY of the operands in the insn are symbolic. */
e0001a05
NC
12591
12592static bfd_boolean
7fa3d080 12593tinsn_has_symbolic_operands (const TInsn *insn)
e0001a05
NC
12594{
12595 int i;
12596 int n = insn->ntok;
12597
9c2799c2 12598 gas_assert (insn->insn_type == ITYPE_INSN);
e0001a05
NC
12599
12600 for (i = 0; i < n; ++i)
12601 {
12602 switch (insn->tok[i].X_op)
12603 {
12604 case O_register:
12605 case O_constant:
12606 break;
12607 default:
12608 return TRUE;
12609 }
12610 }
12611 return FALSE;
12612}
12613
12614
12615bfd_boolean
7fa3d080 12616tinsn_has_invalid_symbolic_operands (const TInsn *insn)
e0001a05 12617{
43cd72b9 12618 xtensa_isa isa = xtensa_default_isa;
e0001a05
NC
12619 int i;
12620 int n = insn->ntok;
12621
9c2799c2 12622 gas_assert (insn->insn_type == ITYPE_INSN);
e0001a05
NC
12623
12624 for (i = 0; i < n; ++i)
12625 {
12626 switch (insn->tok[i].X_op)
12627 {
12628 case O_register:
12629 case O_constant:
12630 break;
43cd72b9
BW
12631 case O_big:
12632 case O_illegal:
12633 case O_absent:
12634 /* Errors for these types are caught later. */
12635 break;
12636 case O_hi16:
12637 case O_lo16:
e0001a05 12638 default:
43cd72b9
BW
12639 /* Symbolic immediates are only allowed on the last immediate
12640 operand. At this time, CONST16 is the only opcode where we
e7da6241 12641 support non-PC-relative relocations. */
43cd72b9
BW
12642 if (i != get_relaxable_immed (insn->opcode)
12643 || (xtensa_operand_is_PCrelative (isa, insn->opcode, i) != 1
12644 && insn->opcode != xtensa_const16_opcode))
12645 {
431ad2d0 12646 as_bad (_("invalid symbolic operand"));
43cd72b9
BW
12647 return TRUE;
12648 }
e0001a05
NC
12649 }
12650 }
12651 return FALSE;
12652}
12653
12654
12655/* For assembly code with complex expressions (e.g. subtraction),
12656 we have to build them in the literal pool so that
12657 their results are calculated correctly after relaxation.
12658 The relaxation only handles expressions that
12659 boil down to SYMBOL + OFFSET. */
12660
12661static bfd_boolean
7fa3d080 12662tinsn_has_complex_operands (const TInsn *insn)
e0001a05
NC
12663{
12664 int i;
12665 int n = insn->ntok;
9c2799c2 12666 gas_assert (insn->insn_type == ITYPE_INSN);
e0001a05
NC
12667 for (i = 0; i < n; ++i)
12668 {
12669 switch (insn->tok[i].X_op)
12670 {
12671 case O_register:
12672 case O_constant:
12673 case O_symbol:
43cd72b9
BW
12674 case O_lo16:
12675 case O_hi16:
e0001a05
NC
12676 break;
12677 default:
12678 return TRUE;
12679 }
12680 }
12681 return FALSE;
12682}
12683
12684
b2d179be
BW
12685/* Encode a TInsn opcode and its constant operands into slotbuf.
12686 Return TRUE if there is a symbol in the immediate field. This
12687 function assumes that:
12688 1) The number of operands are correct.
12689 2) The insn_type is ITYPE_INSN.
12690 3) The opcode can be encoded in the specified format and slot.
12691 4) Operands are either O_constant or O_symbol, and all constants fit. */
43cd72b9
BW
12692
12693static bfd_boolean
7fa3d080
BW
12694tinsn_to_slotbuf (xtensa_format fmt,
12695 int slot,
12696 TInsn *tinsn,
12697 xtensa_insnbuf slotbuf)
43cd72b9
BW
12698{
12699 xtensa_isa isa = xtensa_default_isa;
12700 xtensa_opcode opcode = tinsn->opcode;
12701 bfd_boolean has_fixup = FALSE;
12702 int noperands = xtensa_opcode_num_operands (isa, opcode);
12703 int i;
12704
9c2799c2 12705 gas_assert (tinsn->insn_type == ITYPE_INSN);
43cd72b9
BW
12706 if (noperands != tinsn->ntok)
12707 as_fatal (_("operand number mismatch"));
12708
12709 if (xtensa_opcode_encode (isa, fmt, slot, slotbuf, opcode))
12710 {
12711 as_bad (_("cannot encode opcode \"%s\" in the given format \"%s\""),
12712 xtensa_opcode_name (isa, opcode), xtensa_format_name (isa, fmt));
12713 return FALSE;
12714 }
12715
12716 for (i = 0; i < noperands; i++)
12717 {
91d6fa6a 12718 expressionS *exp = &tinsn->tok[i];
d77b99c9
BW
12719 int rc;
12720 unsigned line;
3b4dbbbf 12721 const char *file_name;
43cd72b9
BW
12722 uint32 opnd_value;
12723
91d6fa6a 12724 switch (exp->X_op)
43cd72b9
BW
12725 {
12726 case O_register:
12727 if (xtensa_operand_is_visible (isa, opcode, i) == 0)
12728 break;
12729 /* The register number has already been checked in
12730 expression_maybe_register, so we don't need to check here. */
91d6fa6a 12731 opnd_value = exp->X_add_number;
43cd72b9
BW
12732 (void) xtensa_operand_encode (isa, opcode, i, &opnd_value);
12733 rc = xtensa_operand_set_field (isa, opcode, i, fmt, slot, slotbuf,
12734 opnd_value);
12735 if (rc != 0)
12736 as_warn (_("xtensa-isa failure: %s"), xtensa_isa_error_msg (isa));
12737 break;
12738
12739 case O_constant:
12740 if (xtensa_operand_is_visible (isa, opcode, i) == 0)
12741 break;
3b4dbbbf 12742 file_name = as_where (&line);
43cd72b9
BW
12743 /* It is a constant and we called this function
12744 then we have to try to fit it. */
12745 xtensa_insnbuf_set_operand (slotbuf, fmt, slot, opcode, i,
91d6fa6a 12746 exp->X_add_number, file_name, line);
e0001a05
NC
12747 break;
12748
e0001a05
NC
12749 default:
12750 has_fixup = TRUE;
12751 break;
12752 }
12753 }
43cd72b9 12754
e0001a05
NC
12755 return has_fixup;
12756}
12757
12758
b2d179be
BW
12759/* Encode a single TInsn into an insnbuf. If the opcode can only be encoded
12760 into a multi-slot instruction, fill the other slots with NOPs.
12761 Return TRUE if there is a symbol in the immediate field. See also the
12762 assumptions listed for tinsn_to_slotbuf. */
12763
12764static bfd_boolean
12765tinsn_to_insnbuf (TInsn *tinsn, xtensa_insnbuf insnbuf)
12766{
12767 static xtensa_insnbuf slotbuf = 0;
12768 static vliw_insn vinsn;
12769 xtensa_isa isa = xtensa_default_isa;
12770 bfd_boolean has_fixup = FALSE;
12771 int i;
12772
12773 if (!slotbuf)
12774 {
12775 slotbuf = xtensa_insnbuf_alloc (isa);
12776 xg_init_vinsn (&vinsn);
12777 }
12778
12779 xg_clear_vinsn (&vinsn);
12780
12781 bundle_tinsn (tinsn, &vinsn);
12782
12783 xtensa_format_encode (isa, vinsn.format, insnbuf);
12784
12785 for (i = 0; i < vinsn.num_slots; i++)
12786 {
12787 /* Only one slot may have a fix-up because the rest contains NOPs. */
12788 has_fixup |=
12789 tinsn_to_slotbuf (vinsn.format, i, &vinsn.slots[i], vinsn.slotbuf[i]);
12790 xtensa_format_set_slot (isa, vinsn.format, i, insnbuf, vinsn.slotbuf[i]);
12791 }
12792
12793 return has_fixup;
12794}
12795
12796
43cd72b9 12797/* Check the instruction arguments. Return TRUE on failure. */
e0001a05 12798
7fa3d080
BW
12799static bfd_boolean
12800tinsn_check_arguments (const TInsn *insn)
e0001a05
NC
12801{
12802 xtensa_isa isa = xtensa_default_isa;
12803 xtensa_opcode opcode = insn->opcode;
6dc6b655
BW
12804 xtensa_regfile t1_regfile, t2_regfile;
12805 int t1_reg, t2_reg;
12806 int t1_base_reg, t1_last_reg;
12807 int t2_base_reg, t2_last_reg;
12808 char t1_inout, t2_inout;
12809 int i, j;
e0001a05
NC
12810
12811 if (opcode == XTENSA_UNDEFINED)
12812 {
12813 as_bad (_("invalid opcode"));
12814 return TRUE;
12815 }
12816
43cd72b9 12817 if (xtensa_opcode_num_operands (isa, opcode) > insn->ntok)
e0001a05
NC
12818 {
12819 as_bad (_("too few operands"));
12820 return TRUE;
12821 }
12822
43cd72b9 12823 if (xtensa_opcode_num_operands (isa, opcode) < insn->ntok)
e0001a05
NC
12824 {
12825 as_bad (_("too many operands"));
12826 return TRUE;
12827 }
6dc6b655
BW
12828
12829 /* Check registers. */
12830 for (j = 0; j < insn->ntok; j++)
12831 {
12832 if (xtensa_operand_is_register (isa, insn->opcode, j) != 1)
12833 continue;
12834
12835 t2_regfile = xtensa_operand_regfile (isa, insn->opcode, j);
12836 t2_base_reg = insn->tok[j].X_add_number;
12837 t2_last_reg
12838 = t2_base_reg + xtensa_operand_num_regs (isa, insn->opcode, j);
12839
12840 for (i = 0; i < insn->ntok; i++)
12841 {
12842 if (i == j)
12843 continue;
12844
12845 if (xtensa_operand_is_register (isa, insn->opcode, i) != 1)
12846 continue;
12847
12848 t1_regfile = xtensa_operand_regfile (isa, insn->opcode, i);
12849
12850 if (t1_regfile != t2_regfile)
12851 continue;
12852
12853 t1_inout = xtensa_operand_inout (isa, insn->opcode, i);
12854 t2_inout = xtensa_operand_inout (isa, insn->opcode, j);
12855
12856 t1_base_reg = insn->tok[i].X_add_number;
12857 t1_last_reg = (t1_base_reg
12858 + xtensa_operand_num_regs (isa, insn->opcode, i));
12859
12860 for (t1_reg = t1_base_reg; t1_reg < t1_last_reg; t1_reg++)
12861 {
12862 for (t2_reg = t2_base_reg; t2_reg < t2_last_reg; t2_reg++)
12863 {
12864 if (t1_reg != t2_reg)
12865 continue;
12866
12867 if (t1_inout != 'i' && t2_inout != 'i')
12868 {
12869 as_bad (_("multiple writes to the same register"));
12870 return TRUE;
12871 }
12872 }
12873 }
12874 }
12875 }
e0001a05
NC
12876 return FALSE;
12877}
12878
12879
12880/* Load an instruction from its encoded form. */
12881
12882static void
7fa3d080 12883tinsn_from_chars (TInsn *tinsn, char *f, int slot)
e0001a05 12884{
43cd72b9 12885 vliw_insn vinsn;
e0001a05 12886
43cd72b9
BW
12887 xg_init_vinsn (&vinsn);
12888 vinsn_from_chars (&vinsn, f);
12889
12890 *tinsn = vinsn.slots[slot];
12891 xg_free_vinsn (&vinsn);
12892}
e0001a05 12893
43cd72b9
BW
12894
12895static void
7fa3d080
BW
12896tinsn_from_insnbuf (TInsn *tinsn,
12897 xtensa_insnbuf slotbuf,
12898 xtensa_format fmt,
12899 int slot)
43cd72b9
BW
12900{
12901 int i;
12902 xtensa_isa isa = xtensa_default_isa;
e0001a05
NC
12903
12904 /* Find the immed. */
43cd72b9
BW
12905 tinsn_init (tinsn);
12906 tinsn->insn_type = ITYPE_INSN;
12907 tinsn->is_specific_opcode = FALSE; /* must not be specific */
12908 tinsn->opcode = xtensa_opcode_decode (isa, fmt, slot, slotbuf);
12909 tinsn->ntok = xtensa_opcode_num_operands (isa, tinsn->opcode);
12910 for (i = 0; i < tinsn->ntok; i++)
e0001a05 12911 {
43cd72b9
BW
12912 set_expr_const (&tinsn->tok[i],
12913 xtensa_insnbuf_get_operand (slotbuf, fmt, slot,
12914 tinsn->opcode, i));
e0001a05
NC
12915 }
12916}
12917
12918
12919/* Read the value of the relaxable immed from the fr_symbol and fr_offset. */
12920
12921static void
7fa3d080 12922tinsn_immed_from_frag (TInsn *tinsn, fragS *fragP, int slot)
e0001a05 12923{
43cd72b9 12924 xtensa_opcode opcode = tinsn->opcode;
e0001a05
NC
12925 int opnum;
12926
43cd72b9 12927 if (fragP->tc_frag_data.slot_symbols[slot])
e0001a05
NC
12928 {
12929 opnum = get_relaxable_immed (opcode);
9c2799c2 12930 gas_assert (opnum >= 0);
e7da6241
BW
12931 set_expr_symbol_offset (&tinsn->tok[opnum],
12932 fragP->tc_frag_data.slot_symbols[slot],
12933 fragP->tc_frag_data.slot_offsets[slot]);
e0001a05 12934 }
19e8f41a 12935 tinsn->extra_arg = fragP->tc_frag_data.free_reg[slot];
e0001a05
NC
12936}
12937
12938
12939static int
7fa3d080 12940get_num_stack_text_bytes (IStack *istack)
e0001a05
NC
12941{
12942 int i;
12943 int text_bytes = 0;
12944
12945 for (i = 0; i < istack->ninsn; i++)
12946 {
43cd72b9
BW
12947 TInsn *tinsn = &istack->insn[i];
12948 if (tinsn->insn_type == ITYPE_INSN)
12949 text_bytes += xg_get_single_size (tinsn->opcode);
e0001a05
NC
12950 }
12951 return text_bytes;
12952}
12953
12954
12955static int
7fa3d080 12956get_num_stack_literal_bytes (IStack *istack)
e0001a05
NC
12957{
12958 int i;
12959 int lit_bytes = 0;
12960
12961 for (i = 0; i < istack->ninsn; i++)
12962 {
43cd72b9
BW
12963 TInsn *tinsn = &istack->insn[i];
12964 if (tinsn->insn_type == ITYPE_LITERAL && tinsn->ntok == 1)
e0001a05
NC
12965 lit_bytes += 4;
12966 }
12967 return lit_bytes;
12968}
12969
43cd72b9
BW
12970\f
12971/* vliw_insn functions. */
12972
7fa3d080
BW
12973static void
12974xg_init_vinsn (vliw_insn *v)
43cd72b9
BW
12975{
12976 int i;
12977 xtensa_isa isa = xtensa_default_isa;
12978
12979 xg_clear_vinsn (v);
12980
12981 v->insnbuf = xtensa_insnbuf_alloc (isa);
12982 if (v->insnbuf == NULL)
12983 as_fatal (_("out of memory"));
12984
62af60e2 12985 for (i = 0; i < config_max_slots; i++)
43cd72b9 12986 {
43cd72b9
BW
12987 v->slotbuf[i] = xtensa_insnbuf_alloc (isa);
12988 if (v->slotbuf[i] == NULL)
12989 as_fatal (_("out of memory"));
12990 }
12991}
12992
12993
7fa3d080
BW
12994static void
12995xg_clear_vinsn (vliw_insn *v)
43cd72b9
BW
12996{
12997 int i;
65738a7d 12998
3739860c 12999 memset (v, 0, offsetof (vliw_insn, slots)
62af60e2 13000 + sizeof(TInsn) * config_max_slots);
65738a7d 13001
43cd72b9
BW
13002 v->format = XTENSA_UNDEFINED;
13003 v->num_slots = 0;
13004 v->inside_bundle = FALSE;
13005
13006 if (xt_saved_debug_type != DEBUG_NONE)
13007 debug_type = xt_saved_debug_type;
13008
62af60e2 13009 for (i = 0; i < config_max_slots; i++)
65738a7d 13010 v->slots[i].opcode = XTENSA_UNDEFINED;
43cd72b9
BW
13011}
13012
13013
d8392fd9
SA
13014static void
13015xg_copy_vinsn (vliw_insn *dst, vliw_insn *src)
13016{
3739860c 13017 memcpy (dst, src,
d8392fd9
SA
13018 offsetof(vliw_insn, slots) + src->num_slots * sizeof(TInsn));
13019 dst->insnbuf = src->insnbuf;
13020 memcpy (dst->slotbuf, src->slotbuf, src->num_slots * sizeof(xtensa_insnbuf));
13021}
13022
13023
7fa3d080
BW
13024static bfd_boolean
13025vinsn_has_specific_opcodes (vliw_insn *v)
43cd72b9
BW
13026{
13027 int i;
c138bc38 13028
43cd72b9
BW
13029 for (i = 0; i < v->num_slots; i++)
13030 {
13031 if (v->slots[i].is_specific_opcode)
13032 return TRUE;
13033 }
13034 return FALSE;
13035}
13036
13037
7fa3d080
BW
13038static void
13039xg_free_vinsn (vliw_insn *v)
43cd72b9
BW
13040{
13041 int i;
13042 xtensa_insnbuf_free (xtensa_default_isa, v->insnbuf);
62af60e2 13043 for (i = 0; i < config_max_slots; i++)
43cd72b9
BW
13044 xtensa_insnbuf_free (xtensa_default_isa, v->slotbuf[i]);
13045}
13046
13047
e7da6241
BW
13048/* Encode a vliw_insn into an insnbuf. Return TRUE if there are any symbolic
13049 operands. See also the assumptions listed for tinsn_to_slotbuf. */
43cd72b9
BW
13050
13051static bfd_boolean
7fa3d080
BW
13052vinsn_to_insnbuf (vliw_insn *vinsn,
13053 char *frag_offset,
13054 fragS *fragP,
13055 bfd_boolean record_fixup)
43cd72b9
BW
13056{
13057 xtensa_isa isa = xtensa_default_isa;
13058 xtensa_format fmt = vinsn->format;
13059 xtensa_insnbuf insnbuf = vinsn->insnbuf;
13060 int slot;
13061 bfd_boolean has_fixup = FALSE;
13062
13063 xtensa_format_encode (isa, fmt, insnbuf);
13064
13065 for (slot = 0; slot < vinsn->num_slots; slot++)
13066 {
13067 TInsn *tinsn = &vinsn->slots[slot];
19e8f41a 13068 expressionS *extra_arg = &tinsn->extra_arg;
43cd72b9
BW
13069 bfd_boolean tinsn_has_fixup =
13070 tinsn_to_slotbuf (vinsn->format, slot, tinsn,
13071 vinsn->slotbuf[slot]);
13072
13073 xtensa_format_set_slot (isa, fmt, slot,
13074 insnbuf, vinsn->slotbuf[slot]);
19e8f41a 13075 if (extra_arg->X_op != O_illegal && extra_arg->X_op != O_register)
28dbbc02
BW
13076 {
13077 if (vinsn->num_slots != 1)
13078 as_bad (_("TLS relocation not allowed in FLIX bundle"));
13079 else if (record_fixup)
13080 /* Instructions that generate TLS relocations should always be
13081 relaxed in the front-end. If "record_fixup" is set, then this
13082 function is being called during back-end relaxation, so flag
13083 the unexpected behavior as an error. */
13084 as_bad (_("unexpected TLS relocation"));
13085 else
13086 fix_new (fragP, frag_offset - fragP->fr_literal,
13087 xtensa_format_length (isa, fmt),
19e8f41a
BW
13088 extra_arg->X_add_symbol, extra_arg->X_add_number,
13089 FALSE, map_operator_to_reloc (extra_arg->X_op, FALSE));
28dbbc02 13090 }
e7da6241 13091 if (tinsn_has_fixup)
43cd72b9
BW
13092 {
13093 int i;
13094 xtensa_opcode opcode = tinsn->opcode;
13095 int noperands = xtensa_opcode_num_operands (isa, opcode);
13096 has_fixup = TRUE;
13097
13098 for (i = 0; i < noperands; i++)
13099 {
91d6fa6a
NC
13100 expressionS* exp = &tinsn->tok[i];
13101 switch (exp->X_op)
43cd72b9
BW
13102 {
13103 case O_symbol:
13104 case O_lo16:
13105 case O_hi16:
13106 if (get_relaxable_immed (opcode) == i)
13107 {
e7da6241
BW
13108 /* Add a fix record for the instruction, except if this
13109 function is being called prior to relaxation, i.e.,
13110 if record_fixup is false, and the instruction might
13111 be relaxed later. */
13112 if (record_fixup
13113 || tinsn->is_specific_opcode
13114 || !xg_is_relaxable_insn (tinsn, 0))
43cd72b9 13115 {
91d6fa6a 13116 xg_add_opcode_fix (tinsn, i, fmt, slot, exp, fragP,
e7da6241 13117 frag_offset - fragP->fr_literal);
43cd72b9
BW
13118 }
13119 else
13120 {
91d6fa6a 13121 if (exp->X_op != O_symbol)
e7da6241 13122 as_bad (_("invalid operand"));
91d6fa6a
NC
13123 tinsn->symbol = exp->X_add_symbol;
13124 tinsn->offset = exp->X_add_number;
43cd72b9
BW
13125 }
13126 }
13127 else
e7da6241 13128 as_bad (_("symbolic operand not allowed"));
43cd72b9
BW
13129 break;
13130
13131 case O_constant:
13132 case O_register:
13133 break;
13134
43cd72b9 13135 default:
e7da6241 13136 as_bad (_("expression too complex"));
43cd72b9
BW
13137 break;
13138 }
13139 }
13140 }
13141 }
13142
13143 return has_fixup;
13144}
13145
13146
13147static void
7fa3d080 13148vinsn_from_chars (vliw_insn *vinsn, char *f)
43cd72b9
BW
13149{
13150 static xtensa_insnbuf insnbuf = NULL;
13151 static xtensa_insnbuf slotbuf = NULL;
13152 int i;
13153 xtensa_format fmt;
13154 xtensa_isa isa = xtensa_default_isa;
13155
13156 if (!insnbuf)
13157 {
13158 insnbuf = xtensa_insnbuf_alloc (isa);
13159 slotbuf = xtensa_insnbuf_alloc (isa);
13160 }
13161
d77b99c9 13162 xtensa_insnbuf_from_chars (isa, insnbuf, (unsigned char *) f, 0);
43cd72b9
BW
13163 fmt = xtensa_format_decode (isa, insnbuf);
13164 if (fmt == XTENSA_UNDEFINED)
13165 as_fatal (_("cannot decode instruction format"));
13166 vinsn->format = fmt;
13167 vinsn->num_slots = xtensa_format_num_slots (isa, fmt);
13168
13169 for (i = 0; i < vinsn->num_slots; i++)
13170 {
13171 TInsn *tinsn = &vinsn->slots[i];
13172 xtensa_format_get_slot (isa, fmt, i, insnbuf, slotbuf);
13173 tinsn_from_insnbuf (tinsn, slotbuf, fmt, i);
13174 }
13175}
13176
e0001a05
NC
13177\f
13178/* Expression utilities. */
13179
43cd72b9 13180/* Return TRUE if the expression is an integer constant. */
e0001a05
NC
13181
13182bfd_boolean
7fa3d080 13183expr_is_const (const expressionS *s)
e0001a05
NC
13184{
13185 return (s->X_op == O_constant);
13186}
13187
13188
13189/* Get the expression constant.
43cd72b9 13190 Calling this is illegal if expr_is_const () returns TRUE. */
e0001a05
NC
13191
13192offsetT
7fa3d080 13193get_expr_const (const expressionS *s)
e0001a05 13194{
9c2799c2 13195 gas_assert (expr_is_const (s));
e0001a05
NC
13196 return s->X_add_number;
13197}
13198
13199
13200/* Set the expression to a constant value. */
13201
13202void
7fa3d080 13203set_expr_const (expressionS *s, offsetT val)
e0001a05
NC
13204{
13205 s->X_op = O_constant;
13206 s->X_add_number = val;
13207 s->X_add_symbol = NULL;
13208 s->X_op_symbol = NULL;
13209}
13210
13211
43cd72b9 13212bfd_boolean
7fa3d080 13213expr_is_register (const expressionS *s)
43cd72b9
BW
13214{
13215 return (s->X_op == O_register);
13216}
13217
13218
13219/* Get the expression constant.
13220 Calling this is illegal if expr_is_const () returns TRUE. */
13221
13222offsetT
7fa3d080 13223get_expr_register (const expressionS *s)
43cd72b9 13224{
9c2799c2 13225 gas_assert (expr_is_register (s));
43cd72b9
BW
13226 return s->X_add_number;
13227}
13228
13229
e0001a05
NC
13230/* Set the expression to a symbol + constant offset. */
13231
13232void
7fa3d080 13233set_expr_symbol_offset (expressionS *s, symbolS *sym, offsetT offset)
e0001a05
NC
13234{
13235 s->X_op = O_symbol;
13236 s->X_add_symbol = sym;
13237 s->X_op_symbol = NULL; /* unused */
13238 s->X_add_number = offset;
13239}
13240
13241
43cd72b9
BW
13242/* Return TRUE if the two expressions are equal. */
13243
e0001a05 13244bfd_boolean
7fa3d080 13245expr_is_equal (expressionS *s1, expressionS *s2)
e0001a05
NC
13246{
13247 if (s1->X_op != s2->X_op)
13248 return FALSE;
13249 if (s1->X_add_symbol != s2->X_add_symbol)
13250 return FALSE;
13251 if (s1->X_op_symbol != s2->X_op_symbol)
13252 return FALSE;
13253 if (s1->X_add_number != s2->X_add_number)
13254 return FALSE;
13255 return TRUE;
13256}
13257
13258
13259static void
7fa3d080 13260copy_expr (expressionS *dst, const expressionS *src)
e0001a05
NC
13261{
13262 memcpy (dst, src, sizeof (expressionS));
13263}
13264
13265\f
9456465c 13266/* Support for the "--rename-section" option. */
e0001a05
NC
13267
13268struct rename_section_struct
13269{
e4a0c708 13270 const char *old_name;
e0001a05
NC
13271 char *new_name;
13272 struct rename_section_struct *next;
13273};
13274
13275static struct rename_section_struct *section_rename;
13276
13277
9456465c
BW
13278/* Parse the string "oldname=new_name(:oldname2=new_name2)*" and add
13279 entries to the section_rename list. Note: Specifying multiple
13280 renamings separated by colons is not documented and is retained only
13281 for backward compatibility. */
e0001a05 13282
7fa3d080
BW
13283static void
13284build_section_rename (const char *arg)
e0001a05 13285{
9456465c 13286 struct rename_section_struct *r;
e0001a05
NC
13287 char *this_arg = NULL;
13288 char *next_arg = NULL;
13289
9456465c 13290 for (this_arg = xstrdup (arg); this_arg != NULL; this_arg = next_arg)
e0001a05 13291 {
9456465c
BW
13292 char *old_name, *new_name;
13293
e0001a05
NC
13294 if (this_arg)
13295 {
13296 next_arg = strchr (this_arg, ':');
13297 if (next_arg)
13298 {
13299 *next_arg = '\0';
13300 next_arg++;
13301 }
13302 }
e0001a05 13303
9456465c
BW
13304 old_name = this_arg;
13305 new_name = strchr (this_arg, '=');
e0001a05 13306
9456465c
BW
13307 if (*old_name == '\0')
13308 {
13309 as_warn (_("ignoring extra '-rename-section' delimiter ':'"));
13310 continue;
13311 }
13312 if (!new_name || new_name[1] == '\0')
13313 {
13314 as_warn (_("ignoring invalid '-rename-section' specification: '%s'"),
13315 old_name);
13316 continue;
13317 }
13318 *new_name = '\0';
13319 new_name++;
e0001a05 13320
9456465c
BW
13321 /* Check for invalid section renaming. */
13322 for (r = section_rename; r != NULL; r = r->next)
13323 {
13324 if (strcmp (r->old_name, old_name) == 0)
13325 as_bad (_("section %s renamed multiple times"), old_name);
13326 if (strcmp (r->new_name, new_name) == 0)
13327 as_bad (_("multiple sections remapped to output section %s"),
13328 new_name);
13329 }
e0001a05 13330
9456465c 13331 /* Now add it. */
325801bd 13332 r = XNEW (struct rename_section_struct);
9456465c
BW
13333 r->old_name = xstrdup (old_name);
13334 r->new_name = xstrdup (new_name);
13335 r->next = section_rename;
13336 section_rename = r;
e0001a05 13337 }
e0001a05
NC
13338}
13339
13340
9456465c 13341char *
e4a0c708 13342xtensa_section_rename (const char *name)
e0001a05
NC
13343{
13344 struct rename_section_struct *r = section_rename;
13345
13346 for (r = section_rename; r != NULL; r = r->next)
43cd72b9
BW
13347 {
13348 if (strcmp (r->old_name, name) == 0)
13349 return r->new_name;
13350 }
e0001a05 13351
e4a0c708 13352 return (char *) name;
e0001a05 13353}
This page took 1.588772 seconds and 4 git commands to generate.