2001-05-25 H.J. Lu <hjl@gnu.org>
[binutils.git] / bfd / elf32-m32r.c
blob1b82d9db173386d44366046a316bafcc0942536f
1 /* M32R-specific support for 32-bit ELF.
2 Copyright 1996, 1997, 1998, 1999, 2000, 2001
3 Free Software Foundation, Inc.
5 This file is part of BFD, the Binary File Descriptor library.
7 This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 2 of the License, or
10 (at your option) any later version.
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License
18 along with this program; if not, write to the Free Software
19 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
21 #include "bfd.h"
22 #include "sysdep.h"
23 #include "libbfd.h"
24 #include "elf-bfd.h"
25 #include "elf/m32r.h"
27 static bfd_reloc_status_type m32r_elf_10_pcrel_reloc
28 PARAMS ((bfd *, arelent *, asymbol *, PTR, asection *, bfd *, char **));
29 static bfd_reloc_status_type m32r_elf_do_10_pcrel_reloc
30 PARAMS ((bfd *, reloc_howto_type *, asection *,
31 bfd_byte *, bfd_vma, asection *, bfd_vma, bfd_vma));
32 static bfd_reloc_status_type m32r_elf_hi16_reloc
33 PARAMS ((bfd *, arelent *, asymbol *, PTR, asection *, bfd *, char **));
34 static void m32r_elf_relocate_hi16
35 PARAMS ((bfd *, int, Elf_Internal_Rela *, Elf_Internal_Rela *,
36 bfd_byte *, bfd_vma));
37 bfd_reloc_status_type m32r_elf_lo16_reloc
38 PARAMS ((bfd *, arelent *, asymbol *, PTR, asection *, bfd *, char **));
39 bfd_reloc_status_type m32r_elf_generic_reloc
40 PARAMS ((bfd *, arelent *, asymbol *, PTR, asection *, bfd *, char **));
41 static bfd_reloc_status_type m32r_elf_sda16_reloc
42 PARAMS ((bfd *, arelent *, asymbol *, PTR, asection *, bfd *, char **));
43 static reloc_howto_type *bfd_elf32_bfd_reloc_type_lookup
44 PARAMS ((bfd *abfd, bfd_reloc_code_real_type code));
45 static void m32r_info_to_howto_rel
46 PARAMS ((bfd *, arelent *, Elf32_Internal_Rel *));
47 boolean _bfd_m32r_elf_section_from_bfd_section
48 PARAMS ((bfd *, Elf32_Internal_Shdr *, asection *, int *));
49 void _bfd_m32r_elf_symbol_processing
50 PARAMS ((bfd *, asymbol *));
51 static boolean m32r_elf_add_symbol_hook
52 PARAMS ((bfd *, struct bfd_link_info *, const Elf_Internal_Sym *,
53 const char **, flagword *, asection **, bfd_vma *));
54 static boolean m32r_elf_relocate_section
55 PARAMS ((bfd *, struct bfd_link_info *, bfd *, asection *, bfd_byte *,
56 Elf_Internal_Rela *, Elf_Internal_Sym *, asection **));
57 #if 0 /* not yet */
58 static boolean m32r_elf_relax_delete_bytes
59 PARAMS ((bfd *, asection *, bfd_vma, int));
60 #endif
62 static bfd_reloc_status_type m32r_elf_final_sda_base
63 PARAMS ((bfd *, struct bfd_link_info *, const char **, bfd_vma *));
64 static boolean m32r_elf_object_p
65 PARAMS ((bfd *));
66 static void m32r_elf_final_write_processing
67 PARAMS ((bfd *, boolean));
68 static boolean m32r_elf_set_private_flags
69 PARAMS ((bfd *, flagword));
70 static boolean m32r_elf_copy_private_bfd_data
71 PARAMS ((bfd *, bfd *));
72 static boolean m32r_elf_merge_private_bfd_data
73 PARAMS ((bfd *, bfd *));
74 static boolean m32r_elf_print_private_bfd_data
75 PARAMS ((bfd *, PTR));
77 #define NOP_INSN 0x7000
78 #define MAKE_PARALLEL(insn) ((insn) | 0x8000)
80 /* Use REL instead of RELA to save space.
81 This only saves space in libraries and object files, but perhaps
82 relocs will be put in ROM? All in all though, REL relocs are a pain
83 to work with. */
84 #define USE_REL
86 static reloc_howto_type m32r_elf_howto_table[] =
88 /* This reloc does nothing. */
89 HOWTO (R_M32R_NONE, /* type */
90 0, /* rightshift */
91 2, /* size (0 = byte, 1 = short, 2 = long) */
92 32, /* bitsize */
93 false, /* pc_relative */
94 0, /* bitpos */
95 complain_overflow_bitfield, /* complain_on_overflow */
96 bfd_elf_generic_reloc, /* special_function */
97 "R_M32R_NONE", /* name */
98 false, /* partial_inplace */
99 0, /* src_mask */
100 0, /* dst_mask */
101 false), /* pcrel_offset */
103 /* A 16 bit absolute relocation. */
104 HOWTO (R_M32R_16, /* type */
105 0, /* rightshift */
106 1, /* size (0 = byte, 1 = short, 2 = long) */
107 16, /* bitsize */
108 false, /* pc_relative */
109 0, /* bitpos */
110 complain_overflow_bitfield, /* complain_on_overflow */
111 m32r_elf_generic_reloc,/* special_function */
112 "R_M32R_16", /* name */
113 true, /* partial_inplace */
114 0xffff, /* src_mask */
115 0xffff, /* dst_mask */
116 false), /* pcrel_offset */
118 /* A 32 bit absolute relocation. */
119 HOWTO (R_M32R_32, /* type */
120 0, /* rightshift */
121 2, /* size (0 = byte, 1 = short, 2 = long) */
122 32, /* bitsize */
123 false, /* pc_relative */
124 0, /* bitpos */
125 complain_overflow_bitfield, /* complain_on_overflow */
126 m32r_elf_generic_reloc,/* special_function */
127 "R_M32R_32", /* name */
128 true, /* partial_inplace */
129 0xffffffff, /* src_mask */
130 0xffffffff, /* dst_mask */
131 false), /* pcrel_offset */
133 /* A 24 bit address. */
134 HOWTO (R_M32R_24, /* type */
135 0, /* rightshift */
136 2, /* size (0 = byte, 1 = short, 2 = long) */
137 24, /* bitsize */
138 false, /* pc_relative */
139 0, /* bitpos */
140 complain_overflow_unsigned, /* complain_on_overflow */
141 m32r_elf_generic_reloc,/* special_function */
142 "R_M32R_24", /* name */
143 true, /* partial_inplace */
144 0xffffff, /* src_mask */
145 0xffffff, /* dst_mask */
146 false), /* pcrel_offset */
148 /* An PC Relative 10-bit relocation, shifted by 2.
149 This reloc is complicated because relocations are relative to pc & -4.
150 i.e. branches in the right insn slot use the address of the left insn
151 slot for pc. */
152 /* ??? It's not clear whether this should have partial_inplace set or not.
153 Branch relaxing in the assembler can store the addend in the insn,
154 and if bfd_install_relocation gets called the addend may get added
155 again. */
156 HOWTO (R_M32R_10_PCREL, /* type */
157 2, /* rightshift */
158 1, /* size (0 = byte, 1 = short, 2 = long) */
159 10, /* bitsize */
160 true, /* pc_relative */
161 0, /* bitpos */
162 complain_overflow_signed, /* complain_on_overflow */
163 m32r_elf_10_pcrel_reloc, /* special_function */
164 "R_M32R_10_PCREL", /* name */
165 false, /* partial_inplace */
166 0xff, /* src_mask */
167 0xff, /* dst_mask */
168 true), /* pcrel_offset */
170 /* A relative 18 bit relocation, right shifted by 2. */
171 HOWTO (R_M32R_18_PCREL, /* type */
172 2, /* rightshift */
173 2, /* size (0 = byte, 1 = short, 2 = long) */
174 16, /* bitsize */
175 true, /* pc_relative */
176 0, /* bitpos */
177 complain_overflow_signed, /* complain_on_overflow */
178 bfd_elf_generic_reloc, /* special_function */
179 "R_M32R_18_PCREL", /* name */
180 false, /* partial_inplace */
181 0xffff, /* src_mask */
182 0xffff, /* dst_mask */
183 true), /* pcrel_offset */
185 /* A relative 26 bit relocation, right shifted by 2. */
186 /* ??? It's not clear whether this should have partial_inplace set or not.
187 Branch relaxing in the assembler can store the addend in the insn,
188 and if bfd_install_relocation gets called the addend may get added
189 again. */
190 HOWTO (R_M32R_26_PCREL, /* type */
191 2, /* rightshift */
192 2, /* size (0 = byte, 1 = short, 2 = long) */
193 26, /* bitsize */
194 true, /* pc_relative */
195 0, /* bitpos */
196 complain_overflow_signed, /* complain_on_overflow */
197 bfd_elf_generic_reloc, /* special_function */
198 "R_M32R_26_PCREL", /* name */
199 false, /* partial_inplace */
200 0xffffff, /* src_mask */
201 0xffffff, /* dst_mask */
202 true), /* pcrel_offset */
204 /* High 16 bits of address when lower 16 is or'd in. */
205 HOWTO (R_M32R_HI16_ULO, /* type */
206 16, /* rightshift */
207 2, /* size (0 = byte, 1 = short, 2 = long) */
208 16, /* bitsize */
209 false, /* pc_relative */
210 0, /* bitpos */
211 complain_overflow_dont, /* complain_on_overflow */
212 m32r_elf_hi16_reloc, /* special_function */
213 "R_M32R_HI16_ULO", /* name */
214 true, /* partial_inplace */
215 0x0000ffff, /* src_mask */
216 0x0000ffff, /* dst_mask */
217 false), /* pcrel_offset */
219 /* High 16 bits of address when lower 16 is added in. */
220 HOWTO (R_M32R_HI16_SLO, /* type */
221 16, /* rightshift */
222 2, /* size (0 = byte, 1 = short, 2 = long) */
223 16, /* bitsize */
224 false, /* pc_relative */
225 0, /* bitpos */
226 complain_overflow_dont, /* complain_on_overflow */
227 m32r_elf_hi16_reloc, /* special_function */
228 "R_M32R_HI16_SLO", /* name */
229 true, /* partial_inplace */
230 0x0000ffff, /* src_mask */
231 0x0000ffff, /* dst_mask */
232 false), /* pcrel_offset */
234 /* Lower 16 bits of address. */
235 HOWTO (R_M32R_LO16, /* type */
236 0, /* rightshift */
237 2, /* size (0 = byte, 1 = short, 2 = long) */
238 16, /* bitsize */
239 false, /* pc_relative */
240 0, /* bitpos */
241 complain_overflow_dont, /* complain_on_overflow */
242 m32r_elf_lo16_reloc, /* special_function */
243 "R_M32R_LO16", /* name */
244 true, /* partial_inplace */
245 0x0000ffff, /* src_mask */
246 0x0000ffff, /* dst_mask */
247 false), /* pcrel_offset */
249 /* Small data area 16 bits offset. */
250 HOWTO (R_M32R_SDA16, /* type */
251 0, /* rightshift */
252 2, /* size (0 = byte, 1 = short, 2 = long) */
253 16, /* bitsize */
254 false, /* pc_relative */
255 0, /* bitpos */
256 complain_overflow_signed, /* complain_on_overflow */
257 m32r_elf_sda16_reloc, /* special_function */
258 "R_M32R_SDA16", /* name */
259 true, /* partial_inplace */ /* FIXME: correct? */
260 0x0000ffff, /* src_mask */
261 0x0000ffff, /* dst_mask */
262 false), /* pcrel_offset */
264 /* GNU extension to record C++ vtable hierarchy */
265 HOWTO (R_M32R_GNU_VTINHERIT, /* type */
266 0, /* rightshift */
267 2, /* size (0 = byte, 1 = short, 2 = long) */
268 0, /* bitsize */
269 false, /* pc_relative */
270 0, /* bitpos */
271 complain_overflow_dont, /* complain_on_overflow */
272 NULL, /* special_function */
273 "R_M32R_GNU_VTINHERIT", /* name */
274 false, /* partial_inplace */
275 0, /* src_mask */
276 0, /* dst_mask */
277 false), /* pcrel_offset */
279 /* GNU extension to record C++ vtable member usage */
280 HOWTO (R_M32R_GNU_VTENTRY, /* type */
281 0, /* rightshift */
282 2, /* size (0 = byte, 1 = short, 2 = long) */
283 0, /* bitsize */
284 false, /* pc_relative */
285 0, /* bitpos */
286 complain_overflow_dont, /* complain_on_overflow */
287 _bfd_elf_rel_vtable_reloc_fn, /* special_function */
288 "R_M32R_GNU_VTENTRY", /* name */
289 false, /* partial_inplace */
290 0, /* src_mask */
291 0, /* dst_mask */
292 false), /* pcrel_offset */
296 /* Handle the R_M32R_10_PCREL reloc. */
298 static bfd_reloc_status_type
299 m32r_elf_10_pcrel_reloc (abfd, reloc_entry, symbol, data,
300 input_section, output_bfd, error_message)
301 bfd * abfd;
302 arelent * reloc_entry;
303 asymbol * symbol;
304 PTR data;
305 asection * input_section;
306 bfd * output_bfd;
307 char ** error_message ATTRIBUTE_UNUSED;
309 /* This part is from bfd_elf_generic_reloc. */
310 if (output_bfd != (bfd *) NULL
311 && (symbol->flags & BSF_SECTION_SYM) == 0
312 && (! reloc_entry->howto->partial_inplace
313 || reloc_entry->addend == 0))
315 reloc_entry->address += input_section->output_offset;
316 return bfd_reloc_ok;
319 if (output_bfd != NULL)
321 /* FIXME: See bfd_perform_relocation. Is this right? */
322 return bfd_reloc_continue;
325 return m32r_elf_do_10_pcrel_reloc (abfd, reloc_entry->howto,
326 input_section,
327 data, reloc_entry->address,
328 symbol->section,
329 (symbol->value
330 + symbol->section->output_section->vma
331 + symbol->section->output_offset),
332 reloc_entry->addend);
335 /* Utility to actually perform an R_M32R_10_PCREL reloc. */
337 static bfd_reloc_status_type
338 m32r_elf_do_10_pcrel_reloc (abfd, howto, input_section, data, offset,
339 symbol_section, symbol_value, addend)
340 bfd *abfd;
341 reloc_howto_type *howto;
342 asection *input_section;
343 bfd_byte *data;
344 bfd_vma offset;
345 asection *symbol_section ATTRIBUTE_UNUSED;
346 bfd_vma symbol_value;
347 bfd_vma addend;
349 bfd_signed_vma relocation;
350 unsigned long x;
351 bfd_reloc_status_type status;
353 /* Sanity check the address (offset in section). */
354 if (offset > input_section->_cooked_size)
355 return bfd_reloc_outofrange;
357 relocation = symbol_value + addend;
358 /* Make it pc relative. */
359 relocation -= (input_section->output_section->vma
360 + input_section->output_offset);
361 /* These jumps mask off the lower two bits of the current address
362 before doing pcrel calculations. */
363 relocation -= (offset & -4L);
365 if (relocation < -0x200 || relocation > 0x1ff)
366 status = bfd_reloc_overflow;
367 else
368 status = bfd_reloc_ok;
370 x = bfd_get_16 (abfd, data + offset);
371 relocation >>= howto->rightshift;
372 relocation <<= howto->bitpos;
373 x = (x & ~howto->dst_mask) | (((x & howto->src_mask) + relocation) & howto->dst_mask);
374 bfd_put_16 (abfd, x, data + offset);
376 return status;
379 /* Handle the R_M32R_HI16_[SU]LO relocs.
380 HI16_SLO is for the add3 and load/store with displacement instructions.
381 HI16_ULO is for the or3 instruction.
382 For R_M32R_HI16_SLO, the lower 16 bits are sign extended when added to
383 the high 16 bytes so if the lower 16 bits are negative (bit 15 == 1) then
384 we must add one to the high 16 bytes (which will get subtracted off when
385 the low 16 bits are added).
386 These relocs have to be done in combination with an R_M32R_LO16 reloc
387 because there is a carry from the LO16 to the HI16. Here we just save
388 the information we need; we do the actual relocation when we see the LO16.
389 This code is copied from the elf32-mips.c. We also support an arbitrary
390 number of HI16 relocs to be associated with a single LO16 reloc. The
391 assembler sorts the relocs to ensure each HI16 immediately precedes its
392 LO16. However if there are multiple copies, the assembler may not find
393 the real LO16 so it picks the first one it finds. */
395 struct m32r_hi16
397 struct m32r_hi16 *next;
398 bfd_byte *addr;
399 bfd_vma addend;
402 /* FIXME: This should not be a static variable. */
404 static struct m32r_hi16 *m32r_hi16_list;
406 static bfd_reloc_status_type
407 m32r_elf_hi16_reloc (abfd, reloc_entry, symbol, data,
408 input_section, output_bfd, error_message)
409 bfd *abfd ATTRIBUTE_UNUSED;
410 arelent *reloc_entry;
411 asymbol *symbol;
412 PTR data;
413 asection *input_section;
414 bfd *output_bfd;
415 char **error_message ATTRIBUTE_UNUSED;
417 bfd_reloc_status_type ret;
418 bfd_vma relocation;
419 struct m32r_hi16 *n;
421 /* This part is from bfd_elf_generic_reloc.
422 If we're relocating, and this an external symbol, we don't want
423 to change anything. */
424 if (output_bfd != (bfd *) NULL
425 && (symbol->flags & BSF_SECTION_SYM) == 0
426 && reloc_entry->addend == 0)
428 reloc_entry->address += input_section->output_offset;
429 return bfd_reloc_ok;
432 /* Sanity check the address (offset in section). */
433 if (reloc_entry->address > input_section->_cooked_size)
434 return bfd_reloc_outofrange;
436 ret = bfd_reloc_ok;
437 if (bfd_is_und_section (symbol->section)
438 && output_bfd == (bfd *) NULL)
439 ret = bfd_reloc_undefined;
441 if (bfd_is_com_section (symbol->section))
442 relocation = 0;
443 else
444 relocation = symbol->value;
446 relocation += symbol->section->output_section->vma;
447 relocation += symbol->section->output_offset;
448 relocation += reloc_entry->addend;
450 /* Save the information, and let LO16 do the actual relocation. */
451 n = (struct m32r_hi16 *) bfd_malloc (sizeof *n);
452 if (n == NULL)
453 return bfd_reloc_outofrange;
454 n->addr = (bfd_byte *) data + reloc_entry->address;
455 n->addend = relocation;
456 n->next = m32r_hi16_list;
457 m32r_hi16_list = n;
459 if (output_bfd != (bfd *) NULL)
460 reloc_entry->address += input_section->output_offset;
462 return ret;
465 /* Handle an M32R ELF HI16 reloc. */
467 static void
468 m32r_elf_relocate_hi16 (input_bfd, type, relhi, rello, contents, addend)
469 bfd *input_bfd;
470 int type;
471 Elf_Internal_Rela *relhi;
472 Elf_Internal_Rela *rello;
473 bfd_byte *contents;
474 bfd_vma addend;
476 unsigned long insn;
477 bfd_vma addlo;
479 insn = bfd_get_32 (input_bfd, contents + relhi->r_offset);
481 addlo = bfd_get_32 (input_bfd, contents + rello->r_offset);
482 if (type == R_M32R_HI16_SLO)
483 addlo = ((addlo & 0xffff) ^ 0x8000) - 0x8000;
484 else
485 addlo &= 0xffff;
487 addend += ((insn & 0xffff) << 16) + addlo;
489 /* Reaccount for sign extension of low part. */
490 if (type == R_M32R_HI16_SLO
491 && (addend & 0x8000) != 0)
492 addend += 0x10000;
494 bfd_put_32 (input_bfd,
495 (insn & 0xffff0000) | ((addend >> 16) & 0xffff),
496 contents + relhi->r_offset);
499 /* Do an R_M32R_LO16 relocation. This is a straightforward 16 bit
500 inplace relocation; this function exists in order to do the
501 R_M32R_HI16_[SU]LO relocation described above. */
503 bfd_reloc_status_type
504 m32r_elf_lo16_reloc (input_bfd, reloc_entry, symbol, data,
505 input_section, output_bfd, error_message)
506 bfd *input_bfd;
507 arelent *reloc_entry;
508 asymbol *symbol;
509 PTR data;
510 asection *input_section;
511 bfd *output_bfd;
512 char **error_message;
514 /* This part is from bfd_elf_generic_reloc.
515 If we're relocating, and this an external symbol, we don't want
516 to change anything. */
517 if (output_bfd != (bfd *) NULL
518 && (symbol->flags & BSF_SECTION_SYM) == 0
519 && reloc_entry->addend == 0)
521 reloc_entry->address += input_section->output_offset;
522 return bfd_reloc_ok;
525 if (m32r_hi16_list != NULL)
527 struct m32r_hi16 *l;
529 l = m32r_hi16_list;
530 while (l != NULL)
532 unsigned long insn;
533 unsigned long val;
534 unsigned long vallo;
535 struct m32r_hi16 *next;
537 /* Do the HI16 relocation. Note that we actually don't need
538 to know anything about the LO16 itself, except where to
539 find the low 16 bits of the addend needed by the LO16. */
540 insn = bfd_get_32 (input_bfd, l->addr);
541 vallo = ((bfd_get_32 (input_bfd, (bfd_byte *) data + reloc_entry->address)
542 & 0xffff) ^ 0x8000) - 0x8000;
543 val = ((insn & 0xffff) << 16) + vallo;
544 val += l->addend;
546 /* Reaccount for sign extension of low part. */
547 if ((val & 0x8000) != 0)
548 val += 0x10000;
550 insn = (insn &~ 0xffff) | ((val >> 16) & 0xffff);
551 bfd_put_32 (input_bfd, insn, l->addr);
553 next = l->next;
554 free (l);
555 l = next;
558 m32r_hi16_list = NULL;
561 /* Now do the LO16 reloc in the usual way.
562 ??? It would be nice to call bfd_elf_generic_reloc here,
563 but we have partial_inplace == TRUE. bfd_elf_generic_reloc will
564 pass the handling back to bfd_install_relocation which will install
565 a section relative addend which is wrong. */
566 return m32r_elf_generic_reloc (input_bfd, reloc_entry, symbol, data,
567 input_section, output_bfd, error_message);
570 /* Do generic partial_inplace relocation.
571 This is a local replacement for bfd_elf_generic_reloc. */
573 bfd_reloc_status_type
574 m32r_elf_generic_reloc (input_bfd, reloc_entry, symbol, data,
575 input_section, output_bfd, error_message)
576 bfd *input_bfd;
577 arelent *reloc_entry;
578 asymbol *symbol;
579 PTR data;
580 asection *input_section;
581 bfd *output_bfd;
582 char **error_message ATTRIBUTE_UNUSED;
584 bfd_reloc_status_type ret;
585 bfd_vma relocation;
586 bfd_byte *inplace_address;
588 /* This part is from bfd_elf_generic_reloc.
589 If we're relocating, and this an external symbol, we don't want
590 to change anything. */
591 if (output_bfd != (bfd *) NULL
592 && (symbol->flags & BSF_SECTION_SYM) == 0
593 && reloc_entry->addend == 0)
595 reloc_entry->address += input_section->output_offset;
596 return bfd_reloc_ok;
599 /* Now do the the reloc in the usual way.
600 ??? It would be nice to call bfd_elf_generic_reloc here,
601 but we have partial_inplace == TRUE. bfd_elf_generic_reloc will
602 pass the handling back to bfd_install_relocation which will install
603 a section relative addend which is wrong. */
605 /* Sanity check the address (offset in section). */
606 if (reloc_entry->address > input_section->_cooked_size)
607 return bfd_reloc_outofrange;
609 ret = bfd_reloc_ok;
610 if (bfd_is_und_section (symbol->section)
611 && output_bfd == (bfd *) NULL)
612 ret = bfd_reloc_undefined;
614 if (bfd_is_com_section (symbol->section)
615 || output_bfd != (bfd *) NULL)
616 relocation = 0;
617 else
618 relocation = symbol->value;
620 /* Only do this for a final link. */
621 if (output_bfd == (bfd *) NULL)
623 relocation += symbol->section->output_section->vma;
624 relocation += symbol->section->output_offset;
627 relocation += reloc_entry->addend;
628 inplace_address = (bfd_byte *) data + reloc_entry->address;
630 #define DOIT(x) \
631 x = ( (x & ~reloc_entry->howto->dst_mask) | \
632 (((x & reloc_entry->howto->src_mask) + relocation) & \
633 reloc_entry->howto->dst_mask))
635 switch (reloc_entry->howto->size)
637 case 1:
639 short x = bfd_get_16 (input_bfd, inplace_address);
640 DOIT (x);
641 bfd_put_16 (input_bfd, x, inplace_address);
643 break;
644 case 2:
646 unsigned long x = bfd_get_32 (input_bfd, inplace_address);
647 DOIT (x);
648 bfd_put_32 (input_bfd, x, inplace_address);
650 break;
651 default:
652 BFD_ASSERT (0);
655 if (output_bfd != (bfd *) NULL)
656 reloc_entry->address += input_section->output_offset;
658 return ret;
661 /* Handle the R_M32R_SDA16 reloc.
662 This reloc is used to compute the address of objects in the small data area
663 and to perform loads and stores from that area.
664 The lower 16 bits are sign extended and added to the register specified
665 in the instruction, which is assumed to point to _SDA_BASE_. */
667 static bfd_reloc_status_type
668 m32r_elf_sda16_reloc (abfd, reloc_entry, symbol, data,
669 input_section, output_bfd, error_message)
670 bfd *abfd ATTRIBUTE_UNUSED;
671 arelent *reloc_entry;
672 asymbol *symbol;
673 PTR data ATTRIBUTE_UNUSED;
674 asection *input_section;
675 bfd *output_bfd;
676 char **error_message ATTRIBUTE_UNUSED;
678 /* This part is from bfd_elf_generic_reloc. */
679 if (output_bfd != (bfd *) NULL
680 && (symbol->flags & BSF_SECTION_SYM) == 0
681 && (! reloc_entry->howto->partial_inplace
682 || reloc_entry->addend == 0))
684 reloc_entry->address += input_section->output_offset;
685 return bfd_reloc_ok;
688 if (output_bfd != NULL)
690 /* FIXME: See bfd_perform_relocation. Is this right? */
691 return bfd_reloc_continue;
694 /* FIXME: not sure what to do here yet. But then again, the linker
695 may never call us. */
696 abort ();
699 /* Map BFD reloc types to M32R ELF reloc types. */
701 struct m32r_reloc_map
703 bfd_reloc_code_real_type bfd_reloc_val;
704 unsigned char elf_reloc_val;
707 static const struct m32r_reloc_map m32r_reloc_map[] =
709 { BFD_RELOC_NONE, R_M32R_NONE },
710 { BFD_RELOC_16, R_M32R_16 },
711 { BFD_RELOC_32, R_M32R_32 },
712 { BFD_RELOC_M32R_24, R_M32R_24 },
713 { BFD_RELOC_M32R_10_PCREL, R_M32R_10_PCREL },
714 { BFD_RELOC_M32R_18_PCREL, R_M32R_18_PCREL },
715 { BFD_RELOC_M32R_26_PCREL, R_M32R_26_PCREL },
716 { BFD_RELOC_M32R_HI16_ULO, R_M32R_HI16_ULO },
717 { BFD_RELOC_M32R_HI16_SLO, R_M32R_HI16_SLO },
718 { BFD_RELOC_M32R_LO16, R_M32R_LO16 },
719 { BFD_RELOC_M32R_SDA16, R_M32R_SDA16 },
720 { BFD_RELOC_VTABLE_INHERIT, R_M32R_GNU_VTINHERIT },
721 { BFD_RELOC_VTABLE_ENTRY, R_M32R_GNU_VTENTRY },
724 static reloc_howto_type *
725 bfd_elf32_bfd_reloc_type_lookup (abfd, code)
726 bfd *abfd ATTRIBUTE_UNUSED;
727 bfd_reloc_code_real_type code;
729 unsigned int i;
731 for (i = 0;
732 i < sizeof (m32r_reloc_map) / sizeof (struct m32r_reloc_map);
733 i++)
735 if (m32r_reloc_map[i].bfd_reloc_val == code)
736 return &m32r_elf_howto_table[m32r_reloc_map[i].elf_reloc_val];
739 return NULL;
742 /* Set the howto pointer for an M32R ELF reloc. */
744 static void
745 m32r_info_to_howto_rel (abfd, cache_ptr, dst)
746 bfd *abfd ATTRIBUTE_UNUSED;
747 arelent *cache_ptr;
748 Elf32_Internal_Rel *dst;
750 unsigned int r_type;
752 r_type = ELF32_R_TYPE (dst->r_info);
753 BFD_ASSERT (r_type < (unsigned int) R_M32R_max);
754 cache_ptr->howto = &m32r_elf_howto_table[r_type];
757 /* Given a BFD section, try to locate the corresponding ELF section
758 index. */
760 boolean
761 _bfd_m32r_elf_section_from_bfd_section (abfd, hdr, sec, retval)
762 bfd *abfd ATTRIBUTE_UNUSED;
763 Elf32_Internal_Shdr *hdr ATTRIBUTE_UNUSED;
764 asection *sec;
765 int *retval;
767 if (strcmp (bfd_get_section_name (abfd, sec), ".scommon") == 0)
769 *retval = SHN_M32R_SCOMMON;
770 return true;
772 return false;
775 /* M32R ELF uses two common sections. One is the usual one, and the other
776 is for small objects. All the small objects are kept together, and then
777 referenced via one register, which yields faster assembler code. It is
778 up to the compiler to emit an instruction to load the register with
779 _SDA_BASE. This is what we use for the small common section. This
780 approach is copied from elf32-mips.c. */
781 static asection m32r_elf_scom_section;
782 static asymbol m32r_elf_scom_symbol;
783 static asymbol *m32r_elf_scom_symbol_ptr;
785 /* Handle the special M32R section numbers that a symbol may use. */
787 void
788 _bfd_m32r_elf_symbol_processing (abfd, asym)
789 bfd *abfd ATTRIBUTE_UNUSED;
790 asymbol *asym;
792 elf_symbol_type *elfsym;
794 elfsym = (elf_symbol_type *) asym;
796 switch (elfsym->internal_elf_sym.st_shndx)
798 case SHN_M32R_SCOMMON:
799 if (m32r_elf_scom_section.name == NULL)
801 /* Initialize the small common section. */
802 m32r_elf_scom_section.name = ".scommon";
803 m32r_elf_scom_section.flags = SEC_IS_COMMON;
804 m32r_elf_scom_section.output_section = &m32r_elf_scom_section;
805 m32r_elf_scom_section.symbol = &m32r_elf_scom_symbol;
806 m32r_elf_scom_section.symbol_ptr_ptr = &m32r_elf_scom_symbol_ptr;
807 m32r_elf_scom_symbol.name = ".scommon";
808 m32r_elf_scom_symbol.flags = BSF_SECTION_SYM;
809 m32r_elf_scom_symbol.section = &m32r_elf_scom_section;
810 m32r_elf_scom_symbol_ptr = &m32r_elf_scom_symbol;
812 asym->section = &m32r_elf_scom_section;
813 asym->value = elfsym->internal_elf_sym.st_size;
814 break;
818 /* Hook called by the linker routine which adds symbols from an object
819 file. We must handle the special M32R section numbers here.
820 We also keep watching for whether we need to create the sdata special
821 linker sections. */
823 static boolean
824 m32r_elf_add_symbol_hook (abfd, info, sym, namep, flagsp, secp, valp)
825 bfd *abfd;
826 struct bfd_link_info *info;
827 const Elf_Internal_Sym *sym;
828 const char **namep;
829 flagword *flagsp ATTRIBUTE_UNUSED;
830 asection **secp;
831 bfd_vma *valp;
833 if (! info->relocateable
834 && (*namep)[0] == '_' && (*namep)[1] == 'S'
835 && strcmp (*namep, "_SDA_BASE_") == 0)
837 /* This is simpler than using _bfd_elf_create_linker_section
838 (our needs are simpler than ppc's needs). Also
839 _bfd_elf_create_linker_section currently has a bug where if a .sdata
840 section already exists a new one is created that follows it which
841 screws of _SDA_BASE_ address calcs because output_offset != 0. */
842 struct elf_link_hash_entry *h;
843 asection *s = bfd_get_section_by_name (abfd, ".sdata");
845 /* The following code was cobbled from elf32-ppc.c and elflink.c. */
847 if (s == NULL)
849 int flags = (SEC_ALLOC | SEC_LOAD | SEC_HAS_CONTENTS
850 | SEC_IN_MEMORY | SEC_LINKER_CREATED);
852 s = bfd_make_section_anyway (abfd, ".sdata");
853 if (s == NULL)
854 return false;
855 bfd_set_section_flags (abfd, s, flags);
856 bfd_set_section_alignment (abfd, s, 2);
859 h = (struct elf_link_hash_entry *)
860 bfd_link_hash_lookup (info->hash, "_SDA_BASE_", false, false, false);
862 if ((h == NULL || h->root.type == bfd_link_hash_undefined)
863 && !(_bfd_generic_link_add_one_symbol (info,
864 abfd,
865 "_SDA_BASE_",
866 BSF_GLOBAL,
868 32768,
869 (const char *) NULL,
870 false,
871 get_elf_backend_data (abfd)->collect,
872 (struct bfd_link_hash_entry **) &h)))
873 return false;
874 h->type = STT_OBJECT;
877 switch (sym->st_shndx)
879 case SHN_M32R_SCOMMON:
880 *secp = bfd_make_section_old_way (abfd, ".scommon");
881 (*secp)->flags |= SEC_IS_COMMON;
882 *valp = sym->st_size;
883 break;
886 return true;
889 /* We have to figure out the SDA_BASE value, so that we can adjust the
890 symbol value correctly. We look up the symbol _SDA_BASE_ in the output
891 BFD. If we can't find it, we're stuck. We cache it in the ELF
892 target data. We don't need to adjust the symbol value for an
893 external symbol if we are producing relocateable output. */
895 static bfd_reloc_status_type
896 m32r_elf_final_sda_base (output_bfd, info, error_message, psb)
897 bfd *output_bfd;
898 struct bfd_link_info *info;
899 const char **error_message;
900 bfd_vma *psb;
902 if (elf_gp (output_bfd) == 0)
904 struct bfd_link_hash_entry *h;
906 h = bfd_link_hash_lookup (info->hash, "_SDA_BASE_", false, false, true);
907 if (h != (struct bfd_link_hash_entry *) NULL
908 && h->type == bfd_link_hash_defined)
909 elf_gp (output_bfd) = (h->u.def.value
910 + h->u.def.section->output_section->vma
911 + h->u.def.section->output_offset);
912 else
914 /* Only get the error once. */
915 *psb = elf_gp (output_bfd) = 4;
916 *error_message =
917 (const char *) _("SDA relocation when _SDA_BASE_ not defined");
918 return bfd_reloc_dangerous;
921 *psb = elf_gp (output_bfd);
922 return bfd_reloc_ok;
925 /* Relocate an M32R/D ELF section.
926 There is some attempt to make this function usable for many architectures,
927 both USE_REL and USE_RELA ['twould be nice if such a critter existed],
928 if only to serve as a learning tool.
930 The RELOCATE_SECTION function is called by the new ELF backend linker
931 to handle the relocations for a section.
933 The relocs are always passed as Rela structures; if the section
934 actually uses Rel structures, the r_addend field will always be
935 zero.
937 This function is responsible for adjust the section contents as
938 necessary, and (if using Rela relocs and generating a
939 relocateable output file) adjusting the reloc addend as
940 necessary.
942 This function does not have to worry about setting the reloc
943 address or the reloc symbol index.
945 LOCAL_SYMS is a pointer to the swapped in local symbols.
947 LOCAL_SECTIONS is an array giving the section in the input file
948 corresponding to the st_shndx field of each local symbol.
950 The global hash table entry for the global symbols can be found
951 via elf_sym_hashes (input_bfd).
953 When generating relocateable output, this function must handle
954 STB_LOCAL/STT_SECTION symbols specially. The output symbol is
955 going to be the section symbol corresponding to the output
956 section, which means that the addend must be adjusted
957 accordingly. */
959 static boolean
960 m32r_elf_relocate_section (output_bfd, info, input_bfd, input_section,
961 contents, relocs, local_syms, local_sections)
962 bfd *output_bfd ATTRIBUTE_UNUSED;
963 struct bfd_link_info *info;
964 bfd *input_bfd;
965 asection *input_section;
966 bfd_byte *contents;
967 Elf_Internal_Rela *relocs;
968 Elf_Internal_Sym *local_syms;
969 asection **local_sections;
971 Elf_Internal_Shdr *symtab_hdr = &elf_tdata (input_bfd)->symtab_hdr;
972 struct elf_link_hash_entry **sym_hashes = elf_sym_hashes (input_bfd);
973 Elf_Internal_Rela *rel, *relend;
974 /* Assume success. */
975 boolean ret = true;
977 rel = relocs;
978 relend = relocs + input_section->reloc_count;
979 for (; rel < relend; rel++)
981 int r_type;
982 reloc_howto_type *howto;
983 unsigned long r_symndx;
984 /* We can't modify r_addend here as elf_link_input_bfd has an assert to
985 ensure it's zero (we use REL relocs, not RELA). Therefore this
986 should be assigning zero to `addend', but for clarity we use
987 `r_addend'. */
988 bfd_vma addend = rel->r_addend;
989 bfd_vma offset = rel->r_offset;
990 struct elf_link_hash_entry *h;
991 Elf_Internal_Sym *sym;
992 asection *sec;
993 const char *sym_name;
994 bfd_reloc_status_type r;
995 const char *errmsg = NULL;
997 h = NULL;
998 r_type = ELF32_R_TYPE (rel->r_info);
999 if (r_type < 0 || r_type >= (int) R_M32R_max)
1001 (*_bfd_error_handler) (_("%s: unknown relocation type %d"),
1002 bfd_get_filename (input_bfd),
1003 (int) r_type);
1004 bfd_set_error (bfd_error_bad_value);
1005 ret = false;
1006 continue;
1009 if (r_type == R_M32R_GNU_VTENTRY
1010 || r_type == R_M32R_GNU_VTINHERIT)
1011 continue;
1013 howto = m32r_elf_howto_table + r_type;
1014 r_symndx = ELF32_R_SYM (rel->r_info);
1016 if (info->relocateable)
1018 /* This is a relocateable link. We don't have to change
1019 anything, unless the reloc is against a section symbol,
1020 in which case we have to adjust according to where the
1021 section symbol winds up in the output section. */
1022 sec = NULL;
1023 if (r_symndx >= symtab_hdr->sh_info)
1025 /* External symbol. */
1026 continue;
1029 /* Local symbol. */
1030 sym = local_syms + r_symndx;
1031 sym_name = "<local symbol>";
1032 /* STT_SECTION: symbol is associated with a section. */
1033 if (ELF_ST_TYPE (sym->st_info) != STT_SECTION)
1035 /* Symbol isn't associated with a section. Nothing to do. */
1036 continue;
1039 sec = local_sections[r_symndx];
1040 addend += sec->output_offset + sym->st_value;
1041 #ifndef USE_REL
1042 /* This can't be done for USE_REL because it doesn't mean anything
1043 and elf_link_input_bfd asserts this stays zero. */
1044 rel->r_addend = addend;
1045 #endif
1047 #ifndef USE_REL
1048 /* Addends are stored with relocs. We're done. */
1049 continue;
1050 #else /* USE_REL */
1051 /* If partial_inplace, we need to store any additional addend
1052 back in the section. */
1053 if (! howto->partial_inplace)
1054 continue;
1055 /* ??? Here is a nice place to call a special_function
1056 like handler. */
1057 if (r_type != R_M32R_HI16_SLO && r_type != R_M32R_HI16_ULO)
1058 r = _bfd_relocate_contents (howto, input_bfd,
1059 addend, contents + offset);
1060 else
1062 Elf_Internal_Rela *lorel;
1064 /* We allow an arbitrary number of HI16 relocs before the
1065 LO16 reloc. This permits gcc to emit the HI and LO relocs
1066 itself. */
1067 for (lorel = rel + 1;
1068 (lorel < relend
1069 && (ELF32_R_TYPE (lorel->r_info) == R_M32R_HI16_SLO
1070 || ELF32_R_TYPE (lorel->r_info) == R_M32R_HI16_ULO));
1071 lorel++)
1072 continue;
1073 if (lorel < relend
1074 && ELF32_R_TYPE (lorel->r_info) == R_M32R_LO16)
1076 m32r_elf_relocate_hi16 (input_bfd, r_type, rel, lorel,
1077 contents, addend);
1078 r = bfd_reloc_ok;
1080 else
1081 r = _bfd_relocate_contents (howto, input_bfd,
1082 addend, contents + offset);
1084 #endif /* USE_REL */
1086 else
1088 bfd_vma relocation;
1090 /* This is a final link. */
1091 sym = NULL;
1092 sec = NULL;
1094 if (r_symndx < symtab_hdr->sh_info)
1096 /* Local symbol. */
1097 sym = local_syms + r_symndx;
1098 sec = local_sections[r_symndx];
1099 sym_name = "<local symbol>";
1100 relocation = (sec->output_section->vma
1101 + sec->output_offset
1102 + sym->st_value);
1104 else
1106 /* External symbol. */
1107 h = sym_hashes[r_symndx - symtab_hdr->sh_info];
1108 while (h->root.type == bfd_link_hash_indirect
1109 || h->root.type == bfd_link_hash_warning)
1110 h = (struct elf_link_hash_entry *) h->root.u.i.link;
1111 sym_name = h->root.root.string;
1113 if (h->root.type == bfd_link_hash_defined
1114 || h->root.type == bfd_link_hash_defweak)
1116 sec = h->root.u.def.section;
1117 if (sec->output_section == NULL)
1118 relocation = 0;
1119 else
1120 relocation = (h->root.u.def.value
1121 + sec->output_section->vma
1122 + sec->output_offset);
1124 else if (h->root.type == bfd_link_hash_undefweak)
1125 relocation = 0;
1126 else
1128 if (! ((*info->callbacks->undefined_symbol)
1129 (info, h->root.root.string, input_bfd,
1130 input_section, offset, true)))
1131 return false;
1132 relocation = 0;
1136 /* Sanity check the address. */
1137 if (offset > input_section->_raw_size)
1139 r = bfd_reloc_outofrange;
1140 goto check_reloc;
1143 switch ((int) r_type)
1145 case (int) R_M32R_10_PCREL :
1146 r = m32r_elf_do_10_pcrel_reloc (input_bfd, howto, input_section,
1147 contents, offset,
1148 sec, relocation, addend);
1149 break;
1151 case (int) R_M32R_HI16_SLO :
1152 case (int) R_M32R_HI16_ULO :
1154 Elf_Internal_Rela *lorel;
1156 /* We allow an arbitrary number of HI16 relocs before the
1157 LO16 reloc. This permits gcc to emit the HI and LO relocs
1158 itself. */
1159 for (lorel = rel + 1;
1160 (lorel < relend
1161 && (ELF32_R_TYPE (lorel->r_info) == R_M32R_HI16_SLO
1162 || ELF32_R_TYPE (lorel->r_info) == R_M32R_HI16_ULO));
1163 lorel++)
1164 continue;
1165 if (lorel < relend
1166 && ELF32_R_TYPE (lorel->r_info) == R_M32R_LO16)
1168 m32r_elf_relocate_hi16 (input_bfd, r_type, rel, lorel,
1169 contents, relocation + addend);
1170 r = bfd_reloc_ok;
1172 else
1173 r = _bfd_final_link_relocate (howto, input_bfd, input_section,
1174 contents, offset,
1175 relocation, addend);
1177 break;
1179 case (int) R_M32R_SDA16 :
1181 const char *name;
1183 BFD_ASSERT (sec != NULL);
1184 name = bfd_get_section_name (abfd, sec);
1186 if (strcmp (name, ".sdata") == 0
1187 || strcmp (name, ".sbss") == 0
1188 || strcmp (name, ".scommon") == 0)
1190 bfd_vma sda_base;
1191 bfd *out_bfd = sec->output_section->owner;
1193 r = m32r_elf_final_sda_base (out_bfd, info,
1194 &errmsg,
1195 &sda_base);
1196 if (r != bfd_reloc_ok)
1198 ret = false;
1199 goto check_reloc;
1202 /* At this point `relocation' contains the object's
1203 address. */
1204 relocation -= sda_base;
1205 /* Now it contains the offset from _SDA_BASE_. */
1207 else
1209 (*_bfd_error_handler) (_("%s: The target (%s) of an %s relocation is in the wrong section (%s)"),
1210 bfd_get_filename (input_bfd),
1211 sym_name,
1212 m32r_elf_howto_table[(int) r_type].name,
1213 bfd_get_section_name (abfd, sec));
1214 /*bfd_set_error (bfd_error_bad_value); ??? why? */
1215 ret = false;
1216 continue;
1219 /* fall through */
1221 default :
1222 r = _bfd_final_link_relocate (howto, input_bfd, input_section,
1223 contents, offset,
1224 relocation, addend);
1225 break;
1229 check_reloc:
1231 if (r != bfd_reloc_ok)
1233 /* FIXME: This should be generic enough to go in a utility. */
1234 const char *name;
1236 if (h != NULL)
1237 name = h->root.root.string;
1238 else
1240 name = (bfd_elf_string_from_elf_section
1241 (input_bfd, symtab_hdr->sh_link, sym->st_name));
1242 if (name == NULL || *name == '\0')
1243 name = bfd_section_name (input_bfd, sec);
1246 if (errmsg != NULL)
1247 goto common_error;
1249 switch (r)
1251 case bfd_reloc_overflow:
1252 if (! ((*info->callbacks->reloc_overflow)
1253 (info, name, howto->name, (bfd_vma) 0,
1254 input_bfd, input_section, offset)))
1255 return false;
1256 break;
1258 case bfd_reloc_undefined:
1259 if (! ((*info->callbacks->undefined_symbol)
1260 (info, name, input_bfd, input_section,
1261 offset, true)))
1262 return false;
1263 break;
1265 case bfd_reloc_outofrange:
1266 errmsg = _("internal error: out of range error");
1267 goto common_error;
1269 case bfd_reloc_notsupported:
1270 errmsg = _("internal error: unsupported relocation error");
1271 goto common_error;
1273 case bfd_reloc_dangerous:
1274 errmsg = _("internal error: dangerous error");
1275 goto common_error;
1277 default:
1278 errmsg = _("internal error: unknown error");
1279 /* fall through */
1281 common_error:
1282 if (!((*info->callbacks->warning)
1283 (info, errmsg, name, input_bfd, input_section,
1284 offset)))
1285 return false;
1286 break;
1291 return ret;
1294 #if 0 /* relaxing not supported yet */
1296 /* This function handles relaxing for the m32r.
1297 Relaxing on the m32r is tricky because of instruction alignment
1298 requirements (4 byte instructions must be aligned on 4 byte boundaries).
1300 The following relaxing opportunities are handled:
1302 seth/add3/jl -> bl24 or bl8
1303 seth/add3 -> ld24
1305 It would be nice to handle bl24 -> bl8 but given:
1307 - 4 byte insns must be on 4 byte boundaries
1308 - branch instructions only branch to insns on 4 byte boundaries
1310 this isn't much of a win because the insn in the 2 "deleted" bytes
1311 must become a nop. With some complexity some real relaxation could be
1312 done but the frequency just wouldn't make it worth it; it's better to
1313 try to do all the code compaction one can elsewhere.
1314 When the chip supports parallel 16 bit insns, things may change.
1317 static boolean
1318 m32r_elf_relax_section (abfd, sec, link_info, again)
1319 bfd *abfd;
1320 asection *sec;
1321 struct bfd_link_info *link_info;
1322 boolean *again;
1324 Elf_Internal_Shdr *symtab_hdr;
1325 /* The Rela structures are used here because that's what
1326 _bfd_elf32_link_read_relocs uses [for convenience - it sets the addend
1327 field to 0]. */
1328 Elf_Internal_Rela *internal_relocs;
1329 Elf_Internal_Rela *free_relocs = NULL;
1330 Elf_Internal_Rela *irel, *irelend;
1331 bfd_byte *contents = NULL;
1332 bfd_byte *free_contents = NULL;
1333 Elf32_External_Sym *extsyms = NULL;
1334 Elf32_External_Sym *free_extsyms = NULL;
1336 /* Assume nothing changes. */
1337 *again = false;
1339 /* We don't have to do anything for a relocateable link, if
1340 this section does not have relocs, or if this is not a
1341 code section. */
1342 if (link_info->relocateable
1343 || (sec->flags & SEC_RELOC) == 0
1344 || sec->reloc_count == 0
1345 || (sec->flags & SEC_CODE) == 0
1346 || 0 /* FIXME: check SHF_M32R_CAN_RELAX */)
1347 return true;
1349 /* If this is the first time we have been called for this section,
1350 initialize the cooked size. */
1351 if (sec->_cooked_size == 0)
1352 sec->_cooked_size = sec->_raw_size;
1354 symtab_hdr = &elf_tdata (abfd)->symtab_hdr;
1356 /* Get a copy of the native relocations. */
1357 internal_relocs = (_bfd_elf32_link_read_relocs
1358 (abfd, sec, (PTR) NULL, (Elf_Internal_Rela *) NULL,
1359 link_info->keep_memory));
1360 if (internal_relocs == NULL)
1361 goto error_return;
1362 if (! link_info->keep_memory)
1363 free_relocs = internal_relocs;
1365 /* Walk through them looking for relaxing opportunities. */
1366 irelend = internal_relocs + sec->reloc_count;
1367 for (irel = internal_relocs; irel < irelend; irel++)
1369 bfd_vma symval;
1371 /* If this isn't something that can be relaxed, then ignore
1372 this reloc. */
1373 if (ELF32_R_TYPE (irel->r_info) != (int) R_M32R_HI16_SLO)
1374 continue;
1376 /* Get the section contents if we haven't done so already. */
1377 if (contents == NULL)
1379 /* Get cached copy if it exists. */
1380 if (elf_section_data (sec)->this_hdr.contents != NULL)
1381 contents = elf_section_data (sec)->this_hdr.contents;
1382 else
1384 /* Go get them off disk. */
1385 contents = (bfd_byte *) bfd_malloc (sec->_raw_size);
1386 if (contents == NULL)
1387 goto error_return;
1388 free_contents = contents;
1390 if (! bfd_get_section_contents (abfd, sec, contents,
1391 (file_ptr) 0, sec->_raw_size))
1392 goto error_return;
1396 /* Read this BFD's symbols if we haven't done so already. */
1397 if (extsyms == NULL)
1399 /* Get cached copy if it exists. */
1400 if (symtab_hdr->contents != NULL)
1401 extsyms = (Elf32_External_Sym *) symtab_hdr->contents;
1402 else
1404 /* Go get them off disk. */
1405 extsyms = ((Elf32_External_Sym *)
1406 bfd_malloc (symtab_hdr->sh_size));
1407 if (extsyms == NULL)
1408 goto error_return;
1409 free_extsyms = extsyms;
1410 if (bfd_seek (abfd, symtab_hdr->sh_offset, SEEK_SET) != 0
1411 || (bfd_read (extsyms, 1, symtab_hdr->sh_size, abfd)
1412 != symtab_hdr->sh_size))
1413 goto error_return;
1417 /* Get the value of the symbol referred to by the reloc. */
1418 if (ELF32_R_SYM (irel->r_info) < symtab_hdr->sh_info)
1420 Elf_Internal_Sym isym;
1421 asection *sym_sec;
1423 /* A local symbol. */
1424 bfd_elf32_swap_symbol_in (abfd,
1425 extsyms + ELF32_R_SYM (irel->r_info),
1426 &isym);
1428 sym_sec = bfd_section_from_elf_index (abfd, isym.st_shndx);
1429 symval = (isym.st_value
1430 + sym_sec->output_section->vma
1431 + sym_sec->output_offset);
1433 else
1435 unsigned long indx;
1436 struct elf_link_hash_entry *h;
1438 /* An external symbol. */
1439 indx = ELF32_R_SYM (irel->r_info) - symtab_hdr->sh_info;
1440 h = elf_sym_hashes (abfd)[indx];
1441 BFD_ASSERT (h != NULL);
1442 if (h->root.type != bfd_link_hash_defined
1443 && h->root.type != bfd_link_hash_defweak)
1445 /* This appears to be a reference to an undefined
1446 symbol. Just ignore it--it will be caught by the
1447 regular reloc processing. */
1448 continue;
1451 symval = (h->root.u.def.value
1452 + h->root.u.def.section->output_section->vma
1453 + h->root.u.def.section->output_offset);
1456 /* For simplicity of coding, we are going to modify the section
1457 contents, the section relocs, and the BFD symbol table. We
1458 must tell the rest of the code not to free up this
1459 information. It would be possible to instead create a table
1460 of changes which have to be made, as is done in coff-mips.c;
1461 that would be more work, but would require less memory when
1462 the linker is run. */
1464 /* Try to change a seth/add3/jl subroutine call to bl24 or bl8.
1465 This sequence is generated by the compiler when compiling in
1466 32 bit mode. Also look for seth/add3 -> ld24. */
1468 if (ELF32_R_TYPE (irel->r_info) == (int) R_M32R_HI16_SLO)
1470 Elf_Internal_Rela *nrel;
1471 bfd_vma pc = (sec->output_section->vma + sec->output_offset
1472 + irel->r_offset);
1473 bfd_signed_vma pcrel_value = symval - pc;
1474 unsigned int code,reg;
1475 int addend,nop_p,bl8_p,to_delete;
1477 /* The tests are ordered so that we get out as quickly as possible
1478 if this isn't something we can relax, taking into account that
1479 we are looking for two separate possibilities (jl/ld24). */
1481 /* Do nothing if no room in the section for this to be what we're
1482 looking for. */
1483 if (irel->r_offset > sec->_cooked_size - 8)
1484 continue;
1486 /* Make sure the next relocation applies to the next
1487 instruction and that it's the add3's reloc. */
1488 nrel = irel + 1;
1489 if (nrel == irelend
1490 || irel->r_offset + 4 != nrel->r_offset
1491 || ELF32_R_TYPE (nrel->r_info) != (int) R_M32R_LO16)
1492 continue;
1494 /* See if the instructions are seth/add3. */
1495 /* FIXME: This is where macros from cgen can come in. */
1496 code = bfd_get_16 (abfd, contents + irel->r_offset + 0);
1497 if ((code & 0xf0ff) != 0xd0c0)
1498 continue; /* not seth rN,foo */
1499 reg = (code & 0x0f00) >> 8;
1500 code = bfd_get_16 (abfd, contents + irel->r_offset + 4);
1501 if (code != (0x80a0 | reg | (reg << 8)))
1502 continue; /* not add3 rN,rN,foo */
1504 /* At this point we've confirmed we have seth/add3. Now check
1505 whether the next insn is a jl, in which case try to change this
1506 to bl24 or bl8. */
1508 /* Ensure the branch target is in range.
1509 The bl24 instruction has a 24 bit operand which is the target
1510 address right shifted by 2, giving a signed range of 26 bits.
1511 Note that 4 bytes are added to the high value because the target
1512 will be at least 4 bytes closer if we can relax. It'll actually
1513 be 4 or 8 bytes closer, but we don't know which just yet and
1514 the difference isn't significant enough to worry about. */
1515 #ifndef USE_REL /* put in for learning purposes */
1516 pcrel_value += irel->r_addend;
1517 #else
1518 addend = bfd_get_signed_16 (abfd, contents + irel->r_offset + 2);
1519 pcrel_value += addend;
1520 #endif
1522 if (pcrel_value >= -(1 << 25) && pcrel_value < (1 << 25) + 4
1523 /* Do nothing if no room in the section for this to be what we're
1524 looking for. */
1525 && (irel->r_offset <= sec->_cooked_size - 12)
1526 /* Ensure the next insn is "jl rN". */
1527 && ((code = bfd_get_16 (abfd, contents + irel->r_offset + 8)),
1528 code != (0x1ec0 | reg)))
1530 /* We can relax to bl24/bl8. */
1532 /* See if there's a nop following the jl.
1533 Also see if we can use a bl8 insn. */
1534 code = bfd_get_16 (abfd, contents + irel->r_offset + 10);
1535 nop_p = (code & 0x7fff) == NOP_INSN;
1536 bl8_p = pcrel_value >= -0x200 && pcrel_value < 0x200;
1538 if (bl8_p)
1540 /* Change "seth rN,foo" to "bl8 foo || nop".
1541 We OR in CODE just in case it's not a nop (technically,
1542 CODE currently must be a nop, but for cleanness we
1543 allow it to be anything). */
1544 #ifndef USE_REL /* put in for learning purposes */
1545 code = 0x7e000000 | MAKE_PARALLEL (code);
1546 #else
1547 code = (0x7e000000 + (((addend >> 2) & 0xff) << 16)) | MAKE_PARALLEL (code);
1548 #endif
1549 to_delete = 8;
1551 else
1553 /* Change the seth rN,foo to a bl24 foo. */
1554 #ifndef USE_REL /* put in for learning purposes */
1555 code = 0xfe000000;
1556 #else
1557 code = 0xfe000000 + ((addend >> 2) & 0xffffff);
1558 #endif
1559 to_delete = nop_p ? 8 : 4;
1562 bfd_put_32 (abfd, code, contents + irel->r_offset);
1564 /* Set the new reloc type. */
1565 irel->r_info = ELF32_R_INFO (ELF32_R_SYM (nrel->r_info),
1566 bl8_p ? R_M32R_10_PCREL : R_M32R_26_PCREL);
1568 /* Delete the add3 reloc by making it a null reloc. */
1569 nrel->r_info = ELF32_R_INFO (ELF32_R_SYM (nrel->r_info),
1570 R_M32R_NONE);
1572 else if (addend >= 0
1573 && symval + addend <= 0xffffff)
1575 /* We can relax to ld24. */
1577 code = 0xe0000000 | (reg << 24) | (addend & 0xffffff);
1578 bfd_put_32 (abfd, code, contents + irel->r_offset);
1579 to_delete = 4;
1580 /* Tell the following code a nop filler isn't needed. */
1581 nop_p = 1;
1583 else
1585 /* Can't do anything here. */
1586 continue;
1589 /* Note that we've changed the relocs, section contents, etc. */
1590 elf_section_data (sec)->relocs = internal_relocs;
1591 free_relocs = NULL;
1593 elf_section_data (sec)->this_hdr.contents = contents;
1594 free_contents = NULL;
1596 symtab_hdr->contents = (bfd_byte *) extsyms;
1597 free_extsyms = NULL;
1599 /* Delete TO_DELETE bytes of data. */
1600 if (!m32r_elf_relax_delete_bytes (abfd, sec,
1601 irel->r_offset + 4, to_delete))
1602 goto error_return;
1604 /* Now that the following bytes have been moved into place, see if
1605 we need to replace the jl with a nop. This happens when we had
1606 to use a bl24 insn and the insn following the jl isn't a nop.
1607 Technically, this situation can't happen (since the insn can
1608 never be executed) but to be clean we do this. When the chip
1609 supports parallel 16 bit insns things may change.
1610 We don't need to do this in the case of relaxing to ld24,
1611 and the above code sets nop_p so this isn't done. */
1612 if (! nop_p && to_delete == 4)
1613 bfd_put_16 (abfd, NOP_INSN, contents + irel->r_offset + 4);
1615 /* That will change things, so we should relax again.
1616 Note that this is not required, and it may be slow. */
1617 *again = true;
1619 continue;
1622 /* loop to try the next reloc */
1625 if (free_relocs != NULL)
1627 free (free_relocs);
1628 free_relocs = NULL;
1631 if (free_contents != NULL)
1633 if (! link_info->keep_memory)
1634 free (free_contents);
1635 else
1637 /* Cache the section contents for elf_link_input_bfd. */
1638 elf_section_data (sec)->this_hdr.contents = contents;
1640 free_contents = NULL;
1643 if (free_extsyms != NULL)
1645 if (! link_info->keep_memory)
1646 free (free_extsyms);
1647 else
1649 /* Cache the symbols for elf_link_input_bfd. */
1650 symtab_hdr->contents = extsyms;
1652 free_extsyms = NULL;
1655 return true;
1657 error_return:
1658 if (free_relocs != NULL)
1659 free (free_relocs);
1660 if (free_contents != NULL)
1661 free (free_contents);
1662 if (free_extsyms != NULL)
1663 free (free_extsyms);
1664 return false;
1667 /* Delete some bytes from a section while relaxing. */
1669 static boolean
1670 m32r_elf_relax_delete_bytes (abfd, sec, addr, count)
1671 bfd *abfd;
1672 asection *sec;
1673 bfd_vma addr;
1674 int count;
1676 Elf_Internal_Shdr *symtab_hdr;
1677 Elf32_External_Sym *extsyms;
1678 int shndx, index;
1679 bfd_byte *contents;
1680 Elf_Internal_Rela *irel, *irelend;
1681 Elf_Internal_Rela *irelalign;
1682 bfd_vma toaddr;
1683 Elf32_External_Sym *esym, *esymend;
1684 struct elf_link_hash_entry *sym_hash;
1686 symtab_hdr = &elf_tdata (abfd)->symtab_hdr;
1687 extsyms = (Elf32_External_Sym *) symtab_hdr->contents;
1689 shndx = _bfd_elf_section_from_bfd_section (abfd, sec);
1691 contents = elf_section_data (sec)->this_hdr.contents;
1693 /* The deletion must stop at the next ALIGN reloc for an aligment
1694 power larger than the number of bytes we are deleting. */
1696 irelalign = NULL;
1697 toaddr = sec->_cooked_size;
1699 irel = elf_section_data (sec)->relocs;
1700 irelend = irel + sec->reloc_count;
1702 /* Actually delete the bytes. */
1703 memmove (contents + addr, contents + addr + count, toaddr - addr - count);
1704 sec->_cooked_size -= count;
1706 /* Adjust all the relocs. */
1707 for (irel = elf_section_data (sec)->relocs; irel < irelend; irel++)
1709 /* Get the new reloc address. */
1710 if ((irel->r_offset > addr
1711 && irel->r_offset < toaddr))
1712 irel->r_offset -= count;
1715 /* Adjust the local symbols defined in this section. */
1716 esym = extsyms;
1717 esymend = esym + symtab_hdr->sh_info;
1718 for (; esym < esymend; esym++)
1720 Elf_Internal_Sym isym;
1722 bfd_elf32_swap_symbol_in (abfd, esym, &isym);
1724 if (isym.st_shndx == shndx
1725 && isym.st_value > addr
1726 && isym.st_value < toaddr)
1728 isym.st_value -= count;
1729 bfd_elf32_swap_symbol_out (abfd, &isym, esym);
1733 /* Now adjust the global symbols defined in this section. */
1734 esym = extsyms + symtab_hdr->sh_info;
1735 esymend = extsyms + (symtab_hdr->sh_size / sizeof (Elf32_External_Sym));
1736 for (index = 0; esym < esymend; esym++, index++)
1738 Elf_Internal_Sym isym;
1740 bfd_elf32_swap_symbol_in (abfd, esym, &isym);
1741 sym_hash = elf_sym_hashes (abfd)[index];
1742 if (isym.st_shndx == shndx
1743 && ((sym_hash)->root.type == bfd_link_hash_defined
1744 || (sym_hash)->root.type == bfd_link_hash_defweak)
1745 && (sym_hash)->root.u.def.section == sec
1746 && (sym_hash)->root.u.def.value > addr
1747 && (sym_hash)->root.u.def.value < toaddr)
1749 (sym_hash)->root.u.def.value -= count;
1753 return true;
1756 /* This is a version of bfd_generic_get_relocated_section_contents
1757 which uses m32r_elf_relocate_section. */
1759 static bfd_byte *
1760 m32r_elf_get_relocated_section_contents (output_bfd, link_info, link_order,
1761 data, relocateable, symbols)
1762 bfd *output_bfd;
1763 struct bfd_link_info *link_info;
1764 struct bfd_link_order *link_order;
1765 bfd_byte *data;
1766 boolean relocateable;
1767 asymbol **symbols;
1769 Elf_Internal_Shdr *symtab_hdr;
1770 asection *input_section = link_order->u.indirect.section;
1771 bfd *input_bfd = input_section->owner;
1772 asection **sections = NULL;
1773 Elf_Internal_Rela *internal_relocs = NULL;
1774 Elf32_External_Sym *external_syms = NULL;
1775 Elf_Internal_Sym *internal_syms = NULL;
1777 /* We only need to handle the case of relaxing, or of having a
1778 particular set of section contents, specially. */
1779 if (relocateable
1780 || elf_section_data (input_section)->this_hdr.contents == NULL)
1781 return bfd_generic_get_relocated_section_contents (output_bfd, link_info,
1782 link_order, data,
1783 relocateable,
1784 symbols);
1786 symtab_hdr = &elf_tdata (input_bfd)->symtab_hdr;
1788 memcpy (data, elf_section_data (input_section)->this_hdr.contents,
1789 input_section->_raw_size);
1791 if ((input_section->flags & SEC_RELOC) != 0
1792 && input_section->reloc_count > 0)
1794 Elf_Internal_Sym *isymp;
1795 asection **secpp;
1796 Elf32_External_Sym *esym, *esymend;
1798 if (symtab_hdr->contents != NULL)
1799 external_syms = (Elf32_External_Sym *) symtab_hdr->contents;
1800 else
1802 external_syms = ((Elf32_External_Sym *)
1803 bfd_malloc (symtab_hdr->sh_info
1804 * sizeof (Elf32_External_Sym)));
1805 if (external_syms == NULL && symtab_hdr->sh_info > 0)
1806 goto error_return;
1807 if (bfd_seek (input_bfd, symtab_hdr->sh_offset, SEEK_SET) != 0
1808 || (bfd_read (external_syms, sizeof (Elf32_External_Sym),
1809 symtab_hdr->sh_info, input_bfd)
1810 != (symtab_hdr->sh_info * sizeof (Elf32_External_Sym))))
1811 goto error_return;
1814 internal_relocs = (_bfd_elf32_link_read_relocs
1815 (input_bfd, input_section, (PTR) NULL,
1816 (Elf_Internal_Rela *) NULL, false));
1817 if (internal_relocs == NULL)
1818 goto error_return;
1820 internal_syms = ((Elf_Internal_Sym *)
1821 bfd_malloc (symtab_hdr->sh_info
1822 * sizeof (Elf_Internal_Sym)));
1823 if (internal_syms == NULL && symtab_hdr->sh_info > 0)
1824 goto error_return;
1826 sections = (asection **) bfd_malloc (symtab_hdr->sh_info
1827 * sizeof (asection *));
1828 if (sections == NULL && symtab_hdr->sh_info > 0)
1829 goto error_return;
1831 isymp = internal_syms;
1832 secpp = sections;
1833 esym = external_syms;
1834 esymend = esym + symtab_hdr->sh_info;
1835 for (; esym < esymend; ++esym, ++isymp, ++secpp)
1837 asection *isec;
1839 bfd_elf32_swap_symbol_in (input_bfd, esym, isymp);
1841 if (isymp->st_shndx == SHN_UNDEF)
1842 isec = bfd_und_section_ptr;
1843 else if (isymp->st_shndx > 0 && isymp->st_shndx < SHN_LORESERVE)
1844 isec = bfd_section_from_elf_index (input_bfd, isymp->st_shndx);
1845 else if (isymp->st_shndx == SHN_ABS)
1846 isec = bfd_abs_section_ptr;
1847 else if (isymp->st_shndx == SHN_COMMON)
1848 isec = bfd_com_section_ptr;
1849 else if (isymp->st_shndx == SHN_M32R_SCOMMON)
1850 isec = &m32r_elf_scom_section;
1851 else
1853 /* Who knows? */
1854 isec = NULL;
1857 *secpp = isec;
1860 if (! m32r_elf_relocate_section (output_bfd, link_info, input_bfd,
1861 input_section, data, internal_relocs,
1862 internal_syms, sections))
1863 goto error_return;
1865 if (sections != NULL)
1866 free (sections);
1867 sections = NULL;
1868 if (internal_syms != NULL)
1869 free (internal_syms);
1870 internal_syms = NULL;
1871 if (external_syms != NULL && symtab_hdr->contents == NULL)
1872 free (external_syms);
1873 external_syms = NULL;
1874 if (internal_relocs != elf_section_data (input_section)->relocs)
1875 free (internal_relocs);
1876 internal_relocs = NULL;
1879 return data;
1881 error_return:
1882 if (internal_relocs != NULL
1883 && internal_relocs != elf_section_data (input_section)->relocs)
1884 free (internal_relocs);
1885 if (external_syms != NULL && symtab_hdr->contents == NULL)
1886 free (external_syms);
1887 if (internal_syms != NULL)
1888 free (internal_syms);
1889 if (sections != NULL)
1890 free (sections);
1891 return NULL;
1894 #endif /* #if 0 */
1896 /* Set the right machine number. */
1897 static boolean
1898 m32r_elf_object_p (abfd)
1899 bfd *abfd;
1901 switch (elf_elfheader (abfd)->e_flags & EF_M32R_ARCH)
1903 default:
1904 case E_M32R_ARCH: (void) bfd_default_set_arch_mach (abfd, bfd_arch_m32r, bfd_mach_m32r); break;
1905 case E_M32RX_ARCH: (void) bfd_default_set_arch_mach (abfd, bfd_arch_m32r, bfd_mach_m32rx); break;
1907 return true;
1910 /* Store the machine number in the flags field. */
1911 static void
1912 m32r_elf_final_write_processing (abfd, linker)
1913 bfd * abfd;
1914 boolean linker ATTRIBUTE_UNUSED;
1916 unsigned long val;
1918 switch (bfd_get_mach (abfd))
1920 default:
1921 case bfd_mach_m32r: val = E_M32R_ARCH; break;
1922 case bfd_mach_m32rx: val = E_M32RX_ARCH; break;
1925 elf_elfheader (abfd)->e_flags &=~ EF_M32R_ARCH;
1926 elf_elfheader (abfd)->e_flags |= val;
1929 /* Function to keep M32R specific file flags. */
1930 static boolean
1931 m32r_elf_set_private_flags (abfd, flags)
1932 bfd * abfd;
1933 flagword flags;
1935 BFD_ASSERT (!elf_flags_init (abfd)
1936 || elf_elfheader (abfd)->e_flags == flags);
1938 elf_elfheader (abfd)->e_flags = flags;
1939 elf_flags_init (abfd) = true;
1940 return true;
1943 /* Copy backend specific data from one object module to another */
1944 static boolean
1945 m32r_elf_copy_private_bfd_data (ibfd, obfd)
1946 bfd * ibfd;
1947 bfd * obfd;
1949 if ( bfd_get_flavour (ibfd) != bfd_target_elf_flavour
1950 || bfd_get_flavour (obfd) != bfd_target_elf_flavour)
1951 return true;
1953 BFD_ASSERT (!elf_flags_init (obfd)
1954 || (elf_elfheader (obfd)->e_flags
1955 == elf_elfheader (ibfd)->e_flags));
1957 elf_gp (obfd) = elf_gp (ibfd);
1958 elf_elfheader (obfd)->e_flags = elf_elfheader (ibfd)->e_flags;
1959 elf_flags_init (obfd) = true;
1960 return true;
1963 /* Merge backend specific data from an object file to the output
1964 object file when linking. */
1965 static boolean
1966 m32r_elf_merge_private_bfd_data (ibfd, obfd)
1967 bfd * ibfd;
1968 bfd * obfd;
1970 flagword out_flags;
1971 flagword in_flags;
1973 if ( bfd_get_flavour (ibfd) != bfd_target_elf_flavour
1974 || bfd_get_flavour (obfd) != bfd_target_elf_flavour)
1975 return true;
1977 in_flags = elf_elfheader (ibfd)->e_flags;
1978 out_flags = elf_elfheader (obfd)->e_flags;
1980 if (! elf_flags_init (obfd))
1982 /* If the input is the default architecture then do not
1983 bother setting the flags for the output architecture,
1984 instead allow future merges to do this. If no future
1985 merges ever set these flags then they will retain their
1986 unitialised values, which surprise surprise, correspond
1987 to the default values. */
1988 if (bfd_get_arch_info (ibfd)->the_default)
1989 return true;
1991 elf_flags_init (obfd) = true;
1992 elf_elfheader (obfd)->e_flags = in_flags;
1994 if (bfd_get_arch (obfd) == bfd_get_arch (ibfd)
1995 && bfd_get_arch_info (obfd)->the_default)
1997 return bfd_set_arch_mach (obfd, bfd_get_arch (ibfd), bfd_get_mach (ibfd));
2000 return true;
2003 /* Check flag compatibility. */
2004 if (in_flags == out_flags)
2005 return true;
2007 if ((in_flags & EF_M32R_ARCH) != (out_flags & EF_M32R_ARCH))
2009 if ((in_flags & EF_M32R_ARCH) != E_M32R_ARCH)
2011 _bfd_error_handler (_("%s: Instruction set mismatch with previous modules"),
2012 bfd_get_filename (ibfd));
2014 bfd_set_error (bfd_error_bad_value);
2015 return false;
2019 return true;
2022 /* Display the flags field */
2023 static boolean
2024 m32r_elf_print_private_bfd_data (abfd, ptr)
2025 bfd * abfd;
2026 PTR ptr;
2028 FILE * file = (FILE *) ptr;
2030 BFD_ASSERT (abfd != NULL && ptr != NULL)
2032 _bfd_elf_print_private_bfd_data (abfd, ptr);
2034 fprintf (file, _("private flags = %lx"), elf_elfheader (abfd)->e_flags);
2036 switch (elf_elfheader (abfd)->e_flags & EF_M32R_ARCH)
2038 default:
2039 case E_M32R_ARCH: fprintf (file, _(": m32r instructions")); break;
2040 case E_M32RX_ARCH: fprintf (file, _(": m32rx instructions")); break;
2043 fputc ('\n', file);
2045 return true;
2048 asection *
2049 m32r_elf_gc_mark_hook (abfd, info, rel, h, sym)
2050 bfd *abfd;
2051 struct bfd_link_info *info ATTRIBUTE_UNUSED;
2052 Elf_Internal_Rela *rel;
2053 struct elf_link_hash_entry *h;
2054 Elf_Internal_Sym *sym;
2056 if (h != NULL)
2058 switch (ELF32_R_TYPE (rel->r_info))
2060 case R_M32R_GNU_VTINHERIT:
2061 case R_M32R_GNU_VTENTRY:
2062 break;
2064 default:
2065 switch (h->root.type)
2067 case bfd_link_hash_defined:
2068 case bfd_link_hash_defweak:
2069 return h->root.u.def.section;
2071 case bfd_link_hash_common:
2072 return h->root.u.c.p->section;
2074 default:
2075 break;
2079 else
2081 if (!(elf_bad_symtab (abfd)
2082 && ELF_ST_BIND (sym->st_info) != STB_LOCAL)
2083 && ! ((sym->st_shndx <= 0 || sym->st_shndx >= SHN_LORESERVE)
2084 && sym->st_shndx != SHN_COMMON))
2086 return bfd_section_from_elf_index (abfd, sym->st_shndx);
2089 return NULL;
2092 static boolean
2093 m32r_elf_gc_sweep_hook (abfd, info, sec, relocs)
2094 bfd *abfd ATTRIBUTE_UNUSED;
2095 struct bfd_link_info *info ATTRIBUTE_UNUSED;
2096 asection *sec ATTRIBUTE_UNUSED;
2097 const Elf_Internal_Rela *relocs ATTRIBUTE_UNUSED;
2099 /* we don't use got and plt entries for m32r */
2100 return true;
2103 /* Look through the relocs for a section during the first phase.
2104 Since we don't do .gots or .plts, we just need to consider the
2105 virtual table relocs for gc. */
2107 static boolean
2108 m32r_elf_check_relocs (abfd, info, sec, relocs)
2109 bfd *abfd;
2110 struct bfd_link_info *info;
2111 asection *sec;
2112 const Elf_Internal_Rela *relocs;
2114 Elf_Internal_Shdr *symtab_hdr;
2115 struct elf_link_hash_entry **sym_hashes, **sym_hashes_end;
2116 const Elf_Internal_Rela *rel;
2117 const Elf_Internal_Rela *rel_end;
2119 if (info->relocateable)
2120 return true;
2122 symtab_hdr = &elf_tdata (abfd)->symtab_hdr;
2123 sym_hashes = elf_sym_hashes (abfd);
2124 sym_hashes_end = sym_hashes + symtab_hdr->sh_size/sizeof (Elf32_External_Sym);
2125 if (!elf_bad_symtab (abfd))
2126 sym_hashes_end -= symtab_hdr->sh_info;
2128 rel_end = relocs + sec->reloc_count;
2129 for (rel = relocs; rel < rel_end; rel++)
2131 struct elf_link_hash_entry *h;
2132 unsigned long r_symndx;
2134 r_symndx = ELF32_R_SYM (rel->r_info);
2135 if (r_symndx < symtab_hdr->sh_info)
2136 h = NULL;
2137 else
2138 h = sym_hashes[r_symndx - symtab_hdr->sh_info];
2140 switch (ELF32_R_TYPE (rel->r_info))
2142 /* This relocation describes the C++ object vtable hierarchy.
2143 Reconstruct it for later use during GC. */
2144 case R_M32R_GNU_VTINHERIT:
2145 if (!_bfd_elf32_gc_record_vtinherit (abfd, sec, h, rel->r_offset))
2146 return false;
2147 break;
2149 /* This relocation describes which C++ vtable entries are actually
2150 used. Record for later use during GC. */
2151 case R_M32R_GNU_VTENTRY:
2152 if (!_bfd_elf32_gc_record_vtentry (abfd, sec, h, rel->r_offset))
2153 return false;
2154 break;
2158 return true;
2161 #define ELF_ARCH bfd_arch_m32r
2162 #define ELF_MACHINE_CODE EM_CYGNUS_M32R
2163 #define ELF_MAXPAGESIZE 0x1 /* Explicitly requested by Mitsubishi. */
2165 #define TARGET_BIG_SYM bfd_elf32_m32r_vec
2166 #define TARGET_BIG_NAME "elf32-m32r"
2168 #define elf_info_to_howto 0
2169 #define elf_info_to_howto_rel m32r_info_to_howto_rel
2170 #define elf_backend_section_from_bfd_section _bfd_m32r_elf_section_from_bfd_section
2171 #define elf_backend_symbol_processing _bfd_m32r_elf_symbol_processing
2172 #define elf_backend_add_symbol_hook m32r_elf_add_symbol_hook
2173 #define elf_backend_relocate_section m32r_elf_relocate_section
2174 #define elf_backend_gc_mark_hook m32r_elf_gc_mark_hook
2175 #define elf_backend_gc_sweep_hook m32r_elf_gc_sweep_hook
2176 #define elf_backend_check_relocs m32r_elf_check_relocs
2178 #define elf_backend_can_gc_sections 1
2179 #if 0 /* not yet */
2180 /* relax support */
2181 #define bfd_elf32_bfd_relax_section m32r_elf_relax_section
2182 #define bfd_elf32_bfd_get_relocated_section_contents \
2183 m32r_elf_get_relocated_section_contents
2184 #endif
2186 #define elf_backend_object_p m32r_elf_object_p
2187 #define elf_backend_final_write_processing m32r_elf_final_write_processing
2188 #define bfd_elf32_bfd_copy_private_bfd_data m32r_elf_copy_private_bfd_data
2189 #define bfd_elf32_bfd_merge_private_bfd_data m32r_elf_merge_private_bfd_data
2190 #define bfd_elf32_bfd_set_private_flags m32r_elf_set_private_flags
2191 #define bfd_elf32_bfd_print_private_bfd_data m32r_elf_print_private_bfd_data
2193 #include "elf32-target.h"