1 /* 32-bit ELF support for Nios II.
2 Copyright (C) 2012-2023 Free Software Foundation, Inc.
3 Contributed by Nigel Gray (ngray@altera.com).
4 Contributed by Mentor Graphics, Inc.
6 This file is part of BFD, the Binary File Descriptor library.
8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 3 of the License, or
11 (at your option) any later version.
13 This program 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.
18 You should have received a copy of the GNU General Public License
19 along with this program; if not, write to the Free Software
20 Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
21 MA 02110-1301, USA. */
23 /* This file handles Altera Nios II ELF targets. */
31 #include "elf/nios2.h"
32 #include "opcode/nios2.h"
33 #include "elf32-nios2.h"
34 #include "libiberty.h"
36 /* Use RELA relocations. */
45 /* Forward declarations. */
46 static bfd_reloc_status_type nios2_elf32_ignore_reloc
47 (bfd
*, arelent
*, asymbol
*, void *, asection
*, bfd
*, char **);
48 static bfd_reloc_status_type nios2_elf32_hi16_relocate
49 (bfd
*, arelent
*, asymbol
*, void *, asection
*, bfd
*, char **);
50 static bfd_reloc_status_type nios2_elf32_lo16_relocate
51 (bfd
*, arelent
*, asymbol
*, void *, asection
*, bfd
*, char **);
52 static bfd_reloc_status_type nios2_elf32_hiadj16_relocate
53 (bfd
*, arelent
*, asymbol
*, void *, asection
*, bfd
*, char **);
54 static bfd_reloc_status_type nios2_elf32_pcrel_lo16_relocate
55 (bfd
*, arelent
*, asymbol
*, void *, asection
*, bfd
*, char **);
56 static bfd_reloc_status_type nios2_elf32_pcrel_hiadj16_relocate
57 (bfd
*, arelent
*, asymbol
*, void *, asection
*, bfd
*, char **);
58 static bfd_reloc_status_type nios2_elf32_pcrel16_relocate
59 (bfd
*, arelent
*, asymbol
*, void *, asection
*, bfd
*, char **);
60 static bfd_reloc_status_type nios2_elf32_call26_relocate
61 (bfd
*, arelent
*, asymbol
*, void *, asection
*, bfd
*, char **);
62 static bfd_reloc_status_type nios2_elf32_gprel_relocate
63 (bfd
*, arelent
*, asymbol
*, void *, asection
*, bfd
*, char **);
64 static bfd_reloc_status_type nios2_elf32_ujmp_relocate
65 (bfd
*, arelent
*, asymbol
*, void *, asection
*, bfd
*, char **);
66 static bfd_reloc_status_type nios2_elf32_cjmp_relocate
67 (bfd
*, arelent
*, asymbol
*, void *, asection
*, bfd
*, char **);
68 static bfd_reloc_status_type nios2_elf32_callr_relocate
69 (bfd
*, arelent
*, asymbol
*, void *, asection
*, bfd
*, char **);
72 extern const bfd_target nios2_elf32_le_vec
;
73 extern const bfd_target nios2_elf32_be_vec
;
75 /* Offset of tp and dtp pointers from start of TLS block. */
76 #define TP_OFFSET 0x7000
77 #define DTP_OFFSET 0x8000
79 /* The relocation tables used for SHT_REL sections. There are separate
80 tables for R1 and R2 encodings. */
81 static reloc_howto_type elf_nios2_r1_howto_table_rel
[] = {
83 HOWTO (R_NIOS2_NONE
, /* type */
87 false, /* pc_relative */
89 complain_overflow_dont
, /* complain_on_overflow */
90 bfd_elf_generic_reloc
, /* special_function */
91 "R_NIOS2_NONE", /* name */
92 false, /* partial_inplace */
95 false), /* pcrel_offset */
97 /* 16-bit signed immediate relocation. */
98 HOWTO (R_NIOS2_S16
, /* type */
102 false, /* pc_relative */
104 complain_overflow_signed
, /* complain on overflow */
105 bfd_elf_generic_reloc
, /* special function */
106 "R_NIOS2_S16", /* name */
107 false, /* partial_inplace */
108 0x003fffc0, /* src_mask */
109 0x003fffc0, /* dest_mask */
110 false), /* pcrel_offset */
112 /* 16-bit unsigned immediate relocation. */
113 HOWTO (R_NIOS2_U16
, /* type */
117 false, /* pc_relative */
119 complain_overflow_unsigned
, /* complain on overflow */
120 bfd_elf_generic_reloc
, /* special function */
121 "R_NIOS2_U16", /* name */
122 false, /* partial_inplace */
123 0x003fffc0, /* src_mask */
124 0x003fffc0, /* dest_mask */
125 false), /* pcrel_offset */
127 HOWTO (R_NIOS2_PCREL16
, /* type */
131 true, /* pc_relative */
133 complain_overflow_signed
, /* complain on overflow */
134 nios2_elf32_pcrel16_relocate
, /* special function */
135 "R_NIOS2_PCREL16", /* name */
136 false, /* partial_inplace */
137 0x003fffc0, /* src_mask */
138 0x003fffc0, /* dest_mask */
139 true), /* pcrel_offset */
141 HOWTO (R_NIOS2_CALL26
, /* type */
145 false, /* pc_relative */
147 complain_overflow_dont
, /* complain on overflow */
148 nios2_elf32_call26_relocate
, /* special function */
149 "R_NIOS2_CALL26", /* name */
150 false, /* partial_inplace */
151 0xffffffc0, /* src_mask */
152 0xffffffc0, /* dst_mask */
153 false), /* pcrel_offset */
161 complain_overflow_bitfield
,
162 bfd_elf_generic_reloc
,
169 HOWTO (R_NIOS2_CACHE_OPX
,
175 complain_overflow_bitfield
,
176 bfd_elf_generic_reloc
,
189 complain_overflow_bitfield
,
190 bfd_elf_generic_reloc
,
203 complain_overflow_bitfield
,
204 bfd_elf_generic_reloc
,
217 complain_overflow_dont
,
218 nios2_elf32_hi16_relocate
,
231 complain_overflow_dont
,
232 nios2_elf32_lo16_relocate
,
239 HOWTO (R_NIOS2_HIADJ16
,
245 complain_overflow_dont
,
246 nios2_elf32_hiadj16_relocate
,
253 HOWTO (R_NIOS2_BFD_RELOC_32
,
259 complain_overflow_dont
,
260 bfd_elf_generic_reloc
,
261 "R_NIOS2_BFD_RELOC32",
267 HOWTO (R_NIOS2_BFD_RELOC_16
,
273 complain_overflow_bitfield
,
274 bfd_elf_generic_reloc
,
275 "R_NIOS2_BFD_RELOC16",
281 HOWTO (R_NIOS2_BFD_RELOC_8
,
287 complain_overflow_bitfield
,
288 bfd_elf_generic_reloc
,
289 "R_NIOS2_BFD_RELOC8",
295 HOWTO (R_NIOS2_GPREL
,
301 complain_overflow_dont
,
302 nios2_elf32_gprel_relocate
,
309 HOWTO (R_NIOS2_GNU_VTINHERIT
,
315 complain_overflow_dont
,
317 "R_NIOS2_GNU_VTINHERIT",
323 HOWTO (R_NIOS2_GNU_VTENTRY
,
329 complain_overflow_dont
,
330 _bfd_elf_rel_vtable_reloc_fn
,
331 "R_NIOS2_GNU_VTENTRY",
343 complain_overflow_dont
,
344 nios2_elf32_ujmp_relocate
,
357 complain_overflow_dont
,
358 nios2_elf32_cjmp_relocate
,
365 HOWTO (R_NIOS2_CALLR
,
371 complain_overflow_dont
,
372 nios2_elf32_callr_relocate
,
379 HOWTO (R_NIOS2_ALIGN
,
385 complain_overflow_dont
,
386 nios2_elf32_ignore_reloc
,
394 HOWTO (R_NIOS2_GOT16
,
400 complain_overflow_bitfield
,
401 bfd_elf_generic_reloc
,
408 HOWTO (R_NIOS2_CALL16
,
414 complain_overflow_bitfield
,
415 bfd_elf_generic_reloc
,
422 HOWTO (R_NIOS2_GOTOFF_LO
,
428 complain_overflow_dont
,
429 bfd_elf_generic_reloc
,
436 HOWTO (R_NIOS2_GOTOFF_HA
,
442 complain_overflow_dont
,
443 bfd_elf_generic_reloc
,
450 HOWTO (R_NIOS2_PCREL_LO
,
456 complain_overflow_dont
,
457 nios2_elf32_pcrel_lo16_relocate
,
464 HOWTO (R_NIOS2_PCREL_HA
,
468 false, /* This is a PC-relative relocation, but we need to subtract
469 PC ourselves before the HIADJ. */
471 complain_overflow_dont
,
472 nios2_elf32_pcrel_hiadj16_relocate
,
479 HOWTO (R_NIOS2_TLS_GD16
,
485 complain_overflow_bitfield
,
486 bfd_elf_generic_reloc
,
493 HOWTO (R_NIOS2_TLS_LDM16
,
499 complain_overflow_bitfield
,
500 bfd_elf_generic_reloc
,
507 HOWTO (R_NIOS2_TLS_LDO16
,
513 complain_overflow_bitfield
,
514 bfd_elf_generic_reloc
,
521 HOWTO (R_NIOS2_TLS_IE16
,
527 complain_overflow_bitfield
,
528 bfd_elf_generic_reloc
,
535 HOWTO (R_NIOS2_TLS_LE16
,
541 complain_overflow_bitfield
,
542 bfd_elf_generic_reloc
,
549 HOWTO (R_NIOS2_TLS_DTPMOD
,
555 complain_overflow_dont
,
556 bfd_elf_generic_reloc
,
557 "R_NIOS2_TLS_DTPMOD",
563 HOWTO (R_NIOS2_TLS_DTPREL
,
569 complain_overflow_dont
,
570 bfd_elf_generic_reloc
,
571 "R_NIOS2_TLS_DTPREL",
577 HOWTO (R_NIOS2_TLS_TPREL
,
583 complain_overflow_dont
,
584 bfd_elf_generic_reloc
,
597 complain_overflow_dont
,
598 bfd_elf_generic_reloc
,
605 HOWTO (R_NIOS2_GLOB_DAT
,
611 complain_overflow_dont
,
612 bfd_elf_generic_reloc
,
619 HOWTO (R_NIOS2_JUMP_SLOT
,
625 complain_overflow_dont
,
626 bfd_elf_generic_reloc
,
633 HOWTO (R_NIOS2_RELATIVE
,
639 complain_overflow_dont
,
640 bfd_elf_generic_reloc
,
647 HOWTO (R_NIOS2_GOTOFF
,
653 complain_overflow_dont
,
654 bfd_elf_generic_reloc
,
661 HOWTO (R_NIOS2_CALL26_NOAT
, /* type */
665 false, /* pc_relative */
667 complain_overflow_dont
, /* complain on overflow */
668 nios2_elf32_call26_relocate
, /* special function */
669 "R_NIOS2_CALL26_NOAT", /* name */
670 false, /* partial_inplace */
671 0xffffffc0, /* src_mask */
672 0xffffffc0, /* dst_mask */
673 false), /* pcrel_offset */
675 HOWTO (R_NIOS2_GOT_LO
,
681 complain_overflow_dont
,
682 bfd_elf_generic_reloc
,
689 HOWTO (R_NIOS2_GOT_HA
,
695 complain_overflow_dont
,
696 bfd_elf_generic_reloc
,
703 HOWTO (R_NIOS2_CALL_LO
,
709 complain_overflow_dont
,
710 bfd_elf_generic_reloc
,
717 HOWTO (R_NIOS2_CALL_HA
,
723 complain_overflow_dont
,
724 bfd_elf_generic_reloc
,
731 /* Add other relocations here. */
734 static reloc_howto_type elf_nios2_r2_howto_table_rel
[] = {
736 HOWTO (R_NIOS2_NONE
, /* type */
740 false, /* pc_relative */
742 complain_overflow_dont
, /* complain_on_overflow */
743 bfd_elf_generic_reloc
, /* special_function */
744 "R_NIOS2_NONE", /* name */
745 false, /* partial_inplace */
748 false), /* pcrel_offset */
750 /* 16-bit signed immediate relocation. */
751 HOWTO (R_NIOS2_S16
, /* type */
755 false, /* pc_relative */
757 complain_overflow_signed
, /* complain on overflow */
758 bfd_elf_generic_reloc
, /* special function */
759 "R_NIOS2_S16", /* name */
760 false, /* partial_inplace */
761 0xffff0000, /* src_mask */
762 0xffff0000, /* dest_mask */
763 false), /* pcrel_offset */
765 /* 16-bit unsigned immediate relocation. */
766 HOWTO (R_NIOS2_U16
, /* type */
770 false, /* pc_relative */
772 complain_overflow_unsigned
, /* complain on overflow */
773 bfd_elf_generic_reloc
, /* special function */
774 "R_NIOS2_U16", /* name */
775 false, /* partial_inplace */
776 0xffff0000, /* src_mask */
777 0xffff0000, /* dest_mask */
778 false), /* pcrel_offset */
780 HOWTO (R_NIOS2_PCREL16
, /* type */
784 true, /* pc_relative */
786 complain_overflow_signed
, /* complain on overflow */
787 nios2_elf32_pcrel16_relocate
, /* special function */
788 "R_NIOS2_PCREL16", /* name */
789 false, /* partial_inplace */
790 0xffff0000, /* src_mask */
791 0xffff0000, /* dest_mask */
792 true), /* pcrel_offset */
794 HOWTO (R_NIOS2_CALL26
, /* type */
798 false, /* pc_relative */
800 complain_overflow_dont
, /* complain on overflow */
801 nios2_elf32_call26_relocate
, /* special function */
802 "R_NIOS2_CALL26", /* name */
803 false, /* partial_inplace */
804 0xffffffc0, /* src_mask */
805 0xffffffc0, /* dst_mask */
806 false), /* pcrel_offset */
814 complain_overflow_bitfield
,
815 bfd_elf_generic_reloc
,
822 HOWTO (R_NIOS2_CACHE_OPX
,
828 complain_overflow_bitfield
,
829 bfd_elf_generic_reloc
,
842 complain_overflow_bitfield
,
843 bfd_elf_generic_reloc
,
856 complain_overflow_bitfield
,
857 bfd_elf_generic_reloc
,
870 complain_overflow_dont
,
871 nios2_elf32_hi16_relocate
,
884 complain_overflow_dont
,
885 nios2_elf32_lo16_relocate
,
892 HOWTO (R_NIOS2_HIADJ16
,
898 complain_overflow_dont
,
899 nios2_elf32_hiadj16_relocate
,
906 HOWTO (R_NIOS2_BFD_RELOC_32
,
912 complain_overflow_dont
,
913 bfd_elf_generic_reloc
,
914 "R_NIOS2_BFD_RELOC32",
920 HOWTO (R_NIOS2_BFD_RELOC_16
,
926 complain_overflow_bitfield
,
927 bfd_elf_generic_reloc
,
928 "R_NIOS2_BFD_RELOC16",
934 HOWTO (R_NIOS2_BFD_RELOC_8
,
940 complain_overflow_bitfield
,
941 bfd_elf_generic_reloc
,
942 "R_NIOS2_BFD_RELOC8",
948 HOWTO (R_NIOS2_GPREL
,
954 complain_overflow_dont
,
955 nios2_elf32_gprel_relocate
,
962 HOWTO (R_NIOS2_GNU_VTINHERIT
,
968 complain_overflow_dont
,
970 "R_NIOS2_GNU_VTINHERIT",
976 HOWTO (R_NIOS2_GNU_VTENTRY
,
982 complain_overflow_dont
,
983 _bfd_elf_rel_vtable_reloc_fn
,
984 "R_NIOS2_GNU_VTENTRY",
996 complain_overflow_dont
,
997 nios2_elf32_ujmp_relocate
,
1004 HOWTO (R_NIOS2_CJMP
,
1010 complain_overflow_dont
,
1011 nios2_elf32_cjmp_relocate
,
1018 HOWTO (R_NIOS2_CALLR
,
1024 complain_overflow_dont
,
1025 nios2_elf32_callr_relocate
,
1032 HOWTO (R_NIOS2_ALIGN
,
1038 complain_overflow_dont
,
1039 nios2_elf32_ignore_reloc
,
1046 HOWTO (R_NIOS2_GOT16
,
1052 complain_overflow_bitfield
,
1053 bfd_elf_generic_reloc
,
1060 HOWTO (R_NIOS2_CALL16
,
1066 complain_overflow_bitfield
,
1067 bfd_elf_generic_reloc
,
1074 HOWTO (R_NIOS2_GOTOFF_LO
,
1080 complain_overflow_dont
,
1081 bfd_elf_generic_reloc
,
1082 "R_NIOS2_GOTOFF_LO",
1088 HOWTO (R_NIOS2_GOTOFF_HA
,
1094 complain_overflow_dont
,
1095 bfd_elf_generic_reloc
,
1096 "R_NIOS2_GOTOFF_HA",
1102 HOWTO (R_NIOS2_PCREL_LO
,
1108 complain_overflow_dont
,
1109 nios2_elf32_pcrel_lo16_relocate
,
1116 HOWTO (R_NIOS2_PCREL_HA
,
1120 false, /* This is a PC-relative relocation, but we need to subtract
1121 PC ourselves before the HIADJ. */
1123 complain_overflow_dont
,
1124 nios2_elf32_pcrel_hiadj16_relocate
,
1131 HOWTO (R_NIOS2_TLS_GD16
,
1137 complain_overflow_bitfield
,
1138 bfd_elf_generic_reloc
,
1145 HOWTO (R_NIOS2_TLS_LDM16
,
1151 complain_overflow_bitfield
,
1152 bfd_elf_generic_reloc
,
1153 "R_NIOS2_TLS_LDM16",
1159 HOWTO (R_NIOS2_TLS_LDO16
,
1165 complain_overflow_bitfield
,
1166 bfd_elf_generic_reloc
,
1167 "R_NIOS2_TLS_LDO16",
1173 HOWTO (R_NIOS2_TLS_IE16
,
1179 complain_overflow_bitfield
,
1180 bfd_elf_generic_reloc
,
1187 HOWTO (R_NIOS2_TLS_LE16
,
1193 complain_overflow_bitfield
,
1194 bfd_elf_generic_reloc
,
1201 HOWTO (R_NIOS2_TLS_DTPMOD
,
1207 complain_overflow_dont
,
1208 bfd_elf_generic_reloc
,
1209 "R_NIOS2_TLS_DTPMOD",
1215 HOWTO (R_NIOS2_TLS_DTPREL
,
1221 complain_overflow_dont
,
1222 bfd_elf_generic_reloc
,
1223 "R_NIOS2_TLS_DTPREL",
1229 HOWTO (R_NIOS2_TLS_TPREL
,
1235 complain_overflow_dont
,
1236 bfd_elf_generic_reloc
,
1237 "R_NIOS2_TLS_TPREL",
1243 HOWTO (R_NIOS2_COPY
,
1249 complain_overflow_dont
,
1250 bfd_elf_generic_reloc
,
1257 HOWTO (R_NIOS2_GLOB_DAT
,
1263 complain_overflow_dont
,
1264 bfd_elf_generic_reloc
,
1271 HOWTO (R_NIOS2_JUMP_SLOT
,
1277 complain_overflow_dont
,
1278 bfd_elf_generic_reloc
,
1279 "R_NIOS2_JUMP_SLOT",
1285 HOWTO (R_NIOS2_RELATIVE
,
1291 complain_overflow_dont
,
1292 bfd_elf_generic_reloc
,
1299 HOWTO (R_NIOS2_GOTOFF
,
1305 complain_overflow_dont
,
1306 bfd_elf_generic_reloc
,
1313 HOWTO (R_NIOS2_CALL26_NOAT
, /* type */
1317 false, /* pc_relative */
1319 complain_overflow_dont
, /* complain on overflow */
1320 nios2_elf32_call26_relocate
, /* special function */
1321 "R_NIOS2_CALL26_NOAT", /* name */
1322 false, /* partial_inplace */
1323 0xffffffc0, /* src_mask */
1324 0xffffffc0, /* dst_mask */
1325 false), /* pcrel_offset */
1327 HOWTO (R_NIOS2_GOT_LO
,
1333 complain_overflow_dont
,
1334 bfd_elf_generic_reloc
,
1341 HOWTO (R_NIOS2_GOT_HA
,
1347 complain_overflow_dont
,
1348 bfd_elf_generic_reloc
,
1355 HOWTO (R_NIOS2_CALL_LO
,
1361 complain_overflow_dont
,
1362 bfd_elf_generic_reloc
,
1369 HOWTO (R_NIOS2_CALL_HA
,
1375 complain_overflow_dont
,
1376 bfd_elf_generic_reloc
,
1383 HOWTO (R_NIOS2_R2_S12
,
1389 complain_overflow_signed
,
1390 bfd_elf_generic_reloc
,
1397 HOWTO (R_NIOS2_R2_I10_1_PCREL
,
1403 complain_overflow_signed
,
1404 bfd_elf_generic_reloc
, /* FIXME? */
1405 "R_NIOS2_R2_I10_1_PCREL",
1411 HOWTO (R_NIOS2_R2_T1I7_1_PCREL
,
1417 complain_overflow_signed
,
1418 bfd_elf_generic_reloc
, /* FIXME? */
1419 "R_NIOS2_R2_T1I7_1_PCREL",
1425 HOWTO (R_NIOS2_R2_T1I7_2
,
1431 complain_overflow_unsigned
,
1432 bfd_elf_generic_reloc
,
1433 "R_NIOS2_R2_T1I7_2",
1439 HOWTO (R_NIOS2_R2_T2I4
,
1445 complain_overflow_unsigned
,
1446 bfd_elf_generic_reloc
,
1453 HOWTO (R_NIOS2_R2_T2I4_1
,
1459 complain_overflow_unsigned
,
1460 bfd_elf_generic_reloc
,
1461 "R_NIOS2_R2_T2I4_1",
1467 HOWTO (R_NIOS2_R2_T2I4_2
,
1473 complain_overflow_unsigned
,
1474 bfd_elf_generic_reloc
,
1475 "R_NIOS2_R2_T2I4_2",
1481 HOWTO (R_NIOS2_R2_X1I7_2
,
1487 complain_overflow_unsigned
,
1488 bfd_elf_generic_reloc
,
1489 "R_NIOS2_R2_X1I7_2",
1495 HOWTO (R_NIOS2_R2_X2L5
,
1501 complain_overflow_unsigned
,
1502 bfd_elf_generic_reloc
,
1509 HOWTO (R_NIOS2_R2_F1I5_2
,
1515 complain_overflow_unsigned
,
1516 bfd_elf_generic_reloc
,
1517 "R_NIOS2_R2_F1L5_2",
1523 HOWTO (R_NIOS2_R2_L5I4X1
,
1529 complain_overflow_unsigned
,
1530 bfd_elf_generic_reloc
,
1531 "R_NIOS2_R2_L5I4X1",
1537 HOWTO (R_NIOS2_R2_T1X1I6
,
1543 complain_overflow_unsigned
,
1544 bfd_elf_generic_reloc
,
1545 "R_NIOS2_R2_T1X1I6",
1551 HOWTO (R_NIOS2_R2_T1X1I6_2
,
1557 complain_overflow_unsigned
,
1558 bfd_elf_generic_reloc
,
1559 "R_NIOS2_R2_T1I1X6_2",
1565 /* Add other relocations here. */
1568 static unsigned char elf_code_to_howto_index
[R_NIOS2_ILLEGAL
+ 1];
1571 /* Return true if producing output for a R2 BFD. */
1572 #define BFD_IS_R2(abfd) (bfd_get_mach (abfd) == bfd_mach_nios2r2)
1574 /* Return the howto for relocation RTYPE. */
1575 static reloc_howto_type
*
1576 lookup_howto (unsigned int rtype
, bfd
*abfd
)
1578 static int initialized
= 0;
1580 /* R2 relocations are a superset of R1, so use that for the lookup
1582 int r1_howto_tbl_size
= (int) ARRAY_SIZE (elf_nios2_r1_howto_table_rel
);
1583 int r2_howto_tbl_size
= (int) ARRAY_SIZE (elf_nios2_r2_howto_table_rel
);
1588 memset (elf_code_to_howto_index
, 0xff,
1589 sizeof (elf_code_to_howto_index
));
1590 for (i
= 0; i
< r2_howto_tbl_size
; i
++)
1592 elf_code_to_howto_index
[elf_nios2_r2_howto_table_rel
[i
].type
] = i
;
1593 if (i
< r1_howto_tbl_size
)
1594 BFD_ASSERT (elf_nios2_r2_howto_table_rel
[i
].type
1595 == elf_nios2_r1_howto_table_rel
[i
].type
);
1599 if (rtype
> R_NIOS2_ILLEGAL
)
1601 i
= elf_code_to_howto_index
[rtype
];
1602 if (BFD_IS_R2 (abfd
))
1604 if (i
>= r2_howto_tbl_size
)
1606 return elf_nios2_r2_howto_table_rel
+ i
;
1610 if (i
>= r1_howto_tbl_size
)
1612 return elf_nios2_r1_howto_table_rel
+ i
;
1616 /* Map for converting BFD reloc types to Nios II reloc types. */
1617 struct elf_reloc_map
1619 bfd_reloc_code_real_type bfd_val
;
1620 enum elf_nios2_reloc_type elf_val
;
1623 static const struct elf_reloc_map nios2_reloc_map
[] =
1625 {BFD_RELOC_NONE
, R_NIOS2_NONE
},
1626 {BFD_RELOC_NIOS2_S16
, R_NIOS2_S16
},
1627 {BFD_RELOC_NIOS2_U16
, R_NIOS2_U16
},
1628 {BFD_RELOC_16_PCREL
, R_NIOS2_PCREL16
},
1629 {BFD_RELOC_NIOS2_CALL26
, R_NIOS2_CALL26
},
1630 {BFD_RELOC_NIOS2_IMM5
, R_NIOS2_IMM5
},
1631 {BFD_RELOC_NIOS2_CACHE_OPX
, R_NIOS2_CACHE_OPX
},
1632 {BFD_RELOC_NIOS2_IMM6
, R_NIOS2_IMM6
},
1633 {BFD_RELOC_NIOS2_IMM8
, R_NIOS2_IMM8
},
1634 {BFD_RELOC_NIOS2_HI16
, R_NIOS2_HI16
},
1635 {BFD_RELOC_NIOS2_LO16
, R_NIOS2_LO16
},
1636 {BFD_RELOC_NIOS2_HIADJ16
, R_NIOS2_HIADJ16
},
1637 {BFD_RELOC_32
, R_NIOS2_BFD_RELOC_32
},
1638 {BFD_RELOC_16
, R_NIOS2_BFD_RELOC_16
},
1639 {BFD_RELOC_8
, R_NIOS2_BFD_RELOC_8
},
1640 {BFD_RELOC_NIOS2_GPREL
, R_NIOS2_GPREL
},
1641 {BFD_RELOC_VTABLE_INHERIT
, R_NIOS2_GNU_VTINHERIT
},
1642 {BFD_RELOC_VTABLE_ENTRY
, R_NIOS2_GNU_VTENTRY
},
1643 {BFD_RELOC_NIOS2_UJMP
, R_NIOS2_UJMP
},
1644 {BFD_RELOC_NIOS2_CJMP
, R_NIOS2_CJMP
},
1645 {BFD_RELOC_NIOS2_CALLR
, R_NIOS2_CALLR
},
1646 {BFD_RELOC_NIOS2_ALIGN
, R_NIOS2_ALIGN
},
1647 {BFD_RELOC_NIOS2_GOT16
, R_NIOS2_GOT16
},
1648 {BFD_RELOC_NIOS2_CALL16
, R_NIOS2_CALL16
},
1649 {BFD_RELOC_NIOS2_GOTOFF_LO
, R_NIOS2_GOTOFF_LO
},
1650 {BFD_RELOC_NIOS2_GOTOFF_HA
, R_NIOS2_GOTOFF_HA
},
1651 {BFD_RELOC_NIOS2_PCREL_LO
, R_NIOS2_PCREL_LO
},
1652 {BFD_RELOC_NIOS2_PCREL_HA
, R_NIOS2_PCREL_HA
},
1653 {BFD_RELOC_NIOS2_TLS_GD16
, R_NIOS2_TLS_GD16
},
1654 {BFD_RELOC_NIOS2_TLS_LDM16
, R_NIOS2_TLS_LDM16
},
1655 {BFD_RELOC_NIOS2_TLS_LDO16
, R_NIOS2_TLS_LDO16
},
1656 {BFD_RELOC_NIOS2_TLS_IE16
, R_NIOS2_TLS_IE16
},
1657 {BFD_RELOC_NIOS2_TLS_LE16
, R_NIOS2_TLS_LE16
},
1658 {BFD_RELOC_NIOS2_TLS_DTPMOD
, R_NIOS2_TLS_DTPMOD
},
1659 {BFD_RELOC_NIOS2_TLS_DTPREL
, R_NIOS2_TLS_DTPREL
},
1660 {BFD_RELOC_NIOS2_TLS_TPREL
, R_NIOS2_TLS_TPREL
},
1661 {BFD_RELOC_NIOS2_COPY
, R_NIOS2_COPY
},
1662 {BFD_RELOC_NIOS2_GLOB_DAT
, R_NIOS2_GLOB_DAT
},
1663 {BFD_RELOC_NIOS2_JUMP_SLOT
, R_NIOS2_JUMP_SLOT
},
1664 {BFD_RELOC_NIOS2_RELATIVE
, R_NIOS2_RELATIVE
},
1665 {BFD_RELOC_NIOS2_GOTOFF
, R_NIOS2_GOTOFF
},
1666 {BFD_RELOC_NIOS2_CALL26_NOAT
, R_NIOS2_CALL26_NOAT
},
1667 {BFD_RELOC_NIOS2_GOT_LO
, R_NIOS2_GOT_LO
},
1668 {BFD_RELOC_NIOS2_GOT_HA
, R_NIOS2_GOT_HA
},
1669 {BFD_RELOC_NIOS2_CALL_LO
, R_NIOS2_CALL_LO
},
1670 {BFD_RELOC_NIOS2_CALL_HA
, R_NIOS2_CALL_HA
},
1671 {BFD_RELOC_NIOS2_R2_S12
, R_NIOS2_R2_S12
},
1672 {BFD_RELOC_NIOS2_R2_I10_1_PCREL
, R_NIOS2_R2_I10_1_PCREL
},
1673 {BFD_RELOC_NIOS2_R2_T1I7_1_PCREL
, R_NIOS2_R2_T1I7_1_PCREL
},
1674 {BFD_RELOC_NIOS2_R2_T1I7_2
, R_NIOS2_R2_T1I7_2
},
1675 {BFD_RELOC_NIOS2_R2_T2I4
, R_NIOS2_R2_T2I4
},
1676 {BFD_RELOC_NIOS2_R2_T2I4_1
, R_NIOS2_R2_T2I4_1
},
1677 {BFD_RELOC_NIOS2_R2_T2I4_2
, R_NIOS2_R2_T2I4_2
},
1678 {BFD_RELOC_NIOS2_R2_X1I7_2
, R_NIOS2_R2_X1I7_2
},
1679 {BFD_RELOC_NIOS2_R2_X2L5
, R_NIOS2_R2_X2L5
},
1680 {BFD_RELOC_NIOS2_R2_F1I5_2
, R_NIOS2_R2_F1I5_2
},
1681 {BFD_RELOC_NIOS2_R2_L5I4X1
, R_NIOS2_R2_L5I4X1
},
1682 {BFD_RELOC_NIOS2_R2_T1X1I6
, R_NIOS2_R2_T1X1I6
},
1683 {BFD_RELOC_NIOS2_R2_T1X1I6_2
, R_NIOS2_R2_T1X1I6_2
},
1686 enum elf32_nios2_stub_type
1688 nios2_stub_call26_before
,
1689 nios2_stub_call26_after
,
1693 struct elf32_nios2_stub_hash_entry
1695 /* Base hash table entry structure. */
1696 struct bfd_hash_entry bh_root
;
1698 /* The stub section. */
1701 /* Offset within stub_sec of the beginning of this stub. */
1702 bfd_vma stub_offset
;
1704 /* Given the symbol's value and its section we can determine its final
1705 value when building the stubs (so the stub knows where to jump. */
1706 bfd_vma target_value
;
1707 asection
*target_section
;
1709 enum elf32_nios2_stub_type stub_type
;
1711 /* The symbol table entry, if any, that this was derived from. */
1712 struct elf32_nios2_link_hash_entry
*hh
;
1714 /* And the reloc addend that this was derived from. */
1717 /* Where this stub is being called from, or, in the case of combined
1718 stub sections, the first input section in the group. */
1722 #define nios2_stub_hash_entry(ent) \
1723 ((struct elf32_nios2_stub_hash_entry *)(ent))
1725 #define nios2_stub_hash_lookup(table, string, create, copy) \
1726 ((struct elf32_nios2_stub_hash_entry *) \
1727 bfd_hash_lookup ((table), (string), (create), (copy)))
1730 /* Nios II ELF linker hash entry. */
1732 struct elf32_nios2_link_hash_entry
1734 struct elf_link_hash_entry root
;
1736 /* A pointer to the most recently used stub hash entry against this
1738 struct elf32_nios2_stub_hash_entry
*hsh_cache
;
1740 #define GOT_UNKNOWN 0
1741 #define GOT_NORMAL 1
1742 #define GOT_TLS_GD 2
1743 #define GOT_TLS_IE 4
1744 unsigned char tls_type
;
1746 /* We need to detect and take special action for symbols which are only
1747 referenced with %call() and not with %got(). Such symbols do not need
1748 a dynamic GOT reloc in shared objects, only a dynamic PLT reloc. Lazy
1749 linking will not work if the dynamic GOT reloc exists.
1750 To check for this condition efficiently, we compare got_types_used against
1752 (got_types_used & (GOT_USED | CALL_USED)) == CALL_USED.
1756 unsigned char got_types_used
;
1759 #define elf32_nios2_hash_entry(ent) \
1760 ((struct elf32_nios2_link_hash_entry *) (ent))
1762 /* Get the Nios II elf linker hash table from a link_info structure. */
1763 #define elf32_nios2_hash_table(info) \
1764 ((struct elf32_nios2_link_hash_table *) ((info)->hash))
1766 /* Nios II ELF linker hash table. */
1767 struct elf32_nios2_link_hash_table
1769 /* The main hash table. */
1770 struct elf_link_hash_table root
;
1772 /* The stub hash table. */
1773 struct bfd_hash_table bstab
;
1775 /* Linker stub bfd. */
1778 /* Linker call-backs. */
1779 asection
* (*add_stub_section
) (const char *, asection
*, bool);
1780 void (*layout_sections_again
) (void);
1782 /* Array to keep track of which stub sections have been created, and
1783 information on stub grouping. */
1786 /* These are the section to which stubs in the group will be
1788 asection
*first_sec
, *last_sec
;
1789 /* The stub sections. There might be stubs inserted either before
1790 or after the real section.*/
1791 asection
*first_stub_sec
, *last_stub_sec
;
1794 /* Assorted information used by nios2_elf32_size_stubs. */
1795 unsigned int bfd_count
;
1796 unsigned int top_index
;
1797 asection
**input_list
;
1798 Elf_Internal_Sym
**all_local_syms
;
1800 /* Short-cuts to get to dynamic linker sections. */
1803 /* GOT pointer symbol _gp_got. */
1804 struct elf_link_hash_entry
*h_gp_got
;
1807 bfd_signed_vma refcount
;
1814 struct nios2_elf32_obj_tdata
1816 struct elf_obj_tdata root
;
1818 /* tls_type for each local got entry. */
1819 char *local_got_tls_type
;
1821 /* TRUE if TLS GD relocs have been seen for this object. */
1825 #define elf32_nios2_tdata(abfd) \
1826 ((struct nios2_elf32_obj_tdata *) (abfd)->tdata.any)
1828 #define elf32_nios2_local_got_tls_type(abfd) \
1829 (elf32_nios2_tdata (abfd)->local_got_tls_type)
1831 /* The name of the dynamic interpreter. This is put in the .interp
1833 #define ELF_DYNAMIC_INTERPRETER "/lib/ld.so.1"
1835 /* PLT implementation for position-dependent code. */
1836 static const bfd_vma nios2_plt_entry
[] = { /* .PLTn: */
1837 0x03c00034, /* movhi r15, %hiadj(plt_got_slot_address) */
1838 0x7bc00017, /* ldw r15, %lo(plt_got_slot_address)(r15) */
1839 0x7800683a /* jmp r15 */
1842 static const bfd_vma nios2_plt0_entry
[] = { /* .PLTresolve */
1843 0x03800034, /* movhi r14, %hiadj(res_0) */
1844 0x73800004, /* addi r14, r14, %lo(res_0) */
1845 0x7b9fc83a, /* sub r15, r15, r14 */
1846 0x03400034, /* movhi r13, %hiadj(_GLOBAL_OFFSET_TABLE_) */
1847 0x6b800017, /* ldw r14, %lo(_GLOBAL_OFFSET_TABLE_+4)(r13) */
1848 0x6b400017, /* ldw r13, %lo(_GLOBAL_OFFSET_TABLE_+8)(r13) */
1849 0x6800683a /* jmp r13 */
1852 /* PLT implementation for position-independent code. */
1853 static const bfd_vma nios2_so_plt_entry
[] = { /* .PLTn */
1854 0x03c00034, /* movhi r15, %hiadj(index * 4) */
1855 0x7bc00004, /* addi r15, r15, %lo(index * 4) */
1856 0x00000006 /* br .PLTresolve */
1859 static const bfd_vma nios2_so_plt0_entry
[] = { /* .PLTresolve */
1860 0x001ce03a, /* nextpc r14 */
1861 0x03400034, /* movhi r13, %hiadj(_GLOBAL_OFFSET_TABLE_) */
1862 0x6b9b883a, /* add r13, r13, r14 */
1863 0x6b800017, /* ldw r14, %lo(_GLOBAL_OFFSET_TABLE_+4)(r13) */
1864 0x6b400017, /* ldw r13, %lo(_GLOBAL_OFFSET_TABLE_+8)(r13) */
1865 0x6800683a /* jmp r13 */
1869 static const bfd_vma nios2_call26_stub_entry
[] = {
1870 0x00400034, /* orhi at, r0, %hiadj(dest) */
1871 0x08400004, /* addi at, at, %lo(dest) */
1872 0x0800683a /* jmp at */
1875 /* Install 16-bit immediate value VALUE at offset OFFSET into section SEC. */
1877 nios2_elf32_install_imm16 (asection
*sec
, bfd_vma offset
, bfd_vma value
)
1879 bfd_vma word
= bfd_get_32 (sec
->owner
, sec
->contents
+ offset
);
1881 BFD_ASSERT (value
<= 0xffff || ((bfd_signed_vma
) value
) >= -0xffff);
1883 bfd_put_32 (sec
->owner
, word
| ((value
& 0xffff) << 6),
1884 sec
->contents
+ offset
);
1887 /* Install COUNT 32-bit values DATA starting at offset OFFSET into
1890 nios2_elf32_install_data (asection
*sec
, const bfd_vma
*data
, bfd_vma offset
,
1895 bfd_put_32 (sec
->owner
, *data
, sec
->contents
+ offset
);
1901 /* The usual way of loading a 32-bit constant into a Nios II register is to
1902 load the high 16 bits in one instruction and then add the low 16 bits with
1903 a signed add. This means that the high halfword needs to be adjusted to
1904 compensate for the sign bit of the low halfword. This function returns the
1905 adjusted high halfword for a given 32-bit constant. */
1907 bfd_vma
hiadj (bfd_vma symbol_value
)
1909 return ((symbol_value
+ 0x8000) >> 16) & 0xffff;
1912 /* Implement elf_backend_grok_prstatus:
1913 Support for core dump NOTE sections. */
1915 nios2_grok_prstatus (bfd
*abfd
, Elf_Internal_Note
*note
)
1920 switch (note
->descsz
)
1925 case 212: /* Linux/Nios II */
1927 elf_tdata (abfd
)->core
->signal
= bfd_get_16 (abfd
, note
->descdata
+ 12);
1930 elf_tdata (abfd
)->core
->pid
= bfd_get_32 (abfd
, note
->descdata
+ 24);
1939 /* Make a ".reg/999" section. */
1940 return _bfd_elfcore_make_pseudosection (abfd
, ".reg",
1941 size
, note
->descpos
+ offset
);
1944 /* Implement elf_backend_grok_psinfo. */
1946 nios2_grok_psinfo (bfd
*abfd
, Elf_Internal_Note
*note
)
1948 switch (note
->descsz
)
1953 case 124: /* Linux/Nios II elf_prpsinfo */
1954 elf_tdata (abfd
)->core
->program
1955 = _bfd_elfcore_strndup (abfd
, note
->descdata
+ 28, 16);
1956 elf_tdata (abfd
)->core
->command
1957 = _bfd_elfcore_strndup (abfd
, note
->descdata
+ 44, 80);
1960 /* Note that for some reason, a spurious space is tacked
1961 onto the end of the args in some (at least one anyway)
1962 implementations, so strip it off if it exists. */
1965 char *command
= elf_tdata (abfd
)->core
->command
;
1966 int n
= strlen (command
);
1968 if (0 < n
&& command
[n
- 1] == ' ')
1969 command
[n
- 1] = '\0';
1975 /* Assorted hash table functions. */
1977 /* Initialize an entry in the stub hash table. */
1978 static struct bfd_hash_entry
*
1979 stub_hash_newfunc (struct bfd_hash_entry
*entry
,
1980 struct bfd_hash_table
*table
,
1983 /* Allocate the structure if it has not already been allocated by a
1987 entry
= bfd_hash_allocate (table
,
1988 sizeof (struct elf32_nios2_stub_hash_entry
));
1993 /* Call the allocation method of the superclass. */
1994 entry
= bfd_hash_newfunc (entry
, table
, string
);
1997 struct elf32_nios2_stub_hash_entry
*hsh
;
1999 /* Initialize the local fields. */
2000 hsh
= (struct elf32_nios2_stub_hash_entry
*) entry
;
2001 hsh
->stub_sec
= NULL
;
2002 hsh
->stub_offset
= 0;
2003 hsh
->target_value
= 0;
2004 hsh
->target_section
= NULL
;
2005 hsh
->stub_type
= nios2_stub_none
;
2013 /* Create an entry in a Nios II ELF linker hash table. */
2014 static struct bfd_hash_entry
*
2015 link_hash_newfunc (struct bfd_hash_entry
*entry
,
2016 struct bfd_hash_table
*table
, const char *string
)
2018 /* Allocate the structure if it has not already been allocated by a
2022 entry
= bfd_hash_allocate (table
,
2023 sizeof (struct elf32_nios2_link_hash_entry
));
2028 /* Call the allocation method of the superclass. */
2029 entry
= _bfd_elf_link_hash_newfunc (entry
, table
, string
);
2032 struct elf32_nios2_link_hash_entry
*eh
;
2034 eh
= (struct elf32_nios2_link_hash_entry
*) entry
;
2035 eh
->hsh_cache
= NULL
;
2036 eh
->tls_type
= GOT_UNKNOWN
;
2037 eh
->got_types_used
= 0;
2043 /* Section name for stubs is the associated section name plus this
2045 #define STUB_SUFFIX ".stub"
2047 /* Build a name for an entry in the stub hash table. */
2049 nios2_stub_name (const asection
*input_section
,
2050 const asection
*sym_sec
,
2051 const struct elf32_nios2_link_hash_entry
*hh
,
2052 const Elf_Internal_Rela
*rel
,
2053 enum elf32_nios2_stub_type stub_type
)
2057 char stubpos
= (stub_type
== nios2_stub_call26_before
) ? 'b' : 'a';
2061 len
= 8 + 1 + 1 + 1+ strlen (hh
->root
.root
.root
.string
) + 1 + 8 + 1;
2062 stub_name
= bfd_malloc (len
);
2063 if (stub_name
!= NULL
)
2065 sprintf (stub_name
, "%08x_%c_%s+%x",
2066 input_section
->id
& 0xffffffff,
2068 hh
->root
.root
.root
.string
,
2069 (int) rel
->r_addend
& 0xffffffff);
2074 len
= 8 + 1 + 1 + 1+ 8 + 1 + 8 + 1 + 8 + 1;
2075 stub_name
= bfd_malloc (len
);
2076 if (stub_name
!= NULL
)
2078 sprintf (stub_name
, "%08x_%c_%x:%x+%x",
2079 input_section
->id
& 0xffffffff,
2081 sym_sec
->id
& 0xffffffff,
2082 (int) ELF32_R_SYM (rel
->r_info
) & 0xffffffff,
2083 (int) rel
->r_addend
& 0xffffffff);
2089 /* Look up an entry in the stub hash. Stub entries are cached because
2090 creating the stub name takes a bit of time. */
2091 static struct elf32_nios2_stub_hash_entry
*
2092 nios2_get_stub_entry (const asection
*input_section
,
2093 const asection
*sym_sec
,
2094 struct elf32_nios2_link_hash_entry
*hh
,
2095 const Elf_Internal_Rela
*rel
,
2096 struct elf32_nios2_link_hash_table
*htab
,
2097 enum elf32_nios2_stub_type stub_type
)
2099 struct elf32_nios2_stub_hash_entry
*hsh
;
2100 const asection
*id_sec
;
2102 /* If this input section is part of a group of sections sharing one
2103 stub section, then use the id of the first/last section in the group,
2104 depending on the stub section placement relative to the group.
2105 Stub names need to include a section id, as there may well be
2106 more than one stub used to reach say, printf, and we need to
2107 distinguish between them. */
2108 if (stub_type
== nios2_stub_call26_before
)
2109 id_sec
= htab
->stub_group
[input_section
->id
].first_sec
;
2111 id_sec
= htab
->stub_group
[input_section
->id
].last_sec
;
2113 if (hh
!= NULL
&& hh
->hsh_cache
!= NULL
2114 && hh
->hsh_cache
->hh
== hh
2115 && hh
->hsh_cache
->id_sec
== id_sec
2116 && hh
->hsh_cache
->stub_type
== stub_type
)
2118 hsh
= hh
->hsh_cache
;
2124 stub_name
= nios2_stub_name (id_sec
, sym_sec
, hh
, rel
, stub_type
);
2125 if (stub_name
== NULL
)
2128 hsh
= nios2_stub_hash_lookup (&htab
->bstab
,
2129 stub_name
, false, false);
2132 hh
->hsh_cache
= hsh
;
2140 /* Add a new stub entry to the stub hash. Not all fields of the new
2141 stub entry are initialised. */
2142 static struct elf32_nios2_stub_hash_entry
*
2143 nios2_add_stub (const char *stub_name
,
2145 struct elf32_nios2_link_hash_table
*htab
,
2146 enum elf32_nios2_stub_type stub_type
)
2150 asection
**secptr
, **linkptr
;
2151 struct elf32_nios2_stub_hash_entry
*hsh
;
2154 if (stub_type
== nios2_stub_call26_before
)
2156 link_sec
= htab
->stub_group
[section
->id
].first_sec
;
2157 secptr
= &(htab
->stub_group
[section
->id
].first_stub_sec
);
2158 linkptr
= &(htab
->stub_group
[link_sec
->id
].first_stub_sec
);
2163 link_sec
= htab
->stub_group
[section
->id
].last_sec
;
2164 secptr
= &(htab
->stub_group
[section
->id
].last_stub_sec
);
2165 linkptr
= &(htab
->stub_group
[link_sec
->id
].last_stub_sec
);
2169 if (stub_sec
== NULL
)
2171 stub_sec
= *linkptr
;
2172 if (stub_sec
== NULL
)
2178 namelen
= strlen (link_sec
->name
);
2179 len
= namelen
+ sizeof (STUB_SUFFIX
);
2180 s_name
= bfd_alloc (htab
->stub_bfd
, len
);
2184 memcpy (s_name
, link_sec
->name
, namelen
);
2185 memcpy (s_name
+ namelen
, STUB_SUFFIX
, sizeof (STUB_SUFFIX
));
2187 stub_sec
= (*htab
->add_stub_section
) (s_name
, link_sec
, afterp
);
2188 if (stub_sec
== NULL
)
2190 *linkptr
= stub_sec
;
2195 /* Enter this entry into the linker stub hash table. */
2196 hsh
= nios2_stub_hash_lookup (&htab
->bstab
, stub_name
,
2200 /* xgettext:c-format */
2201 _bfd_error_handler (_("%pB: cannot create stub entry %s"),
2207 hsh
->stub_sec
= stub_sec
;
2208 hsh
->stub_offset
= 0;
2209 hsh
->id_sec
= link_sec
;
2213 /* Set up various things so that we can make a list of input sections
2214 for each output section included in the link. Returns -1 on error,
2215 0 when no stubs will be needed, and 1 on success. */
2217 nios2_elf32_setup_section_lists (bfd
*output_bfd
, struct bfd_link_info
*info
)
2220 unsigned int bfd_count
;
2221 unsigned int top_id
, top_index
;
2223 asection
**input_list
, **list
;
2225 struct elf32_nios2_link_hash_table
*htab
= elf32_nios2_hash_table (info
);
2227 /* Count the number of input BFDs and find the top input section id. */
2228 for (input_bfd
= info
->input_bfds
, bfd_count
= 0, top_id
= 0;
2230 input_bfd
= input_bfd
->link
.next
)
2233 for (section
= input_bfd
->sections
;
2235 section
= section
->next
)
2237 if (top_id
< section
->id
)
2238 top_id
= section
->id
;
2242 htab
->bfd_count
= bfd_count
;
2244 amt
= sizeof (struct map_stub
) * (top_id
+ 1);
2245 htab
->stub_group
= bfd_zmalloc (amt
);
2246 if (htab
->stub_group
== NULL
)
2249 /* We can't use output_bfd->section_count here to find the top output
2250 section index as some sections may have been removed, and
2251 strip_excluded_output_sections doesn't renumber the indices. */
2252 for (section
= output_bfd
->sections
, top_index
= 0;
2254 section
= section
->next
)
2256 if (top_index
< section
->index
)
2257 top_index
= section
->index
;
2260 htab
->top_index
= top_index
;
2261 amt
= sizeof (asection
*) * (top_index
+ 1);
2262 input_list
= bfd_malloc (amt
);
2263 htab
->input_list
= input_list
;
2264 if (input_list
== NULL
)
2267 /* For sections we aren't interested in, mark their entries with a
2268 value we can check later. */
2269 list
= input_list
+ top_index
;
2271 *list
= bfd_abs_section_ptr
;
2272 while (list
-- != input_list
);
2274 for (section
= output_bfd
->sections
;
2276 section
= section
->next
)
2278 /* FIXME: This is a bit of hack. Currently our .ctors and .dtors
2279 * have PC relative relocs in them but no code flag set. */
2280 if (((section
->flags
& SEC_CODE
) != 0) ||
2281 strcmp(".ctors", section
->name
) ||
2282 strcmp(".dtors", section
->name
))
2283 input_list
[section
->index
] = NULL
;
2289 /* The linker repeatedly calls this function for each input section,
2290 in the order that input sections are linked into output sections.
2291 Build lists of input sections to determine groupings between which
2292 we may insert linker stubs. */
2294 nios2_elf32_next_input_section (struct bfd_link_info
*info
, asection
*isec
)
2296 struct elf32_nios2_link_hash_table
*htab
= elf32_nios2_hash_table (info
);
2298 if (isec
->output_section
->index
<= htab
->top_index
)
2300 asection
**list
= htab
->input_list
+ isec
->output_section
->index
;
2301 if (*list
!= bfd_abs_section_ptr
)
2303 /* Steal the last_sec pointer for our list.
2304 This happens to make the list in reverse order,
2305 which is what we want. */
2306 htab
->stub_group
[isec
->id
].last_sec
= *list
;
2312 /* Segment mask for CALL26 relocation relaxation. */
2313 #define CALL26_SEGMENT(x) ((x) & 0xf0000000)
2315 /* Fudge factor for approximate maximum size of all stubs that might
2316 be inserted by the linker. This does not actually limit the number
2317 of stubs that might be inserted, and only affects strategy for grouping
2318 and placement of stubs. Perhaps this should be computed based on number
2319 of relocations seen, or be specifiable on the command line. */
2320 #define MAX_STUB_SECTION_SIZE 0xffff
2322 /* See whether we can group stub sections together. Grouping stub
2323 sections may result in fewer stubs. More importantly, we need to
2324 put all .init* and .fini* stubs at the end of the .init or
2325 .fini output sections respectively, because glibc splits the
2326 _init and _fini functions into multiple parts. Putting a stub in
2327 the middle of a function is not a good idea.
2328 Rather than computing groups of a maximum fixed size, for Nios II
2329 CALL26 relaxation it makes more sense to compute the groups based on
2330 sections that fit within a 256MB address segment. Also do not allow
2331 a group to span more than one output section, since different output
2332 sections might correspond to different memory banks on a bare-metal
2335 group_sections (struct elf32_nios2_link_hash_table
*htab
)
2337 asection
**list
= htab
->input_list
+ htab
->top_index
;
2340 /* The list is in reverse order so we'll search backwards looking
2341 for the first section that begins in the same memory segment,
2342 marking sections along the way to point at the tail for this
2344 asection
*tail
= *list
;
2345 if (tail
== bfd_abs_section_ptr
)
2347 while (tail
!= NULL
)
2349 bfd_vma start
= tail
->output_section
->vma
+ tail
->output_offset
;
2350 bfd_vma end
= start
+ tail
->size
;
2351 bfd_vma segment
= CALL26_SEGMENT (end
);
2354 if (segment
!= CALL26_SEGMENT (start
)
2355 || segment
!= CALL26_SEGMENT (end
+ MAX_STUB_SECTION_SIZE
))
2356 /* This section spans more than one memory segment, or is
2357 close enough to the end of the segment that adding stub
2358 sections before it might cause it to move so that it
2359 spans memory segments, or that stubs added at the end of
2360 this group might overflow into the next memory segment.
2361 Put it in a group by itself to localize the effects. */
2363 prev
= htab
->stub_group
[tail
->id
].last_sec
;
2364 htab
->stub_group
[tail
->id
].last_sec
= tail
;
2365 htab
->stub_group
[tail
->id
].first_sec
= tail
;
2368 /* Collect more sections for this group. */
2370 asection
*curr
, *first
;
2371 for (curr
= tail
; ; curr
= prev
)
2373 prev
= htab
->stub_group
[curr
->id
].last_sec
;
2375 || tail
->output_section
!= prev
->output_section
2376 || (CALL26_SEGMENT (prev
->output_section
->vma
2377 + prev
->output_offset
)
2382 for (curr
= tail
; ; curr
= prev
)
2384 prev
= htab
->stub_group
[curr
->id
].last_sec
;
2385 htab
->stub_group
[curr
->id
].last_sec
= tail
;
2386 htab
->stub_group
[curr
->id
].first_sec
= first
;
2392 /* Reset tail for the next group. */
2396 while (list
-- != htab
->input_list
);
2397 free (htab
->input_list
);
2400 /* Determine the type of stub needed, if any, for a call. */
2401 static enum elf32_nios2_stub_type
2402 nios2_type_of_stub (asection
*input_sec
,
2403 const Elf_Internal_Rela
*rel
,
2404 struct elf32_nios2_link_hash_entry
*hh
,
2405 struct elf32_nios2_link_hash_table
*htab
,
2406 bfd_vma destination
,
2407 struct bfd_link_info
*info ATTRIBUTE_UNUSED
)
2409 bfd_vma location
, segment
, start
, end
;
2410 asection
*s0
, *s1
, *s
;
2413 !(hh
->root
.root
.type
== bfd_link_hash_defined
2414 || hh
->root
.root
.type
== bfd_link_hash_defweak
))
2415 return nios2_stub_none
;
2417 /* Determine where the call point is. */
2418 location
= (input_sec
->output_section
->vma
2419 + input_sec
->output_offset
+ rel
->r_offset
);
2420 segment
= CALL26_SEGMENT (location
);
2422 /* Nios II CALL and JMPI instructions can transfer control to addresses
2423 within the same 256MB segment as the PC. */
2424 if (segment
== CALL26_SEGMENT (destination
))
2425 return nios2_stub_none
;
2427 /* Find the start and end addresses of the stub group. Also account for
2428 any already-created stub sections for this group. Note that for stubs
2429 in the end section, only the first instruction of the last stub
2430 (12 bytes long) needs to be within range. */
2431 s0
= htab
->stub_group
[input_sec
->id
].first_sec
;
2432 s
= htab
->stub_group
[s0
->id
].first_stub_sec
;
2433 if (s
!= NULL
&& s
->size
> 0)
2434 start
= s
->output_section
->vma
+ s
->output_offset
;
2436 start
= s0
->output_section
->vma
+ s0
->output_offset
;
2438 s1
= htab
->stub_group
[input_sec
->id
].last_sec
;
2439 s
= htab
->stub_group
[s1
->id
].last_stub_sec
;
2440 if (s
!= NULL
&& s
->size
> 0)
2441 end
= s
->output_section
->vma
+ s
->output_offset
+ s
->size
- 8;
2443 end
= s1
->output_section
->vma
+ s1
->output_offset
+ s1
->size
;
2445 BFD_ASSERT (start
< end
);
2446 BFD_ASSERT (start
<= location
);
2447 BFD_ASSERT (location
< end
);
2449 /* Put stubs at the end of the group unless that is not a valid
2450 location and the beginning of the group is. It might be that
2451 neither the beginning nor end works if we have an input section
2452 so large that it spans multiple segment boundaries. In that
2453 case, punt; the end result will be a relocation overflow error no
2454 matter what we do here.
2456 Note that adding stubs pushes up the addresses of all subsequent
2457 sections, so that stubs allocated on one pass through the
2458 relaxation loop may not be valid on the next pass. (E.g., we may
2459 allocate a stub at the beginning of the section on one pass and
2460 find that the call site has been bumped into the next memory
2461 segment on the next pass.) The important thing to note is that
2462 we never try to reclaim the space allocated to such unused stubs,
2463 so code size and section addresses can only increase with each
2464 iteration. Accounting for the start and end addresses of the
2465 already-created stub sections ensures that when the algorithm
2466 converges, it converges accurately, with the entire appropriate
2467 stub section accessible from the call site and not just the
2468 address at the start or end of the stub group proper. */
2470 if (segment
== CALL26_SEGMENT (end
))
2471 return nios2_stub_call26_after
;
2472 else if (segment
== CALL26_SEGMENT (start
))
2473 return nios2_stub_call26_before
;
2475 /* Perhaps this should be a dedicated error code. */
2476 return nios2_stub_none
;
2480 nios2_build_one_stub (struct bfd_hash_entry
*gen_entry
, void *in_arg ATTRIBUTE_UNUSED
)
2482 struct elf32_nios2_stub_hash_entry
*hsh
2483 = (struct elf32_nios2_stub_hash_entry
*) gen_entry
;
2484 asection
*stub_sec
= hsh
->stub_sec
;
2486 struct bfd_link_info
*info
;
2488 info
= (struct bfd_link_info
*) in_arg
;
2490 /* Fail if the target section could not be assigned to an output
2491 section. The user should fix his linker script. */
2492 if (hsh
->target_section
->output_section
== NULL
2493 && info
->non_contiguous_regions
)
2494 info
->callbacks
->einfo (_("%F%P: Could not assign `%pA' to an output section. "
2495 "Retry without --enable-non-contiguous-regions.\n"),
2496 hsh
->target_section
);
2498 /* Make a note of the offset within the stubs for this entry. */
2499 hsh
->stub_offset
= stub_sec
->size
;
2501 switch (hsh
->stub_type
)
2503 case nios2_stub_call26_before
:
2504 case nios2_stub_call26_after
:
2505 /* A call26 stub looks like:
2506 orhi at, %hiadj(dest)
2507 addi at, at, %lo(dest)
2509 Note that call/jmpi instructions can't be used in PIC code
2510 so there is no reason for the stub to be PIC, either. */
2511 sym_value
= (hsh
->target_value
2512 + hsh
->target_section
->output_offset
2513 + hsh
->target_section
->output_section
->vma
2516 nios2_elf32_install_data (stub_sec
, nios2_call26_stub_entry
,
2517 hsh
->stub_offset
, 3);
2518 nios2_elf32_install_imm16 (stub_sec
, hsh
->stub_offset
,
2520 nios2_elf32_install_imm16 (stub_sec
, hsh
->stub_offset
+ 4,
2521 (sym_value
& 0xffff));
2522 stub_sec
->size
+= 12;
2532 /* As above, but don't actually build the stub. Just bump offset so
2533 we know stub section sizes. */
2535 nios2_size_one_stub (struct bfd_hash_entry
*gen_entry
, void *in_arg ATTRIBUTE_UNUSED
)
2537 struct elf32_nios2_stub_hash_entry
*hsh
2538 = (struct elf32_nios2_stub_hash_entry
*) gen_entry
;
2540 switch (hsh
->stub_type
)
2542 case nios2_stub_call26_before
:
2543 case nios2_stub_call26_after
:
2544 hsh
->stub_sec
->size
+= 12;
2553 /* Read in all local syms for all input bfds.
2554 Returns -1 on error, 0 otherwise. */
2557 get_local_syms (bfd
*output_bfd ATTRIBUTE_UNUSED
, bfd
*input_bfd
,
2558 struct bfd_link_info
*info
)
2560 unsigned int bfd_indx
;
2561 Elf_Internal_Sym
*local_syms
, **all_local_syms
;
2562 struct elf32_nios2_link_hash_table
*htab
= elf32_nios2_hash_table (info
);
2564 /* We want to read in symbol extension records only once. To do this
2565 we need to read in the local symbols in parallel and save them for
2566 later use; so hold pointers to the local symbols in an array. */
2567 size_t amt
= sizeof (Elf_Internal_Sym
*) * htab
->bfd_count
;
2568 all_local_syms
= bfd_zmalloc (amt
);
2569 htab
->all_local_syms
= all_local_syms
;
2570 if (all_local_syms
== NULL
)
2573 /* Walk over all the input BFDs, swapping in local symbols. */
2576 input_bfd
= input_bfd
->link
.next
, bfd_indx
++)
2578 Elf_Internal_Shdr
*symtab_hdr
;
2580 /* We'll need the symbol table in a second. */
2581 symtab_hdr
= &elf_tdata (input_bfd
)->symtab_hdr
;
2582 if (symtab_hdr
->sh_info
== 0)
2585 /* We need an array of the local symbols attached to the input bfd. */
2586 local_syms
= (Elf_Internal_Sym
*) symtab_hdr
->contents
;
2587 if (local_syms
== NULL
)
2589 local_syms
= bfd_elf_get_elf_syms (input_bfd
, symtab_hdr
,
2590 symtab_hdr
->sh_info
, 0,
2592 /* Cache them for elf_link_input_bfd. */
2593 symtab_hdr
->contents
= (unsigned char *) local_syms
;
2595 if (local_syms
== NULL
)
2598 all_local_syms
[bfd_indx
] = local_syms
;
2604 /* Determine and set the size of the stub section for a final link. */
2606 nios2_elf32_size_stubs (bfd
*output_bfd
, bfd
*stub_bfd
,
2607 struct bfd_link_info
*info
,
2608 asection
*(*add_stub_section
) (const char *,
2610 void (*layout_sections_again
) (void))
2612 bool stub_changed
= false;
2613 struct elf32_nios2_link_hash_table
*htab
= elf32_nios2_hash_table (info
);
2615 /* Stash our params away. */
2616 htab
->stub_bfd
= stub_bfd
;
2617 htab
->add_stub_section
= add_stub_section
;
2618 htab
->layout_sections_again
= layout_sections_again
;
2620 /* FIXME: We only compute the section groups once. This could cause
2621 problems if adding a large stub section causes following sections,
2622 or parts of them, to move into another segment. However, this seems
2623 to be consistent with the way other back ends handle this.... */
2624 group_sections (htab
);
2626 if (get_local_syms (output_bfd
, info
->input_bfds
, info
))
2628 if (htab
->all_local_syms
)
2629 goto error_ret_free_local
;
2636 unsigned int bfd_indx
;
2639 for (input_bfd
= info
->input_bfds
, bfd_indx
= 0;
2641 input_bfd
= input_bfd
->link
.next
, bfd_indx
++)
2643 Elf_Internal_Shdr
*symtab_hdr
;
2645 Elf_Internal_Sym
*local_syms
;
2647 /* We'll need the symbol table in a second. */
2648 symtab_hdr
= &elf_tdata (input_bfd
)->symtab_hdr
;
2649 if (symtab_hdr
->sh_info
== 0)
2652 local_syms
= htab
->all_local_syms
[bfd_indx
];
2654 /* Walk over each section attached to the input bfd. */
2655 for (section
= input_bfd
->sections
;
2657 section
= section
->next
)
2659 Elf_Internal_Rela
*internal_relocs
, *irelaend
, *irela
;
2661 /* If there aren't any relocs, then there's nothing more
2663 if ((section
->flags
& SEC_RELOC
) == 0
2664 || section
->reloc_count
== 0)
2667 /* If this section is a link-once section that will be
2668 discarded, then don't create any stubs. */
2669 if (section
->output_section
== NULL
2670 || section
->output_section
->owner
!= output_bfd
)
2673 /* Get the relocs. */
2675 = _bfd_elf_link_read_relocs (input_bfd
, section
, NULL
, NULL
,
2677 if (internal_relocs
== NULL
)
2678 goto error_ret_free_local
;
2680 /* Now examine each relocation. */
2681 irela
= internal_relocs
;
2682 irelaend
= irela
+ section
->reloc_count
;
2683 for (; irela
< irelaend
; irela
++)
2685 unsigned int r_type
, r_indx
;
2686 enum elf32_nios2_stub_type stub_type
;
2687 struct elf32_nios2_stub_hash_entry
*hsh
;
2690 bfd_vma destination
;
2691 struct elf32_nios2_link_hash_entry
*hh
;
2693 const asection
*id_sec
;
2695 r_type
= ELF32_R_TYPE (irela
->r_info
);
2696 r_indx
= ELF32_R_SYM (irela
->r_info
);
2698 if (r_type
>= (unsigned int) R_NIOS2_ILLEGAL
)
2700 bfd_set_error (bfd_error_bad_value
);
2701 error_ret_free_internal
:
2702 if (elf_section_data (section
)->relocs
== NULL
)
2703 free (internal_relocs
);
2704 goto error_ret_free_local
;
2707 /* Only look for stubs on CALL and JMPI instructions. */
2708 if (r_type
!= (unsigned int) R_NIOS2_CALL26
)
2711 /* Now determine the call target, its name, value,
2717 if (r_indx
< symtab_hdr
->sh_info
)
2719 /* It's a local symbol. */
2720 Elf_Internal_Sym
*sym
;
2721 Elf_Internal_Shdr
*hdr
;
2724 sym
= local_syms
+ r_indx
;
2725 if (ELF_ST_TYPE (sym
->st_info
) != STT_SECTION
)
2726 sym_value
= sym
->st_value
;
2727 shndx
= sym
->st_shndx
;
2728 if (shndx
< elf_numsections (input_bfd
))
2730 hdr
= elf_elfsections (input_bfd
)[shndx
];
2731 sym_sec
= hdr
->bfd_section
;
2732 destination
= (sym_value
+ irela
->r_addend
2733 + sym_sec
->output_offset
2734 + sym_sec
->output_section
->vma
);
2739 /* It's an external symbol. */
2742 e_indx
= r_indx
- symtab_hdr
->sh_info
;
2743 hh
= ((struct elf32_nios2_link_hash_entry
*)
2744 elf_sym_hashes (input_bfd
)[e_indx
]);
2746 while (hh
->root
.root
.type
== bfd_link_hash_indirect
2747 || hh
->root
.root
.type
== bfd_link_hash_warning
)
2748 hh
= ((struct elf32_nios2_link_hash_entry
*)
2749 hh
->root
.root
.u
.i
.link
);
2751 if (hh
->root
.root
.type
== bfd_link_hash_defined
2752 || hh
->root
.root
.type
== bfd_link_hash_defweak
)
2754 sym_sec
= hh
->root
.root
.u
.def
.section
;
2755 sym_value
= hh
->root
.root
.u
.def
.value
;
2757 if (sym_sec
->output_section
!= NULL
)
2758 destination
= (sym_value
+ irela
->r_addend
2759 + sym_sec
->output_offset
2760 + sym_sec
->output_section
->vma
);
2764 else if (hh
->root
.root
.type
== bfd_link_hash_undefweak
)
2766 if (! bfd_link_pic (info
))
2769 else if (hh
->root
.root
.type
== bfd_link_hash_undefined
)
2771 if (! (info
->unresolved_syms_in_objects
== RM_IGNORE
2772 && (ELF_ST_VISIBILITY (hh
->root
.other
)
2778 bfd_set_error (bfd_error_bad_value
);
2779 goto error_ret_free_internal
;
2783 /* Determine what (if any) linker stub is needed. */
2784 stub_type
= nios2_type_of_stub (section
, irela
, hh
, htab
,
2786 if (stub_type
== nios2_stub_none
)
2789 /* Support for grouping stub sections. */
2790 if (stub_type
== nios2_stub_call26_before
)
2791 id_sec
= htab
->stub_group
[section
->id
].first_sec
;
2793 id_sec
= htab
->stub_group
[section
->id
].last_sec
;
2795 /* Get the name of this stub. */
2796 stub_name
= nios2_stub_name (id_sec
, sym_sec
, hh
, irela
,
2799 goto error_ret_free_internal
;
2801 hsh
= nios2_stub_hash_lookup (&htab
->bstab
,
2806 /* The proper stub has already been created. */
2811 hsh
= nios2_add_stub (stub_name
, section
, htab
, stub_type
);
2815 goto error_ret_free_internal
;
2817 hsh
->target_value
= sym_value
;
2818 hsh
->target_section
= sym_sec
;
2819 hsh
->stub_type
= stub_type
;
2821 hsh
->addend
= irela
->r_addend
;
2822 stub_changed
= true;
2825 /* We're done with the internal relocs, free them. */
2826 if (elf_section_data (section
)->relocs
== NULL
)
2827 free (internal_relocs
);
2834 /* OK, we've added some stubs. Find out the new size of the
2836 for (stub_sec
= htab
->stub_bfd
->sections
;
2838 stub_sec
= stub_sec
->next
)
2841 bfd_hash_traverse (&htab
->bstab
, nios2_size_one_stub
, htab
);
2843 /* Ask the linker to do its stuff. */
2844 (*htab
->layout_sections_again
) ();
2845 stub_changed
= false;
2848 free (htab
->all_local_syms
);
2851 error_ret_free_local
:
2852 free (htab
->all_local_syms
);
2856 /* Build all the stubs associated with the current output file. The
2857 stubs are kept in a hash table attached to the main linker hash
2858 table. This function is called via nios2elf_finish in the linker. */
2860 nios2_elf32_build_stubs (struct bfd_link_info
*info
)
2863 struct bfd_hash_table
*table
;
2864 struct elf32_nios2_link_hash_table
*htab
;
2866 htab
= elf32_nios2_hash_table (info
);
2868 for (stub_sec
= htab
->stub_bfd
->sections
;
2870 stub_sec
= stub_sec
->next
)
2871 /* The stub_bfd may contain non-stub sections if it is also the
2872 dynobj. Any such non-stub sections are created with the
2873 SEC_LINKER_CREATED flag set, while stub sections do not
2874 have that flag. Ignore any non-stub sections here. */
2875 if ((stub_sec
->flags
& SEC_LINKER_CREATED
) == 0)
2879 /* Allocate memory to hold the linker stubs. */
2880 size
= stub_sec
->size
;
2881 stub_sec
->contents
= bfd_zalloc (htab
->stub_bfd
, size
);
2882 if (stub_sec
->contents
== NULL
&& size
!= 0)
2887 /* Build the stubs as directed by the stub hash table. */
2888 table
= &htab
->bstab
;
2889 bfd_hash_traverse (table
, nios2_build_one_stub
, info
);
2895 #define is_nios2_elf(bfd) \
2896 (bfd_get_flavour (bfd) == bfd_target_elf_flavour \
2897 && elf_object_id (bfd) == NIOS2_ELF_DATA)
2899 /* Merge backend specific data from an object file to the output
2900 object file when linking. */
2903 nios2_elf32_merge_private_bfd_data (bfd
*ibfd
, struct bfd_link_info
*info
)
2905 bfd
*obfd
= info
->output_bfd
;
2909 if (!is_nios2_elf (ibfd
) || !is_nios2_elf (obfd
))
2912 /* Check if we have the same endianness. */
2913 if (! _bfd_generic_verify_endian_match (ibfd
, info
))
2916 new_flags
= elf_elfheader (ibfd
)->e_flags
;
2917 old_flags
= elf_elfheader (obfd
)->e_flags
;
2918 if (!elf_flags_init (obfd
))
2920 /* First call, no flags set. */
2921 elf_flags_init (obfd
) = true;
2922 elf_elfheader (obfd
)->e_flags
= new_flags
;
2927 case EF_NIOS2_ARCH_R1
:
2928 bfd_default_set_arch_mach (obfd
, bfd_arch_nios2
, bfd_mach_nios2r1
);
2930 case EF_NIOS2_ARCH_R2
:
2931 if (bfd_big_endian (ibfd
))
2934 (_("error: %pB: big-endian R2 is not supported"), ibfd
);
2935 bfd_set_error (bfd_error_bad_value
);
2938 bfd_default_set_arch_mach (obfd
, bfd_arch_nios2
, bfd_mach_nios2r2
);
2943 /* Incompatible flags. */
2944 else if (new_flags
!= old_flags
)
2946 /* So far, the only incompatible flags denote incompatible
2949 /* xgettext:c-format */
2950 (_("error: %pB: conflicting CPU architectures %d/%d"),
2951 ibfd
, new_flags
, old_flags
);
2952 bfd_set_error (bfd_error_bad_value
);
2956 /* Merge Tag_compatibility attributes and any common GNU ones. */
2957 _bfd_elf_merge_object_attributes (ibfd
, info
);
2962 /* Implement bfd_elf32_bfd_reloc_type_lookup:
2963 Given a BFD reloc type, return a howto structure. */
2965 static reloc_howto_type
*
2966 nios2_elf32_bfd_reloc_type_lookup (bfd
*abfd
,
2967 bfd_reloc_code_real_type code
)
2971 for (i
= 0; i
< (int) ARRAY_SIZE (nios2_reloc_map
); ++i
)
2972 if (nios2_reloc_map
[i
].bfd_val
== code
)
2973 return lookup_howto (nios2_reloc_map
[i
].elf_val
, abfd
);
2977 /* Implement bfd_elf32_bfd_reloc_name_lookup:
2978 Given a reloc name, return a howto structure. */
2980 static reloc_howto_type
*
2981 nios2_elf32_bfd_reloc_name_lookup (bfd
*abfd
,
2985 reloc_howto_type
*howto_tbl
;
2988 if (BFD_IS_R2 (abfd
))
2990 howto_tbl
= elf_nios2_r2_howto_table_rel
;
2991 howto_tbl_size
= (int) ARRAY_SIZE (elf_nios2_r2_howto_table_rel
);
2995 howto_tbl
= elf_nios2_r1_howto_table_rel
;
2996 howto_tbl_size
= (int) ARRAY_SIZE (elf_nios2_r1_howto_table_rel
);
2999 for (i
= 0; i
< howto_tbl_size
; i
++)
3000 if (howto_tbl
[i
].name
&& strcasecmp (howto_tbl
[i
].name
, r_name
) == 0)
3001 return howto_tbl
+ i
;
3006 /* Implement elf_info_to_howto:
3007 Given a ELF32 relocation, fill in a arelent structure. */
3010 nios2_elf32_info_to_howto (bfd
*abfd
, arelent
*cache_ptr
,
3011 Elf_Internal_Rela
*dst
)
3013 unsigned int r_type
;
3015 r_type
= ELF32_R_TYPE (dst
->r_info
);
3016 if ((cache_ptr
->howto
= lookup_howto (r_type
, abfd
)) == NULL
)
3018 /* xgettext:c-format */
3019 _bfd_error_handler (_("%pB: unsupported relocation type %#x"),
3021 bfd_set_error (bfd_error_bad_value
);
3027 /* Return the base VMA address which should be subtracted from real addresses
3028 when resolving @dtpoff relocation.
3029 This is PT_TLS segment p_vaddr. */
3031 dtpoff_base (struct bfd_link_info
*info
)
3033 /* If tls_sec is NULL, we should have signalled an error already. */
3034 if (elf_hash_table (info
)->tls_sec
== NULL
)
3036 return elf_hash_table (info
)->tls_sec
->vma
;
3039 /* Return the relocation value for @tpoff relocation
3040 if STT_TLS virtual address is ADDRESS. */
3042 tpoff (struct bfd_link_info
*info
, bfd_vma address
)
3044 struct elf_link_hash_table
*htab
= elf_hash_table (info
);
3046 /* If tls_sec is NULL, we should have signalled an error already. */
3047 if (htab
->tls_sec
== NULL
)
3049 return address
- htab
->tls_sec
->vma
;
3052 /* Set the GP value for OUTPUT_BFD. Returns FALSE if this is a
3053 dangerous relocation. */
3055 nios2_elf_assign_gp (bfd
*output_bfd
, bfd_vma
*pgp
, struct bfd_link_info
*info
)
3059 struct bfd_hash_entry
*h
;
3060 struct bfd_link_hash_entry
*lh
;
3062 /* If we've already figured out what GP will be, just return it. */
3063 *pgp
= _bfd_get_gp_value (output_bfd
);
3067 h
= bfd_hash_lookup (&info
->hash
->table
, "_gp", false, false);
3068 lh
= (struct bfd_link_hash_entry
*) h
;
3074 case bfd_link_hash_undefined
:
3075 case bfd_link_hash_undefweak
:
3076 case bfd_link_hash_common
:
3079 case bfd_link_hash_defined
:
3080 case bfd_link_hash_defweak
:
3083 asection
*sym_sec
= lh
->u
.def
.section
;
3084 bfd_vma sym_value
= lh
->u
.def
.value
;
3086 if (sym_sec
->output_section
)
3087 sym_value
= (sym_value
+ sym_sec
->output_offset
3088 + sym_sec
->output_section
->vma
);
3092 case bfd_link_hash_indirect
:
3093 case bfd_link_hash_warning
:
3095 /* @@FIXME ignoring warning for now */
3097 case bfd_link_hash_new
:
3107 /* Only get the error once. */
3109 _bfd_set_gp_value (output_bfd
, *pgp
);
3113 _bfd_set_gp_value (output_bfd
, *pgp
);
3118 /* Retrieve the previously cached _gp pointer, returning bfd_reloc_dangerous
3119 if it's not available as we don't have a link_info pointer available here
3120 to look it up in the output symbol table. We don't need to adjust the
3121 symbol value for an external symbol if we are producing relocatable
3123 static bfd_reloc_status_type
3124 nios2_elf_final_gp (bfd
*output_bfd
, asymbol
*symbol
, bool relocatable
,
3125 char **error_message
, bfd_vma
*pgp
)
3127 if (bfd_is_und_section (symbol
->section
) && !relocatable
)
3130 return bfd_reloc_undefined
;
3133 *pgp
= _bfd_get_gp_value (output_bfd
);
3134 if (*pgp
== 0 && (!relocatable
|| (symbol
->flags
& BSF_SECTION_SYM
) != 0))
3138 /* Make up a value. */
3139 *pgp
= symbol
->section
->output_section
->vma
+ 0x4000;
3140 _bfd_set_gp_value (output_bfd
, *pgp
);
3145 = (char *) _("global pointer relative relocation when _gp not defined");
3146 return bfd_reloc_dangerous
;
3150 return bfd_reloc_ok
;
3153 /* Do the relocations that require special handling. */
3154 static bfd_reloc_status_type
3155 nios2_elf32_do_hi16_relocate (bfd
*abfd
, reloc_howto_type
*howto
,
3156 asection
*input_section
,
3157 bfd_byte
*data
, bfd_vma offset
,
3158 bfd_vma symbol_value
, bfd_vma addend
)
3160 symbol_value
= symbol_value
+ addend
;
3162 symbol_value
= (symbol_value
>> 16) & 0xffff;
3163 return _bfd_final_link_relocate (howto
, abfd
, input_section
,
3164 data
, offset
, symbol_value
, addend
);
3167 static bfd_reloc_status_type
3168 nios2_elf32_do_lo16_relocate (bfd
*abfd
, reloc_howto_type
*howto
,
3169 asection
*input_section
,
3170 bfd_byte
*data
, bfd_vma offset
,
3171 bfd_vma symbol_value
, bfd_vma addend
)
3173 symbol_value
= symbol_value
+ addend
;
3175 symbol_value
= symbol_value
& 0xffff;
3176 return _bfd_final_link_relocate (howto
, abfd
, input_section
,
3177 data
, offset
, symbol_value
, addend
);
3180 static bfd_reloc_status_type
3181 nios2_elf32_do_hiadj16_relocate (bfd
*abfd
, reloc_howto_type
*howto
,
3182 asection
*input_section
,
3183 bfd_byte
*data
, bfd_vma offset
,
3184 bfd_vma symbol_value
, bfd_vma addend
)
3186 symbol_value
= symbol_value
+ addend
;
3188 symbol_value
= hiadj(symbol_value
);
3189 return _bfd_final_link_relocate (howto
, abfd
, input_section
, data
, offset
,
3190 symbol_value
, addend
);
3193 static bfd_reloc_status_type
3194 nios2_elf32_do_pcrel_lo16_relocate (bfd
*abfd
, reloc_howto_type
*howto
,
3195 asection
*input_section
,
3196 bfd_byte
*data
, bfd_vma offset
,
3197 bfd_vma symbol_value
, bfd_vma addend
)
3199 symbol_value
= symbol_value
+ addend
;
3201 symbol_value
= symbol_value
& 0xffff;
3202 return _bfd_final_link_relocate (howto
, abfd
, input_section
,
3203 data
, offset
, symbol_value
, addend
);
3206 static bfd_reloc_status_type
3207 nios2_elf32_do_pcrel_hiadj16_relocate (bfd
*abfd
, reloc_howto_type
*howto
,
3208 asection
*input_section
,
3209 bfd_byte
*data
, bfd_vma offset
,
3210 bfd_vma symbol_value
, bfd_vma addend
)
3212 symbol_value
= symbol_value
+ addend
;
3213 symbol_value
-= (input_section
->output_section
->vma
3214 + input_section
->output_offset
);
3215 symbol_value
-= offset
;
3217 symbol_value
= hiadj(symbol_value
);
3218 return _bfd_final_link_relocate (howto
, abfd
, input_section
, data
, offset
,
3219 symbol_value
, addend
);
3222 static bfd_reloc_status_type
3223 nios2_elf32_do_pcrel16_relocate (bfd
*abfd
, reloc_howto_type
*howto
,
3224 asection
*input_section
,
3225 bfd_byte
*data
, bfd_vma offset
,
3226 bfd_vma symbol_value
, bfd_vma addend
)
3228 /* NIOS2 pc relative relocations are relative to the next 32-bit instruction
3229 so we need to subtract 4 before doing a final_link_relocate. */
3230 symbol_value
= symbol_value
+ addend
- 4;
3232 return _bfd_final_link_relocate (howto
, abfd
, input_section
,
3233 data
, offset
, symbol_value
, addend
);
3236 static bfd_reloc_status_type
3237 nios2_elf32_do_call26_relocate (bfd
*abfd
, reloc_howto_type
*howto
,
3238 asection
*input_section
,
3239 bfd_byte
*data
, bfd_vma offset
,
3240 bfd_vma symbol_value
, bfd_vma addend
)
3242 /* Check that the relocation is in the same page as the current address. */
3243 if (CALL26_SEGMENT (symbol_value
+ addend
)
3244 != CALL26_SEGMENT (input_section
->output_section
->vma
3245 + input_section
->output_offset
3247 return bfd_reloc_overflow
;
3249 /* Check that the target address is correctly aligned on a 4-byte
3251 if ((symbol_value
+ addend
) & 0x3)
3252 return bfd_reloc_overflow
;
3254 return _bfd_final_link_relocate (howto
, abfd
, input_section
,
3255 data
, offset
, symbol_value
, addend
);
3258 static bfd_reloc_status_type
3259 nios2_elf32_do_gprel_relocate (bfd
*abfd
, reloc_howto_type
*howto
,
3260 asection
*input_section
,
3261 bfd_byte
*data
, bfd_vma offset
,
3262 bfd_vma symbol_value
, bfd_vma addend
)
3264 /* Because we need the output_bfd, the special handling is done
3265 in nios2_elf32_relocate_section or in nios2_elf32_gprel_relocate. */
3266 return _bfd_final_link_relocate (howto
, abfd
, input_section
,
3267 data
, offset
, symbol_value
, addend
);
3270 static bfd_reloc_status_type
3271 nios2_elf32_do_ujmp_relocate (bfd
*abfd
, reloc_howto_type
*howto
,
3272 asection
*input_section
,
3273 bfd_byte
*data
, bfd_vma offset
,
3274 bfd_vma symbol_value
, bfd_vma addend
)
3276 bfd_vma symbol_lo16
, symbol_hi16
;
3277 bfd_reloc_status_type r
;
3278 symbol_value
= symbol_value
+ addend
;
3280 symbol_hi16
= (symbol_value
>> 16) & 0xffff;
3281 symbol_lo16
= symbol_value
& 0xffff;
3283 r
= _bfd_final_link_relocate (howto
, abfd
, input_section
,
3284 data
, offset
, symbol_hi16
, addend
);
3286 if (r
== bfd_reloc_ok
)
3287 return _bfd_final_link_relocate (howto
, abfd
, input_section
,
3288 data
, offset
+ 4, symbol_lo16
, addend
);
3293 static bfd_reloc_status_type
3294 nios2_elf32_do_cjmp_relocate (bfd
*abfd
, reloc_howto_type
*howto
,
3295 asection
*input_section
,
3296 bfd_byte
*data
, bfd_vma offset
,
3297 bfd_vma symbol_value
, bfd_vma addend
)
3299 bfd_vma symbol_lo16
, symbol_hi16
;
3300 bfd_reloc_status_type r
;
3301 symbol_value
= symbol_value
+ addend
;
3303 symbol_hi16
= (symbol_value
>> 16) & 0xffff;
3304 symbol_lo16
= symbol_value
& 0xffff;
3306 r
= _bfd_final_link_relocate (howto
, abfd
, input_section
,
3307 data
, offset
, symbol_hi16
, addend
);
3309 if (r
== bfd_reloc_ok
)
3310 return _bfd_final_link_relocate (howto
, abfd
, input_section
,
3311 data
, offset
+ 4, symbol_lo16
, addend
);
3316 static bfd_reloc_status_type
3317 nios2_elf32_do_callr_relocate (bfd
*abfd
, reloc_howto_type
*howto
,
3318 asection
*input_section
,
3319 bfd_byte
*data
, bfd_vma offset
,
3320 bfd_vma symbol_value
, bfd_vma addend
)
3322 bfd_vma symbol_lo16
, symbol_hi16
;
3323 bfd_reloc_status_type r
;
3324 symbol_value
= symbol_value
+ addend
;
3326 symbol_hi16
= (symbol_value
>> 16) & 0xffff;
3327 symbol_lo16
= symbol_value
& 0xffff;
3329 r
= _bfd_final_link_relocate (howto
, abfd
, input_section
,
3330 data
, offset
, symbol_hi16
, addend
);
3332 if (r
== bfd_reloc_ok
)
3333 return _bfd_final_link_relocate (howto
, abfd
, input_section
,
3334 data
, offset
+ 4, symbol_lo16
, addend
);
3339 /* HOWTO handlers for relocations that require special handling. */
3341 /* This is for relocations used only when relaxing to ensure
3342 changes in size of section don't screw up .align. */
3343 static bfd_reloc_status_type
3344 nios2_elf32_ignore_reloc (bfd
*abfd ATTRIBUTE_UNUSED
, arelent
*reloc_entry
,
3345 asymbol
*symbol ATTRIBUTE_UNUSED
,
3346 void *data ATTRIBUTE_UNUSED
, asection
*input_section
,
3348 char **error_message ATTRIBUTE_UNUSED
)
3350 if (output_bfd
!= NULL
)
3351 reloc_entry
->address
+= input_section
->output_offset
;
3352 return bfd_reloc_ok
;
3355 static bfd_reloc_status_type
3356 nios2_elf32_hi16_relocate (bfd
*abfd
, arelent
*reloc_entry
, asymbol
*symbol
,
3357 void *data
, asection
*input_section
,
3359 char **error_message ATTRIBUTE_UNUSED
)
3361 /* This part is from bfd_elf_generic_reloc. */
3362 if (output_bfd
!= NULL
3363 && (symbol
->flags
& BSF_SECTION_SYM
) == 0
3364 && (!reloc_entry
->howto
->partial_inplace
|| reloc_entry
->addend
== 0))
3366 reloc_entry
->address
+= input_section
->output_offset
;
3367 return bfd_reloc_ok
;
3370 if (output_bfd
!= NULL
)
3371 /* FIXME: See bfd_perform_relocation. Is this right? */
3372 return bfd_reloc_continue
;
3374 return nios2_elf32_do_hi16_relocate (abfd
, reloc_entry
->howto
,
3376 data
, reloc_entry
->address
,
3378 + symbol
->section
->output_section
->vma
3379 + symbol
->section
->output_offset
),
3380 reloc_entry
->addend
);
3383 static bfd_reloc_status_type
3384 nios2_elf32_lo16_relocate (bfd
*abfd
, arelent
*reloc_entry
, asymbol
*symbol
,
3385 void *data
, asection
*input_section
,
3387 char **error_message ATTRIBUTE_UNUSED
)
3389 /* This part is from bfd_elf_generic_reloc. */
3390 if (output_bfd
!= NULL
3391 && (symbol
->flags
& BSF_SECTION_SYM
) == 0
3392 && (!reloc_entry
->howto
->partial_inplace
|| reloc_entry
->addend
== 0))
3394 reloc_entry
->address
+= input_section
->output_offset
;
3395 return bfd_reloc_ok
;
3398 if (output_bfd
!= NULL
)
3399 /* FIXME: See bfd_perform_relocation. Is this right? */
3400 return bfd_reloc_continue
;
3402 return nios2_elf32_do_lo16_relocate (abfd
, reloc_entry
->howto
,
3404 data
, reloc_entry
->address
,
3406 + symbol
->section
->output_section
->vma
3407 + symbol
->section
->output_offset
),
3408 reloc_entry
->addend
);
3411 static bfd_reloc_status_type
3412 nios2_elf32_hiadj16_relocate (bfd
*abfd
, arelent
*reloc_entry
, asymbol
*symbol
,
3413 void *data
, asection
*input_section
,
3415 char **error_message ATTRIBUTE_UNUSED
)
3417 /* This part is from bfd_elf_generic_reloc. */
3418 if (output_bfd
!= NULL
3419 && (symbol
->flags
& BSF_SECTION_SYM
) == 0
3420 && (!reloc_entry
->howto
->partial_inplace
|| reloc_entry
->addend
== 0))
3422 reloc_entry
->address
+= input_section
->output_offset
;
3423 return bfd_reloc_ok
;
3426 if (output_bfd
!= NULL
)
3427 /* FIXME: See bfd_perform_relocation. Is this right? */
3428 return bfd_reloc_continue
;
3430 return nios2_elf32_do_hiadj16_relocate (abfd
, reloc_entry
->howto
,
3432 data
, reloc_entry
->address
,
3434 + symbol
->section
->output_section
->vma
3435 + symbol
->section
->output_offset
),
3436 reloc_entry
->addend
);
3439 static bfd_reloc_status_type
3440 nios2_elf32_pcrel_lo16_relocate (bfd
*abfd
, arelent
*reloc_entry
,
3441 asymbol
*symbol
, void *data
,
3442 asection
*input_section
, bfd
*output_bfd
,
3443 char **error_message ATTRIBUTE_UNUSED
)
3445 /* This part is from bfd_elf_generic_reloc. */
3446 if (output_bfd
!= NULL
3447 && (symbol
->flags
& BSF_SECTION_SYM
) == 0
3448 && (!reloc_entry
->howto
->partial_inplace
|| reloc_entry
->addend
== 0))
3450 reloc_entry
->address
+= input_section
->output_offset
;
3451 return bfd_reloc_ok
;
3454 if (output_bfd
!= NULL
)
3455 /* FIXME: See bfd_perform_relocation. Is this right? */
3456 return bfd_reloc_continue
;
3458 return nios2_elf32_do_pcrel_lo16_relocate (
3459 abfd
, reloc_entry
->howto
, input_section
, data
, reloc_entry
->address
,
3460 (symbol
->value
+ symbol
->section
->output_section
->vma
3461 + symbol
->section
->output_offset
),
3462 reloc_entry
->addend
);
3465 static bfd_reloc_status_type
3466 nios2_elf32_pcrel_hiadj16_relocate (bfd
*abfd
, arelent
*reloc_entry
,
3467 asymbol
*symbol
, void *data
,
3468 asection
*input_section
, bfd
*output_bfd
,
3469 char **error_message ATTRIBUTE_UNUSED
)
3471 /* This part is from bfd_elf_generic_reloc. */
3472 if (output_bfd
!= NULL
3473 && (symbol
->flags
& BSF_SECTION_SYM
) == 0
3474 && (!reloc_entry
->howto
->partial_inplace
|| reloc_entry
->addend
== 0))
3476 reloc_entry
->address
+= input_section
->output_offset
;
3477 return bfd_reloc_ok
;
3480 if (output_bfd
!= NULL
)
3481 /* FIXME: See bfd_perform_relocation. Is this right? */
3482 return bfd_reloc_continue
;
3484 return nios2_elf32_do_pcrel_hiadj16_relocate (
3485 abfd
, reloc_entry
->howto
, input_section
, data
, reloc_entry
->address
,
3486 (symbol
->value
+ symbol
->section
->output_section
->vma
3487 + symbol
->section
->output_offset
),
3488 reloc_entry
->addend
);
3491 static bfd_reloc_status_type
3492 nios2_elf32_pcrel16_relocate (bfd
*abfd
, arelent
*reloc_entry
, asymbol
*symbol
,
3493 void *data
, asection
*input_section
,
3495 char **error_message ATTRIBUTE_UNUSED
)
3497 /* This part is from bfd_elf_generic_reloc. */
3498 if (output_bfd
!= NULL
3499 && (symbol
->flags
& BSF_SECTION_SYM
) == 0
3500 && (!reloc_entry
->howto
->partial_inplace
|| reloc_entry
->addend
== 0))
3502 reloc_entry
->address
+= input_section
->output_offset
;
3503 return bfd_reloc_ok
;
3506 if (output_bfd
!= NULL
)
3507 /* FIXME: See bfd_perform_relocation. Is this right? */
3508 return bfd_reloc_continue
;
3510 return nios2_elf32_do_pcrel16_relocate (abfd
, reloc_entry
->howto
,
3512 data
, reloc_entry
->address
,
3514 + symbol
->section
->output_section
->vma
3515 + symbol
->section
->output_offset
),
3516 reloc_entry
->addend
);
3519 static bfd_reloc_status_type
3520 nios2_elf32_call26_relocate (bfd
*abfd
, arelent
*reloc_entry
, asymbol
*symbol
,
3521 void *data
, asection
*input_section
,
3523 char **error_message ATTRIBUTE_UNUSED
)
3525 /* This part is from bfd_elf_generic_reloc. */
3526 if (output_bfd
!= NULL
3527 && (symbol
->flags
& BSF_SECTION_SYM
) == 0
3528 && (!reloc_entry
->howto
->partial_inplace
|| reloc_entry
->addend
== 0))
3530 reloc_entry
->address
+= input_section
->output_offset
;
3531 return bfd_reloc_ok
;
3534 if (output_bfd
!= NULL
)
3535 /* FIXME: See bfd_perform_relocation. Is this right? */
3536 return bfd_reloc_continue
;
3538 return nios2_elf32_do_call26_relocate (abfd
, reloc_entry
->howto
,
3540 data
, reloc_entry
->address
,
3542 + symbol
->section
->output_section
->vma
3543 + symbol
->section
->output_offset
),
3544 reloc_entry
->addend
);
3547 static bfd_reloc_status_type
3548 nios2_elf32_gprel_relocate (bfd
*abfd
, arelent
*reloc_entry
, asymbol
*symbol
,
3549 void *data
, asection
*input_section
,
3550 bfd
*output_bfd
, char **msg
)
3554 bfd_reloc_status_type r
;
3557 /* This part is from bfd_elf_generic_reloc. */
3558 if (output_bfd
!= NULL
3559 && (symbol
->flags
& BSF_SECTION_SYM
) == 0
3560 && (!reloc_entry
->howto
->partial_inplace
|| reloc_entry
->addend
== 0))
3562 reloc_entry
->address
+= input_section
->output_offset
;
3563 return bfd_reloc_ok
;
3566 if (output_bfd
!= NULL
)
3567 /* FIXME: See bfd_perform_relocation. Is this right? */
3568 return bfd_reloc_continue
;
3570 relocation
= (symbol
->value
3571 + symbol
->section
->output_section
->vma
3572 + symbol
->section
->output_offset
);
3574 /* This assumes we've already cached the _gp symbol. */
3575 r
= nios2_elf_final_gp (abfd
, symbol
, false, msg
, &gp
);
3576 if (r
== bfd_reloc_ok
)
3578 relocation
= relocation
+ reloc_entry
->addend
- gp
;
3579 reloc_entry
->addend
= 0;
3580 if ((signed) relocation
< -32768 || (signed) relocation
> 32767)
3582 *msg
= _("global pointer relative address out of range");
3583 r
= bfd_reloc_outofrange
;
3586 r
= nios2_elf32_do_gprel_relocate (abfd
, reloc_entry
->howto
,
3588 data
, reloc_entry
->address
,
3589 relocation
, reloc_entry
->addend
);
3595 static bfd_reloc_status_type
3596 nios2_elf32_ujmp_relocate (bfd
*abfd
, arelent
*reloc_entry
, asymbol
*symbol
,
3597 void *data
, asection
*input_section
,
3598 bfd
*output_bfd
, char **msg ATTRIBUTE_UNUSED
)
3600 /* This part is from bfd_elf_generic_reloc. */
3601 if (output_bfd
!= NULL
3602 && (symbol
->flags
& BSF_SECTION_SYM
) == 0
3603 && (!reloc_entry
->howto
->partial_inplace
|| reloc_entry
->addend
== 0))
3605 reloc_entry
->address
+= input_section
->output_offset
;
3606 return bfd_reloc_ok
;
3609 if (output_bfd
!= NULL
)
3610 /* FIXME: See bfd_perform_relocation. Is this right? */
3611 return bfd_reloc_continue
;
3613 return nios2_elf32_do_ujmp_relocate (abfd
, reloc_entry
->howto
,
3615 data
, reloc_entry
->address
,
3617 + symbol
->section
->output_section
->vma
3618 + symbol
->section
->output_offset
),
3619 reloc_entry
->addend
);
3622 static bfd_reloc_status_type
3623 nios2_elf32_cjmp_relocate (bfd
*abfd
, arelent
*reloc_entry
, asymbol
*symbol
,
3624 void *data
, asection
*input_section
,
3625 bfd
*output_bfd
, char **msg ATTRIBUTE_UNUSED
)
3627 /* This part is from bfd_elf_generic_reloc. */
3628 if (output_bfd
!= NULL
3629 && (symbol
->flags
& BSF_SECTION_SYM
) == 0
3630 && (!reloc_entry
->howto
->partial_inplace
|| reloc_entry
->addend
== 0))
3632 reloc_entry
->address
+= input_section
->output_offset
;
3633 return bfd_reloc_ok
;
3636 if (output_bfd
!= NULL
)
3637 /* FIXME: See bfd_perform_relocation. Is this right? */
3638 return bfd_reloc_continue
;
3640 return nios2_elf32_do_cjmp_relocate (abfd
, reloc_entry
->howto
,
3642 data
, reloc_entry
->address
,
3644 + symbol
->section
->output_section
->vma
3645 + symbol
->section
->output_offset
),
3646 reloc_entry
->addend
);
3649 static bfd_reloc_status_type
3650 nios2_elf32_callr_relocate (bfd
*abfd
, arelent
*reloc_entry
, asymbol
*symbol
,
3651 void *data
, asection
*input_section
,
3652 bfd
*output_bfd
, char **msg ATTRIBUTE_UNUSED
)
3654 /* This part is from bfd_elf_generic_reloc. */
3655 if (output_bfd
!= NULL
3656 && (symbol
->flags
& BSF_SECTION_SYM
) == 0
3657 && (!reloc_entry
->howto
->partial_inplace
|| reloc_entry
->addend
== 0))
3659 reloc_entry
->address
+= input_section
->output_offset
;
3660 return bfd_reloc_ok
;
3663 if (output_bfd
!= NULL
)
3664 /* FIXME: See bfd_perform_relocation. Is this right? */
3665 return bfd_reloc_continue
;
3667 return nios2_elf32_do_callr_relocate (abfd
, reloc_entry
->howto
,
3669 data
, reloc_entry
->address
,
3671 + symbol
->section
->output_section
->vma
3672 + symbol
->section
->output_offset
),
3673 reloc_entry
->addend
);
3677 /* Implement elf_backend_relocate_section. */
3679 nios2_elf32_relocate_section (bfd
*output_bfd
,
3680 struct bfd_link_info
*info
,
3682 asection
*input_section
,
3684 Elf_Internal_Rela
*relocs
,
3685 Elf_Internal_Sym
*local_syms
,
3686 asection
**local_sections
)
3688 Elf_Internal_Shdr
*symtab_hdr
;
3689 struct elf_link_hash_entry
**sym_hashes
;
3690 Elf_Internal_Rela
*rel
;
3691 Elf_Internal_Rela
*relend
;
3692 struct elf32_nios2_link_hash_table
*htab
;
3695 asection
*sreloc
= NULL
;
3696 bfd_vma
*local_got_offsets
;
3699 symtab_hdr
= &elf_tdata (input_bfd
)->symtab_hdr
;
3700 sym_hashes
= elf_sym_hashes (input_bfd
);
3701 relend
= relocs
+ input_section
->reloc_count
;
3703 htab
= elf32_nios2_hash_table (info
);
3704 sgot
= htab
->root
.sgot
;
3705 splt
= htab
->root
.splt
;
3706 local_got_offsets
= elf_local_got_offsets (input_bfd
);
3708 if (htab
->h_gp_got
== NULL
)
3711 got_base
= htab
->h_gp_got
->root
.u
.def
.value
;
3713 for (rel
= relocs
; rel
< relend
; rel
++)
3715 reloc_howto_type
*howto
;
3716 unsigned long r_symndx
;
3717 Elf_Internal_Sym
*sym
;
3719 struct elf_link_hash_entry
*h
;
3720 struct elf32_nios2_link_hash_entry
*eh
;
3723 bfd_reloc_status_type r
= bfd_reloc_ok
;
3724 const char *name
= NULL
;
3727 char *msgbuf
= NULL
;
3729 bool unresolved_reloc
;
3733 r_type
= ELF32_R_TYPE (rel
->r_info
);
3734 r_symndx
= ELF32_R_SYM (rel
->r_info
);
3736 howto
= lookup_howto ((unsigned) ELF32_R_TYPE (rel
->r_info
), output_bfd
);
3741 if (r_symndx
< symtab_hdr
->sh_info
)
3743 sym
= local_syms
+ r_symndx
;
3744 sec
= local_sections
[r_symndx
];
3745 relocation
= _bfd_elf_rela_local_sym (output_bfd
, sym
, &sec
, rel
);
3749 bool warned
, ignored
;
3751 RELOC_FOR_GLOBAL_SYMBOL (info
, input_bfd
, input_section
, rel
,
3752 r_symndx
, symtab_hdr
, sym_hashes
,
3754 unresolved_reloc
, warned
, ignored
);
3757 if (sec
&& discarded_section (sec
))
3758 RELOC_AGAINST_DISCARDED_SECTION (info
, input_bfd
, input_section
,
3759 rel
, 1, relend
, howto
, 0, contents
);
3761 /* Nothing more to do unless this is a final link. */
3762 if (bfd_link_relocatable (info
))
3767 bool resolved_to_zero
;
3769 resolved_to_zero
= (h
!= NULL
3770 && UNDEFWEAK_NO_DYNAMIC_RELOC (info
, h
));
3771 switch (howto
->type
)
3774 r
= nios2_elf32_do_hi16_relocate (input_bfd
, howto
,
3776 contents
, rel
->r_offset
,
3777 relocation
, rel
->r_addend
);
3780 r
= nios2_elf32_do_lo16_relocate (input_bfd
, howto
,
3782 contents
, rel
->r_offset
,
3783 relocation
, rel
->r_addend
);
3785 case R_NIOS2_PCREL_LO
:
3786 r
= nios2_elf32_do_pcrel_lo16_relocate (input_bfd
, howto
,
3793 case R_NIOS2_HIADJ16
:
3794 r
= nios2_elf32_do_hiadj16_relocate (input_bfd
, howto
,
3795 input_section
, contents
,
3796 rel
->r_offset
, relocation
,
3799 case R_NIOS2_PCREL_HA
:
3800 r
= nios2_elf32_do_pcrel_hiadj16_relocate (input_bfd
, howto
,
3807 case R_NIOS2_PCREL16
:
3808 r
= nios2_elf32_do_pcrel16_relocate (input_bfd
, howto
,
3809 input_section
, contents
,
3810 rel
->r_offset
, relocation
,
3814 /* Turns an absolute address into a gp-relative address. */
3815 if (!nios2_elf_assign_gp (output_bfd
, &gp
, info
))
3817 bfd_vma reloc_address
;
3819 if (sec
&& sec
->output_section
)
3820 reloc_address
= (sec
->output_section
->vma
3821 + sec
->output_offset
3826 format
= _("global pointer relative relocation at address "
3827 "%#" PRIx64
" when _gp not defined\n");
3828 if (asprintf (&msgbuf
, format
,
3829 (uint64_t) reloc_address
) == -1)
3832 r
= bfd_reloc_dangerous
;
3836 bfd_vma symbol_address
= rel
->r_addend
+ relocation
;
3837 relocation
= symbol_address
- gp
;
3839 if (((signed) relocation
< -32768
3840 || (signed) relocation
> 32767)
3842 || h
->root
.type
== bfd_link_hash_defined
3843 || h
->root
.type
== bfd_link_hash_defweak
))
3846 name
= h
->root
.root
.string
;
3849 name
= (bfd_elf_string_from_elf_section
3850 (input_bfd
, symtab_hdr
->sh_link
,
3852 if (name
== NULL
|| *name
== '\0')
3853 name
= bfd_section_name (sec
);
3855 /* xgettext:c-format */
3856 format
= _("unable to reach %s (at %#" PRIx64
") from "
3857 "the global pointer (at %#" PRIx64
") "
3858 "because the offset (%" PRId64
") is out of "
3859 "the allowed range, -32678 to 32767\n" );
3860 if (asprintf (&msgbuf
, format
, name
,
3861 (uint64_t) symbol_address
, (uint64_t) gp
,
3862 (int64_t) relocation
) == -1)
3865 r
= bfd_reloc_outofrange
;
3868 r
= _bfd_final_link_relocate (howto
, input_bfd
,
3869 input_section
, contents
,
3870 rel
->r_offset
, relocation
,
3875 r
= nios2_elf32_do_ujmp_relocate (input_bfd
, howto
,
3877 contents
, rel
->r_offset
,
3878 relocation
, rel
->r_addend
);
3881 r
= nios2_elf32_do_cjmp_relocate (input_bfd
, howto
,
3883 contents
, rel
->r_offset
,
3884 relocation
, rel
->r_addend
);
3887 r
= nios2_elf32_do_callr_relocate (input_bfd
, howto
,
3888 input_section
, contents
,
3889 rel
->r_offset
, relocation
,
3892 case R_NIOS2_CALL26
:
3893 case R_NIOS2_CALL26_NOAT
:
3894 /* If we have a call to an undefined weak symbol, we just want
3895 to stuff a zero in the bits of the call instruction and
3896 bypass the normal call26 relocation handling, because it'll
3897 diagnose an overflow error if address 0 isn't in the same
3898 256MB segment as the call site. Presumably the call
3899 should be guarded by a null check anyway. */
3900 if (h
!= NULL
&& h
->root
.type
== bfd_link_hash_undefweak
)
3902 BFD_ASSERT (relocation
== 0 && rel
->r_addend
== 0);
3903 r
= _bfd_final_link_relocate (howto
, input_bfd
,
3904 input_section
, contents
,
3905 rel
->r_offset
, relocation
,
3909 /* Handle relocations which should use the PLT entry.
3910 NIOS2_BFD_RELOC_32 relocations will use the symbol's value,
3911 which may point to a PLT entry, but we don't need to handle
3912 that here. If we created a PLT entry, all branches in this
3913 object should go to it. */
3914 if (h
!= NULL
&& splt
!= NULL
&& h
->plt
.offset
!= (bfd_vma
) -1)
3916 /* If we've created a .plt section, and assigned a PLT entry
3917 to this function, it should not be known to bind locally.
3918 If it were, we would have cleared the PLT entry. */
3919 BFD_ASSERT (!SYMBOL_CALLS_LOCAL (info
, h
));
3921 relocation
= (splt
->output_section
->vma
3922 + splt
->output_offset
3925 unresolved_reloc
= false;
3927 /* Detect R_NIOS2_CALL26 relocations that would overflow the
3928 256MB segment. Replace the target with a reference to a
3930 Note that htab->stub_group is null if relaxation has been
3931 disabled by the --no-relax linker command-line option, so
3932 we can use that to skip this processing entirely. */
3933 if (howto
->type
== R_NIOS2_CALL26
&& htab
->stub_group
)
3935 bfd_vma dest
= relocation
+ rel
->r_addend
;
3936 enum elf32_nios2_stub_type stub_type
;
3938 eh
= (struct elf32_nios2_link_hash_entry
*)h
;
3939 stub_type
= nios2_type_of_stub (input_section
, rel
, eh
,
3942 if (stub_type
!= nios2_stub_none
)
3944 struct elf32_nios2_stub_hash_entry
*hsh
;
3946 hsh
= nios2_get_stub_entry (input_section
, sec
,
3947 eh
, rel
, htab
, stub_type
);
3950 r
= bfd_reloc_undefined
;
3954 dest
= (hsh
->stub_offset
3955 + hsh
->stub_sec
->output_offset
3956 + hsh
->stub_sec
->output_section
->vma
);
3957 r
= nios2_elf32_do_call26_relocate (input_bfd
, howto
,
3967 r
= nios2_elf32_do_call26_relocate (input_bfd
, howto
,
3968 input_section
, contents
,
3969 rel
->r_offset
, relocation
,
3974 /* For symmetry this would be
3975 r = nios2_elf32_do_ignore_reloc (input_bfd, howto,
3976 input_section, contents,
3977 rel->r_offset, relocation,
3979 but do_ignore_reloc would do no more than return
3984 case R_NIOS2_CALL16
:
3985 case R_NIOS2_GOT_LO
:
3986 case R_NIOS2_GOT_HA
:
3987 case R_NIOS2_CALL_LO
:
3988 case R_NIOS2_CALL_HA
:
3989 /* Relocation is to the entry for this symbol in the
3990 global offset table. */
3993 r
= bfd_reloc_notsupported
;
4003 eh
= (struct elf32_nios2_link_hash_entry
*)h
;
4004 use_plt
= (eh
->got_types_used
== CALL_USED
4005 && h
->plt
.offset
!= (bfd_vma
) -1);
4007 off
= h
->got
.offset
;
4008 BFD_ASSERT (off
!= (bfd_vma
) -1);
4009 dyn
= htab
->root
.dynamic_sections_created
;
4010 if (! WILL_CALL_FINISH_DYNAMIC_SYMBOL (dyn
,
4011 bfd_link_pic (info
),
4013 || (bfd_link_pic (info
)
4014 && SYMBOL_REFERENCES_LOCAL (info
, h
))
4015 || ((ELF_ST_VISIBILITY (h
->other
)
4016 || resolved_to_zero
)
4017 && h
->root
.type
== bfd_link_hash_undefweak
))
4019 /* This is actually a static link, or it is a -Bsymbolic
4020 link and the symbol is defined locally. We must
4021 initialize this entry in the global offset table.
4022 Since the offset must always be a multiple of 4, we
4023 use the least significant bit to record whether we
4024 have initialized it already.
4026 When doing a dynamic link, we create a .rela.got
4027 relocation entry to initialize the value. This is
4028 done in the finish_dynamic_symbol routine. */
4033 bfd_put_32 (output_bfd
, relocation
,
4034 sgot
->contents
+ off
);
4039 unresolved_reloc
= false;
4043 BFD_ASSERT (local_got_offsets
!= NULL
4044 && local_got_offsets
[r_symndx
] != (bfd_vma
) -1);
4046 off
= local_got_offsets
[r_symndx
];
4048 /* The offset must always be a multiple of 4. We use the
4049 least significant bit to record whether we have already
4050 generated the necessary reloc. */
4055 bfd_put_32 (output_bfd
, relocation
,
4056 sgot
->contents
+ off
);
4058 if (bfd_link_pic (info
))
4061 Elf_Internal_Rela outrel
;
4064 srelgot
= htab
->root
.srelgot
;
4065 BFD_ASSERT (srelgot
!= NULL
);
4067 outrel
.r_addend
= relocation
;
4068 outrel
.r_offset
= (sgot
->output_section
->vma
4069 + sgot
->output_offset
4071 outrel
.r_info
= ELF32_R_INFO (0, R_NIOS2_RELATIVE
);
4072 loc
= srelgot
->contents
;
4073 loc
+= (srelgot
->reloc_count
++ *
4074 sizeof (Elf32_External_Rela
));
4075 bfd_elf32_swap_reloca_out (output_bfd
, &outrel
, loc
);
4078 local_got_offsets
[r_symndx
] |= 1;
4082 if (use_plt
&& bfd_link_pic (info
))
4084 off
= ((h
->plt
.offset
- 24) / 12 + 3) * 4;
4085 relocation
= (htab
->root
.sgotplt
->output_offset
+ off
4089 relocation
= sgot
->output_offset
+ off
- got_base
;
4091 /* This relocation does not use the addend. */
4094 switch (howto
->type
)
4096 case R_NIOS2_GOT_LO
:
4097 case R_NIOS2_CALL_LO
:
4098 r
= nios2_elf32_do_lo16_relocate (input_bfd
, howto
,
4099 input_section
, contents
,
4100 rel
->r_offset
, relocation
,
4103 case R_NIOS2_GOT_HA
:
4104 case R_NIOS2_CALL_HA
:
4105 r
= nios2_elf32_do_hiadj16_relocate (input_bfd
, howto
,
4106 input_section
, contents
,
4112 r
= _bfd_final_link_relocate (howto
, input_bfd
,
4113 input_section
, contents
,
4114 rel
->r_offset
, relocation
,
4120 case R_NIOS2_GOTOFF_LO
:
4121 case R_NIOS2_GOTOFF_HA
:
4122 case R_NIOS2_GOTOFF
:
4123 /* Relocation is relative to the global offset table pointer. */
4125 BFD_ASSERT (sgot
!= NULL
);
4128 r
= bfd_reloc_notsupported
;
4132 /* Note that sgot->output_offset is not involved in this
4133 calculation. We always want the start of .got. */
4134 relocation
-= sgot
->output_section
->vma
;
4136 /* Now we adjust the relocation to be relative to the GOT pointer
4137 (the _gp_got symbol), which possibly contains the 0x8000 bias. */
4138 relocation
-= got_base
;
4140 switch (howto
->type
)
4142 case R_NIOS2_GOTOFF_LO
:
4143 r
= nios2_elf32_do_lo16_relocate (input_bfd
, howto
,
4144 input_section
, contents
,
4145 rel
->r_offset
, relocation
,
4148 case R_NIOS2_GOTOFF_HA
:
4149 r
= nios2_elf32_do_hiadj16_relocate (input_bfd
, howto
,
4150 input_section
, contents
,
4156 r
= _bfd_final_link_relocate (howto
, input_bfd
,
4157 input_section
, contents
,
4158 rel
->r_offset
, relocation
,
4164 case R_NIOS2_TLS_LDO16
:
4165 relocation
-= dtpoff_base (info
) + DTP_OFFSET
;
4167 r
= _bfd_final_link_relocate (howto
, input_bfd
, input_section
,
4168 contents
, rel
->r_offset
,
4169 relocation
, rel
->r_addend
);
4171 case R_NIOS2_TLS_LDM16
:
4172 if (htab
->root
.sgot
== NULL
)
4175 off
= htab
->tls_ldm_got
.offset
;
4181 /* If we don't know the module number, create a relocation
4183 if (bfd_link_pic (info
))
4185 Elf_Internal_Rela outrel
;
4188 if (htab
->root
.srelgot
== NULL
)
4191 outrel
.r_addend
= 0;
4192 outrel
.r_offset
= (htab
->root
.sgot
->output_section
->vma
4193 + htab
->root
.sgot
->output_offset
4195 outrel
.r_info
= ELF32_R_INFO (0, R_NIOS2_TLS_DTPMOD
);
4197 loc
= htab
->root
.srelgot
->contents
;
4198 loc
+= (htab
->root
.srelgot
->reloc_count
++
4199 * sizeof (Elf32_External_Rela
));
4200 bfd_elf32_swap_reloca_out (output_bfd
, &outrel
, loc
);
4203 bfd_put_32 (output_bfd
, 1,
4204 htab
->root
.sgot
->contents
+ off
);
4206 htab
->tls_ldm_got
.offset
|= 1;
4209 relocation
= htab
->root
.sgot
->output_offset
+ off
- got_base
;
4211 r
= _bfd_final_link_relocate (howto
, input_bfd
, input_section
,
4212 contents
, rel
->r_offset
,
4213 relocation
, rel
->r_addend
);
4216 case R_NIOS2_TLS_GD16
:
4217 case R_NIOS2_TLS_IE16
:
4222 if (htab
->root
.sgot
== NULL
)
4229 dyn
= htab
->root
.dynamic_sections_created
;
4230 if (WILL_CALL_FINISH_DYNAMIC_SYMBOL (dyn
,
4231 bfd_link_pic (info
),
4233 && (!bfd_link_pic (info
)
4234 || !SYMBOL_REFERENCES_LOCAL (info
, h
)))
4236 unresolved_reloc
= false;
4239 off
= h
->got
.offset
;
4240 tls_type
= (((struct elf32_nios2_link_hash_entry
*) h
)
4245 if (local_got_offsets
== NULL
)
4247 off
= local_got_offsets
[r_symndx
];
4248 tls_type
= (elf32_nios2_local_got_tls_type (input_bfd
)
4252 if (tls_type
== GOT_UNKNOWN
)
4259 bool need_relocs
= false;
4260 Elf_Internal_Rela outrel
;
4261 bfd_byte
*loc
= NULL
;
4264 /* The GOT entries have not been initialized yet. Do it
4265 now, and emit any relocations. If both an IE GOT and a
4266 GD GOT are necessary, we emit the GD first. */
4268 if ((bfd_link_pic (info
) || indx
!= 0)
4270 || (ELF_ST_VISIBILITY (h
->other
) == STV_DEFAULT
4271 && !resolved_to_zero
)
4272 || h
->root
.type
!= bfd_link_hash_undefweak
))
4275 if (htab
->root
.srelgot
== NULL
)
4277 loc
= htab
->root
.srelgot
->contents
;
4278 loc
+= (htab
->root
.srelgot
->reloc_count
*
4279 sizeof (Elf32_External_Rela
));
4282 if (tls_type
& GOT_TLS_GD
)
4286 outrel
.r_addend
= 0;
4287 outrel
.r_offset
= (htab
->root
.sgot
->output_section
->vma
4288 + htab
->root
.sgot
->output_offset
4290 outrel
.r_info
= ELF32_R_INFO (indx
,
4291 R_NIOS2_TLS_DTPMOD
);
4293 bfd_elf32_swap_reloca_out (output_bfd
, &outrel
,
4295 htab
->root
.srelgot
->reloc_count
++;
4296 loc
+= sizeof (Elf32_External_Rela
);
4299 bfd_put_32 (output_bfd
,
4300 (relocation
- dtpoff_base (info
) -
4302 htab
->root
.sgot
->contents
+ cur_off
+ 4);
4305 outrel
.r_addend
= 0;
4306 outrel
.r_info
= ELF32_R_INFO (indx
,
4307 R_NIOS2_TLS_DTPREL
);
4308 outrel
.r_offset
+= 4;
4310 bfd_elf32_swap_reloca_out (output_bfd
, &outrel
,
4312 htab
->root
.srelgot
->reloc_count
++;
4313 loc
+= sizeof (Elf32_External_Rela
);
4318 /* If we are not emitting relocations for a
4319 general dynamic reference, then we must be in a
4320 static link or an executable link with the
4321 symbol binding locally. Mark it as belonging
4322 to module 1, the executable. */
4323 bfd_put_32 (output_bfd
, 1,
4324 htab
->root
.sgot
->contents
+ cur_off
);
4325 bfd_put_32 (output_bfd
, (relocation
-
4326 dtpoff_base (info
) -
4328 htab
->root
.sgot
->contents
+ cur_off
+ 4);
4334 if (tls_type
& GOT_TLS_IE
)
4339 outrel
.r_addend
= (relocation
-
4340 dtpoff_base (info
));
4342 outrel
.r_addend
= 0;
4343 outrel
.r_offset
= (htab
->root
.sgot
->output_section
->vma
4344 + htab
->root
.sgot
->output_offset
4346 outrel
.r_info
= ELF32_R_INFO (indx
,
4349 bfd_elf32_swap_reloca_out (output_bfd
, &outrel
,
4351 htab
->root
.srelgot
->reloc_count
++;
4352 loc
+= sizeof (Elf32_External_Rela
);
4355 bfd_put_32 (output_bfd
, (tpoff (info
, relocation
)
4357 htab
->root
.sgot
->contents
+ cur_off
);
4364 local_got_offsets
[r_symndx
] |= 1;
4367 if ((tls_type
& GOT_TLS_GD
) && r_type
!= R_NIOS2_TLS_GD16
)
4369 relocation
= htab
->root
.sgot
->output_offset
+ off
- got_base
;
4371 r
= _bfd_final_link_relocate (howto
, input_bfd
, input_section
,
4372 contents
, rel
->r_offset
,
4373 relocation
, rel
->r_addend
);
4377 case R_NIOS2_TLS_LE16
:
4378 if (bfd_link_dll (info
))
4381 /* xgettext:c-format */
4382 (_("%pB(%pA+%#" PRIx64
"): %s relocation not "
4383 "permitted in shared object"),
4384 input_bfd
, input_section
,
4385 (uint64_t) rel
->r_offset
, howto
->name
);
4389 relocation
= tpoff (info
, relocation
) - TP_OFFSET
;
4391 r
= _bfd_final_link_relocate (howto
, input_bfd
, input_section
,
4392 contents
, rel
->r_offset
,
4393 relocation
, rel
->r_addend
);
4396 case R_NIOS2_BFD_RELOC_32
:
4397 if (bfd_link_pic (info
)
4398 && (input_section
->flags
& SEC_ALLOC
) != 0
4400 || (ELF_ST_VISIBILITY (h
->other
) == STV_DEFAULT
4401 && !resolved_to_zero
)
4402 || h
->root
.type
!= bfd_link_hash_undefweak
))
4404 Elf_Internal_Rela outrel
;
4406 bool skip
, relocate
;
4408 /* When generating a shared object, these relocations
4409 are copied into the output file to be resolved at run
4416 = _bfd_elf_section_offset (output_bfd
, info
,
4417 input_section
, rel
->r_offset
);
4418 if (outrel
.r_offset
== (bfd_vma
) -1)
4420 else if (outrel
.r_offset
== (bfd_vma
) -2)
4421 skip
= true, relocate
= true;
4422 outrel
.r_offset
+= (input_section
->output_section
->vma
4423 + input_section
->output_offset
);
4426 memset (&outrel
, 0, sizeof outrel
);
4429 && (!bfd_link_pic (info
)
4430 || !SYMBOLIC_BIND (info
, h
)
4431 || !h
->def_regular
))
4433 outrel
.r_info
= ELF32_R_INFO (h
->dynindx
, r_type
);
4434 outrel
.r_addend
= rel
->r_addend
;
4438 /* This symbol is local, or marked to become local. */
4439 outrel
.r_addend
= relocation
+ rel
->r_addend
;
4441 outrel
.r_info
= ELF32_R_INFO (0, R_NIOS2_RELATIVE
);
4444 sreloc
= elf_section_data (input_section
)->sreloc
;
4448 loc
= sreloc
->contents
;
4449 loc
+= sreloc
->reloc_count
++ * sizeof (Elf32_External_Rela
);
4450 bfd_elf32_swap_reloca_out (output_bfd
, &outrel
, loc
);
4452 /* This reloc will be computed at runtime, so there's no
4453 need to do anything now, except for R_NIOS2_BFD_RELOC_32
4454 relocations that have been turned into
4455 R_NIOS2_RELATIVE. */
4460 r
= _bfd_final_link_relocate (howto
, input_bfd
,
4461 input_section
, contents
,
4462 rel
->r_offset
, relocation
,
4466 case R_NIOS2_TLS_DTPREL
:
4467 relocation
-= dtpoff_base (info
);
4471 r
= _bfd_final_link_relocate (howto
, input_bfd
,
4472 input_section
, contents
,
4473 rel
->r_offset
, relocation
,
4479 r
= bfd_reloc_notsupported
;
4481 if (r
!= bfd_reloc_ok
)
4484 name
= h
->root
.root
.string
;
4487 name
= bfd_elf_string_from_elf_section (input_bfd
,
4488 symtab_hdr
->sh_link
,
4490 if (name
== NULL
|| *name
== '\0')
4491 name
= bfd_section_name (sec
);
4496 case bfd_reloc_overflow
:
4497 (*info
->callbacks
->reloc_overflow
) (info
, NULL
, name
,
4498 howto
->name
, (bfd_vma
) 0,
4499 input_bfd
, input_section
,
4503 case bfd_reloc_undefined
:
4504 (*info
->callbacks
->undefined_symbol
) (info
, name
, input_bfd
,
4506 rel
->r_offset
, true);
4509 case bfd_reloc_outofrange
:
4511 msg
= _("relocation out of range");
4514 case bfd_reloc_notsupported
:
4516 msg
= _("unsupported relocation");
4519 case bfd_reloc_dangerous
:
4521 msg
= _("dangerous relocation");
4526 msg
= _("unknown error");
4532 (*info
->callbacks
->warning
) (info
, msg
, name
, input_bfd
,
4533 input_section
, rel
->r_offset
);
4542 /* Implement elf-backend_section_flags:
4543 Convert NIOS2 specific section flags to bfd internal section flags. */
4545 nios2_elf32_section_flags (const Elf_Internal_Shdr
*hdr
)
4547 if (hdr
->sh_flags
& SHF_NIOS2_GPREL
)
4548 hdr
->bfd_section
->flags
|= SEC_SMALL_DATA
;
4553 /* Implement elf_backend_fake_sections:
4554 Set the correct type for an NIOS2 ELF section. We do this by the
4555 section name, which is a hack, but ought to work. */
4557 nios2_elf32_fake_sections (bfd
*abfd ATTRIBUTE_UNUSED
,
4558 Elf_Internal_Shdr
*hdr
, asection
*sec
)
4560 const char *name
= bfd_section_name (sec
);
4562 if ((sec
->flags
& SEC_SMALL_DATA
)
4563 || strcmp (name
, ".sdata") == 0
4564 || strcmp (name
, ".sbss") == 0
4565 || strcmp (name
, ".lit4") == 0 || strcmp (name
, ".lit8") == 0)
4566 hdr
->sh_flags
|= SHF_NIOS2_GPREL
;
4571 /* Create .got, .gotplt, and .rela.got sections in DYNOBJ, and set up
4572 shortcuts to them in our hash table. */
4574 create_got_section (bfd
*dynobj
, struct bfd_link_info
*info
)
4576 struct elf32_nios2_link_hash_table
*htab
;
4577 struct elf_link_hash_entry
*h
;
4579 htab
= elf32_nios2_hash_table (info
);
4581 if (! _bfd_elf_create_got_section (dynobj
, info
))
4584 /* In order for the two loads in .PLTresolve to share the same %hiadj,
4585 _GLOBAL_OFFSET_TABLE_ must be aligned to a 16-byte boundary. */
4586 if (!bfd_set_section_alignment (htab
->root
.sgotplt
, 4))
4589 /* The Nios II ABI specifies that GOT-relative relocations are relative
4590 to the linker-created symbol _gp_got, rather than using
4591 _GLOBAL_OFFSET_TABLE_ directly. In particular, the latter always
4592 points to the base of the GOT while _gp_got may include a bias. */
4593 h
= _bfd_elf_define_linkage_sym (dynobj
, info
, htab
->root
.sgotplt
,
4602 /* Implement elf_backend_create_dynamic_sections:
4603 Create .plt, .rela.plt, .got, .got.plt, .rela.got, .dynbss, and
4604 .rela.bss sections in DYNOBJ, and set up shortcuts to them in our
4607 nios2_elf32_create_dynamic_sections (bfd
*dynobj
, struct bfd_link_info
*info
)
4609 struct elf32_nios2_link_hash_table
*htab
;
4611 htab
= elf32_nios2_hash_table (info
);
4612 if (!htab
->root
.sgot
&& !create_got_section (dynobj
, info
))
4615 if (!_bfd_elf_create_dynamic_sections (dynobj
, info
))
4618 /* In order for the two loads in a shared object .PLTresolve to share the
4619 same %hiadj, the start of the PLT (as well as the GOT) must be aligned
4620 to a 16-byte boundary. This is because the addresses for these loads
4621 include the -(.plt+4) PIC correction. */
4622 return bfd_set_section_alignment (htab
->root
.splt
, 4);
4625 /* Implement elf_backend_copy_indirect_symbol:
4626 Copy the extra info we tack onto an elf_link_hash_entry. */
4628 nios2_elf32_copy_indirect_symbol (struct bfd_link_info
*info
,
4629 struct elf_link_hash_entry
*dir
,
4630 struct elf_link_hash_entry
*ind
)
4632 struct elf32_nios2_link_hash_entry
*edir
, *eind
;
4634 edir
= (struct elf32_nios2_link_hash_entry
*) dir
;
4635 eind
= (struct elf32_nios2_link_hash_entry
*) ind
;
4637 if (ind
->root
.type
== bfd_link_hash_indirect
4638 && dir
->got
.refcount
<= 0)
4640 edir
->tls_type
= eind
->tls_type
;
4641 eind
->tls_type
= GOT_UNKNOWN
;
4644 edir
->got_types_used
|= eind
->got_types_used
;
4646 _bfd_elf_link_hash_copy_indirect (info
, dir
, ind
);
4649 /* Set the right machine number for a NIOS2 ELF file. */
4652 nios2_elf32_object_p (bfd
*abfd
)
4656 mach
= elf_elfheader (abfd
)->e_flags
;
4661 case EF_NIOS2_ARCH_R1
:
4662 bfd_default_set_arch_mach (abfd
, bfd_arch_nios2
, bfd_mach_nios2r1
);
4664 case EF_NIOS2_ARCH_R2
:
4665 bfd_default_set_arch_mach (abfd
, bfd_arch_nios2
, bfd_mach_nios2r2
);
4672 /* Implement elf_backend_check_relocs:
4673 Look through the relocs for a section during the first phase. */
4675 nios2_elf32_check_relocs (bfd
*abfd
, struct bfd_link_info
*info
,
4676 asection
*sec
, const Elf_Internal_Rela
*relocs
)
4678 Elf_Internal_Shdr
*symtab_hdr
;
4679 struct elf_link_hash_entry
**sym_hashes
;
4680 const Elf_Internal_Rela
*rel
;
4681 const Elf_Internal_Rela
*rel_end
;
4682 struct elf32_nios2_link_hash_table
*htab
;
4683 asection
*sreloc
= NULL
;
4684 bfd_signed_vma
*local_got_refcounts
;
4686 if (bfd_link_relocatable (info
))
4689 symtab_hdr
= &elf_tdata (abfd
)->symtab_hdr
;
4690 sym_hashes
= elf_sym_hashes (abfd
);
4691 local_got_refcounts
= elf_local_got_refcounts (abfd
);
4693 htab
= elf32_nios2_hash_table (info
);
4695 rel_end
= relocs
+ sec
->reloc_count
;
4696 for (rel
= relocs
; rel
< rel_end
; rel
++)
4698 unsigned int r_type
;
4699 struct elf_link_hash_entry
*h
;
4700 unsigned long r_symndx
;
4702 r_symndx
= ELF32_R_SYM (rel
->r_info
);
4703 if (r_symndx
< symtab_hdr
->sh_info
)
4707 h
= sym_hashes
[r_symndx
- symtab_hdr
->sh_info
];
4708 while (h
->root
.type
== bfd_link_hash_indirect
4709 || h
->root
.type
== bfd_link_hash_warning
)
4710 h
= (struct elf_link_hash_entry
*) h
->root
.u
.i
.link
;
4713 r_type
= ELF32_R_TYPE (rel
->r_info
);
4718 case R_NIOS2_GOT_LO
:
4719 case R_NIOS2_GOT_HA
:
4720 case R_NIOS2_CALL16
:
4721 case R_NIOS2_CALL_LO
:
4722 case R_NIOS2_CALL_HA
:
4723 case R_NIOS2_TLS_GD16
:
4724 case R_NIOS2_TLS_IE16
:
4725 /* This symbol requires a global offset table entry. */
4727 int tls_type
, old_tls_type
;
4733 case R_NIOS2_GOT_LO
:
4734 case R_NIOS2_GOT_HA
:
4735 case R_NIOS2_CALL16
:
4736 case R_NIOS2_CALL_LO
:
4737 case R_NIOS2_CALL_HA
:
4738 tls_type
= GOT_NORMAL
;
4740 case R_NIOS2_TLS_GD16
:
4741 tls_type
= GOT_TLS_GD
;
4743 case R_NIOS2_TLS_IE16
:
4744 tls_type
= GOT_TLS_IE
;
4750 struct elf32_nios2_link_hash_entry
*eh
4751 = (struct elf32_nios2_link_hash_entry
*)h
;
4753 old_tls_type
= elf32_nios2_hash_entry(h
)->tls_type
;
4754 if (r_type
== R_NIOS2_CALL16
4755 || r_type
== R_NIOS2_CALL_LO
4756 || r_type
== R_NIOS2_CALL_HA
)
4758 /* Make sure a plt entry is created for this symbol if
4759 it turns out to be a function defined by a dynamic
4764 eh
->got_types_used
|= CALL_USED
;
4767 eh
->got_types_used
|= GOT_USED
;
4771 /* This is a global offset table entry for a local symbol. */
4772 if (local_got_refcounts
== NULL
)
4776 size
= symtab_hdr
->sh_info
;
4777 size
*= (sizeof (bfd_signed_vma
) + sizeof (char));
4779 = ((bfd_signed_vma
*) bfd_zalloc (abfd
, size
));
4780 if (local_got_refcounts
== NULL
)
4782 elf_local_got_refcounts (abfd
) = local_got_refcounts
;
4783 elf32_nios2_local_got_tls_type (abfd
)
4784 = (char *) (local_got_refcounts
+ symtab_hdr
->sh_info
);
4786 local_got_refcounts
[r_symndx
]++;
4787 old_tls_type
= elf32_nios2_local_got_tls_type (abfd
) [r_symndx
];
4790 /* We will already have issued an error message if there is a
4791 TLS / non-TLS mismatch, based on the symbol type. We don't
4792 support any linker relaxations. So just combine any TLS
4794 if (old_tls_type
!= GOT_UNKNOWN
&& old_tls_type
!= GOT_NORMAL
4795 && tls_type
!= GOT_NORMAL
)
4796 tls_type
|= old_tls_type
;
4798 if (old_tls_type
!= tls_type
)
4801 elf32_nios2_hash_entry (h
)->tls_type
= tls_type
;
4803 elf32_nios2_local_got_tls_type (abfd
) [r_symndx
] = tls_type
;
4807 if (htab
->root
.sgot
== NULL
)
4809 if (htab
->root
.dynobj
== NULL
)
4810 htab
->root
.dynobj
= abfd
;
4811 if (!create_got_section (htab
->root
.dynobj
, info
))
4816 case R_NIOS2_TLS_LDM16
:
4817 htab
->tls_ldm_got
.refcount
++;
4820 /* This relocation describes the C++ object vtable hierarchy.
4821 Reconstruct it for later use during GC. */
4822 case R_NIOS2_GNU_VTINHERIT
:
4823 if (!bfd_elf_gc_record_vtinherit (abfd
, sec
, h
, rel
->r_offset
))
4827 /* This relocation describes which C++ vtable entries are actually
4828 used. Record for later use during GC. */
4829 case R_NIOS2_GNU_VTENTRY
:
4830 if (!bfd_elf_gc_record_vtentry (abfd
, sec
, h
, rel
->r_addend
))
4834 case R_NIOS2_BFD_RELOC_32
:
4835 case R_NIOS2_CALL26
:
4836 case R_NIOS2_CALL26_NOAT
:
4837 case R_NIOS2_HIADJ16
:
4842 /* If this reloc is in a read-only section, we might
4843 need a copy reloc. We can't check reliably at this
4844 stage whether the section is read-only, as input
4845 sections have not yet been mapped to output sections.
4846 Tentatively set the flag for now, and correct in
4847 adjust_dynamic_symbol. */
4848 if (!bfd_link_pic (info
))
4851 /* Make sure a plt entry is created for this symbol if it
4852 turns out to be a function defined by a dynamic object. */
4855 if (r_type
== R_NIOS2_CALL26
|| r_type
== R_NIOS2_CALL26_NOAT
)
4859 /* If we are creating a shared library, we need to copy the
4860 reloc into the shared library. */
4861 if (bfd_link_pic (info
)
4862 && (sec
->flags
& SEC_ALLOC
) != 0
4863 && (r_type
== R_NIOS2_BFD_RELOC_32
4864 || (h
!= NULL
&& ! h
->needs_plt
4865 && (! SYMBOLIC_BIND (info
, h
) || ! h
->def_regular
))))
4867 struct elf_dyn_relocs
*p
;
4868 struct elf_dyn_relocs
**head
;
4870 /* When creating a shared object, we must copy these
4871 reloc types into the output file. We create a reloc
4872 section in dynobj and make room for this reloc. */
4875 if (htab
->root
.dynobj
== NULL
)
4876 htab
->root
.dynobj
= abfd
;
4878 sreloc
= _bfd_elf_make_dynamic_reloc_section
4879 (sec
, htab
->root
.dynobj
, 2, abfd
, true);
4884 /* If this is a global symbol, we count the number of
4885 relocations we need for this symbol. */
4887 head
= &h
->dyn_relocs
;
4890 /* Track dynamic relocs needed for local syms too.
4891 We really need local syms available to do this
4896 Elf_Internal_Sym
*isym
;
4898 isym
= bfd_sym_from_r_symndx (&htab
->root
.sym_cache
,
4903 s
= bfd_section_from_elf_index (abfd
, isym
->st_shndx
);
4907 vpp
= &elf_section_data (s
)->local_dynrel
;
4908 head
= (struct elf_dyn_relocs
**) vpp
;
4912 if (p
== NULL
|| p
->sec
!= sec
)
4914 size_t amt
= sizeof *p
;
4915 p
= ((struct elf_dyn_relocs
*)
4916 bfd_alloc (htab
->root
.dynobj
, amt
));
4937 /* Implement elf_backend_gc_mark_hook:
4938 Return the section that should be marked against GC for a given
4941 nios2_elf32_gc_mark_hook (asection
*sec
,
4942 struct bfd_link_info
*info
,
4943 Elf_Internal_Rela
*rel
,
4944 struct elf_link_hash_entry
*h
,
4945 Elf_Internal_Sym
*sym
)
4948 switch (ELF32_R_TYPE (rel
->r_info
))
4950 case R_NIOS2_GNU_VTINHERIT
:
4951 case R_NIOS2_GNU_VTENTRY
:
4954 return _bfd_elf_gc_mark_hook (sec
, info
, rel
, h
, sym
);
4957 /* Implement elf_backend_finish_dynamic_symbols:
4958 Finish up dynamic symbol handling. We set the contents of various
4959 dynamic sections here. */
4961 nios2_elf32_finish_dynamic_symbol (bfd
*output_bfd
,
4962 struct bfd_link_info
*info
,
4963 struct elf_link_hash_entry
*h
,
4964 Elf_Internal_Sym
*sym
)
4966 struct elf32_nios2_link_hash_table
*htab
;
4967 struct elf32_nios2_link_hash_entry
*eh
4968 = (struct elf32_nios2_link_hash_entry
*)h
;
4971 htab
= elf32_nios2_hash_table (info
);
4973 if (h
->plt
.offset
!= (bfd_vma
) -1)
4980 Elf_Internal_Rela rela
;
4982 bfd_vma got_address
;
4984 /* This symbol has an entry in the procedure linkage table. Set
4986 BFD_ASSERT (h
->dynindx
!= -1);
4987 splt
= htab
->root
.splt
;
4988 sgotplt
= htab
->root
.sgotplt
;
4989 srela
= htab
->root
.srelplt
;
4990 BFD_ASSERT (splt
!= NULL
&& sgotplt
!= NULL
&& srela
!= NULL
);
4992 /* Emit the PLT entry. */
4993 if (bfd_link_pic (info
))
4995 nios2_elf32_install_data (splt
, nios2_so_plt_entry
, h
->plt
.offset
,
4997 plt_index
= (h
->plt
.offset
- 24) / 12;
4998 got_offset
= (plt_index
+ 3) * 4;
4999 nios2_elf32_install_imm16 (splt
, h
->plt
.offset
,
5000 hiadj(plt_index
* 4));
5001 nios2_elf32_install_imm16 (splt
, h
->plt
.offset
+ 4,
5002 (plt_index
* 4) & 0xffff);
5003 nios2_elf32_install_imm16 (splt
, h
->plt
.offset
+ 8,
5004 0xfff4 - h
->plt
.offset
);
5005 got_address
= (sgotplt
->output_section
->vma
+ sgotplt
->output_offset
5008 /* Fill in the entry in the global offset table. There are no
5009 res_n slots for a shared object PLT, instead the .got.plt entries
5010 point to the PLT entries. */
5011 bfd_put_32 (output_bfd
,
5012 splt
->output_section
->vma
+ splt
->output_offset
5013 + h
->plt
.offset
, sgotplt
->contents
+ got_offset
);
5017 plt_index
= (h
->plt
.offset
- 28 - htab
->res_n_size
) / 12;
5018 got_offset
= (plt_index
+ 3) * 4;
5020 nios2_elf32_install_data (splt
, nios2_plt_entry
, h
->plt
.offset
, 3);
5021 got_address
= (sgotplt
->output_section
->vma
+ sgotplt
->output_offset
5023 nios2_elf32_install_imm16 (splt
, h
->plt
.offset
, hiadj(got_address
));
5024 nios2_elf32_install_imm16 (splt
, h
->plt
.offset
+ 4,
5025 got_address
& 0xffff);
5027 /* Fill in the entry in the global offset table. */
5028 bfd_put_32 (output_bfd
,
5029 splt
->output_section
->vma
+ splt
->output_offset
5030 + plt_index
* 4, sgotplt
->contents
+ got_offset
);
5033 /* Fill in the entry in the .rela.plt section. */
5034 rela
.r_offset
= got_address
;
5035 rela
.r_info
= ELF32_R_INFO (h
->dynindx
, R_NIOS2_JUMP_SLOT
);
5037 loc
= srela
->contents
+ plt_index
* sizeof (Elf32_External_Rela
);
5038 bfd_elf32_swap_reloca_out (output_bfd
, &rela
, loc
);
5040 if (!h
->def_regular
)
5042 /* Mark the symbol as undefined, rather than as defined in
5043 the .plt section. Leave the value alone. */
5044 sym
->st_shndx
= SHN_UNDEF
;
5045 /* If the symbol is weak, we do need to clear the value.
5046 Otherwise, the PLT entry would provide a definition for
5047 the symbol even if the symbol wasn't defined anywhere,
5048 and so the symbol would never be NULL. */
5049 if (!h
->ref_regular_nonweak
)
5054 use_plt
= (eh
->got_types_used
== CALL_USED
5055 && h
->plt
.offset
!= (bfd_vma
) -1);
5057 if (!use_plt
&& h
->got
.offset
!= (bfd_vma
) -1
5058 && (elf32_nios2_hash_entry (h
)->tls_type
& GOT_TLS_GD
) == 0
5059 && (elf32_nios2_hash_entry (h
)->tls_type
& GOT_TLS_IE
) == 0)
5063 Elf_Internal_Rela rela
;
5067 /* This symbol has an entry in the global offset table. Set it
5069 sgot
= htab
->root
.sgot
;
5070 srela
= htab
->root
.srelgot
;
5071 BFD_ASSERT (sgot
!= NULL
&& srela
!= NULL
);
5073 offset
= (h
->got
.offset
& ~(bfd_vma
) 1);
5074 rela
.r_offset
= (sgot
->output_section
->vma
5075 + sgot
->output_offset
+ offset
);
5077 /* If this is a -Bsymbolic link, and the symbol is defined
5078 locally, we just want to emit a RELATIVE reloc. Likewise if
5079 the symbol was forced to be local because of a version file.
5080 The entry in the global offset table will already have been
5081 initialized in the relocate_section function. */
5083 if (bfd_link_pic (info
) && SYMBOL_REFERENCES_LOCAL (info
, h
))
5085 rela
.r_info
= ELF32_R_INFO (0, R_NIOS2_RELATIVE
);
5086 rela
.r_addend
= bfd_get_signed_32 (output_bfd
,
5087 (sgot
->contents
+ offset
));
5088 bfd_put_32 (output_bfd
, (bfd_vma
) 0, sgot
->contents
+ offset
);
5092 bfd_put_32 (output_bfd
, (bfd_vma
) 0,
5093 sgot
->contents
+ offset
);
5094 rela
.r_info
= ELF32_R_INFO (h
->dynindx
, R_NIOS2_GLOB_DAT
);
5098 loc
= srela
->contents
;
5099 loc
+= srela
->reloc_count
++ * sizeof (Elf32_External_Rela
);
5100 bfd_elf32_swap_reloca_out (output_bfd
, &rela
, loc
);
5103 if (use_plt
&& h
->got
.offset
!= (bfd_vma
) -1)
5105 bfd_vma offset
= (h
->got
.offset
& ~(bfd_vma
) 1);
5106 asection
*sgot
= htab
->root
.sgot
;
5107 asection
*splt
= htab
->root
.splt
;
5108 bfd_put_32 (output_bfd
, (splt
->output_section
->vma
+ splt
->output_offset
5110 sgot
->contents
+ offset
);
5116 Elf_Internal_Rela rela
;
5119 /* This symbol needs a copy reloc. Set it up. */
5120 BFD_ASSERT (h
->dynindx
!= -1
5121 && (h
->root
.type
== bfd_link_hash_defined
5122 || h
->root
.type
== bfd_link_hash_defweak
));
5124 rela
.r_offset
= (h
->root
.u
.def
.value
5125 + h
->root
.u
.def
.section
->output_section
->vma
5126 + h
->root
.u
.def
.section
->output_offset
);
5127 rela
.r_info
= ELF32_R_INFO (h
->dynindx
, R_NIOS2_COPY
);
5129 if (h
->root
.u
.def
.section
== htab
->root
.sdynrelro
)
5130 s
= htab
->root
.sreldynrelro
;
5132 s
= htab
->root
.srelbss
;
5133 BFD_ASSERT (s
!= NULL
);
5134 loc
= s
->contents
+ s
->reloc_count
++ * sizeof (Elf32_External_Rela
);
5135 bfd_elf32_swap_reloca_out (output_bfd
, &rela
, loc
);
5138 /* Mark _DYNAMIC, _GLOBAL_OFFSET_TABLE_, and _gp_got as absolute. */
5139 if (strcmp (h
->root
.root
.string
, "_DYNAMIC") == 0
5140 || h
== htab
->root
.hgot
5141 || h
== htab
->h_gp_got
)
5142 sym
->st_shndx
= SHN_ABS
;
5147 /* Implement elf_backend_finish_dynamic_sections. */
5149 nios2_elf32_finish_dynamic_sections (bfd
*output_bfd
,
5150 struct bfd_link_info
*info
)
5154 struct elf32_nios2_link_hash_table
*htab
;
5156 htab
= elf32_nios2_hash_table (info
);
5157 sgotplt
= htab
->root
.sgotplt
;
5160 if (htab
->root
.dynamic_sections_created
)
5163 Elf32_External_Dyn
*dyncon
, *dynconend
;
5165 splt
= htab
->root
.splt
;
5166 sdyn
= bfd_get_linker_section (htab
->root
.dynobj
, ".dynamic");
5167 BFD_ASSERT (splt
!= NULL
&& sdyn
!= NULL
&& sgotplt
!= NULL
);
5169 dyncon
= (Elf32_External_Dyn
*) sdyn
->contents
;
5170 dynconend
= (Elf32_External_Dyn
*) (sdyn
->contents
+ sdyn
->size
);
5171 for (; dyncon
< dynconend
; dyncon
++)
5173 Elf_Internal_Dyn dyn
;
5176 bfd_elf32_swap_dyn_in (htab
->root
.dynobj
, dyncon
, &dyn
);
5184 s
= htab
->root
.sgotplt
;
5185 dyn
.d_un
.d_ptr
= s
->output_section
->vma
+ s
->output_offset
;
5186 bfd_elf32_swap_dyn_out (output_bfd
, &dyn
, dyncon
);
5190 s
= htab
->root
.srelplt
;
5191 dyn
.d_un
.d_ptr
= s
->output_section
->vma
+ s
->output_offset
;
5192 bfd_elf32_swap_dyn_out (output_bfd
, &dyn
, dyncon
);
5196 s
= htab
->root
.srelplt
;
5197 dyn
.d_un
.d_val
= s
->size
;
5198 bfd_elf32_swap_dyn_out (output_bfd
, &dyn
, dyncon
);
5202 s
= htab
->root
.sgotplt
;
5204 = s
->output_section
->vma
+ s
->output_offset
+ 0x7ff0;
5205 bfd_elf32_swap_dyn_out (output_bfd
, &dyn
, dyncon
);
5210 /* Fill in the first entry in the procedure linkage table. */
5213 bfd_vma got_address
= (sgotplt
->output_section
->vma
5214 + sgotplt
->output_offset
);
5215 if (bfd_link_pic (info
))
5217 bfd_vma got_pcrel
= got_address
- (splt
->output_section
->vma
5218 + splt
->output_offset
);
5219 /* Both GOT and PLT must be aligned to a 16-byte boundary
5220 for the two loads to share the %hiadj part. The 4-byte
5221 offset for nextpc is accounted for in the %lo offsets
5223 BFD_ASSERT ((got_pcrel
& 0xf) == 0);
5224 nios2_elf32_install_data (splt
, nios2_so_plt0_entry
, 0, 6);
5225 nios2_elf32_install_imm16 (splt
, 4, hiadj (got_pcrel
));
5226 nios2_elf32_install_imm16 (splt
, 12, got_pcrel
& 0xffff);
5227 nios2_elf32_install_imm16 (splt
, 16, (got_pcrel
+ 4) & 0xffff);
5231 /* Divide by 4 here, not 3 because we already corrected for the
5233 bfd_vma res_size
= (splt
->size
- 28) / 4;
5234 bfd_vma res_start
= (splt
->output_section
->vma
5235 + splt
->output_offset
);
5238 for (res_offset
= 0; res_offset
< res_size
; res_offset
+= 4)
5239 bfd_put_32 (output_bfd
,
5240 6 | ((res_size
- (res_offset
+ 4)) << 6),
5241 splt
->contents
+ res_offset
);
5243 /* The GOT must be aligned to a 16-byte boundary for the
5244 two loads to share the same %hiadj part. */
5245 BFD_ASSERT ((got_address
& 0xf) == 0);
5247 nios2_elf32_install_data (splt
, nios2_plt0_entry
, res_size
, 7);
5248 nios2_elf32_install_imm16 (splt
, res_size
, hiadj (res_start
));
5249 nios2_elf32_install_imm16 (splt
, res_size
+ 4,
5250 res_start
& 0xffff);
5251 nios2_elf32_install_imm16 (splt
, res_size
+ 12,
5252 hiadj (got_address
));
5253 nios2_elf32_install_imm16 (splt
, res_size
+ 16,
5254 (got_address
+ 4) & 0xffff);
5255 nios2_elf32_install_imm16 (splt
, res_size
+ 20,
5256 (got_address
+ 8) & 0xffff);
5261 /* Fill in the first three entries in the global offset table. */
5262 if (sgotplt
!= NULL
&& sgotplt
->size
> 0)
5265 bfd_put_32 (output_bfd
, (bfd_vma
) 0, sgotplt
->contents
);
5267 bfd_put_32 (output_bfd
,
5268 sdyn
->output_section
->vma
+ sdyn
->output_offset
,
5270 bfd_put_32 (output_bfd
, (bfd_vma
) 0, sgotplt
->contents
+ 4);
5271 bfd_put_32 (output_bfd
, (bfd_vma
) 0, sgotplt
->contents
+ 8);
5273 if (sgotplt
->output_section
!= bfd_abs_section_ptr
)
5274 elf_section_data (sgotplt
->output_section
)->this_hdr
.sh_entsize
= 4;
5280 /* Implement elf_backend_adjust_dynamic_symbol:
5281 Adjust a symbol defined by a dynamic object and referenced by a
5282 regular object. The current definition is in some section of the
5283 dynamic object, but we're not including those sections. We have to
5284 change the definition to something the rest of the link can
5287 nios2_elf32_adjust_dynamic_symbol (struct bfd_link_info
*info
,
5288 struct elf_link_hash_entry
*h
)
5290 struct elf32_nios2_link_hash_table
*htab
;
5295 htab
= elf32_nios2_hash_table (info
);
5296 dynobj
= htab
->root
.dynobj
;
5298 /* Make sure we know what is going on here. */
5299 BFD_ASSERT (dynobj
!= NULL
5304 && !h
->def_regular
)));
5306 /* If this is a function, put it in the procedure linkage table. We
5307 will fill in the contents of the procedure linkage table later,
5308 when we know the address of the .got section. */
5309 if (h
->type
== STT_FUNC
|| h
->needs_plt
)
5311 if (h
->plt
.refcount
<= 0
5312 || SYMBOL_CALLS_LOCAL (info
, h
)
5313 || (ELF_ST_VISIBILITY (h
->other
) != STV_DEFAULT
5314 && h
->root
.type
== bfd_link_hash_undefweak
))
5316 /* This case can occur if we saw a PLT reloc in an input
5317 file, but the symbol was never referred to by a dynamic
5318 object, or if all references were garbage collected. In
5319 such a case, we don't actually need to build a procedure
5320 linkage table, and we can just do a PCREL reloc instead. */
5321 h
->plt
.offset
= (bfd_vma
) -1;
5328 /* Reinitialize the plt offset now that it is not used as a reference
5330 h
->plt
.offset
= (bfd_vma
) -1;
5332 /* If this is a weak symbol, and there is a real definition, the
5333 processor independent code will have arranged for us to see the
5334 real definition first, and we can just use the same value. */
5335 if (h
->is_weakalias
)
5337 struct elf_link_hash_entry
*def
= weakdef (h
);
5338 BFD_ASSERT (def
->root
.type
== bfd_link_hash_defined
);
5339 h
->root
.u
.def
.section
= def
->root
.u
.def
.section
;
5340 h
->root
.u
.def
.value
= def
->root
.u
.def
.value
;
5344 /* If there are no non-GOT references, we do not need a copy
5346 if (!h
->non_got_ref
)
5349 /* This is a reference to a symbol defined by a dynamic object which
5351 If we are creating a shared library, we must presume that the
5352 only references to the symbol are via the global offset table.
5353 For such cases we need not do anything here; the relocations will
5354 be handled correctly by relocate_section. */
5355 if (bfd_link_pic (info
))
5360 _bfd_error_handler (_("dynamic variable `%s' is zero size"),
5361 h
->root
.root
.string
);
5365 /* We must allocate the symbol in our .dynbss section, which will
5366 become part of the .bss section of the executable. There will be
5367 an entry for this symbol in the .dynsym section. The dynamic
5368 object will contain position independent code, so all references
5369 from the dynamic object to this symbol will go through the global
5370 offset table. The dynamic linker will use the .dynsym entry to
5371 determine the address it must put in the global offset table, so
5372 both the dynamic object and the regular object will refer to the
5373 same memory location for the variable. */
5374 /* We must generate a R_NIOS2_COPY reloc to tell the dynamic linker to
5375 copy the initial value out of the dynamic object and into the
5376 runtime process image. We need to remember the offset into the
5377 .rela.bss section we are going to use. */
5378 if ((h
->root
.u
.def
.section
->flags
& SEC_READONLY
) != 0)
5380 s
= htab
->root
.sdynrelro
;
5381 srel
= htab
->root
.sreldynrelro
;
5385 s
= htab
->root
.sdynbss
;
5386 srel
= htab
->root
.srelbss
;
5388 if ((h
->root
.u
.def
.section
->flags
& SEC_ALLOC
) != 0)
5390 srel
->size
+= sizeof (Elf32_External_Rela
);
5394 align2
= bfd_log2 (h
->size
);
5395 if (align2
> h
->root
.u
.def
.section
->alignment_power
)
5396 align2
= h
->root
.u
.def
.section
->alignment_power
;
5399 s
->size
= BFD_ALIGN (s
->size
, (bfd_size_type
)1 << align2
);
5400 if (align2
> bfd_section_alignment (s
)
5401 && !bfd_set_section_alignment (s
, align2
))
5404 /* Define the symbol as being at this point in the section. */
5405 h
->root
.u
.def
.section
= s
;
5406 h
->root
.u
.def
.value
= s
->size
;
5408 /* Increment the section size to make room for the symbol. */
5414 /* Worker function for nios2_elf32_size_dynamic_sections. */
5416 adjust_dynrelocs (struct elf_link_hash_entry
*h
, void *inf
)
5418 struct bfd_link_info
*info
;
5419 struct elf32_nios2_link_hash_table
*htab
;
5421 if (h
->root
.type
== bfd_link_hash_indirect
)
5424 if (h
->root
.type
== bfd_link_hash_warning
)
5425 /* When warning symbols are created, they **replace** the "real"
5426 entry in the hash table, thus we never get to see the real
5427 symbol in a hash traversal. So look at it now. */
5428 h
= (struct elf_link_hash_entry
*) h
->root
.u
.i
.link
;
5430 info
= (struct bfd_link_info
*) inf
;
5431 htab
= elf32_nios2_hash_table (info
);
5433 if (h
->plt
.offset
!= (bfd_vma
)-1)
5434 h
->plt
.offset
+= htab
->res_n_size
;
5435 if (htab
->root
.splt
== h
->root
.u
.def
.section
)
5436 h
->root
.u
.def
.value
+= htab
->res_n_size
;
5441 /* Another worker function for nios2_elf32_size_dynamic_sections.
5442 Allocate space in .plt, .got and associated reloc sections for
5445 allocate_dynrelocs (struct elf_link_hash_entry
*h
, void *inf
)
5447 struct bfd_link_info
*info
;
5448 struct elf32_nios2_link_hash_table
*htab
;
5449 struct elf32_nios2_link_hash_entry
*eh
;
5450 struct elf_dyn_relocs
*p
;
5453 if (h
->root
.type
== bfd_link_hash_indirect
)
5456 if (h
->root
.type
== bfd_link_hash_warning
)
5457 /* When warning symbols are created, they **replace** the "real"
5458 entry in the hash table, thus we never get to see the real
5459 symbol in a hash traversal. So look at it now. */
5460 h
= (struct elf_link_hash_entry
*) h
->root
.u
.i
.link
;
5462 info
= (struct bfd_link_info
*) inf
;
5463 htab
= elf32_nios2_hash_table (info
);
5465 if (htab
->root
.dynamic_sections_created
5466 && h
->plt
.refcount
> 0)
5468 /* Make sure this symbol is output as a dynamic symbol.
5469 Undefined weak syms won't yet be marked as dynamic. */
5470 if (h
->dynindx
== -1
5472 && !bfd_elf_link_record_dynamic_symbol (info
, h
))
5475 if (WILL_CALL_FINISH_DYNAMIC_SYMBOL (1, bfd_link_pic (info
), h
))
5477 asection
*s
= htab
->root
.splt
;
5479 /* Allocate room for the header. */
5482 if (bfd_link_pic (info
))
5488 h
->plt
.offset
= s
->size
;
5490 /* If this symbol is not defined in a regular file, and we are
5491 not generating a shared library, then set the symbol to this
5492 location in the .plt. This is required to make function
5493 pointers compare as equal between the normal executable and
5494 the shared library. */
5495 if (! bfd_link_pic (info
)
5498 h
->root
.u
.def
.section
= s
;
5499 h
->root
.u
.def
.value
= h
->plt
.offset
;
5502 /* Make room for this entry. */
5505 /* We also need to make an entry in the .rela.plt section. */
5506 htab
->root
.srelplt
->size
+= sizeof (Elf32_External_Rela
);
5508 /* And the .got.plt section. */
5509 htab
->root
.sgotplt
->size
+= 4;
5513 h
->plt
.offset
= (bfd_vma
) -1;
5519 h
->plt
.offset
= (bfd_vma
) -1;
5523 eh
= (struct elf32_nios2_link_hash_entry
*) h
;
5524 use_plt
= (eh
->got_types_used
== CALL_USED
5525 && h
->plt
.offset
!= (bfd_vma
) -1);
5527 if (h
->got
.refcount
> 0)
5531 int tls_type
= eh
->tls_type
;
5534 /* Make sure this symbol is output as a dynamic symbol.
5535 Undefined weak syms won't yet be marked as dynamic. */
5536 if (h
->dynindx
== -1
5538 && !bfd_elf_link_record_dynamic_symbol (info
, h
))
5541 s
= htab
->root
.sgot
;
5542 h
->got
.offset
= s
->size
;
5544 if (tls_type
== GOT_UNKNOWN
)
5547 if (tls_type
== GOT_NORMAL
)
5548 /* Non-TLS symbols need one GOT slot. */
5552 if (tls_type
& GOT_TLS_GD
)
5553 /* R_NIOS2_TLS_GD16 needs 2 consecutive GOT slots. */
5555 if (tls_type
& GOT_TLS_IE
)
5556 /* R_NIOS2_TLS_IE16 needs one GOT slot. */
5560 dyn
= htab
->root
.dynamic_sections_created
;
5563 if (WILL_CALL_FINISH_DYNAMIC_SYMBOL (dyn
, bfd_link_pic (info
), h
)
5564 && (!bfd_link_pic (info
)
5565 || !SYMBOL_REFERENCES_LOCAL (info
, h
)))
5568 if (tls_type
!= GOT_NORMAL
5569 && (bfd_link_pic (info
) || indx
!= 0)
5570 && (ELF_ST_VISIBILITY (h
->other
) == STV_DEFAULT
5571 || h
->root
.type
!= bfd_link_hash_undefweak
))
5573 if (tls_type
& GOT_TLS_IE
)
5574 htab
->root
.srelgot
->size
+= sizeof (Elf32_External_Rela
);
5576 if (tls_type
& GOT_TLS_GD
)
5577 htab
->root
.srelgot
->size
+= sizeof (Elf32_External_Rela
);
5579 if ((tls_type
& GOT_TLS_GD
) && indx
!= 0)
5580 htab
->root
.srelgot
->size
+= sizeof (Elf32_External_Rela
);
5582 else if ((ELF_ST_VISIBILITY (h
->other
) == STV_DEFAULT
5583 || h
->root
.type
!= bfd_link_hash_undefweak
)
5585 && (bfd_link_pic (info
)
5586 || WILL_CALL_FINISH_DYNAMIC_SYMBOL (dyn
, 0, h
)))
5587 htab
->root
.srelgot
->size
+= sizeof (Elf32_External_Rela
);
5590 h
->got
.offset
= (bfd_vma
) -1;
5592 if (h
->dyn_relocs
== NULL
)
5595 /* In the shared -Bsymbolic case, discard space allocated for
5596 dynamic pc-relative relocs against symbols which turn out to be
5597 defined in regular objects. For the normal shared case, discard
5598 space for pc-relative relocs that have become local due to symbol
5599 visibility changes. */
5601 if (bfd_link_pic (info
))
5604 && (h
->forced_local
|| SYMBOLIC_BIND (info
, h
)))
5606 struct elf_dyn_relocs
**pp
;
5608 for (pp
= &h
->dyn_relocs
; (p
= *pp
) != NULL
; )
5610 p
->count
-= p
->pc_count
;
5619 /* Also discard relocs on undefined weak syms with non-default
5621 if (h
->dyn_relocs
!= NULL
5622 && h
->root
.type
== bfd_link_hash_undefweak
)
5624 if (ELF_ST_VISIBILITY (h
->other
) != STV_DEFAULT
5625 || UNDEFWEAK_NO_DYNAMIC_RELOC (info
, h
))
5626 h
->dyn_relocs
= NULL
;
5628 /* Make sure undefined weak symbols are output as a dynamic
5630 else if (h
->dynindx
== -1
5632 && !bfd_elf_link_record_dynamic_symbol (info
, h
))
5638 /* For the non-shared case, discard space for relocs against
5639 symbols which turn out to need copy relocs or are not
5643 && ((h
->def_dynamic
&& !h
->def_regular
)
5644 || (htab
->root
.dynamic_sections_created
5645 && (h
->root
.type
== bfd_link_hash_undefweak
5646 || h
->root
.type
== bfd_link_hash_undefined
))))
5648 /* Make sure this symbol is output as a dynamic symbol.
5649 Undefined weak syms won't yet be marked as dynamic. */
5650 if (h
->dynindx
== -1
5652 && !bfd_elf_link_record_dynamic_symbol (info
, h
))
5655 /* If that succeeded, we know we'll be keeping all the
5657 if (h
->dynindx
!= -1)
5661 h
->dyn_relocs
= NULL
;
5666 /* Finally, allocate space. */
5667 for (p
= h
->dyn_relocs
; p
!= NULL
; p
= p
->next
)
5669 asection
*sreloc
= elf_section_data (p
->sec
)->sreloc
;
5670 sreloc
->size
+= p
->count
* sizeof (Elf32_External_Rela
);
5676 /* Implement elf_backend_size_dynamic_sections:
5677 Set the sizes of the dynamic sections. */
5679 nios2_elf32_size_dynamic_sections (bfd
*output_bfd ATTRIBUTE_UNUSED
,
5680 struct bfd_link_info
*info
)
5686 struct elf32_nios2_link_hash_table
*htab
;
5688 htab
= elf32_nios2_hash_table (info
);
5689 dynobj
= htab
->root
.dynobj
;
5690 BFD_ASSERT (dynobj
!= NULL
);
5692 htab
->res_n_size
= 0;
5693 if (htab
->root
.dynamic_sections_created
)
5695 /* Set the contents of the .interp section to the interpreter. */
5696 if (bfd_link_executable (info
) && !info
->nointerp
)
5698 s
= bfd_get_linker_section (dynobj
, ".interp");
5699 BFD_ASSERT (s
!= NULL
);
5700 s
->size
= sizeof ELF_DYNAMIC_INTERPRETER
;
5701 s
->contents
= (unsigned char *) ELF_DYNAMIC_INTERPRETER
;
5706 /* We may have created entries in the .rela.got section.
5707 However, if we are not creating the dynamic sections, we will
5708 not actually use these entries. Reset the size of .rela.got,
5709 which will cause it to get stripped from the output file
5711 s
= htab
->root
.srelgot
;
5716 /* Set up .got offsets for local syms, and space for local dynamic
5718 for (ibfd
= info
->input_bfds
; ibfd
!= NULL
; ibfd
= ibfd
->link
.next
)
5720 bfd_signed_vma
*local_got
;
5721 bfd_signed_vma
*end_local_got
;
5722 char *local_tls_type
;
5723 bfd_size_type locsymcount
;
5724 Elf_Internal_Shdr
*symtab_hdr
;
5727 if (bfd_get_flavour (ibfd
) != bfd_target_elf_flavour
)
5730 for (s
= ibfd
->sections
; s
!= NULL
; s
= s
->next
)
5732 struct elf_dyn_relocs
*p
;
5734 for (p
= elf_section_data (s
)->local_dynrel
; p
!= NULL
; p
= p
->next
)
5736 if (!bfd_is_abs_section (p
->sec
)
5737 && bfd_is_abs_section (p
->sec
->output_section
))
5739 /* Input section has been discarded, either because
5740 it is a copy of a linkonce section or due to
5741 linker script /DISCARD/, so we'll be discarding
5744 else if (p
->count
!= 0)
5746 srel
= elf_section_data (p
->sec
)->sreloc
;
5747 srel
->size
+= p
->count
* sizeof (Elf32_External_Rela
);
5752 local_got
= elf_local_got_refcounts (ibfd
);
5756 symtab_hdr
= &elf_tdata (ibfd
)->symtab_hdr
;
5757 locsymcount
= symtab_hdr
->sh_info
;
5758 end_local_got
= local_got
+ locsymcount
;
5759 local_tls_type
= elf32_nios2_local_got_tls_type (ibfd
);
5760 s
= htab
->root
.sgot
;
5761 srel
= htab
->root
.srelgot
;
5762 for (; local_got
< end_local_got
; ++local_got
, ++local_tls_type
)
5766 *local_got
= s
->size
;
5767 if (*local_tls_type
& GOT_TLS_GD
)
5768 /* TLS_GD relocs need an 8-byte structure in the GOT. */
5770 if (*local_tls_type
& GOT_TLS_IE
)
5772 if (*local_tls_type
== GOT_NORMAL
)
5775 if (bfd_link_pic (info
) || *local_tls_type
== GOT_TLS_GD
)
5776 srel
->size
+= sizeof (Elf32_External_Rela
);
5779 *local_got
= (bfd_vma
) -1;
5783 if (htab
->tls_ldm_got
.refcount
> 0)
5785 /* Allocate two GOT entries and one dynamic relocation (if necessary)
5786 for R_NIOS2_TLS_LDM16 relocations. */
5787 htab
->tls_ldm_got
.offset
= htab
->root
.sgot
->size
;
5788 htab
->root
.sgot
->size
+= 8;
5789 if (bfd_link_pic (info
))
5790 htab
->root
.srelgot
->size
+= sizeof (Elf32_External_Rela
);
5793 htab
->tls_ldm_got
.offset
= -1;
5795 /* Allocate global sym .plt and .got entries, and space for global
5796 sym dynamic relocs. */
5797 elf_link_hash_traverse (& htab
->root
, allocate_dynrelocs
, info
);
5799 if (htab
->root
.dynamic_sections_created
)
5801 /* If the .got section is more than 0x8000 bytes, we add
5802 0x8000 to the value of _gp_got, so that 16-bit relocations
5803 have a greater chance of working. */
5804 if (htab
->root
.sgot
->size
>= 0x8000
5805 && htab
->h_gp_got
->root
.u
.def
.value
== 0)
5806 htab
->h_gp_got
->root
.u
.def
.value
= 0x8000;
5809 /* The check_relocs and adjust_dynamic_symbol entry points have
5810 determined the sizes of the various dynamic sections. Allocate
5813 for (s
= dynobj
->sections
; s
!= NULL
; s
= s
->next
)
5817 if ((s
->flags
& SEC_LINKER_CREATED
) == 0)
5820 /* It's OK to base decisions on the section name, because none
5821 of the dynobj section names depend upon the input files. */
5822 name
= bfd_section_name (s
);
5824 if (startswith (name
, ".rela"))
5828 if (s
!= htab
->root
.srelplt
)
5831 /* We use the reloc_count field as a counter if we need
5832 to copy relocs into the output file. */
5836 else if (s
== htab
->root
.splt
)
5838 /* Correct for the number of res_N branches. */
5839 if (s
->size
!= 0 && !bfd_link_pic (info
))
5841 htab
->res_n_size
= (s
->size
- 28) / 3;
5842 s
->size
+= htab
->res_n_size
;
5845 else if (s
!= htab
->sbss
5846 && s
!= htab
->root
.sgot
5847 && s
!= htab
->root
.sgotplt
5848 && s
!= htab
->root
.sdynbss
5849 && s
!= htab
->root
.sdynrelro
)
5850 /* It's not one of our sections, so don't allocate space. */
5855 s
->flags
|= SEC_EXCLUDE
;
5859 if ((s
->flags
& SEC_HAS_CONTENTS
) == 0)
5862 /* Allocate memory for the section contents. */
5863 s
->contents
= (bfd_byte
*) bfd_zalloc (dynobj
, s
->size
);
5864 if (s
->contents
== NULL
)
5868 /* Adjust dynamic symbols that point to the plt to account for the
5869 now-known number of resN slots. */
5870 if (htab
->res_n_size
)
5871 elf_link_hash_traverse (& htab
->root
, adjust_dynrelocs
, info
);
5873 return _bfd_elf_add_dynamic_tags (output_bfd
, info
, relocs
);
5876 /* Free the derived linker hash table. */
5878 nios2_elf32_link_hash_table_free (bfd
*obfd
)
5880 struct elf32_nios2_link_hash_table
*htab
5881 = (struct elf32_nios2_link_hash_table
*) obfd
->link
.hash
;
5883 bfd_hash_table_free (&htab
->bstab
);
5884 _bfd_elf_link_hash_table_free (obfd
);
5887 /* Implement bfd_elf32_bfd_link_hash_table_create. */
5888 static struct bfd_link_hash_table
*
5889 nios2_elf32_link_hash_table_create (bfd
*abfd
)
5891 struct elf32_nios2_link_hash_table
*ret
;
5892 size_t amt
= sizeof (struct elf32_nios2_link_hash_table
);
5894 ret
= bfd_zmalloc (amt
);
5898 if (!_bfd_elf_link_hash_table_init (&ret
->root
, abfd
,
5901 elf32_nios2_link_hash_entry
),
5908 /* Init the stub hash table too. */
5909 if (!bfd_hash_table_init (&ret
->bstab
, stub_hash_newfunc
,
5910 sizeof (struct elf32_nios2_stub_hash_entry
)))
5912 _bfd_elf_link_hash_table_free (abfd
);
5915 ret
->root
.root
.hash_table_free
= nios2_elf32_link_hash_table_free
;
5917 return &ret
->root
.root
;
5920 /* Implement elf_backend_reloc_type_class. */
5921 static enum elf_reloc_type_class
5922 nios2_elf32_reloc_type_class (const struct bfd_link_info
*info ATTRIBUTE_UNUSED
,
5923 const asection
*rel_sec ATTRIBUTE_UNUSED
,
5924 const Elf_Internal_Rela
*rela
)
5926 switch ((int) ELF32_R_TYPE (rela
->r_info
))
5928 case R_NIOS2_RELATIVE
:
5929 return reloc_class_relative
;
5930 case R_NIOS2_JUMP_SLOT
:
5931 return reloc_class_plt
;
5933 return reloc_class_copy
;
5935 return reloc_class_normal
;
5939 /* Return 1 if target is one of ours. */
5941 is_nios2_elf_target (const struct bfd_target
*targ
)
5943 return (targ
== &nios2_elf32_le_vec
5944 || targ
== &nios2_elf32_be_vec
);
5947 /* Implement elf_backend_add_symbol_hook.
5948 This hook is called by the linker when adding symbols from an object
5949 file. We use it to put .comm items in .sbss, and not .bss. */
5951 nios2_elf_add_symbol_hook (bfd
*abfd
,
5952 struct bfd_link_info
*info
,
5953 Elf_Internal_Sym
*sym
,
5954 const char **namep ATTRIBUTE_UNUSED
,
5955 flagword
*flagsp ATTRIBUTE_UNUSED
,
5959 if (sym
->st_shndx
== SHN_COMMON
5960 && !bfd_link_relocatable (info
)
5961 && sym
->st_size
<= elf_gp_size (abfd
)
5962 && is_nios2_elf_target (info
->output_bfd
->xvec
))
5964 /* Common symbols less than or equal to -G nn bytes are automatically
5966 struct elf32_nios2_link_hash_table
*htab
;
5968 htab
= elf32_nios2_hash_table (info
);
5969 if (htab
->sbss
== NULL
)
5971 flagword flags
= SEC_IS_COMMON
| SEC_SMALL_DATA
| SEC_LINKER_CREATED
;
5973 if (htab
->root
.dynobj
== NULL
)
5974 htab
->root
.dynobj
= abfd
;
5976 htab
->sbss
= bfd_make_section_anyway_with_flags (htab
->root
.dynobj
,
5978 if (htab
->sbss
== NULL
)
5983 *valp
= sym
->st_size
;
5989 /* Implement elf_backend_can_make_relative_eh_frame:
5990 Decide whether to attempt to turn absptr or lsda encodings in
5991 shared libraries into pcrel within the given input section. */
5993 nios2_elf32_can_make_relative_eh_frame (bfd
*input_bfd ATTRIBUTE_UNUSED
,
5994 struct bfd_link_info
*info
5996 asection
*eh_frame_section
5999 /* We can't use PC-relative encodings in the .eh_frame section. */
6003 /* Implement elf_backend_special_sections. */
6004 const struct bfd_elf_special_section elf32_nios2_special_sections
[] =
6006 { STRING_COMMA_LEN (".sbss"), -2, SHT_NOBITS
,
6007 SHF_ALLOC
+ SHF_WRITE
+ SHF_NIOS2_GPREL
},
6008 { STRING_COMMA_LEN (".sdata"), -2, SHT_PROGBITS
,
6009 SHF_ALLOC
+ SHF_WRITE
+ SHF_NIOS2_GPREL
},
6010 { NULL
, 0, 0, 0, 0 }
6013 #define ELF_ARCH bfd_arch_nios2
6014 #define ELF_TARGET_ID NIOS2_ELF_DATA
6015 #define ELF_MACHINE_CODE EM_ALTERA_NIOS2
6017 /* The Nios II MMU uses a 4K page size. */
6019 #define ELF_MAXPAGESIZE 0x1000
6021 #define bfd_elf32_bfd_link_hash_table_create \
6022 nios2_elf32_link_hash_table_create
6024 #define bfd_elf32_bfd_merge_private_bfd_data \
6025 nios2_elf32_merge_private_bfd_data
6027 /* Relocation table lookup macros. */
6029 #define bfd_elf32_bfd_reloc_type_lookup nios2_elf32_bfd_reloc_type_lookup
6030 #define bfd_elf32_bfd_reloc_name_lookup nios2_elf32_bfd_reloc_name_lookup
6032 /* JUMP_TABLE_LINK macros. */
6034 /* elf_info_to_howto (using RELA relocations). */
6036 #define elf_info_to_howto nios2_elf32_info_to_howto
6038 /* elf backend functions. */
6040 #define elf_backend_can_gc_sections 1
6041 #define elf_backend_can_refcount 1
6042 #define elf_backend_plt_readonly 1
6043 #define elf_backend_want_got_plt 1
6044 #define elf_backend_want_dynrelro 1
6045 #define elf_backend_rela_normal 1
6046 #define elf_backend_dtrel_excludes_plt 1
6048 #define elf_backend_relocate_section nios2_elf32_relocate_section
6049 #define elf_backend_section_flags nios2_elf32_section_flags
6050 #define elf_backend_fake_sections nios2_elf32_fake_sections
6051 #define elf_backend_check_relocs nios2_elf32_check_relocs
6053 #define elf_backend_gc_mark_hook nios2_elf32_gc_mark_hook
6054 #define elf_backend_create_dynamic_sections \
6055 nios2_elf32_create_dynamic_sections
6056 #define elf_backend_finish_dynamic_symbol nios2_elf32_finish_dynamic_symbol
6057 #define elf_backend_finish_dynamic_sections \
6058 nios2_elf32_finish_dynamic_sections
6059 #define elf_backend_adjust_dynamic_symbol nios2_elf32_adjust_dynamic_symbol
6060 #define elf_backend_reloc_type_class nios2_elf32_reloc_type_class
6061 #define elf_backend_size_dynamic_sections nios2_elf32_size_dynamic_sections
6062 #define elf_backend_add_symbol_hook nios2_elf_add_symbol_hook
6063 #define elf_backend_copy_indirect_symbol nios2_elf32_copy_indirect_symbol
6064 #define elf_backend_object_p nios2_elf32_object_p
6066 #define elf_backend_grok_prstatus nios2_grok_prstatus
6067 #define elf_backend_grok_psinfo nios2_grok_psinfo
6069 #undef elf_backend_can_make_relative_eh_frame
6070 #define elf_backend_can_make_relative_eh_frame \
6071 nios2_elf32_can_make_relative_eh_frame
6073 #define elf_backend_special_sections elf32_nios2_special_sections
6075 #define TARGET_LITTLE_SYM nios2_elf32_le_vec
6076 #define TARGET_LITTLE_NAME "elf32-littlenios2"
6077 #define TARGET_BIG_SYM nios2_elf32_be_vec
6078 #define TARGET_BIG_NAME "elf32-bignios2"
6080 #define elf_backend_got_header_size 12
6081 #define elf_backend_default_execstack 0
6083 #include "elf32-target.h"