* config/tc-mips.h (TC_ADDRESS_BYTES): New macro.
[deliverable/binutils-gdb.git] / gas / write.c
CommitLineData
252b5132 1/* write.c - emit .o file
f7e42eb4 2 Copyright 1986, 1987, 1990, 1991, 1992, 1993, 1994, 1995, 1996, 1997,
e35a414d
AM
3 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009,
4 2010 Free Software Foundation, Inc.
252b5132
RH
5
6 This file is part of GAS, the GNU Assembler.
7
8 GAS is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
ec2655a6 10 the Free Software Foundation; either version 3, or (at your option)
252b5132
RH
11 any later version.
12
13 GAS is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
17
18 You should have received a copy of the GNU General Public License
19 along with GAS; see the file COPYING. If not, write to the Free
4b4da160
NC
20 Software Foundation, 51 Franklin Street - Fifth Floor, Boston, MA
21 02110-1301, USA. */
252b5132 22
efaf0ba4 23/* This thing should be set up to do byteordering correctly. But... */
252b5132
RH
24
25#include "as.h"
26#include "subsegs.h"
27#include "obstack.h"
28#include "output-file.h"
220e750f 29#include "dwarf2dbg.h"
e7ff5c73 30#include "libbfd.h"
0acf065b 31#include "compress-debug.h"
252b5132 32
252b5132 33#ifndef TC_ADJUST_RELOC_COUNT
df44284e 34#define TC_ADJUST_RELOC_COUNT(FIX, COUNT)
252b5132
RH
35#endif
36
37#ifndef TC_FORCE_RELOCATION
a161fe53 38#define TC_FORCE_RELOCATION(FIX) \
ae6063d4 39 (generic_force_reloc (FIX))
252b5132
RH
40#endif
41
a161fe53
AM
42#ifndef TC_FORCE_RELOCATION_ABS
43#define TC_FORCE_RELOCATION_ABS(FIX) \
44 (TC_FORCE_RELOCATION (FIX))
45#endif
46
47#ifndef TC_FORCE_RELOCATION_LOCAL
48#define TC_FORCE_RELOCATION_LOCAL(FIX) \
49 (!(FIX)->fx_pcrel \
a161fe53
AM
50 || TC_FORCE_RELOCATION (FIX))
51#endif
52
53#ifndef TC_FORCE_RELOCATION_SUB_SAME
54#define TC_FORCE_RELOCATION_SUB_SAME(FIX, SEG) \
426318c5 55 (! SEG_NORMAL (SEG))
a161fe53
AM
56#endif
57
9a97a5d7
AM
58#ifndef md_register_arithmetic
59# define md_register_arithmetic 1
60#endif
61
a161fe53 62#ifndef TC_FORCE_RELOCATION_SUB_ABS
9a97a5d7
AM
63#define TC_FORCE_RELOCATION_SUB_ABS(FIX, SEG) \
64 (!md_register_arithmetic && (SEG) == reg_section)
a161fe53
AM
65#endif
66
67#ifndef TC_FORCE_RELOCATION_SUB_LOCAL
68#ifdef DIFF_EXPR_OK
5db484ff
AM
69#define TC_FORCE_RELOCATION_SUB_LOCAL(FIX, SEG) \
70 (!md_register_arithmetic && (SEG) == reg_section)
a161fe53 71#else
5db484ff 72#define TC_FORCE_RELOCATION_SUB_LOCAL(FIX, SEG) 1
a161fe53
AM
73#endif
74#endif
75
76#ifndef TC_VALIDATE_FIX_SUB
77#ifdef UNDEFINED_DIFFERENCE_OK
78/* The PA needs this for PIC code generation. */
5db484ff
AM
79#define TC_VALIDATE_FIX_SUB(FIX, SEG) \
80 (md_register_arithmetic || (SEG) != reg_section)
a161fe53 81#else
5db484ff
AM
82#define TC_VALIDATE_FIX_SUB(FIX, SEG) \
83 ((md_register_arithmetic || (SEG) != reg_section) \
84 && ((FIX)->fx_r_type == BFD_RELOC_GPREL32 \
85 || (FIX)->fx_r_type == BFD_RELOC_GPREL16))
a161fe53 86#endif
252b5132
RH
87#endif
88
58a77e41
EC
89#ifndef TC_LINKRELAX_FIXUP
90#define TC_LINKRELAX_FIXUP(SEG) 1
91#endif
92
a161fe53
AM
93#ifndef MD_APPLY_SYM_VALUE
94#define MD_APPLY_SYM_VALUE(FIX) 1
8f36cd18 95#endif
ef99799a 96
87548816
NC
97#ifndef TC_FINALIZE_SYMS_BEFORE_SIZE_SEG
98#define TC_FINALIZE_SYMS_BEFORE_SIZE_SEG 1
99#endif
100
252b5132 101#ifndef MD_PCREL_FROM_SECTION
df44284e 102#define MD_PCREL_FROM_SECTION(FIX, SEC) md_pcrel_from (FIX)
252b5132
RH
103#endif
104
c9cd7160
L
105#ifndef TC_FAKE_LABEL
106#define TC_FAKE_LABEL(NAME) (strcmp ((NAME), FAKE_LABEL_NAME) == 0)
107#endif
108
d31f0f6d
AM
109/* Positive values of TC_FX_SIZE_SLACK allow a target to define
110 fixups that far past the end of a frag. Having such fixups
111 is of course most most likely a bug in setting fx_size correctly.
112 A negative value disables the fixup check entirely, which is
113 appropriate for something like the Renesas / SuperH SH_COUNT
114 reloc. */
115#ifndef TC_FX_SIZE_SLACK
116#define TC_FX_SIZE_SLACK(FIX) 0
117#endif
118
6386f3a7
AM
119/* Used to control final evaluation of expressions. */
120int finalize_syms = 0;
e46d99eb 121
252b5132 122int symbol_table_frozen;
a161fe53
AM
123
124symbolS *abs_section_sym;
125
26346241
AM
126/* Remember the value of dot when parsing expressions. */
127addressT dot_value;
128
05e9452c
AM
129/* Relocs generated by ".reloc" pseudo. */
130struct reloc_list* reloc_list;
131
d7342424 132void print_fixup (fixS *);
252b5132 133
252b5132
RH
134/* We generally attach relocs to frag chains. However, after we have
135 chained these all together into a segment, any relocs we add after
136 that must be attached to a segment. This will include relocs added
137 in md_estimate_size_for_relax, for example. */
138static int frags_chained = 0;
252b5132
RH
139
140static int n_fixups;
141
df44284e 142#define RELOC_ENUM enum bfd_reloc_code_real
df44284e 143
efaf0ba4
NC
144/* Create a fixS in obstack 'notes'. */
145
252b5132 146static fixS *
d7342424
KH
147fix_new_internal (fragS *frag, /* Which frag? */
148 int where, /* Where in that frag? */
149 int size, /* 1, 2, or 4 usually. */
150 symbolS *add_symbol, /* X_add_symbol. */
151 symbolS *sub_symbol, /* X_op_symbol. */
152 offsetT offset, /* X_add_number. */
153 int pcrel, /* TRUE if PC-relative relocation. */
c865e45b
RS
154 RELOC_ENUM r_type ATTRIBUTE_UNUSED /* Relocation type. */,
155 int at_beginning) /* Add to the start of the list? */
252b5132
RH
156{
157 fixS *fixP;
158
159 n_fixups++;
160
1e9cc1c2 161 fixP = (fixS *) obstack_alloc (&notes, sizeof (fixS));
252b5132
RH
162
163 fixP->fx_frag = frag;
164 fixP->fx_where = where;
165 fixP->fx_size = size;
166 /* We've made fx_size a narrow field; check that it's wide enough. */
167 if (fixP->fx_size != size)
168 {
169 as_bad (_("field fx_size too small to hold %d"), size);
170 abort ();
171 }
172 fixP->fx_addsy = add_symbol;
173 fixP->fx_subsy = sub_symbol;
174 fixP->fx_offset = offset;
26346241 175 fixP->fx_dot_value = dot_value;
252b5132 176 fixP->fx_pcrel = pcrel;
252b5132 177 fixP->fx_r_type = r_type;
252b5132
RH
178 fixP->fx_im_disp = 0;
179 fixP->fx_pcrel_adjust = 0;
180 fixP->fx_bit_fixP = 0;
181 fixP->fx_addnumber = 0;
182 fixP->fx_tcbit = 0;
20ee54e8 183 fixP->fx_tcbit2 = 0;
252b5132
RH
184 fixP->fx_done = 0;
185 fixP->fx_no_overflow = 0;
186 fixP->fx_signed = 0;
187
188#ifdef USING_CGEN
189 fixP->fx_cgen.insn = NULL;
190 fixP->fx_cgen.opinfo = 0;
191#endif
192
193#ifdef TC_FIX_TYPE
efaf0ba4 194 TC_INIT_FIX_DATA (fixP);
252b5132
RH
195#endif
196
197 as_where (&fixP->fx_file, &fixP->fx_line);
198
252b5132
RH
199 {
200
252b5132
RH
201 fixS **seg_fix_rootP = (frags_chained
202 ? &seg_info (now_seg)->fix_root
203 : &frchain_now->fix_root);
204 fixS **seg_fix_tailP = (frags_chained
205 ? &seg_info (now_seg)->fix_tail
206 : &frchain_now->fix_tail);
252b5132 207
c865e45b
RS
208 if (at_beginning)
209 {
210 fixP->fx_next = *seg_fix_rootP;
211 *seg_fix_rootP = fixP;
212 if (fixP->fx_next == NULL)
213 *seg_fix_tailP = fixP;
214 }
252b5132 215 else
c865e45b
RS
216 {
217 fixP->fx_next = NULL;
218 if (*seg_fix_tailP)
219 (*seg_fix_tailP)->fx_next = fixP;
220 else
221 *seg_fix_rootP = fixP;
222 *seg_fix_tailP = fixP;
223 }
252b5132
RH
224 }
225
226 return fixP;
227}
228
229/* Create a fixup relative to a symbol (plus a constant). */
230
231fixS *
d7342424
KH
232fix_new (fragS *frag, /* Which frag? */
233 int where, /* Where in that frag? */
234 int size, /* 1, 2, or 4 usually. */
235 symbolS *add_symbol, /* X_add_symbol. */
236 offsetT offset, /* X_add_number. */
237 int pcrel, /* TRUE if PC-relative relocation. */
238 RELOC_ENUM r_type /* Relocation type. */)
252b5132
RH
239{
240 return fix_new_internal (frag, where, size, add_symbol,
c865e45b 241 (symbolS *) NULL, offset, pcrel, r_type, FALSE);
252b5132
RH
242}
243
244/* Create a fixup for an expression. Currently we only support fixups
245 for difference expressions. That is itself more than most object
246 file formats support anyhow. */
247
248fixS *
d7342424
KH
249fix_new_exp (fragS *frag, /* Which frag? */
250 int where, /* Where in that frag? */
251 int size, /* 1, 2, or 4 usually. */
252 expressionS *exp, /* Expression. */
253 int pcrel, /* TRUE if PC-relative relocation. */
254 RELOC_ENUM r_type /* Relocation type. */)
252b5132
RH
255{
256 symbolS *add = NULL;
257 symbolS *sub = NULL;
258 offsetT off = 0;
259
260 switch (exp->X_op)
261 {
262 case O_absent:
263 break;
264
37006e43
NC
265 case O_register:
266 as_bad (_("register value used as expression"));
267 break;
268
252b5132
RH
269 case O_add:
270 /* This comes up when _GLOBAL_OFFSET_TABLE_+(.-L0) is read, if
271 the difference expression cannot immediately be reduced. */
272 {
273 symbolS *stmp = make_expr_symbol (exp);
58a77e41 274
252b5132
RH
275 exp->X_op = O_symbol;
276 exp->X_op_symbol = 0;
277 exp->X_add_symbol = stmp;
278 exp->X_add_number = 0;
58a77e41 279
252b5132
RH
280 return fix_new_exp (frag, where, size, exp, pcrel, r_type);
281 }
282
283 case O_symbol_rva:
284 add = exp->X_add_symbol;
285 off = exp->X_add_number;
252b5132 286 r_type = BFD_RELOC_RVA;
252b5132
RH
287 break;
288
289 case O_uminus:
290 sub = exp->X_add_symbol;
291 off = exp->X_add_number;
292 break;
293
294 case O_subtract:
295 sub = exp->X_op_symbol;
296 /* Fall through. */
297 case O_symbol:
298 add = exp->X_add_symbol;
efaf0ba4 299 /* Fall through. */
252b5132
RH
300 case O_constant:
301 off = exp->X_add_number;
302 break;
303
304 default:
305 add = make_expr_symbol (exp);
306 break;
307 }
308
c865e45b
RS
309 return fix_new_internal (frag, where, size, add, sub, off, pcrel,
310 r_type, FALSE);
311}
312
313/* Create a fixup at the beginning of FRAG. The arguments are the same
314 as for fix_new, except that WHERE is implicitly 0. */
315
316fixS *
317fix_at_start (fragS *frag, int size, symbolS *add_symbol,
318 offsetT offset, int pcrel, RELOC_ENUM r_type)
319{
320 return fix_new_internal (frag, 0, size, add_symbol,
321 (symbolS *) NULL, offset, pcrel, r_type, TRUE);
252b5132
RH
322}
323
ae6063d4
AM
324/* Generic function to determine whether a fixup requires a relocation. */
325int
d7342424 326generic_force_reloc (fixS *fix)
ae6063d4 327{
ae6063d4
AM
328 if (fix->fx_r_type == BFD_RELOC_VTABLE_INHERIT
329 || fix->fx_r_type == BFD_RELOC_VTABLE_ENTRY)
330 return 1;
7be1c489 331
61e192bf
NC
332 if (fix->fx_addsy == NULL)
333 return 0;
334
ae6063d4
AM
335 return S_FORCE_RELOC (fix->fx_addsy, fix->fx_subsy == NULL);
336}
337
252b5132
RH
338/* Append a string onto another string, bumping the pointer along. */
339void
d7342424 340append (char **charPP, char *fromP, unsigned long length)
252b5132 341{
efaf0ba4 342 /* Don't trust memcpy() of 0 chars. */
252b5132
RH
343 if (length == 0)
344 return;
345
346 memcpy (*charPP, fromP, length);
347 *charPP += length;
348}
349
efaf0ba4
NC
350/* This routine records the largest alignment seen for each segment.
351 If the beginning of the segment is aligned on the worst-case
352 boundary, all of the other alignments within it will work. At
353 least one object format really uses this info. */
354
252b5132 355void
d7342424
KH
356record_alignment (/* Segment to which alignment pertains. */
357 segT seg,
358 /* Alignment, as a power of 2 (e.g., 1 => 2-byte
359 boundary, 2 => 4-byte boundary, etc.) */
360 int align)
252b5132
RH
361{
362 if (seg == absolute_section)
363 return;
7be1c489 364
252b5132
RH
365 if ((unsigned int) align > bfd_get_section_alignment (stdoutput, seg))
366 bfd_set_section_alignment (stdoutput, seg, align);
252b5132
RH
367}
368
0a9ef439 369int
d7342424 370get_recorded_alignment (segT seg)
0a9ef439
RH
371{
372 if (seg == absolute_section)
373 return 0;
7be1c489 374
0a9ef439 375 return bfd_get_section_alignment (stdoutput, seg);
0a9ef439
RH
376}
377
252b5132
RH
378/* Reset the section indices after removing the gas created sections. */
379
380static void
e7ff5c73 381renumber_sections (bfd *abfd ATTRIBUTE_UNUSED, asection *sec, void *countparg)
252b5132
RH
382{
383 int *countp = (int *) countparg;
384
385 sec->index = *countp;
386 ++*countp;
387}
388
252b5132 389static fragS *
d7342424 390chain_frchains_together_1 (segT section, struct frchain *frchp)
252b5132
RH
391{
392 fragS dummy, *prev_frag = &dummy;
252b5132 393 fixS fix_dummy, *prev_fix = &fix_dummy;
252b5132 394
c9049d30 395 for (; frchp; frchp = frchp->frch_next)
252b5132
RH
396 {
397 prev_frag->fr_next = frchp->frch_root;
398 prev_frag = frchp->frch_last;
9c2799c2 399 gas_assert (prev_frag->fr_type != 0);
252b5132
RH
400 if (frchp->fix_root != (fixS *) NULL)
401 {
402 if (seg_info (section)->fix_root == (fixS *) NULL)
403 seg_info (section)->fix_root = frchp->fix_root;
404 prev_fix->fx_next = frchp->fix_root;
405 seg_info (section)->fix_tail = frchp->fix_tail;
406 prev_fix = frchp->fix_tail;
407 }
252b5132 408 }
9c2799c2
NC
409 gas_assert (prev_frag->fr_type != 0);
410 gas_assert (prev_frag != &dummy);
252b5132
RH
411 prev_frag->fr_next = 0;
412 return prev_frag;
413}
414
252b5132 415static void
d7342424
KH
416chain_frchains_together (bfd *abfd ATTRIBUTE_UNUSED,
417 segT section,
e7ff5c73 418 void *xxx ATTRIBUTE_UNUSED)
252b5132
RH
419{
420 segment_info_type *info;
421
422 /* BFD may have introduced its own sections without using
423 subseg_new, so it is possible that seg_info is NULL. */
424 info = seg_info (section);
425 if (info != (segment_info_type *) NULL)
efaf0ba4
NC
426 info->frchainP->frch_last
427 = chain_frchains_together_1 (section, info->frchainP);
252b5132
RH
428
429 /* Now that we've chained the frags together, we must add new fixups
430 to the segment, not to the frag chain. */
431 frags_chained = 1;
432}
433
252b5132 434static void
d7342424 435cvt_frag_to_fill (segT sec ATTRIBUTE_UNUSED, fragS *fragP)
252b5132
RH
436{
437 switch (fragP->fr_type)
438 {
439 case rs_align:
440 case rs_align_code:
0a9ef439 441 case rs_align_test:
252b5132
RH
442 case rs_org:
443 case rs_space:
444#ifdef HANDLE_ALIGN
445 HANDLE_ALIGN (fragP);
446#endif
447 know (fragP->fr_next != NULL);
448 fragP->fr_offset = (fragP->fr_next->fr_address
449 - fragP->fr_address
450 - fragP->fr_fix) / fragP->fr_var;
451 if (fragP->fr_offset < 0)
452 {
14ad458a
ILT
453 as_bad_where (fragP->fr_file, fragP->fr_line,
454 _("attempt to .org/.space backwards? (%ld)"),
455 (long) fragP->fr_offset);
3f3cdb03 456 fragP->fr_offset = 0;
252b5132
RH
457 }
458 fragP->fr_type = rs_fill;
459 break;
460
461 case rs_fill:
462 break;
463
464 case rs_leb128:
465 {
466 valueT value = S_GET_VALUE (fragP->fr_symbol);
467 int size;
468
469 size = output_leb128 (fragP->fr_literal + fragP->fr_fix, value,
470 fragP->fr_subtype);
471
472 fragP->fr_fix += size;
473 fragP->fr_type = rs_fill;
474 fragP->fr_var = 0;
475 fragP->fr_offset = 0;
476 fragP->fr_symbol = NULL;
477 }
478 break;
479
480 case rs_cfa:
481 eh_frame_convert_frag (fragP);
482 break;
483
220e750f
RH
484 case rs_dwarf2dbg:
485 dwarf2dbg_convert_frag (fragP);
486 break;
487
252b5132 488 case rs_machine_dependent:
252b5132 489 md_convert_frag (stdoutput, sec, fragP);
252b5132 490
9c2799c2 491 gas_assert (fragP->fr_next == NULL
252b5132
RH
492 || ((offsetT) (fragP->fr_next->fr_address - fragP->fr_address)
493 == fragP->fr_fix));
494
efaf0ba4
NC
495 /* After md_convert_frag, we make the frag into a ".space 0".
496 md_convert_frag() should set up any fixSs and constants
497 required. */
252b5132
RH
498 frag_wane (fragP);
499 break;
500
501#ifndef WORKING_DOT_WORD
502 case rs_broken_word:
503 {
504 struct broken_word *lie;
505
506 if (fragP->fr_subtype)
507 {
508 fragP->fr_fix += md_short_jump_size;
509 for (lie = (struct broken_word *) (fragP->fr_symbol);
510 lie && lie->dispfrag == fragP;
511 lie = lie->next_broken_word)
512 if (lie->added == 1)
513 fragP->fr_fix += md_long_jump_size;
514 }
515 frag_wane (fragP);
516 }
517 break;
518#endif
519
520 default:
521 BAD_CASE (fragP->fr_type);
522 break;
523 }
09b935ac
AM
524#ifdef md_frag_check
525 md_frag_check (fragP);
526#endif
252b5132
RH
527}
528
32638454
AM
529struct relax_seg_info
530{
531 int pass;
532 int changed;
533};
d7342424 534
252b5132 535static void
32638454 536relax_seg (bfd *abfd ATTRIBUTE_UNUSED, asection *sec, void *xxx)
e46d99eb
AM
537{
538 segment_info_type *seginfo = seg_info (sec);
32638454 539 struct relax_seg_info *info = (struct relax_seg_info *) xxx;
e46d99eb
AM
540
541 if (seginfo && seginfo->frchainP
32638454
AM
542 && relax_segment (seginfo->frchainP->frch_root, sec, info->pass))
543 info->changed = 1;
e46d99eb
AM
544}
545
e46d99eb 546static void
e7ff5c73 547size_seg (bfd *abfd, asection *sec, void *xxx ATTRIBUTE_UNUSED)
252b5132
RH
548{
549 flagword flags;
550 fragS *fragp;
551 segment_info_type *seginfo;
552 int x;
553 valueT size, newsize;
554
555 subseg_change (sec, 0);
556
252b5132
RH
557 seginfo = seg_info (sec);
558 if (seginfo && seginfo->frchainP)
559 {
252b5132
RH
560 for (fragp = seginfo->frchainP->frch_root; fragp; fragp = fragp->fr_next)
561 cvt_frag_to_fill (sec, fragp);
562 for (fragp = seginfo->frchainP->frch_root;
563 fragp->fr_next;
564 fragp = fragp->fr_next)
efaf0ba4
NC
565 /* Walk to last elt. */
566 ;
252b5132
RH
567 size = fragp->fr_address + fragp->fr_fix;
568 }
569 else
570 size = 0;
571
e46d99eb 572 flags = bfd_get_section_flags (abfd, sec);
f3d2b04b
KT
573 if (size == 0 && bfd_get_section_size (sec) != 0 &&
574 (flags & SEC_HAS_CONTENTS) != 0)
575 return;
e46d99eb 576
252b5132
RH
577 if (size > 0 && ! seginfo->bss)
578 flags |= SEC_HAS_CONTENTS;
579
e5435dec 580 flags &= ~SEC_RELOC;
252b5132 581 x = bfd_set_section_flags (abfd, sec, flags);
9c2799c2 582 gas_assert (x);
252b5132
RH
583
584 newsize = md_section_align (sec, size);
585 x = bfd_set_section_size (abfd, sec, newsize);
9c2799c2 586 gas_assert (x);
252b5132
RH
587
588 /* If the size had to be rounded up, add some padding in the last
589 non-empty frag. */
9c2799c2 590 gas_assert (newsize >= size);
252b5132
RH
591 if (size != newsize)
592 {
593 fragS *last = seginfo->frchainP->frch_last;
594 fragp = seginfo->frchainP->frch_root;
595 while (fragp->fr_next != last)
596 fragp = fragp->fr_next;
597 last->fr_address = size;
18e1d487
AM
598 if ((newsize - size) % fragp->fr_var == 0)
599 fragp->fr_offset += (newsize - size) / fragp->fr_var;
600 else
601 /* If we hit this abort, it's likely due to subsegs_finish not
602 providing sufficient alignment on the last frag, and the
603 machine dependent code using alignment frags with fr_var
604 greater than 1. */
605 abort ();
252b5132
RH
606 }
607
608#ifdef tc_frob_section
609 tc_frob_section (sec);
610#endif
611#ifdef obj_frob_section
612 obj_frob_section (sec);
613#endif
614}
615
616#ifdef DEBUG2
617static void
988392e2 618dump_section_relocs (bfd *abfd ATTRIBUTE_UNUSED, asection *sec, FILE *stream)
252b5132 619{
252b5132
RH
620 segment_info_type *seginfo = seg_info (sec);
621 fixS *fixp = seginfo->fix_root;
622
623 if (!fixp)
624 return;
625
626 fprintf (stream, "sec %s relocs:\n", sec->name);
627 while (fixp)
628 {
629 symbolS *s = fixp->fx_addsy;
e723ef7c
ILT
630
631 fprintf (stream, " %08lx: type %d ", (unsigned long) fixp,
632 (int) fixp->fx_r_type);
633 if (s == NULL)
634 fprintf (stream, "no sym\n");
635 else
252b5132 636 {
e723ef7c
ILT
637 print_symbol_value_1 (stream, s);
638 fprintf (stream, "\n");
252b5132 639 }
252b5132
RH
640 fixp = fixp->fx_next;
641 }
642}
643#else
644#define dump_section_relocs(ABFD,SEC,STREAM) ((void) 0)
645#endif
646
647#ifndef EMIT_SECTION_SYMBOLS
648#define EMIT_SECTION_SYMBOLS 1
649#endif
650
05e9452c
AM
651/* Resolve U.A.OFFSET_SYM and U.A.SYM fields of RELOC_LIST entries,
652 and check for validity. Convert RELOC_LIST from using U.A fields
653 to U.B fields. */
654static void
655resolve_reloc_expr_symbols (void)
656{
657 struct reloc_list *r;
658
659 for (r = reloc_list; r; r = r->next)
660 {
661 expressionS *symval;
662 symbolS *sym;
663 bfd_vma offset, addend;
664 asection *sec;
665 reloc_howto_type *howto;
666
667 resolve_symbol_value (r->u.a.offset_sym);
668 symval = symbol_get_value_expression (r->u.a.offset_sym);
669
670 offset = 0;
671 sym = NULL;
672 if (symval->X_op == O_constant)
673 sym = r->u.a.offset_sym;
674 else if (symval->X_op == O_symbol)
675 {
676 sym = symval->X_add_symbol;
677 offset = symval->X_add_number;
678 symval = symbol_get_value_expression (symval->X_add_symbol);
679 }
680 if (sym == NULL
681 || symval->X_op != O_constant
682 || (sec = S_GET_SEGMENT (sym)) == NULL
683 || !SEG_NORMAL (sec))
684 {
685 as_bad_where (r->file, r->line, _("invalid offset expression"));
686 sec = NULL;
687 }
688 else
689 offset += S_GET_VALUE (sym);
690
691 sym = NULL;
692 addend = r->u.a.addend;
693 if (r->u.a.sym != NULL)
694 {
695 resolve_symbol_value (r->u.a.sym);
696 symval = symbol_get_value_expression (r->u.a.sym);
697 if (symval->X_op == O_constant)
698 sym = r->u.a.sym;
699 else if (symval->X_op == O_symbol)
700 {
701 sym = symval->X_add_symbol;
702 addend += symval->X_add_number;
703 symval = symbol_get_value_expression (symval->X_add_symbol);
704 }
705 if (symval->X_op != O_constant)
706 {
707 as_bad_where (r->file, r->line, _("invalid reloc expression"));
708 sec = NULL;
709 }
710 else if (sym != NULL)
711 symbol_mark_used_in_reloc (sym);
712 }
713 if (sym == NULL)
714 {
715 if (abs_section_sym == NULL)
716 abs_section_sym = section_symbol (absolute_section);
717 sym = abs_section_sym;
718 }
719
720 howto = r->u.a.howto;
721
722 r->u.b.sec = sec;
723 r->u.b.s = symbol_get_bfdsym (sym);
724 r->u.b.r.sym_ptr_ptr = &r->u.b.s;
725 r->u.b.r.address = offset;
726 r->u.b.r.addend = addend;
727 r->u.b.r.howto = howto;
728 }
729}
730
df44284e
AM
731/* This pass over fixups decides whether symbols can be replaced with
732 section symbols. */
733
252b5132 734static void
d7342424
KH
735adjust_reloc_syms (bfd *abfd ATTRIBUTE_UNUSED,
736 asection *sec,
e7ff5c73 737 void *xxx ATTRIBUTE_UNUSED)
252b5132
RH
738{
739 segment_info_type *seginfo = seg_info (sec);
740 fixS *fixp;
741
742 if (seginfo == NULL)
743 return;
744
745 dump_section_relocs (abfd, sec, stderr);
746
747 for (fixp = seginfo->fix_root; fixp; fixp = fixp->fx_next)
748 if (fixp->fx_done)
efaf0ba4
NC
749 /* Ignore it. */
750 ;
252b5132
RH
751 else if (fixp->fx_addsy)
752 {
753 symbolS *sym;
754 asection *symsec;
755
756#ifdef DEBUG5
757 fprintf (stderr, "\n\nadjusting fixup:\n");
758 print_fixup (fixp);
759#endif
760
761 sym = fixp->fx_addsy;
762
763 /* All symbols should have already been resolved at this
764 point. It is possible to see unresolved expression
765 symbols, though, since they are not in the regular symbol
766 table. */
df44284e 767 resolve_symbol_value (sym);
efaf0ba4 768
49309057 769 if (fixp->fx_subsy != NULL)
6386f3a7 770 resolve_symbol_value (fixp->fx_subsy);
252b5132 771
60938e80
L
772 /* If this symbol is equated to an undefined or common symbol,
773 convert the fixup to being against that symbol. */
b4b24b79
AM
774 while (symbol_equated_reloc_p (sym)
775 || S_IS_WEAKREFR (sym))
252b5132 776 {
b4b24b79
AM
777 symbolS *newsym = symbol_get_value_expression (sym)->X_add_symbol;
778 if (sym == newsym)
779 break;
49309057 780 fixp->fx_offset += symbol_get_value_expression (sym)->X_add_number;
b4b24b79
AM
781 fixp->fx_addsy = newsym;
782 sym = newsym;
252b5132
RH
783 }
784
df44284e 785 if (symbol_mri_common_p (sym))
252b5132 786 {
b4b24b79
AM
787 fixp->fx_offset += S_GET_VALUE (sym);
788 fixp->fx_addsy = symbol_get_value_expression (sym)->X_add_symbol;
df44284e 789 continue;
252b5132
RH
790 }
791
a161fe53
AM
792 /* If the symbol is undefined, common, weak, or global (ELF
793 shared libs), we can't replace it with the section symbol. */
ae6063d4 794 if (S_FORCE_RELOC (fixp->fx_addsy, 1))
a161fe53
AM
795 continue;
796
797 /* Is there some other (target cpu dependent) reason we can't adjust
798 this one? (E.g. relocations involving function addresses on
799 the PA. */
800#ifdef tc_fix_adjustable
801 if (! tc_fix_adjustable (fixp))
802 continue;
803#endif
804
805 /* Since we're reducing to section symbols, don't attempt to reduce
806 anything that's already using one. */
807 if (symbol_section_p (sym))
808 continue;
809
252b5132 810 symsec = S_GET_SEGMENT (sym);
252b5132
RH
811 if (symsec == NULL)
812 abort ();
efaf0ba4 813
252b5132
RH
814 if (bfd_is_abs_section (symsec))
815 {
a161fe53 816 /* The fixup_segment routine normally will not use this
b4b24b79 817 symbol in a relocation. */
df44284e 818 continue;
252b5132
RH
819 }
820
7565ed77 821 /* Don't try to reduce relocs which refer to non-local symbols
b4b24b79
AM
822 in .linkonce sections. It can lead to confusion when a
823 debugging section refers to a .linkonce section. I hope
824 this will always be correct. */
7565ed77 825 if (symsec != sec && ! S_IS_LOCAL (sym))
252b5132 826 {
a161fe53
AM
827 if ((symsec->flags & SEC_LINK_ONCE) != 0
828 || (IS_ELF
829 /* The GNU toolchain uses an extension for ELF: a
830 section beginning with the magic string
831 .gnu.linkonce is a linkonce section. */
832 && strncmp (segment_name (symsec), ".gnu.linkonce",
833 sizeof ".gnu.linkonce" - 1) == 0))
834 continue;
252b5132 835 }
f7460f5f
JJ
836
837 /* Never adjust a reloc against local symbol in a merge section
838 with non-zero addend. */
5045ec7a
AM
839 if ((symsec->flags & SEC_MERGE) != 0
840 && (fixp->fx_offset != 0 || fixp->fx_subsy != NULL))
a161fe53 841 continue;
13ae64f3
JJ
842
843 /* Never adjust a reloc against TLS local symbol. */
df44284e 844 if ((symsec->flags & SEC_THREAD_LOCAL) != 0)
a161fe53 845 continue;
252b5132 846
a161fe53 847 /* We refetch the segment when calling section_symbol, rather
252b5132 848 than using symsec, because S_GET_VALUE may wind up changing
efaf0ba4 849 the section when it calls resolve_symbol_value. */
252b5132
RH
850 fixp->fx_offset += S_GET_VALUE (sym);
851 fixp->fx_addsy = section_symbol (S_GET_SEGMENT (sym));
e723ef7c
ILT
852#ifdef DEBUG5
853 fprintf (stderr, "\nadjusted fixup:\n");
854 print_fixup (fixp);
855#endif
252b5132 856 }
252b5132
RH
857
858 dump_section_relocs (abfd, sec, stderr);
859}
860
e7ff5c73
AM
861/* fixup_segment()
862
863 Go through all the fixS's in a segment and see which ones can be
864 handled now. (These consist of fixS where we have since discovered
865 the value of a symbol, or the address of the frag involved.)
866 For each one, call md_apply_fix to put the fix into the frag data.
867
868 Result is a count of how many relocation structs will be needed to
869 handle the remaining fixS's that we couldn't completely handle here.
870 These will be output later by emit_relocations(). */
871
872static long
873fixup_segment (fixS *fixP, segT this_segment)
874{
875 long seg_reloc_count = 0;
876 valueT add_number;
877 fragS *fragP;
878 segT add_symbol_segment = absolute_section;
879
880 if (fixP != NULL && abs_section_sym == NULL)
881 abs_section_sym = section_symbol (absolute_section);
882
883 /* If the linker is doing the relaxing, we must not do any fixups.
884
885 Well, strictly speaking that's not true -- we could do any that
886 are PC-relative and don't cross regions that could change size.
887 And for the i960 we might be able to turn callx/callj into bal
888 anyways in cases where we know the maximum displacement. */
889 if (linkrelax && TC_LINKRELAX_FIXUP (this_segment))
890 {
891 for (; fixP; fixP = fixP->fx_next)
892 if (!fixP->fx_done)
893 {
894 if (fixP->fx_addsy == NULL)
895 {
896 /* There was no symbol required by this relocation.
897 However, BFD doesn't really handle relocations
898 without symbols well. So fake up a local symbol in
899 the absolute section. */
900 fixP->fx_addsy = abs_section_sym;
901 }
902 symbol_mark_used_in_reloc (fixP->fx_addsy);
903 if (fixP->fx_subsy != NULL)
904 symbol_mark_used_in_reloc (fixP->fx_subsy);
905 seg_reloc_count++;
906 }
907 TC_ADJUST_RELOC_COUNT (fixP, seg_reloc_count);
908 return seg_reloc_count;
909 }
910
911 for (; fixP; fixP = fixP->fx_next)
912 {
913#ifdef DEBUG5
914 fprintf (stderr, "\nprocessing fixup:\n");
915 print_fixup (fixP);
916#endif
917
918 fragP = fixP->fx_frag;
919 know (fragP);
920#ifdef TC_VALIDATE_FIX
921 TC_VALIDATE_FIX (fixP, this_segment, skip);
922#endif
923 add_number = fixP->fx_offset;
924
e7ff5c73
AM
925 if (fixP->fx_addsy != NULL)
926 add_symbol_segment = S_GET_SEGMENT (fixP->fx_addsy);
927
928 if (fixP->fx_subsy != NULL)
929 {
930 segT sub_symbol_segment;
931 resolve_symbol_value (fixP->fx_subsy);
932 sub_symbol_segment = S_GET_SEGMENT (fixP->fx_subsy);
933 if (fixP->fx_addsy != NULL
934 && sub_symbol_segment == add_symbol_segment
c969da64
RS
935 && !S_FORCE_RELOC (fixP->fx_addsy, 0)
936 && !S_FORCE_RELOC (fixP->fx_subsy, 0)
e7ff5c73
AM
937 && !TC_FORCE_RELOCATION_SUB_SAME (fixP, add_symbol_segment))
938 {
939 add_number += S_GET_VALUE (fixP->fx_addsy);
940 add_number -= S_GET_VALUE (fixP->fx_subsy);
941 fixP->fx_offset = add_number;
942 fixP->fx_addsy = NULL;
943 fixP->fx_subsy = NULL;
944#ifdef TC_M68K
945 /* See the comment below about 68k weirdness. */
946 fixP->fx_pcrel = 0;
947#endif
948 }
949 else if (sub_symbol_segment == absolute_section
c969da64 950 && !S_FORCE_RELOC (fixP->fx_subsy, 0)
9a97a5d7 951 && !TC_FORCE_RELOCATION_SUB_ABS (fixP, add_symbol_segment))
e7ff5c73
AM
952 {
953 add_number -= S_GET_VALUE (fixP->fx_subsy);
954 fixP->fx_offset = add_number;
955 fixP->fx_subsy = NULL;
956 }
957 else if (sub_symbol_segment == this_segment
c969da64 958 && !S_FORCE_RELOC (fixP->fx_subsy, 0)
5db484ff 959 && !TC_FORCE_RELOCATION_SUB_LOCAL (fixP, add_symbol_segment))
e7ff5c73
AM
960 {
961 add_number -= S_GET_VALUE (fixP->fx_subsy);
962 fixP->fx_offset = (add_number + fixP->fx_dot_value
963 + fixP->fx_frag->fr_address);
964
965 /* Make it pc-relative. If the back-end code has not
966 selected a pc-relative reloc, cancel the adjustment
967 we do later on all pc-relative relocs. */
968 if (0
969#ifdef TC_M68K
970 /* Do this for m68k even if it's already described
971 as pc-relative. On the m68k, an operand of
972 "pc@(foo-.-2)" should address "foo" in a
973 pc-relative mode. */
974 || 1
975#endif
976 || !fixP->fx_pcrel)
977 add_number += MD_PCREL_FROM_SECTION (fixP, this_segment);
978 fixP->fx_subsy = NULL;
979 fixP->fx_pcrel = 1;
980 }
5db484ff 981 else if (!TC_VALIDATE_FIX_SUB (fixP, add_symbol_segment))
e7ff5c73 982 {
9a97a5d7
AM
983 if (!md_register_arithmetic
984 && (add_symbol_segment == reg_section
985 || sub_symbol_segment == reg_section))
986 as_bad_where (fixP->fx_file, fixP->fx_line,
987 _("register value used as expression"));
988 else
989 as_bad_where (fixP->fx_file, fixP->fx_line,
990 _("can't resolve `%s' {%s section} - `%s' {%s section}"),
991 fixP->fx_addsy ? S_GET_NAME (fixP->fx_addsy) : "0",
992 segment_name (add_symbol_segment),
993 S_GET_NAME (fixP->fx_subsy),
994 segment_name (sub_symbol_segment));
e7ff5c73
AM
995 }
996 }
997
998 if (fixP->fx_addsy)
999 {
1fc5d88e 1000 if (add_symbol_segment == this_segment
c969da64 1001 && !S_FORCE_RELOC (fixP->fx_addsy, 0)
e7ff5c73
AM
1002 && !TC_FORCE_RELOCATION_LOCAL (fixP))
1003 {
1004 /* This fixup was made when the symbol's segment was
1005 SEG_UNKNOWN, but it is now in the local segment.
1006 So we know how to do the address without relocation. */
1007 add_number += S_GET_VALUE (fixP->fx_addsy);
1008 fixP->fx_offset = add_number;
1009 if (fixP->fx_pcrel)
1010 add_number -= MD_PCREL_FROM_SECTION (fixP, this_segment);
1011 fixP->fx_addsy = NULL;
1012 fixP->fx_pcrel = 0;
1013 }
1014 else if (add_symbol_segment == absolute_section
c969da64 1015 && !S_FORCE_RELOC (fixP->fx_addsy, 0)
e7ff5c73
AM
1016 && !TC_FORCE_RELOCATION_ABS (fixP))
1017 {
1018 add_number += S_GET_VALUE (fixP->fx_addsy);
1019 fixP->fx_offset = add_number;
1020 fixP->fx_addsy = NULL;
1021 }
1022 else if (add_symbol_segment != undefined_section
1023 && ! bfd_is_com_section (add_symbol_segment)
1024 && MD_APPLY_SYM_VALUE (fixP))
1025 add_number += S_GET_VALUE (fixP->fx_addsy);
1026 }
1027
1028 if (fixP->fx_pcrel)
1029 {
1030 add_number -= MD_PCREL_FROM_SECTION (fixP, this_segment);
1031 if (!fixP->fx_done && fixP->fx_addsy == NULL)
1032 {
1033 /* There was no symbol required by this relocation.
1034 However, BFD doesn't really handle relocations
1035 without symbols well. So fake up a local symbol in
1036 the absolute section. */
1037 fixP->fx_addsy = abs_section_sym;
1038 }
1039 }
1040
1041 if (!fixP->fx_done)
1042 md_apply_fix (fixP, &add_number, this_segment);
1043
1044 if (!fixP->fx_done)
1045 {
1046 ++seg_reloc_count;
1047 if (fixP->fx_addsy == NULL)
1048 fixP->fx_addsy = abs_section_sym;
1049 symbol_mark_used_in_reloc (fixP->fx_addsy);
1050 if (fixP->fx_subsy != NULL)
1051 symbol_mark_used_in_reloc (fixP->fx_subsy);
1052 }
1053
1054 if (!fixP->fx_bit_fixP && !fixP->fx_no_overflow && fixP->fx_size != 0)
1055 {
1056 if (fixP->fx_size < sizeof (valueT))
1057 {
1058 valueT mask;
1059
1060 mask = 0;
1061 mask--; /* Set all bits to one. */
1062 mask <<= fixP->fx_size * 8 - (fixP->fx_signed ? 1 : 0);
1063 if ((add_number & mask) != 0 && (add_number & mask) != mask)
1064 {
1065 char buf[50], buf2[50];
1066 sprint_value (buf, fragP->fr_address + fixP->fx_where);
1067 if (add_number > 1000)
1068 sprint_value (buf2, add_number);
1069 else
1070 sprintf (buf2, "%ld", (long) add_number);
1071 as_bad_where (fixP->fx_file, fixP->fx_line,
1072 _("value of %s too large for field of %d bytes at %s"),
1073 buf2, fixP->fx_size, buf);
1074 } /* Generic error checking. */
1075 }
1076#ifdef WARN_SIGNED_OVERFLOW_WORD
1077 /* Warn if a .word value is too large when treated as a signed
1078 number. We already know it is not too negative. This is to
1079 catch over-large switches generated by gcc on the 68k. */
1080 if (!flag_signed_overflow_ok
1081 && fixP->fx_size == 2
1082 && add_number > 0x7fff)
1083 as_bad_where (fixP->fx_file, fixP->fx_line,
1084 _("signed .word overflow; switch may be too large; %ld at 0x%lx"),
1085 (long) add_number,
1086 (long) (fragP->fr_address + fixP->fx_where));
1087#endif
1088 } /* Not a bit fix. */
1089
1090#ifdef TC_VALIDATE_FIX
1091 skip: ATTRIBUTE_UNUSED_LABEL
1092 ;
1093#endif
1094#ifdef DEBUG5
1095 fprintf (stderr, "result:\n");
1096 print_fixup (fixP);
1097#endif
1098 } /* For each fixS in this segment. */
1099
1100 TC_ADJUST_RELOC_COUNT (fixP, seg_reloc_count);
1101 return seg_reloc_count;
1102}
1103
a161fe53 1104static void
d7342424
KH
1105fix_segment (bfd *abfd ATTRIBUTE_UNUSED,
1106 asection *sec,
e7ff5c73 1107 void *xxx ATTRIBUTE_UNUSED)
a161fe53
AM
1108{
1109 segment_info_type *seginfo = seg_info (sec);
1110
1111 fixup_segment (seginfo->fix_root, sec);
1112}
1113
e5435dec
AM
1114static void
1115install_reloc (asection *sec, arelent *reloc, fragS *fragp,
1116 char *file, unsigned int line)
1117{
1118 char *err;
1119 bfd_reloc_status_type s;
76d12939
AM
1120 asymbol *sym;
1121
1122 if (reloc->sym_ptr_ptr != NULL
1123 && (sym = *reloc->sym_ptr_ptr) != NULL
1124 && (sym->flags & BSF_KEEP) == 0
1125 && ((sym->flags & BSF_SECTION_SYM) == 0
55f8b826
AM
1126 || (EMIT_SECTION_SYMBOLS
1127 && !bfd_is_abs_section (sym->section))))
76d12939 1128 as_bad_where (file, line, _("redefined symbol cannot be used on reloc"));
e5435dec
AM
1129
1130 s = bfd_install_relocation (stdoutput, reloc,
1131 fragp->fr_literal, fragp->fr_address,
1132 sec, &err);
1133 switch (s)
1134 {
1135 case bfd_reloc_ok:
1136 break;
1137 case bfd_reloc_overflow:
1138 as_bad_where (file, line, _("relocation overflow"));
1139 break;
1140 case bfd_reloc_outofrange:
1141 as_bad_where (file, line, _("relocation out of range"));
1142 break;
1143 default:
1144 as_fatal (_("%s:%u: bad return from bfd_install_relocation: %x"),
1145 file, line, s);
1146 }
1147}
1148
252b5132 1149static void
e7ff5c73 1150write_relocs (bfd *abfd, asection *sec, void *xxx ATTRIBUTE_UNUSED)
252b5132
RH
1151{
1152 segment_info_type *seginfo = seg_info (sec);
927781e2 1153 unsigned int i;
252b5132 1154 unsigned int n;
05e9452c 1155 struct reloc_list *my_reloc_list, **rp, *r;
252b5132
RH
1156 arelent **relocs;
1157 fixS *fixp;
252b5132
RH
1158
1159 /* If seginfo is NULL, we did not create this section; don't do
1160 anything with it. */
1161 if (seginfo == NULL)
1162 return;
1163
252b5132
RH
1164 n = 0;
1165 for (fixp = seginfo->fix_root; fixp; fixp = fixp->fx_next)
e5435dec
AM
1166 if (!fixp->fx_done)
1167 n++;
1168
1169#ifdef RELOC_EXPANSION_POSSIBLE
1170 n *= MAX_RELOC_EXPANSION;
1171#endif
252b5132 1172
05e9452c
AM
1173 /* Extract relocs for this section from reloc_list. */
1174 rp = &reloc_list;
1175 my_reloc_list = NULL;
1176 while ((r = *rp) != NULL)
1177 {
1178 if (r->u.b.sec == sec)
1179 {
1180 *rp = r->next;
1181 r->next = my_reloc_list;
1182 my_reloc_list = r;
1183 n++;
1184 }
1185 else
1186 rp = &r->next;
1187 }
1188
1e9cc1c2 1189 relocs = (arelent **) xcalloc (n, sizeof (arelent *));
252b5132
RH
1190
1191 i = 0;
1192 for (fixp = seginfo->fix_root; fixp != (fixS *) NULL; fixp = fixp->fx_next)
1193 {
e5435dec 1194 int j;
d31f0f6d
AM
1195 int fx_size, slack;
1196 offsetT loc;
252b5132
RH
1197
1198 if (fixp->fx_done)
e5435dec 1199 continue;
252b5132 1200
d31f0f6d
AM
1201 fx_size = fixp->fx_size;
1202 slack = TC_FX_SIZE_SLACK (fixp);
1203 if (slack > 0)
1204 fx_size = fx_size > slack ? fx_size - slack : 0;
1205 loc = fixp->fx_where + fx_size;
e5435dec 1206 if (slack >= 0 && loc > fixp->fx_frag->fr_fix)
d31f0f6d
AM
1207 as_bad_where (fixp->fx_file, fixp->fx_line,
1208 _("internal error: fixup not contained within frag"));
252b5132 1209
e5435dec
AM
1210#ifndef RELOC_EXPANSION_POSSIBLE
1211 {
1212 arelent *reloc = tc_gen_reloc (sec, fixp);
252b5132 1213
e5435dec 1214 if (!reloc)
252b5132 1215 continue;
e5435dec
AM
1216 relocs[i++] = reloc;
1217 j = 1;
1218 }
1219#else
1220 {
1221 arelent **reloc = tc_gen_reloc (sec, fixp);
252b5132 1222
e5435dec 1223 for (j = 0; reloc[j]; j++)
efaf0ba4 1224 relocs[i++] = reloc[j];
e5435dec
AM
1225 }
1226#endif
d31f0f6d 1227
e5435dec
AM
1228 for ( ; j != 0; --j)
1229 install_reloc (sec, relocs[i - j], fixp->fx_frag,
1230 fixp->fx_file, fixp->fx_line);
252b5132
RH
1231 }
1232 n = i;
252b5132
RH
1233
1234#ifdef DEBUG4
1235 {
988392e2 1236 unsigned int i, j, nsyms;
252b5132
RH
1237 asymbol **sympp;
1238 sympp = bfd_get_outsymbols (stdoutput);
1239 nsyms = bfd_get_symcount (stdoutput);
1240 for (i = 0; i < n; i++)
1241 if (((*relocs[i]->sym_ptr_ptr)->flags & BSF_SECTION_SYM) == 0)
1242 {
1243 for (j = 0; j < nsyms; j++)
1244 if (sympp[j] == *relocs[i]->sym_ptr_ptr)
1245 break;
1246 if (j == nsyms)
1247 abort ();
1248 }
1249 }
1250#endif
1251
05e9452c
AM
1252 for (r = my_reloc_list; r != NULL; r = r->next)
1253 {
1254 fragS *f;
1255 for (f = seginfo->frchainP->frch_root; f; f = f->fr_next)
1256 if (f->fr_address <= r->u.b.r.address
1257 && r->u.b.r.address < f->fr_address + f->fr_fix)
1258 break;
1259 if (f == NULL)
1260 as_bad_where (r->file, r->line,
1261 _("reloc not within (fixed part of) section"));
1262 else
1263 {
1264 relocs[n++] = &r->u.b.r;
1265 install_reloc (sec, &r->u.b.r, f, r->file, r->line);
1266 }
1267 }
1268
252b5132 1269 if (n)
e5435dec
AM
1270 {
1271 flagword flags = bfd_get_section_flags (abfd, sec);
1272 flags |= SEC_RELOC;
1273 bfd_set_section_flags (abfd, sec, flags);
1274 bfd_set_reloc (stdoutput, sec, relocs, n);
1275 }
252b5132 1276
945a1a6b
ILT
1277#ifdef SET_SECTION_RELOCS
1278 SET_SECTION_RELOCS (sec, relocs, n);
1279#endif
1280
252b5132
RH
1281#ifdef DEBUG3
1282 {
988392e2 1283 unsigned int i;
252b5132
RH
1284 arelent *r;
1285 asymbol *s;
1286 fprintf (stderr, "relocs for sec %s\n", sec->name);
1287 for (i = 0; i < n; i++)
1288 {
1289 r = relocs[i];
1290 s = *r->sym_ptr_ptr;
988392e2
CG
1291 fprintf (stderr, " reloc %2d @%p off %4lx : sym %-10s addend %lx\n",
1292 i, r, (unsigned long)r->address, s->name, (unsigned long)r->addend);
252b5132
RH
1293 }
1294 }
1295#endif
1296}
1297
0acf065b
CC
1298static int
1299compress_frag (struct z_stream_s *strm, const char *contents, int in_size,
1300 fragS **last_newf, struct obstack *ob)
1301{
1302 int out_size;
1303 int total_out_size = 0;
1304 fragS *f = *last_newf;
1305 char *next_out;
1306 int avail_out;
1307
1308 /* Call the compression routine repeatedly until it has finished
1309 processing the frag. */
1310 while (in_size > 0)
1311 {
1312 /* Reserve all the space available in the current chunk.
1313 If none is available, start a new frag. */
1314 avail_out = obstack_room (ob);
1315 if (avail_out <= 0)
1316 {
1317 obstack_finish (ob);
1318 f = frag_alloc (ob);
1319 f->fr_type = rs_fill;
1320 (*last_newf)->fr_next = f;
1321 *last_newf = f;
1322 avail_out = obstack_room (ob);
1323 }
1324 if (avail_out <= 0)
1325 as_fatal (_("can't extend frag"));
1326 next_out = obstack_next_free (ob);
1327 obstack_blank_fast (ob, avail_out);
1328 out_size = compress_data (strm, &contents, &in_size,
1329 &next_out, &avail_out);
1330 if (out_size < 0)
1331 return -1;
1332
1333 f->fr_fix += out_size;
1334 total_out_size += out_size;
1335
1336 /* Return unused space. */
1337 if (avail_out > 0)
1338 obstack_blank_fast (ob, -avail_out);
1339 }
1340
1341 return total_out_size;
1342}
1343
1344static void
1345compress_debug (bfd *abfd, asection *sec, void *xxx ATTRIBUTE_UNUSED)
1346{
1347 segment_info_type *seginfo = seg_info (sec);
1348 fragS *f;
1349 fragS *first_newf;
1350 fragS *last_newf;
1351 struct obstack *ob = &seginfo->frchainP->frch_obstack;
1352 bfd_size_type uncompressed_size = (bfd_size_type) sec->size;
1353 bfd_size_type compressed_size;
1354 const char *section_name;
1355 char *compressed_name;
1356 char *header;
1357 struct z_stream_s *strm;
1358 int x;
4a114e3e 1359 flagword flags = bfd_get_section_flags (abfd, sec);
0acf065b
CC
1360
1361 if (seginfo == NULL
4a114e3e 1362 || (flags & (SEC_ALLOC | SEC_HAS_CONTENTS)) == SEC_ALLOC)
0acf065b
CC
1363 return;
1364
1365 section_name = bfd_get_section_name (stdoutput, sec);
1366 if (strncmp (section_name, ".debug_", 7) != 0)
1367 return;
1368
1369 strm = compress_init ();
1370 if (strm == NULL)
1371 return;
1372
1373 /* Create a new frag to contain the "ZLIB" header. */
1374 first_newf = frag_alloc (ob);
1375 if (obstack_room (ob) < 12)
1376 first_newf = frag_alloc (ob);
1377 if (obstack_room (ob) < 12)
1378 as_fatal (_("can't extend frag %u chars"), 12);
1379 last_newf = first_newf;
1380 obstack_blank_fast (ob, 12);
1381 last_newf->fr_type = rs_fill;
1382 last_newf->fr_fix = 12;
1383 header = last_newf->fr_literal;
1384 memcpy (header, "ZLIB", 4);
1385 header[11] = uncompressed_size; uncompressed_size >>= 8;
1386 header[10] = uncompressed_size; uncompressed_size >>= 8;
1387 header[9] = uncompressed_size; uncompressed_size >>= 8;
1388 header[8] = uncompressed_size; uncompressed_size >>= 8;
1389 header[7] = uncompressed_size; uncompressed_size >>= 8;
1390 header[6] = uncompressed_size; uncompressed_size >>= 8;
1391 header[5] = uncompressed_size; uncompressed_size >>= 8;
1392 header[4] = uncompressed_size;
1393 compressed_size = 12;
1394
1395 /* Stream the frags through the compression engine, adding new frags
1396 as necessary to accomodate the compressed output. */
1397 for (f = seginfo->frchainP->frch_root;
1398 f;
1399 f = f->fr_next)
1400 {
1401 offsetT fill_size;
1402 char *fill_literal;
1403 offsetT count;
1404 int out_size;
1405
1406 gas_assert (f->fr_type == rs_fill);
1407 if (f->fr_fix)
1408 {
1409 out_size = compress_frag (strm, f->fr_literal, f->fr_fix,
1410 &last_newf, ob);
1411 if (out_size < 0)
1412 return;
1413 compressed_size += out_size;
1414 }
1415 fill_literal = f->fr_literal + f->fr_fix;
1416 fill_size = f->fr_var;
1417 count = f->fr_offset;
1418 gas_assert (count >= 0);
1419 if (fill_size && count)
1420 {
1421 while (count--)
1422 {
1423 out_size = compress_frag (strm, fill_literal, (int) fill_size,
1424 &last_newf, ob);
1425 if (out_size < 0)
1426 return;
1427 compressed_size += out_size;
1428 }
1429 }
1430 }
1431
1432 /* Flush the compression state. */
1433 for (;;)
1434 {
1435 int avail_out;
1436 char *next_out;
1437 int out_size;
1438
1439 /* Reserve all the space available in the current chunk.
1440 If none is available, start a new frag. */
1441 avail_out = obstack_room (ob);
1442 if (avail_out <= 0)
1443 {
1444 fragS *newf;
1445
1446 obstack_finish (ob);
1447 newf = frag_alloc (ob);
1448 newf->fr_type = rs_fill;
1449 last_newf->fr_next = newf;
1450 last_newf = newf;
1451 avail_out = obstack_room (ob);
1452 }
1453 if (avail_out <= 0)
1454 as_fatal (_("can't extend frag"));
1455 next_out = obstack_next_free (ob);
1456 obstack_blank_fast (ob, avail_out);
1457 x = compress_finish (strm, &next_out, &avail_out, &out_size);
1458 if (x < 0)
1459 return;
1460
1461 last_newf->fr_fix += out_size;
1462 compressed_size += out_size;
1463
1464 /* Return unused space. */
1465 if (avail_out > 0)
1466 obstack_blank_fast (ob, -avail_out);
1467
1468 if (x == 0)
1469 break;
1470 }
1471
1472 /* Replace the uncompressed frag list with the compressed frag list. */
1473 seginfo->frchainP->frch_root = first_newf;
1474 seginfo->frchainP->frch_last = last_newf;
1475
1476 /* Update the section size and its name. */
1477 x = bfd_set_section_size (abfd, sec, compressed_size);
1478 gas_assert (x);
1479 compressed_name = (char *) xmalloc (strlen (section_name) + 2);
1480 compressed_name[0] = '.';
1481 compressed_name[1] = 'z';
1482 strcpy (compressed_name + 2, section_name + 1);
1483 bfd_section_name (stdoutput, sec) = compressed_name;
1484}
1485
252b5132 1486static void
d7342424
KH
1487write_contents (bfd *abfd ATTRIBUTE_UNUSED,
1488 asection *sec,
e7ff5c73 1489 void *xxx ATTRIBUTE_UNUSED)
252b5132
RH
1490{
1491 segment_info_type *seginfo = seg_info (sec);
685736be 1492 addressT offset = 0;
252b5132
RH
1493 fragS *f;
1494
1495 /* Write out the frags. */
1496 if (seginfo == NULL
efaf0ba4 1497 || !(bfd_get_section_flags (abfd, sec) & SEC_HAS_CONTENTS))
252b5132
RH
1498 return;
1499
1500 for (f = seginfo->frchainP->frch_root;
1501 f;
1502 f = f->fr_next)
1503 {
1504 int x;
685736be 1505 addressT fill_size;
252b5132 1506 char *fill_literal;
685736be 1507 offsetT count;
252b5132 1508
9c2799c2 1509 gas_assert (f->fr_type == rs_fill);
252b5132
RH
1510 if (f->fr_fix)
1511 {
1512 x = bfd_set_section_contents (stdoutput, sec,
1513 f->fr_literal, (file_ptr) offset,
1514 (bfd_size_type) f->fr_fix);
b34976b6 1515 if (!x)
885afe7b
AM
1516 as_fatal (_("can't write %s: %s"), stdoutput->filename,
1517 bfd_errmsg (bfd_get_error ()));
252b5132
RH
1518 offset += f->fr_fix;
1519 }
1520 fill_literal = f->fr_literal + f->fr_fix;
1521 fill_size = f->fr_var;
1522 count = f->fr_offset;
9c2799c2 1523 gas_assert (count >= 0);
252b5132
RH
1524 if (fill_size && count)
1525 {
1526 char buf[256];
efaf0ba4 1527 if (fill_size > sizeof (buf))
252b5132 1528 {
efaf0ba4 1529 /* Do it the old way. Can this ever happen? */
252b5132
RH
1530 while (count--)
1531 {
1532 x = bfd_set_section_contents (stdoutput, sec,
1533 fill_literal,
1534 (file_ptr) offset,
1535 (bfd_size_type) fill_size);
b34976b6 1536 if (!x)
885afe7b
AM
1537 as_fatal (_("can't write %s: %s"), stdoutput->filename,
1538 bfd_errmsg (bfd_get_error ()));
252b5132
RH
1539 offset += fill_size;
1540 }
1541 }
1542 else
1543 {
1544 /* Build a buffer full of fill objects and output it as
1545 often as necessary. This saves on the overhead of
1546 potentially lots of bfd_set_section_contents calls. */
1547 int n_per_buf, i;
1548 if (fill_size == 1)
1549 {
1550 n_per_buf = sizeof (buf);
1551 memset (buf, *fill_literal, n_per_buf);
1552 }
1553 else
1554 {
1555 char *bufp;
efaf0ba4 1556 n_per_buf = sizeof (buf) / fill_size;
252b5132 1557 for (i = n_per_buf, bufp = buf; i; i--, bufp += fill_size)
efaf0ba4 1558 memcpy (bufp, fill_literal, fill_size);
252b5132
RH
1559 }
1560 for (; count > 0; count -= n_per_buf)
1561 {
1562 n_per_buf = n_per_buf > count ? count : n_per_buf;
efaf0ba4
NC
1563 x = bfd_set_section_contents
1564 (stdoutput, sec, buf, (file_ptr) offset,
1565 (bfd_size_type) n_per_buf * fill_size);
b34976b6 1566 if (!x)
0e389e77 1567 as_fatal (_("cannot write to output file"));
252b5132
RH
1568 offset += n_per_buf * fill_size;
1569 }
1570 }
1571 }
1572 }
1573}
252b5132 1574
252b5132 1575static void
d7342424 1576merge_data_into_text (void)
252b5132 1577{
252b5132
RH
1578 seg_info (text_section)->frchainP->frch_last->fr_next =
1579 seg_info (data_section)->frchainP->frch_root;
1580 seg_info (text_section)->frchainP->frch_last =
1581 seg_info (data_section)->frchainP->frch_last;
1582 seg_info (data_section)->frchainP = 0;
252b5132 1583}
252b5132 1584
252b5132 1585static void
d7342424 1586set_symtab (void)
252b5132
RH
1587{
1588 int nsyms;
1589 asymbol **asympp;
1590 symbolS *symp;
b34976b6 1591 bfd_boolean result;
252b5132
RH
1592
1593 /* Count symbols. We can't rely on a count made by the loop in
1594 write_object_file, because *_frob_file may add a new symbol or
1595 two. */
1596 nsyms = 0;
1597 for (symp = symbol_rootP; symp; symp = symbol_next (symp))
1598 nsyms++;
1599
1600 if (nsyms)
1601 {
1602 int i;
0e1a166b 1603 bfd_size_type amt = (bfd_size_type) nsyms * sizeof (asymbol *);
252b5132 1604
1e9cc1c2 1605 asympp = (asymbol **) bfd_alloc (stdoutput, amt);
252b5132
RH
1606 symp = symbol_rootP;
1607 for (i = 0; i < nsyms; i++, symp = symbol_next (symp))
1608 {
49309057 1609 asympp[i] = symbol_get_bfdsym (symp);
76d12939
AM
1610 if (asympp[i]->flags != BSF_SECTION_SYM
1611 || !(bfd_is_const_section (asympp[i]->section)
1612 && asympp[i]->section->symbol == asympp[i]))
1613 asympp[i]->flags |= BSF_KEEP;
49309057 1614 symbol_mark_written (symp);
252b5132
RH
1615 }
1616 }
1617 else
1618 asympp = 0;
1619 result = bfd_set_symtab (stdoutput, asympp, nsyms);
9c2799c2 1620 gas_assert (result);
252b5132
RH
1621 symbol_table_frozen = 1;
1622}
252b5132
RH
1623
1624/* Finish the subsegments. After every sub-segment, we fake an
1625 ".align ...". This conforms to BSD4.2 brane-damage. We then fake
1626 ".fill 0" because that is the kind of frag that requires least
1627 thought. ".align" frags like to have a following frag since that
1628 makes calculating their intended length trivial. */
1629
1630#ifndef SUB_SEGMENT_ALIGN
18e1d487 1631#ifdef HANDLE_ALIGN
436d9e46 1632/* The last subsegment gets an alignment corresponding to the alignment
18e1d487
AM
1633 of the section. This allows proper nop-filling at the end of
1634 code-bearing sections. */
1635#define SUB_SEGMENT_ALIGN(SEG, FRCHAIN) \
c9049d30 1636 (!(FRCHAIN)->frch_next ? get_recorded_alignment (SEG) : 0)
18e1d487 1637#else
18e1d487 1638#define SUB_SEGMENT_ALIGN(SEG, FRCHAIN) 0
252b5132
RH
1639#endif
1640#endif
1641
1642void
d7342424 1643subsegs_finish (void)
252b5132
RH
1644{
1645 struct frchain *frchainP;
c9049d30 1646 asection *s;
252b5132 1647
c9049d30 1648 for (s = stdoutput->sections; s; s = s->next)
252b5132 1649 {
c9049d30
AM
1650 segment_info_type *seginfo = seg_info (s);
1651 if (!seginfo)
1652 continue;
0a9ef439 1653
c9049d30
AM
1654 for (frchainP = seginfo->frchainP;
1655 frchainP != NULL;
1656 frchainP = frchainP->frch_next)
381a1ab3 1657 {
c9049d30
AM
1658 int alignment = 0;
1659
1660 subseg_set (s, frchainP->frch_subseg);
381a1ab3 1661
c9049d30
AM
1662 /* This now gets called even if we had errors. In that case,
1663 any alignment is meaningless, and, moreover, will look weird
1664 if we are generating a listing. */
1665 if (!had_errors ())
1666 {
1667 alignment = SUB_SEGMENT_ALIGN (now_seg, frchainP);
1668 if ((bfd_get_section_flags (now_seg->owner, now_seg) & SEC_MERGE)
1669 && now_seg->entsize)
381a1ab3 1670 {
c9049d30
AM
1671 unsigned int entsize = now_seg->entsize;
1672 int entalign = 0;
1673
1674 while ((entsize & 1) == 0)
1675 {
1676 ++entalign;
1677 entsize >>= 1;
1678 }
1679 if (entalign > alignment)
1680 alignment = entalign;
381a1ab3 1681 }
381a1ab3 1682 }
0a9ef439 1683
c9049d30
AM
1684 if (subseg_text_p (now_seg))
1685 frag_align_code (alignment, 0);
1686 else
1687 frag_align (alignment, 0, 0);
252b5132 1688
c9049d30
AM
1689 /* frag_align will have left a new frag.
1690 Use this last frag for an empty ".fill".
252b5132 1691
c9049d30
AM
1692 For this segment ...
1693 Create a last frag. Do not leave a "being filled in frag". */
1694 frag_wane (frag_now);
1695 frag_now->fr_fix = 0;
1696 know (frag_now->fr_next == NULL);
1697 }
252b5132
RH
1698 }
1699}
1700
1701/* Write the object file. */
1702
1703void
d7342424 1704write_object_file (void)
252b5132 1705{
32638454 1706 struct relax_seg_info rsi;
7be1c489 1707#ifndef WORKING_DOT_WORD
efaf0ba4 1708 fragS *fragP; /* Track along all frags. */
252b5132
RH
1709#endif
1710
1711 /* Do we really want to write it? */
1712 {
1713 int n_warns, n_errs;
1714 n_warns = had_warnings ();
1715 n_errs = had_errors ();
1716 /* The -Z flag indicates that an object file should be generated,
1717 regardless of warnings and errors. */
1718 if (flag_always_generate_output)
1719 {
1720 if (n_warns || n_errs)
0e389e77 1721 as_warn (_("%d error%s, %d warning%s, generating bad object file"),
252b5132
RH
1722 n_errs, n_errs == 1 ? "" : "s",
1723 n_warns, n_warns == 1 ? "" : "s");
1724 }
1725 else
1726 {
1727 if (n_errs)
0e389e77 1728 as_fatal (_("%d error%s, %d warning%s, no object file generated"),
252b5132
RH
1729 n_errs, n_errs == 1 ? "" : "s",
1730 n_warns, n_warns == 1 ? "" : "s");
1731 }
1732 }
1733
1734#ifdef OBJ_VMS
1735 /* Under VMS we try to be compatible with VAX-11 "C". Thus, we call
1736 a routine to check for the definition of the procedure "_main",
efaf0ba4 1737 and if so -- fix it up so that it can be program entry point. */
252b5132 1738 vms_check_for_main ();
efaf0ba4 1739#endif /* OBJ_VMS */
252b5132
RH
1740
1741 /* From now on, we don't care about sub-segments. Build one frag chain
1742 for each segment. Linked thru fr_next. */
1743
252b5132
RH
1744 /* Remove the sections created by gas for its own purposes. */
1745 {
252b5132
RH
1746 int i;
1747
5daa8fe7
L
1748 bfd_section_list_remove (stdoutput, reg_section);
1749 bfd_section_list_remove (stdoutput, expr_section);
1750 stdoutput->section_count -= 2;
252b5132
RH
1751 i = 0;
1752 bfd_map_over_sections (stdoutput, renumber_sections, &i);
1753 }
1754
1755 bfd_map_over_sections (stdoutput, chain_frchains_together, (char *) 0);
252b5132
RH
1756
1757 /* We have two segments. If user gave -R flag, then we must put the
1758 data frags into the text segment. Do this before relaxing so
1759 we know to take advantage of -R and make shorter addresses. */
252b5132
RH
1760 if (flag_readonly_data_in_text)
1761 {
1762 merge_data_into_text ();
1763 }
252b5132 1764
32638454 1765 rsi.pass = 0;
e46d99eb
AM
1766 while (1)
1767 {
aacb5251
HPN
1768#ifndef WORKING_DOT_WORD
1769 /* We need to reset the markers in the broken word list and
1770 associated frags between calls to relax_segment (via
1771 relax_seg). Since the broken word list is global, we do it
1772 once per round, rather than locally in relax_segment for each
1773 segment. */
1774 struct broken_word *brokp;
1775
1776 for (brokp = broken_words;
1777 brokp != (struct broken_word *) NULL;
1778 brokp = brokp->next_broken_word)
1779 {
1780 brokp->added = 0;
1781
1782 if (brokp->dispfrag != (fragS *) NULL
1783 && brokp->dispfrag->fr_type == rs_broken_word)
1784 brokp->dispfrag->fr_subtype = 0;
1785 }
1786#endif
1787
32638454
AM
1788 rsi.changed = 0;
1789 bfd_map_over_sections (stdoutput, relax_seg, &rsi);
1790 rsi.pass++;
1791 if (!rsi.changed)
e46d99eb
AM
1792 break;
1793 }
e027f3e8 1794
87548816
NC
1795 /* Note - Most ports will use the default value of
1796 TC_FINALIZE_SYMS_BEFORE_SIZE_SEG, which 1. This will force
1797 local symbols to be resolved, removing their frag information.
1798 Some ports however, will not have finished relaxing all of
1799 their frags and will still need the local symbol frag
1800 information. These ports can set
1801 TC_FINALIZE_SYMS_BEFORE_SIZE_SEG to 0. */
1802 finalize_syms = TC_FINALIZE_SYMS_BEFORE_SIZE_SEG;
1803
e46d99eb 1804 bfd_map_over_sections (stdoutput, size_seg, (char *) 0);
e46d99eb 1805
38b87a1b
NC
1806 /* Relaxation has completed. Freeze all syms. */
1807 finalize_syms = 1;
1808
e0001a05
NC
1809#ifdef md_post_relax_hook
1810 md_post_relax_hook;
1811#endif
1812
252b5132
RH
1813#ifndef WORKING_DOT_WORD
1814 {
1815 struct broken_word *lie;
1816 struct broken_word **prevP;
1817
1818 prevP = &broken_words;
1819 for (lie = broken_words; lie; lie = lie->next_broken_word)
1820 if (!lie->added)
1821 {
1822 expressionS exp;
1823
1824 subseg_change (lie->seg, lie->subseg);
1825 exp.X_op = O_subtract;
1826 exp.X_add_symbol = lie->add;
1827 exp.X_op_symbol = lie->sub;
1828 exp.X_add_number = lie->addnum;
252b5132
RH
1829#ifdef TC_CONS_FIX_NEW
1830 TC_CONS_FIX_NEW (lie->frag,
efaf0ba4
NC
1831 lie->word_goes_here - lie->frag->fr_literal,
1832 2, &exp);
252b5132
RH
1833#else
1834 fix_new_exp (lie->frag,
1835 lie->word_goes_here - lie->frag->fr_literal,
1836 2, &exp, 0, BFD_RELOC_16);
1837#endif
252b5132
RH
1838 *prevP = lie->next_broken_word;
1839 }
1840 else
1841 prevP = &(lie->next_broken_word);
1842
1843 for (lie = broken_words; lie;)
1844 {
1845 struct broken_word *untruth;
1846 char *table_ptr;
1847 addressT table_addr;
1848 addressT from_addr, to_addr;
1849 int n, m;
1850
1851 subseg_change (lie->seg, lie->subseg);
1852 fragP = lie->dispfrag;
1853
1854 /* Find out how many broken_words go here. */
1855 n = 0;
efaf0ba4
NC
1856 for (untruth = lie;
1857 untruth && untruth->dispfrag == fragP;
1858 untruth = untruth->next_broken_word)
252b5132
RH
1859 if (untruth->added == 1)
1860 n++;
1861
1862 table_ptr = lie->dispfrag->fr_opcode;
efaf0ba4
NC
1863 table_addr = (lie->dispfrag->fr_address
1864 + (table_ptr - lie->dispfrag->fr_literal));
252b5132
RH
1865 /* Create the jump around the long jumps. This is a short
1866 jump from table_ptr+0 to table_ptr+n*long_jump_size. */
1867 from_addr = table_addr;
1868 to_addr = table_addr + md_short_jump_size + n * md_long_jump_size;
efaf0ba4
NC
1869 md_create_short_jump (table_ptr, from_addr, to_addr, lie->dispfrag,
1870 lie->add);
252b5132
RH
1871 table_ptr += md_short_jump_size;
1872 table_addr += md_short_jump_size;
1873
efaf0ba4
NC
1874 for (m = 0;
1875 lie && lie->dispfrag == fragP;
1876 m++, lie = lie->next_broken_word)
252b5132
RH
1877 {
1878 if (lie->added == 2)
1879 continue;
efaf0ba4 1880 /* Patch the jump table. */
187af7df 1881 for (untruth = (struct broken_word *) (fragP->fr_symbol);
efaf0ba4
NC
1882 untruth && untruth->dispfrag == fragP;
1883 untruth = untruth->next_broken_word)
252b5132
RH
1884 {
1885 if (untruth->use_jump == lie)
187af7df
HPN
1886 {
1887 /* This is the offset from ??? to table_ptr+0.
1888 The target is the same for all users of this
1889 md_long_jump, but the "sub" bases (and hence the
1890 offsets) may be different. */
1891 addressT to_word = table_addr - S_GET_VALUE (untruth->sub);
1892#ifdef TC_CHECK_ADJUSTED_BROKEN_DOT_WORD
1893 TC_CHECK_ADJUSTED_BROKEN_DOT_WORD (to_word, untruth);
1894#endif
1895 md_number_to_chars (untruth->word_goes_here, to_word, 2);
1896 }
252b5132
RH
1897 }
1898
efaf0ba4
NC
1899 /* Install the long jump. */
1900 /* This is a long jump from table_ptr+0 to the final target. */
252b5132
RH
1901 from_addr = table_addr;
1902 to_addr = S_GET_VALUE (lie->add) + lie->addnum;
efaf0ba4
NC
1903 md_create_long_jump (table_ptr, from_addr, to_addr, lie->dispfrag,
1904 lie->add);
252b5132
RH
1905 table_ptr += md_long_jump_size;
1906 table_addr += md_long_jump_size;
1907 }
1908 }
1909 }
efaf0ba4 1910#endif /* not WORKING_DOT_WORD */
252b5132 1911
252b5132
RH
1912 /* Resolve symbol values. This needs to be done before processing
1913 the relocations. */
1914 if (symbol_rootP)
1915 {
1916 symbolS *symp;
1917
1918 for (symp = symbol_rootP; symp; symp = symbol_next (symp))
6386f3a7 1919 resolve_symbol_value (symp);
252b5132 1920 }
49309057 1921 resolve_local_symbol_values ();
05e9452c 1922 resolve_reloc_expr_symbols ();
252b5132
RH
1923
1924 PROGRESS (1);
1925
1926#ifdef tc_frob_file_before_adjust
1927 tc_frob_file_before_adjust ();
1928#endif
1929#ifdef obj_frob_file_before_adjust
1930 obj_frob_file_before_adjust ();
1931#endif
1932
efaf0ba4 1933 bfd_map_over_sections (stdoutput, adjust_reloc_syms, (char *) 0);
252b5132 1934
a161fe53
AM
1935#ifdef tc_frob_file_before_fix
1936 tc_frob_file_before_fix ();
1937#endif
1938#ifdef obj_frob_file_before_fix
1939 obj_frob_file_before_fix ();
1940#endif
1941
1942 bfd_map_over_sections (stdoutput, fix_segment, (char *) 0);
1943
252b5132
RH
1944 /* Set up symbol table, and write it out. */
1945 if (symbol_rootP)
1946 {
1947 symbolS *symp;
aaac53f5 1948 bfd_boolean skip_next_symbol = FALSE;
252b5132
RH
1949
1950 for (symp = symbol_rootP; symp; symp = symbol_next (symp))
1951 {
1952 int punt = 0;
1953 const char *name;
1954
aaac53f5
HPN
1955 if (skip_next_symbol)
1956 {
1957 /* Don't do anything besides moving the value of the
1958 symbol from the GAS value-field to the BFD value-field. */
1959 symbol_get_bfdsym (symp)->value = S_GET_VALUE (symp);
1960 skip_next_symbol = FALSE;
1961 continue;
1962 }
1963
49309057 1964 if (symbol_mri_common_p (symp))
252b5132
RH
1965 {
1966 if (S_IS_EXTERNAL (symp))
1967 as_bad (_("%s: global symbols not supported in common sections"),
1968 S_GET_NAME (symp));
1969 symbol_remove (symp, &symbol_rootP, &symbol_lastP);
1970 continue;
1971 }
1972
1973 name = S_GET_NAME (symp);
1974 if (name)
1975 {
efaf0ba4
NC
1976 const char *name2 =
1977 decode_local_label_name ((char *) S_GET_NAME (symp));
252b5132
RH
1978 /* They only differ if `name' is a fb or dollar local
1979 label name. */
1980 if (name2 != name && ! S_IS_DEFINED (symp))
0e389e77 1981 as_bad (_("local label `%s' is not defined"), name2);
252b5132
RH
1982 }
1983
1984 /* Do it again, because adjust_reloc_syms might introduce
1985 more symbols. They'll probably only be section symbols,
1986 but they'll still need to have the values computed. */
6386f3a7 1987 resolve_symbol_value (symp);
252b5132
RH
1988
1989 /* Skip symbols which were equated to undefined or common
b4b24b79 1990 symbols. */
06e77878
AO
1991 if (symbol_equated_reloc_p (symp)
1992 || S_IS_WEAKREFR (symp))
252b5132 1993 {
91d6fa6a
NC
1994 const char *sname = S_GET_NAME (symp);
1995
60938e80 1996 if (S_IS_COMMON (symp)
91d6fa6a 1997 && !TC_FAKE_LABEL (sname)
06e77878 1998 && !S_IS_WEAKREFR (symp)
60938e80
L
1999 && (!S_IS_EXTERNAL (symp) || S_IS_LOCAL (symp)))
2000 {
2001 expressionS *e = symbol_get_value_expression (symp);
91d6fa6a 2002
60938e80 2003 as_bad (_("Local symbol `%s' can't be equated to common symbol `%s'"),
91d6fa6a 2004 sname, S_GET_NAME (e->X_add_symbol));
60938e80 2005 }
d0548f34
L
2006 if (S_GET_SEGMENT (symp) == reg_section)
2007 {
2008 /* Report error only if we know the symbol name. */
2009 if (S_GET_NAME (symp) != reg_section->name)
2010 as_bad (_("can't make global register symbol `%s'"),
91d6fa6a 2011 sname);
d0548f34 2012 }
252b5132
RH
2013 symbol_remove (symp, &symbol_rootP, &symbol_lastP);
2014 continue;
2015 }
2016
252b5132
RH
2017#ifdef obj_frob_symbol
2018 obj_frob_symbol (symp, punt);
2019#endif
2020#ifdef tc_frob_symbol
49309057 2021 if (! punt || symbol_used_in_reloc_p (symp))
252b5132
RH
2022 tc_frob_symbol (symp, punt);
2023#endif
2024
2025 /* If we don't want to keep this symbol, splice it out of
2026 the chain now. If EMIT_SECTION_SYMBOLS is 0, we never
2027 want section symbols. Otherwise, we skip local symbols
2028 and symbols that the frob_symbol macros told us to punt,
2029 but we keep such symbols if they are used in relocs. */
a161fe53
AM
2030 if (symp == abs_section_sym
2031 || (! EMIT_SECTION_SYMBOLS
2032 && symbol_section_p (symp))
e97b3f28 2033 /* Note that S_IS_EXTERNAL and S_IS_LOCAL are not always
252b5132
RH
2034 opposites. Sometimes the former checks flags and the
2035 latter examines the name... */
e97b3f28 2036 || (!S_IS_EXTERNAL (symp)
461b725f
AO
2037 && (punt || S_IS_LOCAL (symp) ||
2038 (S_IS_WEAKREFD (symp) && ! symbol_used_p (symp)))
49309057 2039 && ! symbol_used_in_reloc_p (symp)))
252b5132
RH
2040 {
2041 symbol_remove (symp, &symbol_rootP, &symbol_lastP);
efaf0ba4 2042
252b5132
RH
2043 /* After symbol_remove, symbol_next(symp) still returns
2044 the one that came after it in the chain. So we don't
2045 need to do any extra cleanup work here. */
252b5132
RH
2046 continue;
2047 }
2048
2049 /* Make sure we really got a value for the symbol. */
49309057 2050 if (! symbol_resolved_p (symp))
252b5132 2051 {
0e389e77 2052 as_bad (_("can't resolve value for symbol `%s'"),
252b5132 2053 S_GET_NAME (symp));
49309057 2054 symbol_mark_resolved (symp);
252b5132
RH
2055 }
2056
2057 /* Set the value into the BFD symbol. Up til now the value
2058 has only been kept in the gas symbolS struct. */
49309057 2059 symbol_get_bfdsym (symp)->value = S_GET_VALUE (symp);
aaac53f5
HPN
2060
2061 /* A warning construct is a warning symbol followed by the
2062 symbol warned about. Don't let anything object-format or
2063 target-specific muck with it; it's ready for output. */
2064 if (symbol_get_bfdsym (symp)->flags & BSF_WARNING)
2065 skip_next_symbol = TRUE;
252b5132
RH
2066 }
2067 }
2068
2069 PROGRESS (1);
2070
2071 /* Now do any format-specific adjustments to the symbol table, such
2072 as adding file symbols. */
2073#ifdef tc_adjust_symtab
2074 tc_adjust_symtab ();
2075#endif
2076#ifdef obj_adjust_symtab
2077 obj_adjust_symtab ();
2078#endif
2079
d0548f34
L
2080 /* Stop if there is an error. */
2081 if (had_errors ())
2082 return;
2083
252b5132
RH
2084 /* Now that all the sizes are known, and contents correct, we can
2085 start writing to the file. */
2086 set_symtab ();
2087
2088 /* If *_frob_file changes the symbol value at this point, it is
2089 responsible for moving the changed value into symp->bsym->value
2090 as well. Hopefully all symbol value changing can be done in
2091 *_frob_symbol. */
2092#ifdef tc_frob_file
2093 tc_frob_file ();
2094#endif
2095#ifdef obj_frob_file
2096 obj_frob_file ();
2097#endif
f3d2b04b
KT
2098#ifdef obj_coff_generate_pdata
2099 obj_coff_generate_pdata ();
2100#endif
252b5132
RH
2101 bfd_map_over_sections (stdoutput, write_relocs, (char *) 0);
2102
f1c2d4af 2103#ifdef tc_frob_file_after_relocs
252b5132
RH
2104 tc_frob_file_after_relocs ();
2105#endif
2106#ifdef obj_frob_file_after_relocs
2107 obj_frob_file_after_relocs ();
2108#endif
f1c2d4af 2109
0acf065b
CC
2110 /* Once all relocations have been written, we can compress the
2111 contents of the debug sections. This needs to be done before
2112 we start writing any sections, because it will affect the file
2113 layout, which is fixed once we start writing contents. */
2114 if (flag_compress_debug)
2115 bfd_map_over_sections (stdoutput, compress_debug, (char *) 0);
2116
252b5132 2117 bfd_map_over_sections (stdoutput, write_contents, (char *) 0);
252b5132 2118}
252b5132
RH
2119
2120#ifdef TC_GENERIC_RELAX_TABLE
252b5132
RH
2121/* Relax a fragment by scanning TC_GENERIC_RELAX_TABLE. */
2122
2123long
d7342424 2124relax_frag (segT segment, fragS *fragP, long stretch)
252b5132
RH
2125{
2126 const relax_typeS *this_type;
2127 const relax_typeS *start_type;
2128 relax_substateT next_state;
2129 relax_substateT this_state;
685736be 2130 offsetT growth;
38686296
AM
2131 offsetT aim;
2132 addressT target;
2133 addressT address;
2134 symbolS *symbolP;
2135 const relax_typeS *table;
2136
2137 target = fragP->fr_offset;
2138 address = fragP->fr_address;
2139 table = TC_GENERIC_RELAX_TABLE;
252b5132
RH
2140 this_state = fragP->fr_subtype;
2141 start_type = this_type = table + this_state;
38686296 2142 symbolP = fragP->fr_symbol;
252b5132
RH
2143
2144 if (symbolP)
2145 {
c842b53a
ILT
2146 fragS *sym_frag;
2147
2148 sym_frag = symbol_get_frag (symbolP);
2149
252b5132 2150#ifndef DIFF_EXPR_OK
c842b53a 2151 know (sym_frag != NULL);
252b5132 2152#endif
a161fe53 2153 know (S_GET_SEGMENT (symbolP) != absolute_section
c842b53a 2154 || sym_frag == &zero_address_frag);
ac62c346 2155 target += S_GET_VALUE (symbolP);
252b5132 2156
e35a414d
AM
2157 /* If SYM_FRAG has yet to be reached on this pass, assume it
2158 will move by STRETCH just as we did, unless there is an
2159 alignment frag between here and SYM_FRAG. An alignment may
2160 well absorb any STRETCH, and we don't want to choose a larger
2161 branch insn by overestimating the needed reach of this
2162 branch. It isn't critical to calculate TARGET exactly; We
2163 know we'll be doing another pass if STRETCH is non-zero. */
252b5132 2164
c842b53a 2165 if (stretch != 0
38686296
AM
2166 && sym_frag->relax_marker != fragP->relax_marker
2167 && S_GET_SEGMENT (symbolP) == segment)
252b5132 2168 {
e35a414d
AM
2169 if (stretch < 0
2170 || sym_frag->region == fragP->region)
2171 target += stretch;
e5940dff
AM
2172 /* If we get here we know we have a forward branch. This
2173 relax pass may have stretched previous instructions so
2174 far that omitting STRETCH would make the branch
2175 negative. Don't allow this in case the negative reach is
2176 large enough to require a larger branch instruction. */
2177 else if (target < address)
2178 target = fragP->fr_next->fr_address + stretch;
252b5132
RH
2179 }
2180 }
2181
2182 aim = target - address - fragP->fr_fix;
2183#ifdef TC_PCREL_ADJUST
efaf0ba4
NC
2184 /* Currently only the ns32k family needs this. */
2185 aim += TC_PCREL_ADJUST (fragP);
efaf0ba4 2186#endif
59c871b4
BE
2187
2188#ifdef md_prepare_relax_scan
2189 /* Formerly called M68K_AIM_KLUDGE. */
252b5132
RH
2190 md_prepare_relax_scan (fragP, address, aim, this_state, this_type);
2191#endif
2192
2193 if (aim < 0)
2194 {
efaf0ba4 2195 /* Look backwards. */
252b5132
RH
2196 for (next_state = this_type->rlx_more; next_state;)
2197 if (aim >= this_type->rlx_backward)
2198 next_state = 0;
2199 else
2200 {
efaf0ba4 2201 /* Grow to next state. */
252b5132
RH
2202 this_state = next_state;
2203 this_type = table + this_state;
2204 next_state = this_type->rlx_more;
2205 }
2206 }
2207 else
2208 {
efaf0ba4 2209 /* Look forwards. */
252b5132
RH
2210 for (next_state = this_type->rlx_more; next_state;)
2211 if (aim <= this_type->rlx_forward)
2212 next_state = 0;
2213 else
2214 {
efaf0ba4 2215 /* Grow to next state. */
252b5132
RH
2216 this_state = next_state;
2217 this_type = table + this_state;
2218 next_state = this_type->rlx_more;
2219 }
2220 }
2221
2222 growth = this_type->rlx_length - start_type->rlx_length;
2223 if (growth != 0)
2224 fragP->fr_subtype = this_state;
2225 return growth;
2226}
2227
efaf0ba4 2228#endif /* defined (TC_GENERIC_RELAX_TABLE) */
252b5132
RH
2229
2230/* Relax_align. Advance location counter to next address that has 'alignment'
2231 lowest order bits all 0s, return size of adjustment made. */
2232static relax_addressT
d7342424
KH
2233relax_align (register relax_addressT address, /* Address now. */
2234 register int alignment /* Alignment (binary). */)
252b5132
RH
2235{
2236 relax_addressT mask;
2237 relax_addressT new_address;
2238
2239 mask = ~((~0) << alignment);
2240 new_address = (address + mask) & (~mask);
2241#ifdef LINKER_RELAXING_SHRINKS_ONLY
2242 if (linkrelax)
2243 /* We must provide lots of padding, so the linker can discard it
2244 when needed. The linker will not add extra space, ever. */
2245 new_address += (1 << alignment);
2246#endif
2247 return (new_address - address);
2248}
2249
efaf0ba4
NC
2250/* Now we have a segment, not a crowd of sub-segments, we can make
2251 fr_address values.
58a77e41 2252
efaf0ba4 2253 Relax the frags.
58a77e41 2254
efaf0ba4
NC
2255 After this, all frags in this segment have addresses that are correct
2256 within the segment. Since segments live in different file addresses,
2257 these frag addresses may not be the same as final object-file
2258 addresses. */
2259
e46d99eb 2260int
32638454 2261relax_segment (struct frag *segment_frag_root, segT segment, int pass)
252b5132 2262{
4111faa5
NC
2263 unsigned long frag_count;
2264 struct frag *fragP;
2265 relax_addressT address;
e35a414d 2266 int region;
e46d99eb
AM
2267 int ret;
2268
efaf0ba4 2269 /* In case md_estimate_size_before_relax() wants to make fixSs. */
252b5132
RH
2270 subseg_change (segment, 0);
2271
2272 /* For each frag in segment: count and store (a 1st guess of)
2273 fr_address. */
2274 address = 0;
e35a414d 2275 region = 0;
4111faa5
NC
2276 for (frag_count = 0, fragP = segment_frag_root;
2277 fragP;
2278 fragP = fragP->fr_next, frag_count ++)
252b5132 2279 {
e35a414d 2280 fragP->region = region;
38686296 2281 fragP->relax_marker = 0;
252b5132
RH
2282 fragP->fr_address = address;
2283 address += fragP->fr_fix;
2284
2285 switch (fragP->fr_type)
2286 {
2287 case rs_fill:
2288 address += fragP->fr_offset * fragP->fr_var;
2289 break;
2290
2291 case rs_align:
2292 case rs_align_code:
0a9ef439 2293 case rs_align_test:
252b5132
RH
2294 {
2295 addressT offset = relax_align (address, (int) fragP->fr_offset);
2296
2297 if (fragP->fr_subtype != 0 && offset > fragP->fr_subtype)
2298 offset = 0;
2299
2300 if (offset % fragP->fr_var != 0)
2301 {
54d3cad9
AM
2302 as_bad_where (fragP->fr_file, fragP->fr_line,
2303 _("alignment padding (%lu bytes) not a multiple of %ld"),
2304 (unsigned long) offset, (long) fragP->fr_var);
252b5132
RH
2305 offset -= (offset % fragP->fr_var);
2306 }
2307
2308 address += offset;
e35a414d 2309 region += 1;
252b5132
RH
2310 }
2311 break;
2312
2313 case rs_org:
252b5132 2314 /* Assume .org is nugatory. It will grow with 1st relax. */
e35a414d
AM
2315 region += 1;
2316 break;
2317
2318 case rs_space:
252b5132
RH
2319 break;
2320
2321 case rs_machine_dependent:
e0890092
AM
2322 /* If fr_symbol is an expression, this call to
2323 resolve_symbol_value sets up the correct segment, which will
2324 likely be needed in md_estimate_size_before_relax. */
2325 if (fragP->fr_symbol)
2326 resolve_symbol_value (fragP->fr_symbol);
2327
252b5132
RH
2328 address += md_estimate_size_before_relax (fragP, segment);
2329 break;
2330
2331#ifndef WORKING_DOT_WORD
efaf0ba4 2332 /* Broken words don't concern us yet. */
252b5132
RH
2333 case rs_broken_word:
2334 break;
2335#endif
2336
2337 case rs_leb128:
efaf0ba4 2338 /* Initial guess is always 1; doing otherwise can result in
252b5132
RH
2339 stable solutions that are larger than the minimum. */
2340 address += fragP->fr_offset = 1;
2341 break;
2342
2343 case rs_cfa:
2344 address += eh_frame_estimate_size_before_relax (fragP);
2345 break;
2346
220e750f
RH
2347 case rs_dwarf2dbg:
2348 address += dwarf2dbg_estimate_size_before_relax (fragP);
2349 break;
2350
252b5132
RH
2351 default:
2352 BAD_CASE (fragP->fr_type);
2353 break;
efaf0ba4
NC
2354 }
2355 }
252b5132
RH
2356
2357 /* Do relax(). */
2358 {
4111faa5 2359 unsigned long max_iterations;
d1c5f158
AM
2360
2361 /* Cumulative address adjustment. */
2362 offsetT stretch;
2363
2364 /* Have we made any adjustment this pass? We can't just test
2365 stretch because one piece of code may have grown and another
2366 shrank. */
2367 int stretched;
2368
2369 /* Most horrible, but gcc may give us some exception data that
2370 is impossible to assemble, of the form
2371
2372 .align 4
2373 .byte 0, 0
2374 .uleb128 end - start
2375 start:
2376 .space 128*128 - 1
2377 .align 4
2378 end:
2379
2380 If the leb128 is two bytes in size, then end-start is 128*128,
2381 which requires a three byte leb128. If the leb128 is three
2382 bytes in size, then end-start is 128*128-1, which requires a
2383 two byte leb128. We work around this dilemma by inserting
2384 an extra 4 bytes of alignment just after the .align. This
2385 works because the data after the align is accessed relative to
2386 the end label.
2387
2388 This counter is used in a tiny state machine to detect
2389 whether a leb128 followed by an align is impossible to
2390 relax. */
2391 int rs_leb128_fudge = 0;
252b5132 2392
4111faa5
NC
2393 /* We want to prevent going into an infinite loop where one frag grows
2394 depending upon the location of a symbol which is in turn moved by
2395 the growing frag. eg:
2396
b4b24b79
AM
2397 foo = .
2398 .org foo+16
2399 foo = .
4111faa5 2400
b4b24b79 2401 So we dictate that this algorithm can be at most O2. */
4111faa5
NC
2402 max_iterations = frag_count * frag_count;
2403 /* Check for overflow. */
2404 if (max_iterations < frag_count)
2405 max_iterations = frag_count;
2406
32638454 2407 ret = 0;
252b5132
RH
2408 do
2409 {
e46d99eb
AM
2410 stretch = 0;
2411 stretched = 0;
58a77e41 2412
252b5132
RH
2413 for (fragP = segment_frag_root; fragP; fragP = fragP->fr_next)
2414 {
685736be 2415 offsetT growth = 0;
252b5132
RH
2416 addressT was_address;
2417 offsetT offset;
2418 symbolS *symbolP;
2419
38686296 2420 fragP->relax_marker ^= 1;
252b5132
RH
2421 was_address = fragP->fr_address;
2422 address = fragP->fr_address += stretch;
2423 symbolP = fragP->fr_symbol;
2424 offset = fragP->fr_offset;
2425
2426 switch (fragP->fr_type)
2427 {
efaf0ba4 2428 case rs_fill: /* .fill never relaxes. */
252b5132
RH
2429 growth = 0;
2430 break;
2431
2432#ifndef WORKING_DOT_WORD
2433 /* JF: This is RMS's idea. I do *NOT* want to be blamed
2434 for it I do not want to write it. I do not want to have
2435 anything to do with it. This is not the proper way to
2436 implement this misfeature. */
2437 case rs_broken_word:
2438 {
2439 struct broken_word *lie;
2440 struct broken_word *untruth;
2441
2442 /* Yes this is ugly (storing the broken_word pointer
2443 in the symbol slot). Still, this whole chunk of
2444 code is ugly, and I don't feel like doing anything
2445 about it. Think of it as stubbornness in action. */
2446 growth = 0;
2447 for (lie = (struct broken_word *) (fragP->fr_symbol);
2448 lie && lie->dispfrag == fragP;
2449 lie = lie->next_broken_word)
2450 {
2451
2452 if (lie->added)
2453 continue;
2454
ac62c346 2455 offset = (S_GET_VALUE (lie->add)
252b5132 2456 + lie->addnum
ac62c346 2457 - S_GET_VALUE (lie->sub));
252b5132
RH
2458 if (offset <= -32768 || offset >= 32767)
2459 {
2460 if (flag_warn_displacement)
2461 {
2462 char buf[50];
2463 sprint_value (buf, (addressT) lie->addnum);
54d3cad9
AM
2464 as_warn_where (fragP->fr_file, fragP->fr_line,
2465 _(".word %s-%s+%s didn't fit"),
2466 S_GET_NAME (lie->add),
2467 S_GET_NAME (lie->sub),
2468 buf);
252b5132 2469 }
252b5132
RH
2470 if (fragP->fr_subtype == 0)
2471 {
2472 fragP->fr_subtype++;
2473 growth += md_short_jump_size;
2474 }
187af7df
HPN
2475
2476 /* Redirect *all* words of this table with the same
2477 target, lest we have to handle the case where the
2478 same target but with a offset that fits on this
2479 round overflows at the next relaxation round. */
2480 for (untruth = (struct broken_word *) (fragP->fr_symbol);
252b5132
RH
2481 untruth && untruth->dispfrag == lie->dispfrag;
2482 untruth = untruth->next_broken_word)
49309057
ILT
2483 if ((symbol_get_frag (untruth->add)
2484 == symbol_get_frag (lie->add))
2485 && (S_GET_VALUE (untruth->add)
2486 == S_GET_VALUE (lie->add)))
252b5132
RH
2487 {
2488 untruth->added = 2;
2489 untruth->use_jump = lie;
2490 }
187af7df
HPN
2491
2492 lie->added = 1;
252b5132
RH
2493 growth += md_long_jump_size;
2494 }
2495 }
2496
2497 break;
efaf0ba4 2498 } /* case rs_broken_word */
252b5132
RH
2499#endif
2500 case rs_align:
2501 case rs_align_code:
0a9ef439 2502 case rs_align_test:
252b5132
RH
2503 {
2504 addressT oldoff, newoff;
2505
2506 oldoff = relax_align (was_address + fragP->fr_fix,
2507 (int) offset);
2508 newoff = relax_align (address + fragP->fr_fix,
2509 (int) offset);
2510
2511 if (fragP->fr_subtype != 0)
2512 {
2513 if (oldoff > fragP->fr_subtype)
2514 oldoff = 0;
2515 if (newoff > fragP->fr_subtype)
2516 newoff = 0;
2517 }
2518
2519 growth = newoff - oldoff;
d1c5f158
AM
2520
2521 /* If this align happens to follow a leb128 and
2522 we have determined that the leb128 is bouncing
2523 in size, then break the cycle by inserting an
2524 extra alignment. */
2525 if (growth < 0
2526 && (rs_leb128_fudge & 16) != 0
2527 && (rs_leb128_fudge & 15) >= 2)
2528 {
2529 segment_info_type *seginfo = seg_info (segment);
2530 struct obstack *ob = &seginfo->frchainP->frch_obstack;
2531 struct frag *newf;
2532
2533 newf = frag_alloc (ob);
2534 obstack_blank_fast (ob, fragP->fr_var);
2535 obstack_finish (ob);
2536 memcpy (newf, fragP, SIZEOF_STRUCT_FRAG);
2537 memcpy (newf->fr_literal,
2538 fragP->fr_literal + fragP->fr_fix,
2539 fragP->fr_var);
2540 newf->fr_type = rs_fill;
20f5cfbd 2541 newf->fr_address = address + fragP->fr_fix + newoff;
d1c5f158
AM
2542 newf->fr_fix = 0;
2543 newf->fr_offset = (((offsetT) 1 << fragP->fr_offset)
2544 / fragP->fr_var);
2545 if (newf->fr_offset * newf->fr_var
2546 != (offsetT) 1 << fragP->fr_offset)
2547 {
2548 newf->fr_offset = (offsetT) 1 << fragP->fr_offset;
2549 newf->fr_var = 1;
2550 }
20f5cfbd 2551 /* Include size of new frag in GROWTH. */
d1c5f158 2552 growth += newf->fr_offset * newf->fr_var;
20f5cfbd
AM
2553 /* Adjust the new frag address for the amount
2554 we'll add when we process the new frag. */
2555 newf->fr_address -= stretch + growth;
d1c5f158
AM
2556 newf->relax_marker ^= 1;
2557 fragP->fr_next = newf;
2558#ifdef DEBUG
2559 as_warn (_("padding added"));
2560#endif
2561 }
252b5132
RH
2562 }
2563 break;
2564
2565 case rs_org:
2566 {
e46d99eb
AM
2567 addressT target = offset;
2568 addressT after;
252b5132
RH
2569
2570 if (symbolP)
2571 {
b4b24b79
AM
2572 /* Convert from an actual address to an octet offset
2573 into the section. Here it is assumed that the
2574 section's VMA is zero, and can omit subtracting it
2575 from the symbol's value to get the address offset. */
2576 know (S_GET_SEGMENT (symbolP)->vma == 0);
6e917903 2577 target += S_GET_VALUE (symbolP) * OCTETS_PER_BYTE;
ac62c346 2578 }
252b5132
RH
2579
2580 know (fragP->fr_next);
6afe8e98 2581 after = fragP->fr_next->fr_address + stretch;
252b5132
RH
2582 growth = target - after;
2583 if (growth < 0)
2584 {
32638454
AM
2585 growth = 0;
2586
2587 /* Don't error on first few frag relax passes.
2588 The symbol might be an expression involving
2589 symbol values from other sections. If those
2590 sections have not yet been processed their
2591 frags will all have zero addresses, so we
2592 will calculate incorrect values for them. The
2593 number of passes we allow before giving an
2594 error is somewhat arbitrary. It should be at
2595 least one, with larger values requiring
2596 increasingly contrived dependencies between
2597 frags to trigger a false error. */
2598 if (pass < 2)
2599 {
2600 /* Force another pass. */
2601 ret = 1;
2602 break;
2603 }
2604
252b5132
RH
2605 /* Growth may be negative, but variable part of frag
2606 cannot have fewer than 0 chars. That is, we can't
efaf0ba4 2607 .org backwards. */
14ad458a 2608 as_bad_where (fragP->fr_file, fragP->fr_line,
685736be 2609 _("attempt to move .org backwards"));
14ad458a
ILT
2610
2611 /* We've issued an error message. Change the
b4b24b79 2612 frag to avoid cascading errors. */
14ad458a
ILT
2613 fragP->fr_type = rs_align;
2614 fragP->fr_subtype = 0;
2615 fragP->fr_offset = 0;
6afe8e98 2616 fragP->fr_fix = after - address;
252b5132 2617 }
252b5132 2618 }
6afe8e98 2619 break;
252b5132
RH
2620
2621 case rs_space:
54d3cad9 2622 growth = 0;
252b5132
RH
2623 if (symbolP)
2624 {
766c03c9
AM
2625 offsetT amount;
2626
2627 amount = S_GET_VALUE (symbolP);
9e40345d 2628 if (S_GET_SEGMENT (symbolP) != absolute_section
252b5132
RH
2629 || S_IS_COMMON (symbolP)
2630 || ! S_IS_DEFINED (symbolP))
252b5132 2631 {
54d3cad9
AM
2632 as_bad_where (fragP->fr_file, fragP->fr_line,
2633 _(".space specifies non-absolute value"));
2634 /* Prevent repeat of this error message. */
2635 fragP->fr_symbol = 0;
2636 }
2637 else if (amount < 0)
2638 {
32638454
AM
2639 /* Don't error on first few frag relax passes.
2640 See rs_org comment for a longer explanation. */
2641 if (pass < 2)
2642 {
2643 ret = 1;
2644 break;
2645 }
2646
54d3cad9
AM
2647 as_warn_where (fragP->fr_file, fragP->fr_line,
2648 _(".space or .fill with negative value, ignored"));
766c03c9 2649 fragP->fr_symbol = 0;
252b5132 2650 }
54d3cad9 2651 else
050be34e 2652 growth = (was_address + fragP->fr_fix + amount
54d3cad9 2653 - fragP->fr_next->fr_address);
252b5132 2654 }
252b5132
RH
2655 break;
2656
2657 case rs_machine_dependent:
2658#ifdef md_relax_frag
c842b53a 2659 growth = md_relax_frag (segment, fragP, stretch);
252b5132
RH
2660#else
2661#ifdef TC_GENERIC_RELAX_TABLE
2662 /* The default way to relax a frag is to look through
2663 TC_GENERIC_RELAX_TABLE. */
c842b53a 2664 growth = relax_frag (segment, fragP, stretch);
efaf0ba4 2665#endif /* TC_GENERIC_RELAX_TABLE */
252b5132
RH
2666#endif
2667 break;
2668
2669 case rs_leb128:
2670 {
2671 valueT value;
685736be 2672 offsetT size;
252b5132 2673
6386f3a7 2674 value = resolve_symbol_value (fragP->fr_symbol);
252b5132
RH
2675 size = sizeof_leb128 (value, fragP->fr_subtype);
2676 growth = size - fragP->fr_offset;
2677 fragP->fr_offset = size;
2678 }
2679 break;
2680
2681 case rs_cfa:
2682 growth = eh_frame_relax_frag (fragP);
2683 break;
2684
220e750f
RH
2685 case rs_dwarf2dbg:
2686 growth = dwarf2dbg_relax_frag (fragP);
2687 break;
2688
252b5132
RH
2689 default:
2690 BAD_CASE (fragP->fr_type);
2691 break;
2692 }
2693 if (growth)
2694 {
2695 stretch += growth;
e46d99eb 2696 stretched = 1;
d1c5f158
AM
2697 if (fragP->fr_type == rs_leb128)
2698 rs_leb128_fudge += 16;
2699 else if (fragP->fr_type == rs_align
2700 && (rs_leb128_fudge & 16) != 0
2701 && stretch == 0)
2702 rs_leb128_fudge += 16;
2703 else
2704 rs_leb128_fudge = 0;
252b5132 2705 }
4111faa5 2706 }
d1c5f158
AM
2707
2708 if (stretch == 0
2709 && (rs_leb128_fudge & 16) == 0
2710 && (rs_leb128_fudge & -16) != 0)
2711 rs_leb128_fudge += 1;
2712 else
2713 rs_leb128_fudge = 0;
252b5132 2714 }
4111faa5
NC
2715 /* Until nothing further to relax. */
2716 while (stretched && -- max_iterations);
2717
2718 if (stretched)
2719 as_fatal (_("Infinite loop encountered whilst attempting to compute the addresses of symbols in section %s"),
2720 segment_name (segment));
2721 }
252b5132 2722
e46d99eb
AM
2723 for (fragP = segment_frag_root; fragP; fragP = fragP->fr_next)
2724 if (fragP->last_fr_address != fragP->fr_address)
2725 {
2726 fragP->last_fr_address = fragP->fr_address;
2727 ret = 1;
2728 }
2729 return ret;
efaf0ba4 2730}
252b5132 2731
252b5132 2732void
d7342424 2733number_to_chars_bigendian (char *buf, valueT val, int n)
252b5132 2734{
937149dd 2735 if (n <= 0)
252b5132
RH
2736 abort ();
2737 while (n--)
2738 {
2739 buf[n] = val & 0xff;
2740 val >>= 8;
2741 }
2742}
2743
2744void
d7342424 2745number_to_chars_littleendian (char *buf, valueT val, int n)
252b5132 2746{
937149dd 2747 if (n <= 0)
252b5132
RH
2748 abort ();
2749 while (n--)
2750 {
2751 *buf++ = val & 0xff;
2752 val >>= 8;
2753 }
2754}
2755
2756void
d7342424 2757write_print_statistics (FILE *file)
252b5132 2758{
6d4d30bb 2759 fprintf (file, "fixups: %d\n", n_fixups);
252b5132
RH
2760}
2761
efaf0ba4 2762/* For debugging. */
252b5132
RH
2763extern int indent_level;
2764
2765void
d7342424 2766print_fixup (fixS *fixp)
252b5132
RH
2767{
2768 indent_level = 1;
d2df793a
NC
2769 fprintf (stderr, "fix ");
2770 fprintf_vma (stderr, (bfd_vma)((bfd_hostptr_t) fixp));
2771 fprintf (stderr, " %s:%d",fixp->fx_file, fixp->fx_line);
252b5132
RH
2772 if (fixp->fx_pcrel)
2773 fprintf (stderr, " pcrel");
2774 if (fixp->fx_pcrel_adjust)
2775 fprintf (stderr, " pcrel_adjust=%d", fixp->fx_pcrel_adjust);
2776 if (fixp->fx_im_disp)
2777 {
2778#ifdef TC_NS32K
2779 fprintf (stderr, " im_disp=%d", fixp->fx_im_disp);
2780#else
2781 fprintf (stderr, " im_disp");
2782#endif
2783 }
2784 if (fixp->fx_tcbit)
2785 fprintf (stderr, " tcbit");
2786 if (fixp->fx_done)
2787 fprintf (stderr, " done");
d2df793a
NC
2788 fprintf (stderr, "\n size=%d frag=", fixp->fx_size);
2789 fprintf_vma (stderr, (bfd_vma) ((bfd_hostptr_t) fixp->fx_frag));
2790 fprintf (stderr, " where=%ld offset=%lx addnumber=%lx",
2791 (long) fixp->fx_where,
0af1713e
AM
2792 (unsigned long) fixp->fx_offset,
2793 (unsigned long) fixp->fx_addnumber);
252b5132
RH
2794 fprintf (stderr, "\n %s (%d)", bfd_get_reloc_code_name (fixp->fx_r_type),
2795 fixp->fx_r_type);
252b5132
RH
2796 if (fixp->fx_addsy)
2797 {
2798 fprintf (stderr, "\n +<");
2799 print_symbol_value_1 (stderr, fixp->fx_addsy);
2800 fprintf (stderr, ">");
2801 }
2802 if (fixp->fx_subsy)
2803 {
2804 fprintf (stderr, "\n -<");
2805 print_symbol_value_1 (stderr, fixp->fx_subsy);
2806 fprintf (stderr, ">");
2807 }
2808 fprintf (stderr, "\n");
2809#ifdef TC_FIX_DATA_PRINT
2810 TC_FIX_DATA_PRINT (stderr, fixp);
2811#endif
2812}
This page took 1.083245 seconds and 4 git commands to generate.