Coverage Report

Created: 2025-06-24 06:45

/src/binutils-gdb/bfd/elf32-ppc.c
Line
Count
Source (jump to first uncovered line)
1
/* PowerPC-specific support for 32-bit ELF
2
   Copyright (C) 1994-2025 Free Software Foundation, Inc.
3
   Written by Ian Lance Taylor, Cygnus Support.
4
5
   This file is part of BFD, the Binary File Descriptor library.
6
7
   This program is free software; you can redistribute it and/or modify
8
   it under the terms of the GNU General Public License as published by
9
   the Free Software Foundation; either version 3 of the License, or
10
   (at your option) any later version.
11
12
   This program is distributed in the hope that it will be useful,
13
   but WITHOUT ANY WARRANTY; without even the implied warranty of
14
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15
   GNU General Public License for more details.
16
17
   You should have received a copy of the GNU General Public License
18
   along with this program; if not, write to the
19
   Free Software Foundation, Inc., 51 Franklin Street - Fifth Floor,
20
   Boston, MA 02110-1301, USA.  */
21
22
/* The assembler should generate a full set of section symbols even
23
   when they appear unused.  The linux kernel build tool recordmcount
24
   needs them.  */
25
#define TARGET_KEEP_UNUSED_SECTION_SYMBOLS true
26
27
#include "sysdep.h"
28
#include <stdarg.h>
29
#include "bfd.h"
30
#include "bfdlink.h"
31
#include "libbfd.h"
32
#include "elf-bfd.h"
33
#include "elf/ppc.h"
34
#include "elf32-ppc.h"
35
#include "elf-vxworks.h"
36
#include "dwarf2.h"
37
#include "opcode/ppc.h"
38
39
/* All users of this file have bfd_octets_per_byte (abfd, sec) == 1.  */
40
0
#define OCTETS_PER_BYTE(ABFD, SEC) 1
41
42
typedef enum split16_format_type
43
{
44
  split16a_type = 0,
45
  split16d_type
46
}
47
split16_format_type;
48
49
/* RELA relocations are used here.  */
50
51
static bfd_reloc_status_type ppc_elf_addr16_ha_reloc
52
  (bfd *, arelent *, asymbol *, void *, asection *, bfd *, char **);
53
static bfd_reloc_status_type ppc_elf_unhandled_reloc
54
  (bfd *, arelent *, asymbol *, void *, asection *, bfd *, char **);
55
56
/* Branch prediction bit for branch taken relocs.  */
57
0
#define BRANCH_PREDICT_BIT 0x200000
58
/* Mask to set RA in memory instructions.  */
59
0
#define RA_REGISTER_MASK 0x001f0000
60
/* Value to shift register by to insert RA.  */
61
0
#define RA_REGISTER_SHIFT 16
62
63
/* The name of the dynamic interpreter.  This is put in the .interp
64
   section.  */
65
0
#define ELF_DYNAMIC_INTERPRETER "/usr/lib/ld.so.1"
66
67
/* For old-style PLT.  */
68
/* The number of single-slot PLT entries (the rest use two slots).  */
69
0
#define PLT_NUM_SINGLE_ENTRIES 8192
70
71
/* For new-style .glink and .plt.  */
72
0
#define GLINK_PLTRESOLVE 16*4
73
#define GLINK_ENTRY_SIZE(htab, h)         \
74
0
  ((4*4                 \
75
0
    + (h != NULL              \
76
0
       && h == htab->tls_get_addr          \
77
0
       && !htab->params->no_tls_get_addr_opt ? 8*4 : 0)     \
78
0
    + (1u << htab->params->plt_stub_align) - 1)       \
79
0
   & -(1u << htab->params->plt_stub_align))
80
81
/* VxWorks uses its own plt layout, filled in by the static linker.  */
82
83
/* The standard VxWorks PLT entry.  */
84
0
#define VXWORKS_PLT_ENTRY_SIZE 32
85
static const bfd_vma ppc_elf_vxworks_plt_entry
86
    [VXWORKS_PLT_ENTRY_SIZE / 4] =
87
  {
88
    0x3d800000, /* lis     r12,0     */
89
    0x818c0000, /* lwz     r12,0(r12)    */
90
    0x7d8903a6, /* mtctr   r12       */
91
    0x4e800420, /* bctr        */
92
    0x39600000, /* li    r11,0     */
93
    0x48000000, /* b     14 <.PLT0resolve+0x4> */
94
    0x60000000, /* nop         */
95
    0x60000000, /* nop         */
96
  };
97
static const bfd_vma ppc_elf_vxworks_pic_plt_entry
98
    [VXWORKS_PLT_ENTRY_SIZE / 4] =
99
  {
100
    0x3d9e0000, /* addis r12,r30,0 */
101
    0x818c0000, /* lwz   r12,0(r12) */
102
    0x7d8903a6, /* mtctr r12 */
103
    0x4e800420, /* bctr */
104
    0x39600000, /* li  r11,0 */
105
    0x48000000, /* b   14 <.PLT0resolve+0x4> 14: R_PPC_REL24 .PLTresolve */
106
    0x60000000, /* nop */
107
    0x60000000, /* nop */
108
  };
109
110
/* The initial VxWorks PLT entry.  */
111
0
#define VXWORKS_PLT_INITIAL_ENTRY_SIZE 32
112
static const bfd_vma ppc_elf_vxworks_plt0_entry
113
    [VXWORKS_PLT_INITIAL_ENTRY_SIZE / 4] =
114
  {
115
    0x3d800000, /* lis     r12,0  */
116
    0x398c0000, /* addi    r12,r12,0  */
117
    0x800c0008, /* lwz     r0,8(r12)  */
118
    0x7c0903a6, /* mtctr   r0   */
119
    0x818c0004, /* lwz     r12,4(r12) */
120
    0x4e800420, /* bctr     */
121
    0x60000000, /* nop      */
122
    0x60000000, /* nop      */
123
  };
124
static const bfd_vma ppc_elf_vxworks_pic_plt0_entry
125
    [VXWORKS_PLT_INITIAL_ENTRY_SIZE / 4] =
126
  {
127
    0x819e0008, /* lwz   r12,8(r30) */
128
    0x7d8903a6, /* mtctr r12      */
129
    0x819e0004, /* lwz   r12,4(r30) */
130
    0x4e800420, /* bctr       */
131
    0x60000000, /* nop        */
132
    0x60000000, /* nop        */
133
    0x60000000, /* nop        */
134
    0x60000000, /* nop        */
135
  };
136
137
/* For executables, we have some additional relocations in
138
   .rela.plt.unloaded, for the kernel loader.  */
139
140
/* The number of non-JMP_SLOT relocations per PLT0 slot. */
141
0
#define VXWORKS_PLT_NON_JMP_SLOT_RELOCS 3
142
/* The number of relocations in the PLTResolve slot. */
143
0
#define VXWORKS_PLTRESOLVE_RELOCS 2
144
/* The number of relocations in the PLTResolve slot when creating
145
   a shared library. */
146
#define VXWORKS_PLTRESOLVE_RELOCS_SHLIB 0
147
148
/* Some instructions.  */
149
#define ADDIS_11_11 0x3d6b0000
150
#define ADDIS_11_30 0x3d7e0000
151
#define ADDIS_12_12 0x3d8c0000
152
#define ADDI_11_11  0x396b0000
153
#define ADD_0_11_11 0x7c0b5a14
154
#define ADD_3_12_2  0x7c6c1214
155
#define ADD_11_0_11 0x7d605a14
156
3
#define B   0x48000000
157
#define BA    0x48000002
158
#define BCL_20_31 0x429f0005
159
1
#define BCTR    0x4e800420
160
#define BEQLR   0x4d820020
161
#define CMPWI_11_0  0x2c0b0000
162
8
#define LIS_11    0x3d600000
163
#define LIS_12    0x3d800000
164
#define LWZU_0_12 0x840c0000
165
#define LWZ_0_12  0x800c0000
166
#define LWZ_11_3  0x81630000
167
5
#define LWZ_11_11 0x816b0000
168
#define LWZ_11_30 0x817e0000
169
#define LWZ_12_3  0x81830000
170
#define LWZ_12_12 0x818c0000
171
#define MR_0_3    0x7c601b78
172
#define MR_3_0    0x7c030378
173
#define MFLR_0    0x7c0802a6
174
#define MFLR_12   0x7d8802a6
175
#define MTCTR_0   0x7c0903a6
176
5
#define MTCTR_11  0x7d6903a6
177
#define MTLR_0    0x7c0803a6
178
1
#define NOP   0x60000000
179
#define SUB_11_11_12  0x7d6c5850
180
181
/* Offset of tp and dtp pointers from start of TLS block.  */
182
0
#define TP_OFFSET 0x7000
183
0
#define DTP_OFFSET  0x8000
184
185
/* The value of a defined global symbol.  */
186
#define SYM_VAL(SYM) \
187
0
  ((SYM)->root.u.def.section->output_section->vma \
188
0
   + (SYM)->root.u.def.section->output_offset   \
189
0
   + (SYM)->root.u.def.value)
190

191
/* Relocation HOWTO's.  */
192
/* Like other ELF RELA targets that don't apply multiple
193
   field-altering relocations to the same localation, src_mask is
194
   always zero and pcrel_offset is the same as pc_relative.
195
   PowerPC can always use a zero bitpos, even when the field is not at
196
   the LSB.  For example, a REL24 could use rightshift=2, bisize=24
197
   and bitpos=2 which matches the ABI description, or as we do here,
198
   rightshift=0, bitsize=26 and bitpos=0.  */
199
#define HOW(type, size, bitsize, mask, rightshift, pc_relative, \
200
      complain, special_func)       \
201
  HOWTO (type, rightshift, size, bitsize, pc_relative, 0, \
202
   complain_overflow_ ## complain, special_func,    \
203
   #type, false, 0, mask, pc_relative)
204
205
static reloc_howto_type *ppc_elf_howto_table[R_PPC_max];
206
207
static reloc_howto_type ppc_elf_howto_raw[] = {
208
  /* This reloc does nothing.  */
209
  HOW (R_PPC_NONE, 0, 0, 0, 0, false, dont,
210
       bfd_elf_generic_reloc),
211
212
  /* A standard 32 bit relocation.  */
213
  HOW (R_PPC_ADDR32, 4, 32, 0xffffffff, 0, false, dont,
214
       bfd_elf_generic_reloc),
215
216
  /* An absolute 26 bit branch; the lower two bits must be zero.
217
     FIXME: we don't check that, we just clear them.  */
218
  HOW (R_PPC_ADDR24, 4, 26, 0x3fffffc, 0, false, signed,
219
       bfd_elf_generic_reloc),
220
221
  /* A standard 16 bit relocation.  */
222
  HOW (R_PPC_ADDR16, 2, 16, 0xffff, 0, false, bitfield,
223
       bfd_elf_generic_reloc),
224
225
  /* A 16 bit relocation without overflow.  */
226
  HOW (R_PPC_ADDR16_LO, 2, 16, 0xffff, 0, false, dont,
227
       bfd_elf_generic_reloc),
228
229
  /* The high order 16 bits of an address.  */
230
  HOW (R_PPC_ADDR16_HI, 2, 16, 0xffff, 16, false, dont,
231
       bfd_elf_generic_reloc),
232
233
  /* The high order 16 bits of an address, plus 1 if the contents of
234
     the low 16 bits, treated as a signed number, is negative.  */
235
  HOW (R_PPC_ADDR16_HA, 2, 16, 0xffff, 16, false, dont,
236
       ppc_elf_addr16_ha_reloc),
237
238
  /* An absolute 16 bit branch; the lower two bits must be zero.
239
     FIXME: we don't check that, we just clear them.  */
240
  HOW (R_PPC_ADDR14, 4, 16, 0xfffc, 0, false, signed,
241
       bfd_elf_generic_reloc),
242
243
  /* An absolute 16 bit branch, for which bit 10 should be set to
244
     indicate that the branch is expected to be taken.  The lower two
245
     bits must be zero.  */
246
  HOW (R_PPC_ADDR14_BRTAKEN, 4, 16, 0xfffc, 0, false, signed,
247
       bfd_elf_generic_reloc),
248
249
  /* An absolute 16 bit branch, for which bit 10 should be set to
250
     indicate that the branch is not expected to be taken.  The lower
251
     two bits must be zero.  */
252
  HOW (R_PPC_ADDR14_BRNTAKEN, 4, 16, 0xfffc, 0, false, signed,
253
       bfd_elf_generic_reloc),
254
255
  /* A relative 26 bit branch; the lower two bits must be zero.  */
256
  HOW (R_PPC_REL24, 4, 26, 0x3fffffc, 0, true, signed,
257
       bfd_elf_generic_reloc),
258
259
  /* A relative 16 bit branch; the lower two bits must be zero.  */
260
  HOW (R_PPC_REL14, 4, 16, 0xfffc, 0, true, signed,
261
       bfd_elf_generic_reloc),
262
263
  /* A relative 16 bit branch.  Bit 10 should be set to indicate that
264
     the branch is expected to be taken.  The lower two bits must be
265
     zero.  */
266
  HOW (R_PPC_REL14_BRTAKEN, 4, 16, 0xfffc, 0, true, signed,
267
       bfd_elf_generic_reloc),
268
269
  /* A relative 16 bit branch.  Bit 10 should be set to indicate that
270
     the branch is not expected to be taken.  The lower two bits must
271
     be zero.  */
272
  HOW (R_PPC_REL14_BRNTAKEN, 4, 16, 0xfffc, 0, true, signed,
273
       bfd_elf_generic_reloc),
274
275
  /* Like R_PPC_ADDR16, but referring to the GOT table entry for the
276
     symbol.  */
277
  HOW (R_PPC_GOT16, 2, 16, 0xffff, 0, false, signed,
278
       ppc_elf_unhandled_reloc),
279
280
  /* Like R_PPC_ADDR16_LO, but referring to the GOT table entry for
281
     the symbol.  */
282
  HOW (R_PPC_GOT16_LO, 2, 16, 0xffff, 0, false, dont,
283
       ppc_elf_unhandled_reloc),
284
285
  /* Like R_PPC_ADDR16_HI, but referring to the GOT table entry for
286
     the symbol.  */
287
  HOW (R_PPC_GOT16_HI, 2, 16, 0xffff, 16, false, dont,
288
       ppc_elf_unhandled_reloc),
289
290
  /* Like R_PPC_ADDR16_HA, but referring to the GOT table entry for
291
     the symbol.  */
292
  HOW (R_PPC_GOT16_HA, 2, 16, 0xffff, 16, false, dont,
293
       ppc_elf_unhandled_reloc),
294
295
  /* Like R_PPC_REL24, but referring to the procedure linkage table
296
     entry for the symbol.  */
297
  HOW (R_PPC_PLTREL24, 4, 26, 0x3fffffc, 0, true, signed,
298
       ppc_elf_unhandled_reloc),
299
300
  /* This is used only by the dynamic linker.  The symbol should exist
301
     both in the object being run and in some shared library.  The
302
     dynamic linker copies the data addressed by the symbol from the
303
     shared library into the object, because the object being
304
     run has to have the data at some particular address.  */
305
  HOW (R_PPC_COPY, 4, 32, 0, 0, false, dont,
306
       ppc_elf_unhandled_reloc),
307
308
  /* Like R_PPC_ADDR32, but used when setting global offset table
309
     entries.  */
310
  HOW (R_PPC_GLOB_DAT, 4, 32, 0xffffffff, 0, false, dont,
311
       ppc_elf_unhandled_reloc),
312
313
  /* Marks a procedure linkage table entry for a symbol.  */
314
  HOW (R_PPC_JMP_SLOT, 4, 32, 0, 0, false, dont,
315
       ppc_elf_unhandled_reloc),
316
317
  /* Used only by the dynamic linker.  When the object is run, this
318
     longword is set to the load address of the object, plus the
319
     addend.  */
320
  HOW (R_PPC_RELATIVE, 4, 32, 0xffffffff, 0, false, dont,
321
       bfd_elf_generic_reloc),
322
323
  /* Like R_PPC_REL24, but uses the value of the symbol within the
324
     object rather than the final value.  Normally used for
325
     _GLOBAL_OFFSET_TABLE_.  */
326
  HOW (R_PPC_LOCAL24PC, 4, 26, 0x3fffffc, 0, true, signed,
327
       bfd_elf_generic_reloc),
328
329
  /* Like R_PPC_ADDR32, but may be unaligned.  */
330
  HOW (R_PPC_UADDR32, 4, 32, 0xffffffff, 0, false, dont,
331
       bfd_elf_generic_reloc),
332
333
  /* Like R_PPC_ADDR16, but may be unaligned.  */
334
  HOW (R_PPC_UADDR16, 2, 16, 0xffff, 0, false, bitfield,
335
       bfd_elf_generic_reloc),
336
337
  /* 32-bit PC relative */
338
  HOW (R_PPC_REL32, 4, 32, 0xffffffff, 0, true, dont,
339
       bfd_elf_generic_reloc),
340
341
  /* 32-bit relocation to the symbol's procedure linkage table.
342
     FIXME: not supported.  */
343
  HOW (R_PPC_PLT32, 4, 32, 0, 0, false, dont,
344
       ppc_elf_unhandled_reloc),
345
346
  /* 32-bit PC relative relocation to the symbol's procedure linkage table.
347
     FIXME: not supported.  */
348
  HOW (R_PPC_PLTREL32, 4, 32, 0, 0, true, dont,
349
       ppc_elf_unhandled_reloc),
350
351
  /* Like R_PPC_ADDR16_LO, but referring to the PLT table entry for
352
     the symbol.  */
353
  HOW (R_PPC_PLT16_LO, 2, 16, 0xffff, 0, false, dont,
354
       ppc_elf_unhandled_reloc),
355
356
  /* Like R_PPC_ADDR16_HI, but referring to the PLT table entry for
357
     the symbol.  */
358
  HOW (R_PPC_PLT16_HI, 2, 16, 0xffff, 16, false, dont,
359
       ppc_elf_unhandled_reloc),
360
361
  /* Like R_PPC_ADDR16_HA, but referring to the PLT table entry for
362
     the symbol.  */
363
  HOW (R_PPC_PLT16_HA, 2, 16, 0xffff, 16, false, dont,
364
       ppc_elf_unhandled_reloc),
365
366
  /* A sign-extended 16 bit value relative to _SDA_BASE_, for use with
367
     small data items.  */
368
  HOW (R_PPC_SDAREL16, 2, 16, 0xffff, 0, false, signed,
369
       ppc_elf_unhandled_reloc),
370
371
  /* 16-bit section relative relocation.  */
372
  HOW (R_PPC_SECTOFF, 2, 16, 0xffff, 0, false, signed,
373
       ppc_elf_unhandled_reloc),
374
375
  /* 16-bit lower half section relative relocation.  */
376
  HOW (R_PPC_SECTOFF_LO, 2, 16, 0xffff, 0, false, dont,
377
       ppc_elf_unhandled_reloc),
378
379
  /* 16-bit upper half section relative relocation.  */
380
  HOW (R_PPC_SECTOFF_HI, 2, 16, 0xffff, 16, false, dont,
381
       ppc_elf_unhandled_reloc),
382
383
  /* 16-bit upper half adjusted section relative relocation.  */
384
  HOW (R_PPC_SECTOFF_HA, 2, 16, 0xffff, 16, false, dont,
385
       ppc_elf_unhandled_reloc),
386
387
  /* Marker relocs for TLS.  */
388
  HOW (R_PPC_TLS, 4, 32, 0, 0, false, dont,
389
       bfd_elf_generic_reloc),
390
391
  HOW (R_PPC_TLSGD, 4, 32, 0, 0, false, dont,
392
       bfd_elf_generic_reloc),
393
394
  HOW (R_PPC_TLSLD, 4, 32, 0, 0, false, dont,
395
       bfd_elf_generic_reloc),
396
397
  /* Marker relocs on inline plt call instructions.  */
398
  HOW (R_PPC_PLTSEQ, 4, 32, 0, 0, false, dont,
399
       bfd_elf_generic_reloc),
400
401
  HOW (R_PPC_PLTCALL, 4, 32, 0, 0, false, dont,
402
       bfd_elf_generic_reloc),
403
404
  /* Computes the load module index of the load module that contains the
405
     definition of its TLS sym.  */
406
  HOW (R_PPC_DTPMOD32, 4, 32, 0xffffffff, 0, false, dont,
407
       ppc_elf_unhandled_reloc),
408
409
  /* Computes a dtv-relative displacement, the difference between the value
410
     of sym+add and the base address of the thread-local storage block that
411
     contains the definition of sym, minus 0x8000.  */
412
  HOW (R_PPC_DTPREL32, 4, 32, 0xffffffff, 0, false, dont,
413
       ppc_elf_unhandled_reloc),
414
415
  /* A 16 bit dtprel reloc.  */
416
  HOW (R_PPC_DTPREL16, 2, 16, 0xffff, 0, false, signed,
417
       ppc_elf_unhandled_reloc),
418
419
  /* Like DTPREL16, but no overflow.  */
420
  HOW (R_PPC_DTPREL16_LO, 2, 16, 0xffff, 0, false, dont,
421
       ppc_elf_unhandled_reloc),
422
423
  /* Like DTPREL16_LO, but next higher group of 16 bits.  */
424
  HOW (R_PPC_DTPREL16_HI, 2, 16, 0xffff, 16, false, dont,
425
       ppc_elf_unhandled_reloc),
426
427
  /* Like DTPREL16_HI, but adjust for low 16 bits.  */
428
  HOW (R_PPC_DTPREL16_HA, 2, 16, 0xffff, 16, false, dont,
429
       ppc_elf_unhandled_reloc),
430
431
  /* Computes a tp-relative displacement, the difference between the value of
432
     sym+add and the value of the thread pointer (r13).  */
433
  HOW (R_PPC_TPREL32, 4, 32, 0xffffffff, 0, false, dont,
434
       ppc_elf_unhandled_reloc),
435
436
  /* A 16 bit tprel reloc.  */
437
  HOW (R_PPC_TPREL16, 2, 16, 0xffff, 0, false, signed,
438
       ppc_elf_unhandled_reloc),
439
440
  /* Like TPREL16, but no overflow.  */
441
  HOW (R_PPC_TPREL16_LO, 2, 16, 0xffff, 0, false, dont,
442
       ppc_elf_unhandled_reloc),
443
444
  /* Like TPREL16_LO, but next higher group of 16 bits.  */
445
  HOW (R_PPC_TPREL16_HI, 2, 16, 0xffff, 16, false, dont,
446
       ppc_elf_unhandled_reloc),
447
448
  /* Like TPREL16_HI, but adjust for low 16 bits.  */
449
  HOW (R_PPC_TPREL16_HA, 2, 16, 0xffff, 16, false, dont,
450
       ppc_elf_unhandled_reloc),
451
452
  /* Allocates two contiguous entries in the GOT to hold a tls_index structure,
453
     with values (sym+add)@dtpmod and (sym+add)@dtprel, and computes the offset
454
     to the first entry.  */
455
  HOW (R_PPC_GOT_TLSGD16, 2, 16, 0xffff, 0, false, signed,
456
       ppc_elf_unhandled_reloc),
457
458
  /* Like GOT_TLSGD16, but no overflow.  */
459
  HOW (R_PPC_GOT_TLSGD16_LO, 2, 16, 0xffff, 0, false, dont,
460
       ppc_elf_unhandled_reloc),
461
462
  /* Like GOT_TLSGD16_LO, but next higher group of 16 bits.  */
463
  HOW (R_PPC_GOT_TLSGD16_HI, 2, 16, 0xffff, 16, false, dont,
464
       ppc_elf_unhandled_reloc),
465
466
  /* Like GOT_TLSGD16_HI, but adjust for low 16 bits.  */
467
  HOW (R_PPC_GOT_TLSGD16_HA, 2, 16, 0xffff, 16, false, dont,
468
       ppc_elf_unhandled_reloc),
469
470
  /* Allocates two contiguous entries in the GOT to hold a tls_index structure,
471
     with values (sym+add)@dtpmod and zero, and computes the offset to the
472
     first entry.  */
473
  HOW (R_PPC_GOT_TLSLD16, 2, 16, 0xffff, 0, false, signed,
474
       ppc_elf_unhandled_reloc),
475
476
  /* Like GOT_TLSLD16, but no overflow.  */
477
  HOW (R_PPC_GOT_TLSLD16_LO, 2, 16, 0xffff, 0, false, dont,
478
       ppc_elf_unhandled_reloc),
479
480
  /* Like GOT_TLSLD16_LO, but next higher group of 16 bits.  */
481
  HOW (R_PPC_GOT_TLSLD16_HI, 2, 16, 0xffff, 16, false, dont,
482
       ppc_elf_unhandled_reloc),
483
484
  /* Like GOT_TLSLD16_HI, but adjust for low 16 bits.  */
485
  HOW (R_PPC_GOT_TLSLD16_HA, 2, 16, 0xffff, 16, false, dont,
486
       ppc_elf_unhandled_reloc),
487
488
  /* Allocates an entry in the GOT with value (sym+add)@dtprel, and computes
489
     the offset to the entry.  */
490
  HOW (R_PPC_GOT_DTPREL16, 2, 16, 0xffff, 0, false, signed,
491
       ppc_elf_unhandled_reloc),
492
493
  /* Like GOT_DTPREL16, but no overflow.  */
494
  HOW (R_PPC_GOT_DTPREL16_LO, 2, 16, 0xffff, 0, false, dont,
495
       ppc_elf_unhandled_reloc),
496
497
  /* Like GOT_DTPREL16_LO, but next higher group of 16 bits.  */
498
  HOW (R_PPC_GOT_DTPREL16_HI, 2, 16, 0xffff, 16, false, dont,
499
       ppc_elf_unhandled_reloc),
500
501
  /* Like GOT_DTPREL16_HI, but adjust for low 16 bits.  */
502
  HOW (R_PPC_GOT_DTPREL16_HA, 2, 16, 0xffff, 16, false, dont,
503
       ppc_elf_unhandled_reloc),
504
505
  /* Allocates an entry in the GOT with value (sym+add)@tprel, and computes the
506
     offset to the entry.  */
507
  HOW (R_PPC_GOT_TPREL16, 2, 16, 0xffff, 0, false, signed,
508
       ppc_elf_unhandled_reloc),
509
510
  /* Like GOT_TPREL16, but no overflow.  */
511
  HOW (R_PPC_GOT_TPREL16_LO, 2, 16, 0xffff, 0, false, dont,
512
       ppc_elf_unhandled_reloc),
513
514
  /* Like GOT_TPREL16_LO, but next higher group of 16 bits.  */
515
  HOW (R_PPC_GOT_TPREL16_HI, 2, 16, 0xffff, 16, false, dont,
516
       ppc_elf_unhandled_reloc),
517
518
  /* Like GOT_TPREL16_HI, but adjust for low 16 bits.  */
519
  HOW (R_PPC_GOT_TPREL16_HA, 2, 16, 0xffff, 16, false, dont,
520
       ppc_elf_unhandled_reloc),
521
522
  /* The remaining relocs are from the Embedded ELF ABI, and are not
523
     in the SVR4 ELF ABI.  */
524
525
  /* 32 bit value resulting from the addend minus the symbol.  */
526
  HOW (R_PPC_EMB_NADDR32, 4, 32, 0xffffffff, 0, false, dont,
527
       ppc_elf_unhandled_reloc),
528
529
  /* 16 bit value resulting from the addend minus the symbol.  */
530
  HOW (R_PPC_EMB_NADDR16, 2, 16, 0xffff, 0, false, signed,
531
       ppc_elf_unhandled_reloc),
532
533
  /* 16 bit value resulting from the addend minus the symbol.  */
534
  HOW (R_PPC_EMB_NADDR16_LO, 2, 16, 0xffff, 0, false, dont,
535
       ppc_elf_unhandled_reloc),
536
537
  /* The high order 16 bits of the addend minus the symbol.  */
538
  HOW (R_PPC_EMB_NADDR16_HI, 2, 16, 0xffff, 16, false, dont,
539
       ppc_elf_unhandled_reloc),
540
541
  /* The high order 16 bits of the result of the addend minus the address,
542
     plus 1 if the contents of the low 16 bits, treated as a signed number,
543
     is negative.  */
544
  HOW (R_PPC_EMB_NADDR16_HA, 2, 16, 0xffff, 16, false, dont,
545
       ppc_elf_unhandled_reloc),
546
547
  /* 16 bit value resulting from allocating a 4 byte word to hold an
548
     address in the .sdata section, and returning the offset from
549
     _SDA_BASE_ for that relocation.  */
550
  HOW (R_PPC_EMB_SDAI16, 2, 16, 0xffff, 0, false, signed,
551
       ppc_elf_unhandled_reloc),
552
553
  /* 16 bit value resulting from allocating a 4 byte word to hold an
554
     address in the .sdata2 section, and returning the offset from
555
     _SDA2_BASE_ for that relocation.  */
556
  HOW (R_PPC_EMB_SDA2I16, 2, 16, 0xffff, 0, false, signed,
557
       ppc_elf_unhandled_reloc),
558
559
  /* A sign-extended 16 bit value relative to _SDA2_BASE_, for use with
560
     small data items.   */
561
  HOW (R_PPC_EMB_SDA2REL, 2, 16, 0xffff, 0, false, signed,
562
       ppc_elf_unhandled_reloc),
563
564
  /* Relocate against either _SDA_BASE_ or _SDA2_BASE_, filling in the 16 bit
565
     signed offset from the appropriate base, and filling in the register
566
     field with the appropriate register (0, 2, or 13).  */
567
  HOW (R_PPC_EMB_SDA21, 4, 16, 0xffff, 0, false, signed,
568
       ppc_elf_unhandled_reloc),
569
570
  /* Relocation not handled: R_PPC_EMB_MRKREF */
571
  /* Relocation not handled: R_PPC_EMB_RELSEC16 */
572
  /* Relocation not handled: R_PPC_EMB_RELST_LO */
573
  /* Relocation not handled: R_PPC_EMB_RELST_HI */
574
  /* Relocation not handled: R_PPC_EMB_RELST_HA */
575
  /* Relocation not handled: R_PPC_EMB_BIT_FLD */
576
577
  /* PC relative relocation against either _SDA_BASE_ or _SDA2_BASE_, filling
578
     in the 16 bit signed offset from the appropriate base, and filling in the
579
     register field with the appropriate register (0, 2, or 13).  */
580
  HOW (R_PPC_EMB_RELSDA, 2, 16, 0xffff, 0, false, signed,
581
       ppc_elf_unhandled_reloc),
582
583
  /* A relative 8 bit branch.  */
584
  HOW (R_PPC_VLE_REL8, 2, 8, 0xff, 1, true, signed,
585
       bfd_elf_generic_reloc),
586
587
  /* A relative 15 bit branch.  */
588
  HOW (R_PPC_VLE_REL15, 4, 16, 0xfffe, 0, true, signed,
589
       bfd_elf_generic_reloc),
590
591
  /* A relative 24 bit branch.  */
592
  HOW (R_PPC_VLE_REL24, 4, 25, 0x1fffffe, 0, true, signed,
593
       bfd_elf_generic_reloc),
594
595
  /* The 16 LSBS in split16a format.  */
596
  HOW (R_PPC_VLE_LO16A, 4, 16, 0x1f07ff, 0, false, dont,
597
       ppc_elf_unhandled_reloc),
598
599
  /* The 16 LSBS in split16d format.  */
600
  HOW (R_PPC_VLE_LO16D, 4, 16, 0x3e007ff, 0, false, dont,
601
       ppc_elf_unhandled_reloc),
602
603
  /* Bits 16-31 split16a format.  */
604
  HOW (R_PPC_VLE_HI16A, 4, 16, 0x1f07ff, 16, false, dont,
605
       ppc_elf_unhandled_reloc),
606
607
  /* Bits 16-31 split16d format.  */
608
  HOW (R_PPC_VLE_HI16D, 4, 16, 0x3e007ff, 16, false, dont,
609
       ppc_elf_unhandled_reloc),
610
611
  /* Bits 16-31 (High Adjusted) in split16a format.  */
612
  HOW (R_PPC_VLE_HA16A, 4, 16, 0x1f07ff, 16, false, dont,
613
       ppc_elf_unhandled_reloc),
614
615
  /* Bits 16-31 (High Adjusted) in split16d format.  */
616
  HOW (R_PPC_VLE_HA16D, 4, 16, 0x3e007ff, 16, false, dont,
617
       ppc_elf_unhandled_reloc),
618
619
  /* This reloc is like R_PPC_EMB_SDA21 but only applies to e_add16i
620
     instructions.  If the register base is 0 then the linker changes
621
     the e_add16i to an e_li instruction.  */
622
  HOW (R_PPC_VLE_SDA21, 4, 16, 0xffff, 0, false, signed,
623
       ppc_elf_unhandled_reloc),
624
625
  /* Like R_PPC_VLE_SDA21 but ignore overflow.  */
626
  HOW (R_PPC_VLE_SDA21_LO, 4, 16, 0xffff, 0, false, dont,
627
       ppc_elf_unhandled_reloc),
628
629
  /* The 16 LSBS relative to _SDA_BASE_ in split16a format.  */
630
  HOW (R_PPC_VLE_SDAREL_LO16A, 4, 16, 0x1f07ff, 0, false, dont,
631
       ppc_elf_unhandled_reloc),
632
633
  /* The 16 LSBS relative to _SDA_BASE_ in split16d format.  */
634
  HOW (R_PPC_VLE_SDAREL_LO16D, 4, 16, 0x3e007ff, 0, false, dont,
635
       ppc_elf_unhandled_reloc),
636
637
  /* Bits 16-31 relative to _SDA_BASE_ in split16a format.  */
638
  HOW (R_PPC_VLE_SDAREL_HI16A, 4, 16, 0x1f07ff, 16, false, dont,
639
       ppc_elf_unhandled_reloc),
640
641
  /* Bits 16-31 relative to _SDA_BASE_ in split16d format.  */
642
  HOW (R_PPC_VLE_SDAREL_HI16D, 4, 16, 0x3e007ff, 16, false, dont,
643
       ppc_elf_unhandled_reloc),
644
645
  /* Bits 16-31 (HA) relative to _SDA_BASE split16a format.  */
646
  HOW (R_PPC_VLE_SDAREL_HA16A, 4, 16, 0x1f07ff, 16, false, dont,
647
       ppc_elf_unhandled_reloc),
648
649
  /* Bits 16-31 (HA) relative to _SDA_BASE split16d format.  */
650
  HOW (R_PPC_VLE_SDAREL_HA16D, 4, 16, 0x3e007ff, 16, false, dont,
651
       ppc_elf_unhandled_reloc),
652
653
  /* e_li split20 format.  */
654
  HOW (R_PPC_VLE_ADDR20, 4, 20, 0x1f7fff, 0, false, dont,
655
       ppc_elf_unhandled_reloc),
656
657
  HOW (R_PPC_IRELATIVE, 4, 32, 0xffffffff, 0, false, dont,
658
       ppc_elf_unhandled_reloc),
659
660
  /* A 16 bit relative relocation.  */
661
  HOW (R_PPC_REL16, 2, 16, 0xffff, 0, true, signed,
662
       bfd_elf_generic_reloc),
663
664
  /* A 16 bit relative relocation without overflow.  */
665
  HOW (R_PPC_REL16_LO, 2, 16, 0xffff, 0, true, dont,
666
       bfd_elf_generic_reloc),
667
668
  /* The high order 16 bits of a relative address.  */
669
  HOW (R_PPC_REL16_HI, 2, 16, 0xffff, 16, true, dont,
670
       bfd_elf_generic_reloc),
671
672
  /* The high order 16 bits of a relative address, plus 1 if the contents of
673
     the low 16 bits, treated as a signed number, is negative.  */
674
  HOW (R_PPC_REL16_HA, 2, 16, 0xffff, 16, true, dont,
675
       ppc_elf_addr16_ha_reloc),
676
677
  /* Like R_PPC_REL16_HA but for split field in addpcis.  */
678
  HOW (R_PPC_REL16DX_HA, 4, 16, 0x1fffc1, 16, true, signed,
679
       ppc_elf_addr16_ha_reloc),
680
681
  /* A split-field reloc for addpcis, non-relative (gas internal use only).  */
682
  HOW (R_PPC_16DX_HA, 4, 16, 0x1fffc1, 16, false, signed,
683
       ppc_elf_addr16_ha_reloc),
684
685
  /* GNU extension to record C++ vtable hierarchy.  */
686
  HOW (R_PPC_GNU_VTINHERIT, 0, 0, 0, 0, false, dont,
687
       NULL),
688
689
  /* GNU extension to record C++ vtable member usage.  */
690
  HOW (R_PPC_GNU_VTENTRY, 0, 0, 0, 0, false, dont,
691
       NULL),
692
693
  /* Phony reloc to handle AIX style TOC entries.  */
694
  HOW (R_PPC_TOC16, 2, 16, 0xffff, 0, false, signed,
695
       ppc_elf_unhandled_reloc),
696
};
697

698
/* Initialize the ppc_elf_howto_table, so that linear accesses can be done.  */
699
700
static void
701
ppc_elf_howto_init (void)
702
2
{
703
2
  unsigned int i, type;
704
705
2
  for (i = 0;
706
216
       i < sizeof (ppc_elf_howto_raw) / sizeof (ppc_elf_howto_raw[0]);
707
214
       i++)
708
214
    {
709
214
      type = ppc_elf_howto_raw[i].type;
710
214
      if (type >= (sizeof (ppc_elf_howto_table)
711
214
       / sizeof (ppc_elf_howto_table[0])))
712
0
  abort ();
713
214
      ppc_elf_howto_table[type] = &ppc_elf_howto_raw[i];
714
214
    }
715
2
}
716
717
static reloc_howto_type *
718
ppc_elf_reloc_type_lookup (bfd *abfd ATTRIBUTE_UNUSED,
719
         bfd_reloc_code_real_type code)
720
0
{
721
0
  enum elf_ppc_reloc_type r;
722
723
  /* Initialize howto table if not already done.  */
724
0
  if (!ppc_elf_howto_table[R_PPC_ADDR32])
725
0
    ppc_elf_howto_init ();
726
727
0
  switch (code)
728
0
    {
729
0
    default:
730
0
      return NULL;
731
732
0
    case BFD_RELOC_NONE:    r = R_PPC_NONE;     break;
733
0
    case BFD_RELOC_32:      r = R_PPC_ADDR32;   break;
734
0
    case BFD_RELOC_PPC_BA26:    r = R_PPC_ADDR24;   break;
735
0
    case BFD_RELOC_PPC64_ADDR16_DS:
736
0
    case BFD_RELOC_16:      r = R_PPC_ADDR16;   break;
737
0
    case BFD_RELOC_PPC64_ADDR16_LO_DS:
738
0
    case BFD_RELOC_LO16:    r = R_PPC_ADDR16_LO;    break;
739
0
    case BFD_RELOC_HI16:    r = R_PPC_ADDR16_HI;    break;
740
0
    case BFD_RELOC_HI16_S:    r = R_PPC_ADDR16_HA;    break;
741
0
    case BFD_RELOC_PPC_BA16:    r = R_PPC_ADDR14;   break;
742
0
    case BFD_RELOC_PPC_BA16_BRTAKEN:  r = R_PPC_ADDR14_BRTAKEN; break;
743
0
    case BFD_RELOC_PPC_BA16_BRNTAKEN: r = R_PPC_ADDR14_BRNTAKEN;  break;
744
0
    case BFD_RELOC_PPC_B26:   r = R_PPC_REL24;    break;
745
0
    case BFD_RELOC_PPC_B16:   r = R_PPC_REL14;    break;
746
0
    case BFD_RELOC_PPC_B16_BRTAKEN: r = R_PPC_REL14_BRTAKEN;  break;
747
0
    case BFD_RELOC_PPC_B16_BRNTAKEN:  r = R_PPC_REL14_BRNTAKEN; break;
748
0
    case BFD_RELOC_PPC64_GOT16_DS:
749
0
    case BFD_RELOC_16_GOTOFF:   r = R_PPC_GOT16;    break;
750
0
    case BFD_RELOC_PPC64_GOT16_LO_DS:
751
0
    case BFD_RELOC_LO16_GOTOFF:   r = R_PPC_GOT16_LO;   break;
752
0
    case BFD_RELOC_HI16_GOTOFF:   r = R_PPC_GOT16_HI;   break;
753
0
    case BFD_RELOC_HI16_S_GOTOFF: r = R_PPC_GOT16_HA;   break;
754
0
    case BFD_RELOC_24_PLT_PCREL:  r = R_PPC_PLTREL24;   break;
755
0
    case BFD_RELOC_PPC_COPY:    r = R_PPC_COPY;     break;
756
0
    case BFD_RELOC_PPC_GLOB_DAT:  r = R_PPC_GLOB_DAT;   break;
757
0
    case BFD_RELOC_PPC_LOCAL24PC: r = R_PPC_LOCAL24PC;    break;
758
0
    case BFD_RELOC_32_PCREL:    r = R_PPC_REL32;    break;
759
0
    case BFD_RELOC_32_PLTOFF:   r = R_PPC_PLT32;    break;
760
0
    case BFD_RELOC_32_PLT_PCREL:  r = R_PPC_PLTREL32;   break;
761
0
    case BFD_RELOC_PPC64_PLT16_LO_DS:
762
0
    case BFD_RELOC_LO16_PLTOFF:   r = R_PPC_PLT16_LO;   break;
763
0
    case BFD_RELOC_HI16_PLTOFF:   r = R_PPC_PLT16_HI;   break;
764
0
    case BFD_RELOC_HI16_S_PLTOFF: r = R_PPC_PLT16_HA;   break;
765
0
    case BFD_RELOC_GPREL16:   r = R_PPC_SDAREL16;   break;
766
0
    case BFD_RELOC_PPC64_SECTOFF_DS:
767
0
    case BFD_RELOC_16_BASEREL:    r = R_PPC_SECTOFF;    break;
768
0
    case BFD_RELOC_PPC64_SECTOFF_LO_DS:
769
0
    case BFD_RELOC_LO16_BASEREL:  r = R_PPC_SECTOFF_LO;   break;
770
0
    case BFD_RELOC_HI16_BASEREL:  r = R_PPC_SECTOFF_HI;   break;
771
0
    case BFD_RELOC_HI16_S_BASEREL:  r = R_PPC_SECTOFF_HA;   break;
772
0
    case BFD_RELOC_CTOR:    r = R_PPC_ADDR32;   break;
773
0
    case BFD_RELOC_PPC64_TOC16_DS:
774
0
    case BFD_RELOC_PPC_TOC16:   r = R_PPC_TOC16;    break;
775
0
    case BFD_RELOC_PPC_TLS:   r = R_PPC_TLS;      break;
776
0
    case BFD_RELOC_PPC_TLSGD:   r = R_PPC_TLSGD;    break;
777
0
    case BFD_RELOC_PPC_TLSLD:   r = R_PPC_TLSLD;    break;
778
0
    case BFD_RELOC_PPC_DTPMOD:    r = R_PPC_DTPMOD32;   break;
779
0
    case BFD_RELOC_PPC64_TPREL16_DS:
780
0
    case BFD_RELOC_PPC_TPREL16:   r = R_PPC_TPREL16;    break;
781
0
    case BFD_RELOC_PPC64_TPREL16_LO_DS:
782
0
    case BFD_RELOC_PPC_TPREL16_LO:  r = R_PPC_TPREL16_LO;   break;
783
0
    case BFD_RELOC_PPC_TPREL16_HI:  r = R_PPC_TPREL16_HI;   break;
784
0
    case BFD_RELOC_PPC_TPREL16_HA:  r = R_PPC_TPREL16_HA;   break;
785
0
    case BFD_RELOC_PPC_TPREL:   r = R_PPC_TPREL32;    break;
786
0
    case BFD_RELOC_PPC64_DTPREL16_DS:
787
0
    case BFD_RELOC_PPC_DTPREL16:  r = R_PPC_DTPREL16;   break;
788
0
    case BFD_RELOC_PPC64_DTPREL16_LO_DS:
789
0
    case BFD_RELOC_PPC_DTPREL16_LO: r = R_PPC_DTPREL16_LO;    break;
790
0
    case BFD_RELOC_PPC_DTPREL16_HI: r = R_PPC_DTPREL16_HI;    break;
791
0
    case BFD_RELOC_PPC_DTPREL16_HA: r = R_PPC_DTPREL16_HA;    break;
792
0
    case BFD_RELOC_PPC_DTPREL:    r = R_PPC_DTPREL32;   break;
793
0
    case BFD_RELOC_PPC_GOT_TLSGD16: r = R_PPC_GOT_TLSGD16;    break;
794
0
    case BFD_RELOC_PPC_GOT_TLSGD16_LO:  r = R_PPC_GOT_TLSGD16_LO; break;
795
0
    case BFD_RELOC_PPC_GOT_TLSGD16_HI:  r = R_PPC_GOT_TLSGD16_HI; break;
796
0
    case BFD_RELOC_PPC_GOT_TLSGD16_HA:  r = R_PPC_GOT_TLSGD16_HA; break;
797
0
    case BFD_RELOC_PPC_GOT_TLSLD16: r = R_PPC_GOT_TLSLD16;    break;
798
0
    case BFD_RELOC_PPC_GOT_TLSLD16_LO:  r = R_PPC_GOT_TLSLD16_LO; break;
799
0
    case BFD_RELOC_PPC_GOT_TLSLD16_HI:  r = R_PPC_GOT_TLSLD16_HI; break;
800
0
    case BFD_RELOC_PPC_GOT_TLSLD16_HA:  r = R_PPC_GOT_TLSLD16_HA; break;
801
0
    case BFD_RELOC_PPC_GOT_TPREL16: r = R_PPC_GOT_TPREL16;    break;
802
0
    case BFD_RELOC_PPC_GOT_TPREL16_LO:  r = R_PPC_GOT_TPREL16_LO; break;
803
0
    case BFD_RELOC_PPC_GOT_TPREL16_HI:  r = R_PPC_GOT_TPREL16_HI; break;
804
0
    case BFD_RELOC_PPC_GOT_TPREL16_HA:  r = R_PPC_GOT_TPREL16_HA; break;
805
0
    case BFD_RELOC_PPC_GOT_DTPREL16:  r = R_PPC_GOT_DTPREL16;   break;
806
0
    case BFD_RELOC_PPC_GOT_DTPREL16_LO: r = R_PPC_GOT_DTPREL16_LO;  break;
807
0
    case BFD_RELOC_PPC_GOT_DTPREL16_HI: r = R_PPC_GOT_DTPREL16_HI;  break;
808
0
    case BFD_RELOC_PPC_GOT_DTPREL16_HA: r = R_PPC_GOT_DTPREL16_HA;  break;
809
0
    case BFD_RELOC_PPC_EMB_NADDR32: r = R_PPC_EMB_NADDR32;    break;
810
0
    case BFD_RELOC_PPC_EMB_NADDR16: r = R_PPC_EMB_NADDR16;    break;
811
0
    case BFD_RELOC_PPC_EMB_NADDR16_LO:  r = R_PPC_EMB_NADDR16_LO; break;
812
0
    case BFD_RELOC_PPC_EMB_NADDR16_HI:  r = R_PPC_EMB_NADDR16_HI; break;
813
0
    case BFD_RELOC_PPC_EMB_NADDR16_HA:  r = R_PPC_EMB_NADDR16_HA; break;
814
0
    case BFD_RELOC_PPC_EMB_SDAI16:  r = R_PPC_EMB_SDAI16;   break;
815
0
    case BFD_RELOC_PPC_EMB_SDA2I16: r = R_PPC_EMB_SDA2I16;    break;
816
0
    case BFD_RELOC_PPC_EMB_SDA2REL: r = R_PPC_EMB_SDA2REL;    break;
817
0
    case BFD_RELOC_PPC_EMB_SDA21: r = R_PPC_EMB_SDA21;    break;
818
0
    case BFD_RELOC_PPC_EMB_MRKREF:  r = R_PPC_EMB_MRKREF;   break;
819
0
    case BFD_RELOC_PPC_EMB_RELSEC16:  r = R_PPC_EMB_RELSEC16;   break;
820
0
    case BFD_RELOC_PPC_EMB_RELST_LO:  r = R_PPC_EMB_RELST_LO;   break;
821
0
    case BFD_RELOC_PPC_EMB_RELST_HI:  r = R_PPC_EMB_RELST_HI;   break;
822
0
    case BFD_RELOC_PPC_EMB_RELST_HA:  r = R_PPC_EMB_RELST_HA;   break;
823
0
    case BFD_RELOC_PPC_EMB_BIT_FLD: r = R_PPC_EMB_BIT_FLD;    break;
824
0
    case BFD_RELOC_PPC_EMB_RELSDA:  r = R_PPC_EMB_RELSDA;   break;
825
0
    case BFD_RELOC_PPC_VLE_REL8:  r = R_PPC_VLE_REL8;   break;
826
0
    case BFD_RELOC_PPC_VLE_REL15: r = R_PPC_VLE_REL15;    break;
827
0
    case BFD_RELOC_PPC_VLE_REL24: r = R_PPC_VLE_REL24;    break;
828
0
    case BFD_RELOC_PPC_VLE_LO16A: r = R_PPC_VLE_LO16A;    break;
829
0
    case BFD_RELOC_PPC_VLE_LO16D: r = R_PPC_VLE_LO16D;    break;
830
0
    case BFD_RELOC_PPC_VLE_HI16A: r = R_PPC_VLE_HI16A;    break;
831
0
    case BFD_RELOC_PPC_VLE_HI16D: r = R_PPC_VLE_HI16D;    break;
832
0
    case BFD_RELOC_PPC_VLE_HA16A: r = R_PPC_VLE_HA16A;    break;
833
0
    case BFD_RELOC_PPC_VLE_HA16D: r = R_PPC_VLE_HA16D;    break;
834
0
    case BFD_RELOC_PPC_VLE_SDA21: r = R_PPC_VLE_SDA21;    break;
835
0
    case BFD_RELOC_PPC_VLE_SDA21_LO:  r = R_PPC_VLE_SDA21_LO;   break;
836
0
    case BFD_RELOC_PPC_VLE_SDAREL_LO16A:
837
0
      r = R_PPC_VLE_SDAREL_LO16A;
838
0
      break;
839
0
    case BFD_RELOC_PPC_VLE_SDAREL_LO16D:
840
0
      r = R_PPC_VLE_SDAREL_LO16D;
841
0
      break;
842
0
    case BFD_RELOC_PPC_VLE_SDAREL_HI16A:
843
0
      r = R_PPC_VLE_SDAREL_HI16A;
844
0
      break;
845
0
    case BFD_RELOC_PPC_VLE_SDAREL_HI16D:
846
0
      r = R_PPC_VLE_SDAREL_HI16D;
847
0
      break;
848
0
    case BFD_RELOC_PPC_VLE_SDAREL_HA16A:
849
0
      r = R_PPC_VLE_SDAREL_HA16A;
850
0
      break;
851
0
    case BFD_RELOC_PPC_VLE_SDAREL_HA16D:
852
0
      r = R_PPC_VLE_SDAREL_HA16D;
853
0
      break;
854
0
    case BFD_RELOC_16_PCREL:    r = R_PPC_REL16;    break;
855
0
    case BFD_RELOC_LO16_PCREL:    r = R_PPC_REL16_LO;   break;
856
0
    case BFD_RELOC_HI16_PCREL:    r = R_PPC_REL16_HI;   break;
857
0
    case BFD_RELOC_HI16_S_PCREL:  r = R_PPC_REL16_HA;   break;
858
0
    case BFD_RELOC_PPC_16DX_HA:   r = R_PPC_16DX_HA;    break;
859
0
    case BFD_RELOC_PPC_REL16DX_HA:  r = R_PPC_REL16DX_HA;   break;
860
0
    case BFD_RELOC_VTABLE_INHERIT:  r = R_PPC_GNU_VTINHERIT;  break;
861
0
    case BFD_RELOC_VTABLE_ENTRY:  r = R_PPC_GNU_VTENTRY;    break;
862
0
    }
863
864
0
  return ppc_elf_howto_table[r];
865
0
};
866
867
static reloc_howto_type *
868
ppc_elf_reloc_name_lookup (bfd *abfd ATTRIBUTE_UNUSED,
869
         const char *r_name)
870
0
{
871
0
  unsigned int i;
872
873
0
  for (i = 0;
874
0
       i < sizeof (ppc_elf_howto_raw) / sizeof (ppc_elf_howto_raw[0]);
875
0
       i++)
876
0
    if (ppc_elf_howto_raw[i].name != NULL
877
0
  && strcasecmp (ppc_elf_howto_raw[i].name, r_name) == 0)
878
0
      return &ppc_elf_howto_raw[i];
879
880
0
  return NULL;
881
0
}
882
883
/* Set the howto pointer for a PowerPC ELF reloc.  */
884
885
static bool
886
ppc_elf_info_to_howto (bfd *abfd,
887
           arelent *cache_ptr,
888
           Elf_Internal_Rela *dst)
889
855
{
890
855
  unsigned int r_type;
891
892
  /* Initialize howto table if not already done.  */
893
855
  if (!ppc_elf_howto_table[R_PPC_ADDR32])
894
2
    ppc_elf_howto_init ();
895
896
855
  r_type = ELF32_R_TYPE (dst->r_info);
897
855
  if (r_type >= R_PPC_max)
898
0
    {
899
      /* xgettext:c-format */
900
0
      _bfd_error_handler (_("%pB: unsupported relocation type %#x"),
901
0
        abfd, r_type);
902
0
      bfd_set_error (bfd_error_bad_value);
903
0
      return false;
904
0
    }
905
906
855
  cache_ptr->howto = ppc_elf_howto_table[r_type];
907
908
  /* Just because the above assert didn't trigger doesn't mean that
909
     ELF32_R_TYPE (dst->r_info) is necessarily a valid relocation.  */
910
855
  if (cache_ptr->howto == NULL)
911
6
    {
912
      /* xgettext:c-format */
913
6
      _bfd_error_handler (_("%pB: unsupported relocation type %#x"),
914
6
        abfd, r_type);
915
6
      bfd_set_error (bfd_error_bad_value);
916
917
6
      return false;
918
6
    }
919
920
849
  return true;
921
855
}
922
923
/* Handle the R_PPC_ADDR16_HA and R_PPC_REL16_HA relocs.  */
924
925
static bfd_reloc_status_type
926
ppc_elf_addr16_ha_reloc (bfd *abfd,
927
       arelent *reloc_entry,
928
       asymbol *symbol,
929
       void *data,
930
       asection *input_section,
931
       bfd *output_bfd,
932
       char **error_message ATTRIBUTE_UNUSED)
933
53
{
934
53
  enum elf_ppc_reloc_type r_type;
935
53
  long insn;
936
53
  bfd_size_type octets;
937
53
  bfd_vma value;
938
939
53
  if (output_bfd != NULL)
940
0
    {
941
0
      reloc_entry->address += input_section->output_offset;
942
0
      return bfd_reloc_ok;
943
0
    }
944
945
53
  reloc_entry->addend += 0x8000;
946
53
  r_type = reloc_entry->howto->type;
947
53
  if (r_type != R_PPC_REL16DX_HA)
948
53
    return bfd_reloc_continue;
949
950
0
  value = 0;
951
0
  if (!bfd_is_com_section (symbol->section))
952
0
    value = symbol->value;
953
0
  value += (reloc_entry->addend
954
0
      + symbol->section->output_offset
955
0
      + symbol->section->output_section->vma);
956
0
  value -= (reloc_entry->address
957
0
      + input_section->output_offset
958
0
      + input_section->output_section->vma);
959
0
  value >>= 16;
960
961
0
  octets = reloc_entry->address * OCTETS_PER_BYTE (abfd, input_section);
962
0
  if (!bfd_reloc_offset_in_range (reloc_entry->howto, abfd,
963
0
          input_section, octets))
964
0
    return bfd_reloc_outofrange;
965
966
0
  insn = bfd_get_32 (abfd, (bfd_byte *) data + octets);
967
0
  insn &= ~0x1fffc1;
968
0
  insn |= (value & 0xffc1) | ((value & 0x3e) << 15);
969
0
  bfd_put_32 (abfd, insn, (bfd_byte *) data + octets);
970
0
  return bfd_reloc_ok;
971
0
}
972
973
static bfd_reloc_status_type
974
ppc_elf_unhandled_reloc (bfd *abfd,
975
       arelent *reloc_entry,
976
       asymbol *symbol,
977
       void *data,
978
       asection *input_section,
979
       bfd *output_bfd,
980
       char **error_message)
981
39
{
982
  /* If this is a relocatable link (output_bfd test tells us), just
983
     call the generic function.  Any adjustment will be done at final
984
     link time.  */
985
39
  if (output_bfd != NULL)
986
0
    return bfd_elf_generic_reloc (abfd, reloc_entry, symbol, data,
987
0
          input_section, output_bfd, error_message);
988
989
39
  if (error_message != NULL)
990
39
    *error_message = bfd_asprintf (_("generic linker can't handle %s"),
991
39
             reloc_entry->howto->name);
992
39
  return bfd_reloc_dangerous;
993
39
}
994

995
/* Sections created by the linker.  */
996
997
typedef struct elf_linker_section
998
{
999
  /* Pointer to the bfd section.  */
1000
  asection *section;
1001
  /* Section name.  */
1002
  const char *name;
1003
  /* Associated bss section name.  */
1004
  const char *bss_name;
1005
  /* Associated symbol name.  */
1006
  const char *sym_name;
1007
  /* Associated symbol.  */
1008
  struct elf_link_hash_entry *sym;
1009
} elf_linker_section_t;
1010
1011
/* Linked list of allocated pointer entries.  This hangs off of the
1012
   symbol lists, and provides allows us to return different pointers,
1013
   based on different addend's.  */
1014
1015
typedef struct elf_linker_section_pointers
1016
{
1017
  /* next allocated pointer for this symbol */
1018
  struct elf_linker_section_pointers *next;
1019
  /* offset of pointer from beginning of section */
1020
  bfd_vma offset;
1021
  /* addend used */
1022
  bfd_vma addend;
1023
  /* which linker section this is */
1024
  elf_linker_section_t *lsect;
1025
} elf_linker_section_pointers_t;
1026
1027
struct ppc_elf_obj_tdata
1028
{
1029
  struct elf_obj_tdata elf;
1030
1031
  /* A mapping from local symbols to offsets into the various linker
1032
     sections added.  This is index by the symbol index.  */
1033
  elf_linker_section_pointers_t **linker_section_pointers;
1034
1035
  /* Flags used to auto-detect plt type.  */
1036
  unsigned int makes_plt_call : 1;
1037
  unsigned int has_rel16 : 1;
1038
};
1039
1040
#define ppc_elf_tdata(bfd) \
1041
0
  ((struct ppc_elf_obj_tdata *) (bfd)->tdata.any)
1042
1043
#define elf_local_ptr_offsets(bfd) \
1044
0
  (ppc_elf_tdata (bfd)->linker_section_pointers)
1045
1046
#define is_ppc_elf(bfd) \
1047
0
  (bfd_get_flavour (bfd) == bfd_target_elf_flavour \
1048
0
   && elf_object_id (bfd) == PPC32_ELF_DATA)
1049
1050
/* Override the generic function because we store some extras.  */
1051
1052
static bool
1053
ppc_elf_mkobject (bfd *abfd)
1054
410k
{
1055
410k
  return bfd_elf_allocate_object (abfd, sizeof (struct ppc_elf_obj_tdata));
1056
410k
}
1057
1058
/* When defaulting arch/mach, decode apuinfo to find a better match.  */
1059
1060
bool
1061
_bfd_elf_ppc_set_arch (bfd *abfd)
1062
35.0k
{
1063
35.0k
  unsigned long mach = 0;
1064
35.0k
  asection *s;
1065
35.0k
  unsigned char *contents;
1066
1067
35.0k
  if (abfd->arch_info->bits_per_word == 32
1068
35.0k
      && bfd_big_endian (abfd))
1069
5.68k
    {
1070
1071
6.84k
      for (s = abfd->sections; s != NULL; s = s->next)
1072
1.16k
  if ((elf_section_data (s)->this_hdr.sh_flags & SHF_PPC_VLE) != 0)
1073
0
    break;
1074
5.68k
      if (s != NULL)
1075
0
  mach = bfd_mach_ppc_vle;
1076
5.68k
    }
1077
1078
35.0k
  if (mach == 0)
1079
35.0k
    {
1080
35.0k
      s = bfd_get_section_by_name (abfd, APUINFO_SECTION_NAME);
1081
35.0k
      if (s != NULL
1082
35.0k
    && s->size >= 24
1083
35.0k
    && (s->flags & SEC_HAS_CONTENTS) != 0
1084
35.0k
    && bfd_malloc_and_get_section (abfd, s, &contents))
1085
110
  {
1086
110
    unsigned int apuinfo_size = bfd_get_32 (abfd, contents + 4);
1087
110
    unsigned int i;
1088
1089
138k
    for (i = 20; i < apuinfo_size + 20 && i + 4 <= s->size; i += 4)
1090
138k
      {
1091
138k
        unsigned int val = bfd_get_32 (abfd, contents + i);
1092
138k
        switch (val >> 16)
1093
138k
    {
1094
1.18k
    case PPC_APUINFO_PMR:
1095
2.45k
    case PPC_APUINFO_RFMCI:
1096
2.45k
      if (mach == 0)
1097
2
        mach = bfd_mach_ppc_titan;
1098
2.45k
      break;
1099
1100
836
    case PPC_APUINFO_ISEL:
1101
1.27k
    case PPC_APUINFO_CACHELCK:
1102
1.27k
      if (mach == bfd_mach_ppc_titan)
1103
0
        mach = bfd_mach_ppc_e500mc;
1104
1.27k
      break;
1105
1106
1.22k
    case PPC_APUINFO_SPE:
1107
10.1k
    case PPC_APUINFO_EFS:
1108
11.1k
    case PPC_APUINFO_BRLOCK:
1109
11.1k
      if (mach != bfd_mach_ppc_vle)
1110
10.5k
        mach = bfd_mach_ppc_e500;
1111
11.1k
      break;
1112
1113
204
    case PPC_APUINFO_VLE:
1114
204
      mach = bfd_mach_ppc_vle;
1115
204
      break;
1116
1117
123k
    default:
1118
123k
      mach = -1ul;
1119
138k
    }
1120
138k
      }
1121
110
    free (contents);
1122
110
  }
1123
35.0k
    }
1124
1125
35.0k
  if (mach != 0 && mach != -1ul)
1126
12
    {
1127
12
      const bfd_arch_info_type *arch;
1128
1129
168
      for (arch = abfd->arch_info->next; arch; arch = arch->next)
1130
168
  if (arch->mach == mach)
1131
12
    {
1132
12
      abfd->arch_info = arch;
1133
12
      break;
1134
12
    }
1135
12
    }
1136
35.0k
  return true;
1137
35.0k
}
1138
1139
/* Fix bad default arch selected for a 32 bit input bfd when the
1140
   default is 64 bit.  Also select arch based on apuinfo.  */
1141
1142
static bool
1143
ppc_elf_object_p (bfd *abfd)
1144
24.3k
{
1145
24.3k
  if (!abfd->arch_info->the_default)
1146
0
    return true;
1147
1148
24.3k
  if (abfd->arch_info->bits_per_word == 64)
1149
24.3k
    {
1150
24.3k
      Elf_Internal_Ehdr *i_ehdr = elf_elfheader (abfd);
1151
1152
24.3k
      if (i_ehdr->e_ident[EI_CLASS] == ELFCLASS32)
1153
24.3k
  {
1154
    /* Relies on arch after 64 bit default being 32 bit default.  */
1155
24.3k
    abfd->arch_info = abfd->arch_info->next;
1156
24.3k
    BFD_ASSERT (abfd->arch_info->bits_per_word == 32);
1157
24.3k
  }
1158
24.3k
    }
1159
24.3k
  return _bfd_elf_ppc_set_arch (abfd);
1160
24.3k
}
1161
1162
/* Function to set whether a module needs the -mrelocatable bit set.  */
1163
1164
static bool
1165
ppc_elf_set_private_flags (bfd *abfd, flagword flags)
1166
0
{
1167
0
  BFD_ASSERT (!elf_flags_init (abfd)
1168
0
        || elf_elfheader (abfd)->e_flags == flags);
1169
1170
0
  elf_elfheader (abfd)->e_flags = flags;
1171
0
  elf_flags_init (abfd) = true;
1172
0
  return true;
1173
0
}
1174
1175
/* Support for core dump NOTE sections.  */
1176
1177
static bool
1178
ppc_elf_grok_prstatus (bfd *abfd, Elf_Internal_Note *note)
1179
40
{
1180
40
  int offset;
1181
40
  unsigned int size;
1182
1183
40
  switch (note->descsz)
1184
40
    {
1185
40
    default:
1186
40
      return false;
1187
1188
0
    case 268:   /* Linux/PPC.  */
1189
      /* pr_cursig */
1190
0
      elf_tdata (abfd)->core->signal = bfd_get_16 (abfd, note->descdata + 12);
1191
1192
      /* pr_pid */
1193
0
      elf_tdata (abfd)->core->lwpid = bfd_get_32 (abfd, note->descdata + 24);
1194
1195
      /* pr_reg */
1196
0
      offset = 72;
1197
0
      size = 192;
1198
1199
0
      break;
1200
40
    }
1201
1202
  /* Make a ".reg/999" section.  */
1203
0
  return _bfd_elfcore_make_pseudosection (abfd, ".reg",
1204
0
            size, note->descpos + offset);
1205
40
}
1206
1207
static bool
1208
ppc_elf_grok_psinfo (bfd *abfd, Elf_Internal_Note *note)
1209
18
{
1210
18
  switch (note->descsz)
1211
18
    {
1212
18
    default:
1213
18
      return false;
1214
1215
0
    case 128:   /* Linux/PPC elf_prpsinfo.  */
1216
0
      elf_tdata (abfd)->core->pid
1217
0
  = bfd_get_32 (abfd, note->descdata + 16);
1218
0
      elf_tdata (abfd)->core->program
1219
0
  = _bfd_elfcore_strndup (abfd, note->descdata + 32, 16);
1220
0
      elf_tdata (abfd)->core->command
1221
0
  = _bfd_elfcore_strndup (abfd, note->descdata + 48, 80);
1222
18
    }
1223
1224
  /* Note that for some reason, a spurious space is tacked
1225
     onto the end of the args in some (at least one anyway)
1226
     implementations, so strip it off if it exists.  */
1227
1228
0
  {
1229
0
    char *command = elf_tdata (abfd)->core->command;
1230
0
    int n = strlen (command);
1231
1232
0
    if (0 < n && command[n - 1] == ' ')
1233
0
      command[n - 1] = '\0';
1234
0
  }
1235
1236
0
  return true;
1237
18
}
1238
1239
static char *
1240
ppc_elf_write_core_note (bfd *abfd, char *buf, int *bufsiz, int note_type, ...)
1241
0
{
1242
0
  switch (note_type)
1243
0
    {
1244
0
    default:
1245
0
      return NULL;
1246
1247
0
    case NT_PRPSINFO:
1248
0
      {
1249
0
  char data[128] ATTRIBUTE_NONSTRING;
1250
0
  va_list ap;
1251
1252
0
  va_start (ap, note_type);
1253
0
  memset (data, 0, sizeof (data));
1254
0
  strncpy (data + 32, va_arg (ap, const char *), 16);
1255
#if GCC_VERSION == 8000 || GCC_VERSION == 8001
1256
  DIAGNOSTIC_PUSH;
1257
  /* GCC 8.0 and 8.1 warn about 80 equals destination size with
1258
     -Wstringop-truncation:
1259
     https://gcc.gnu.org/bugzilla/show_bug.cgi?id=85643
1260
   */
1261
  DIAGNOSTIC_IGNORE_STRINGOP_TRUNCATION;
1262
#endif
1263
0
  strncpy (data + 48, va_arg (ap, const char *), 80);
1264
#if GCC_VERSION == 8000 || GCC_VERSION == 8001
1265
  DIAGNOSTIC_POP;
1266
#endif
1267
0
  va_end (ap);
1268
0
  return elfcore_write_note (abfd, buf, bufsiz,
1269
0
           "CORE", note_type, data, sizeof (data));
1270
0
      }
1271
1272
0
    case NT_PRSTATUS:
1273
0
      {
1274
0
  char data[268];
1275
0
  va_list ap;
1276
0
  long pid;
1277
0
  int cursig;
1278
0
  const void *greg;
1279
1280
0
  va_start (ap, note_type);
1281
0
  memset (data, 0, 72);
1282
0
  pid = va_arg (ap, long);
1283
0
  bfd_put_32 (abfd, pid, data + 24);
1284
0
  cursig = va_arg (ap, int);
1285
0
  bfd_put_16 (abfd, cursig, data + 12);
1286
0
  greg = va_arg (ap, const void *);
1287
0
  memcpy (data + 72, greg, 192);
1288
0
  memset (data + 264, 0, 4);
1289
0
  va_end (ap);
1290
0
  return elfcore_write_note (abfd, buf, bufsiz,
1291
0
           "CORE", note_type, data, sizeof (data));
1292
0
      }
1293
0
    }
1294
0
}
1295
1296
static flagword
1297
ppc_elf_lookup_section_flags (char *flag_name)
1298
0
{
1299
1300
0
  if (!strcmp (flag_name, "SHF_PPC_VLE"))
1301
0
    return SHF_PPC_VLE;
1302
1303
0
  return 0;
1304
0
}
1305
1306
/* Return address for Ith PLT stub in section PLT, for relocation REL
1307
   or (bfd_vma) -1 if it should not be included.  */
1308
1309
static bfd_vma
1310
ppc_elf_plt_sym_val (bfd_vma i ATTRIBUTE_UNUSED,
1311
         const asection *plt ATTRIBUTE_UNUSED,
1312
         const arelent *rel)
1313
0
{
1314
0
  return rel->address;
1315
0
}
1316
1317
/* Handle a PowerPC specific section when reading an object file.  This
1318
   is called when bfd_section_from_shdr finds a section with an unknown
1319
   type.  */
1320
1321
static bool
1322
ppc_elf_section_from_shdr (bfd *abfd,
1323
         Elf_Internal_Shdr *hdr,
1324
         const char *name,
1325
         int shindex)
1326
97.7k
{
1327
97.7k
  asection *newsect;
1328
97.7k
  flagword flags;
1329
1330
97.7k
  if (! _bfd_elf_make_section_from_shdr (abfd, hdr, name, shindex))
1331
1
    return false;
1332
1333
97.7k
  newsect = hdr->bfd_section;
1334
97.7k
  flags = 0;
1335
97.7k
  if (hdr->sh_flags & SHF_EXCLUDE)
1336
25.0k
    flags |= SEC_EXCLUDE;
1337
1338
97.7k
  if (hdr->sh_type == SHT_ORDERED)
1339
476
    flags |= SEC_SORT_ENTRIES;
1340
1341
97.7k
  if (startswith (name, ".PPC.EMB"))
1342
2.55k
    name += 8;
1343
97.7k
  if (startswith (name, ".sbss")
1344
97.7k
      || startswith (name, ".sdata"))
1345
7.83k
    flags |= SEC_SMALL_DATA;
1346
1347
97.7k
  return (flags == 0
1348
97.7k
    || bfd_set_section_flags (newsect, newsect->flags | flags));
1349
97.7k
}
1350
1351
/* Set up any other section flags and such that may be necessary.  */
1352
1353
static bool
1354
ppc_elf_fake_sections (bfd *abfd ATTRIBUTE_UNUSED,
1355
           Elf_Internal_Shdr *shdr,
1356
           asection *asect)
1357
29
{
1358
29
  if ((asect->flags & SEC_SORT_ENTRIES) != 0)
1359
0
    shdr->sh_type = SHT_ORDERED;
1360
1361
29
  return true;
1362
29
}
1363
1364
/* If we have .sbss2 or .PPC.EMB.sbss0 output sections, we
1365
   need to bump up the number of section headers.  */
1366
1367
static int
1368
ppc_elf_additional_program_headers (bfd *abfd,
1369
            struct bfd_link_info *info ATTRIBUTE_UNUSED)
1370
0
{
1371
0
  asection *s;
1372
0
  int ret = 0;
1373
1374
0
  s = bfd_get_section_by_name (abfd, ".sbss2");
1375
0
  if (s != NULL && (s->flags & SEC_ALLOC) != 0)
1376
0
    ++ret;
1377
1378
0
  s = bfd_get_section_by_name (abfd, ".PPC.EMB.sbss0");
1379
0
  if (s != NULL && (s->flags & SEC_ALLOC) != 0)
1380
0
    ++ret;
1381
1382
0
  return ret;
1383
0
}
1384
1385
/* Modify the segment map for VLE executables.  */
1386
1387
bool
1388
ppc_elf_modify_segment_map (bfd *abfd,
1389
          struct bfd_link_info *info ATTRIBUTE_UNUSED)
1390
1
{
1391
1
  struct elf_segment_map *m;
1392
1393
  /* At this point in the link, output sections have already been sorted by
1394
     LMA and assigned to segments.  All that is left to do is to ensure
1395
     there is no mixing of VLE & non-VLE sections in a text segment.
1396
     If we find that case, we split the segment.
1397
     We maintain the original output section order.  */
1398
1399
10
  for (m = elf_seg_map (abfd); m != NULL; m = m->next)
1400
9
    {
1401
9
      struct elf_segment_map *n;
1402
9
      size_t amt;
1403
9
      unsigned int j, k;
1404
9
      unsigned int p_flags;
1405
1406
9
      if (m->p_type != PT_LOAD || m->count == 0)
1407
7
  continue;
1408
1409
23
      for (p_flags = PF_R, j = 0; j != m->count; ++j)
1410
22
  {
1411
22
    if ((m->sections[j]->flags & SEC_READONLY) == 0)
1412
11
      p_flags |= PF_W;
1413
22
    if ((m->sections[j]->flags & SEC_CODE) != 0)
1414
1
      {
1415
1
        p_flags |= PF_X;
1416
1
        if ((elf_section_flags (m->sections[j]) & SHF_PPC_VLE) != 0)
1417
0
    p_flags |= PF_PPC_VLE;
1418
1
        break;
1419
1
      }
1420
22
  }
1421
2
      if (j != m->count)
1422
6
  while (++j != m->count)
1423
5
    {
1424
5
      unsigned int p_flags1 = PF_R;
1425
1426
5
      if ((m->sections[j]->flags & SEC_READONLY) == 0)
1427
0
        p_flags1 |= PF_W;
1428
5
      if ((m->sections[j]->flags & SEC_CODE) != 0)
1429
2
        {
1430
2
    p_flags1 |= PF_X;
1431
2
    if ((elf_section_flags (m->sections[j]) & SHF_PPC_VLE) != 0)
1432
0
      p_flags1 |= PF_PPC_VLE;
1433
2
    if (((p_flags1 ^ p_flags) & PF_PPC_VLE) != 0)
1434
0
      break;
1435
2
        }
1436
5
      p_flags |= p_flags1;
1437
5
    }
1438
      /* If we're splitting a segment which originally contained rw
1439
   sections then those sections might now only be in one of the
1440
   two parts.  So always set p_flags if splitting, even if we
1441
   are being called for objcopy with p_flags_valid set.  */
1442
2
      if (j != m->count || !m->p_flags_valid)
1443
0
  {
1444
0
    m->p_flags_valid = 1;
1445
0
    m->p_flags = p_flags;
1446
0
  }
1447
2
      if (j == m->count)
1448
2
  continue;
1449
1450
      /* Sections 0..j-1 stay in this (current) segment,
1451
   the remainder are put in a new segment.
1452
   The scan resumes with the new segment.  */
1453
1454
0
      amt = sizeof (struct elf_segment_map);
1455
0
      amt += (m->count - j - 1) * sizeof (asection *);
1456
0
      n = (struct elf_segment_map *) bfd_zalloc (abfd, amt);
1457
0
      if (n == NULL)
1458
0
  return false;
1459
1460
0
      n->p_type = PT_LOAD;
1461
0
      n->count = m->count - j;
1462
0
      for (k = 0; k < n->count; ++k)
1463
0
  n->sections[k] = m->sections[j + k];
1464
0
      m->count = j;
1465
0
      m->p_size_valid = 0;
1466
0
      n->next = m->next;
1467
0
      m->next = n;
1468
0
    }
1469
1470
1
  return true;
1471
1
}
1472
1473
/* Add extra PPC sections -- Note, for now, make .sbss2 and
1474
   .PPC.EMB.sbss0 a normal section, and not a bss section so
1475
   that the linker doesn't crater when trying to make more than
1476
   2 sections.  */
1477
1478
static const struct bfd_elf_special_section ppc_elf_special_sections[] =
1479
{
1480
  { STRING_COMMA_LEN (".plt"), 0, SHT_NOBITS, SHF_ALLOC + SHF_EXECINSTR },
1481
  { STRING_COMMA_LEN (".sbss"), -2, SHT_NOBITS, SHF_ALLOC + SHF_WRITE },
1482
  { STRING_COMMA_LEN (".sbss2"), -2, SHT_PROGBITS, SHF_ALLOC },
1483
  { STRING_COMMA_LEN (".sdata"), -2, SHT_PROGBITS, SHF_ALLOC + SHF_WRITE },
1484
  { STRING_COMMA_LEN (".sdata2"), -2, SHT_PROGBITS, SHF_ALLOC },
1485
  { STRING_COMMA_LEN (".tags"), 0, SHT_ORDERED, SHF_ALLOC },
1486
  { STRING_COMMA_LEN (APUINFO_SECTION_NAME), 0, SHT_NOTE, 0 },
1487
  { STRING_COMMA_LEN (".PPC.EMB.sbss0"), 0, SHT_PROGBITS, SHF_ALLOC },
1488
  { STRING_COMMA_LEN (".PPC.EMB.sdata0"), 0, SHT_PROGBITS, SHF_ALLOC },
1489
  { NULL, 0, 0, 0, 0 }
1490
};
1491
1492
/* This is what we want for new plt/got.  */
1493
static const struct bfd_elf_special_section ppc_alt_plt =
1494
  { STRING_COMMA_LEN (".plt"),       0, SHT_PROGBITS, SHF_ALLOC };
1495
1496
static const struct bfd_elf_special_section *
1497
ppc_elf_get_sec_type_attr (bfd *abfd, asection *sec)
1498
157k
{
1499
157k
  const struct bfd_elf_special_section *ssect;
1500
1501
  /* See if this is one of the special sections.  */
1502
157k
  if (sec->name == NULL)
1503
0
    return NULL;
1504
1505
157k
  ssect = _bfd_elf_get_special_section (sec->name, ppc_elf_special_sections,
1506
157k
          sec->use_rela_p);
1507
157k
  if (ssect != NULL)
1508
3.75k
    {
1509
3.75k
      if (ssect == ppc_elf_special_sections && (sec->flags & SEC_LOAD) != 0)
1510
1
  ssect = &ppc_alt_plt;
1511
3.75k
      return ssect;
1512
3.75k
    }
1513
1514
153k
  return _bfd_elf_get_sec_type_attr (abfd, sec);
1515
157k
}
1516

1517
/* Very simple linked list structure for recording apuinfo values.  */
1518
typedef struct apuinfo_list
1519
{
1520
  struct apuinfo_list *next;
1521
  unsigned long value;
1522
}
1523
apuinfo_list;
1524
1525
static apuinfo_list *head;
1526
static bool apuinfo_set;
1527
1528
static void
1529
apuinfo_list_init (void)
1530
0
{
1531
0
  head = NULL;
1532
0
  apuinfo_set = false;
1533
0
}
1534
1535
static void
1536
apuinfo_list_add (unsigned long value)
1537
0
{
1538
0
  apuinfo_list *entry = head;
1539
1540
0
  while (entry != NULL)
1541
0
    {
1542
0
      if (entry->value == value)
1543
0
  return;
1544
0
      entry = entry->next;
1545
0
    }
1546
1547
0
  entry = bfd_malloc (sizeof (* entry));
1548
0
  if (entry == NULL)
1549
0
    return;
1550
1551
0
  entry->value = value;
1552
0
  entry->next  = head;
1553
0
  head = entry;
1554
0
}
1555
1556
static unsigned
1557
apuinfo_list_length (void)
1558
0
{
1559
0
  apuinfo_list *entry;
1560
0
  unsigned long count;
1561
1562
0
  for (entry = head, count = 0;
1563
0
       entry;
1564
0
       entry = entry->next)
1565
0
    ++ count;
1566
1567
0
  return count;
1568
0
}
1569
1570
static inline unsigned long
1571
apuinfo_list_element (unsigned long number)
1572
0
{
1573
0
  apuinfo_list * entry;
1574
1575
0
  for (entry = head;
1576
0
       entry && number --;
1577
0
       entry = entry->next)
1578
0
    ;
1579
1580
0
  return entry ? entry->value : 0;
1581
0
}
1582
1583
static void
1584
apuinfo_list_finish (void)
1585
0
{
1586
0
  apuinfo_list *entry;
1587
1588
0
  for (entry = head; entry;)
1589
0
    {
1590
0
      apuinfo_list *next = entry->next;
1591
0
      free (entry);
1592
0
      entry = next;
1593
0
    }
1594
1595
0
  head = NULL;
1596
0
}
1597
1598
/* Scan the input BFDs and create a linked list of
1599
   the APUinfo values that will need to be emitted.  */
1600
1601
static void
1602
ppc_elf_begin_write_processing (bfd *abfd, struct bfd_link_info *link_info)
1603
1
{
1604
1
  bfd *ibfd;
1605
1
  asection *asec;
1606
1
  char *buffer = NULL;
1607
1
  bfd_size_type largest_input_size = 0;
1608
1
  unsigned i;
1609
1
  unsigned long length;
1610
1
  const char *error_message = NULL;
1611
1612
1
  if (link_info == NULL)
1613
1
    return;
1614
1615
0
  apuinfo_list_init ();
1616
1617
  /* Read in the input sections contents.  */
1618
0
  for (ibfd = link_info->input_bfds; ibfd; ibfd = ibfd->link.next)
1619
0
    {
1620
0
      unsigned long datum;
1621
1622
0
      asec = bfd_get_section_by_name (ibfd, APUINFO_SECTION_NAME);
1623
0
      if (asec == NULL)
1624
0
  continue;
1625
1626
      /* xgettext:c-format */
1627
0
      error_message = _("corrupt %s section in %pB");
1628
0
      length = asec->size;
1629
0
      if (length < 20)
1630
0
  goto fail;
1631
1632
0
      apuinfo_set = true;
1633
0
      if (largest_input_size < asec->size)
1634
0
  {
1635
0
    free (buffer);
1636
0
    largest_input_size = asec->size;
1637
0
    buffer = bfd_malloc (largest_input_size);
1638
0
    if (!buffer)
1639
0
      return;
1640
0
  }
1641
1642
0
      if (bfd_seek (ibfd, asec->filepos, SEEK_SET) != 0
1643
0
    || (bfd_read (buffer, length, ibfd) != length))
1644
0
  {
1645
    /* xgettext:c-format */
1646
0
    error_message = _("unable to read in %s section from %pB");
1647
0
    goto fail;
1648
0
  }
1649
1650
      /* Verify the contents of the header.  Note - we have to
1651
   extract the values this way in order to allow for a
1652
   host whose endian-ness is different from the target.  */
1653
0
      datum = bfd_get_32 (ibfd, buffer);
1654
0
      if (datum != sizeof APUINFO_LABEL)
1655
0
  goto fail;
1656
1657
0
      datum = bfd_get_32 (ibfd, buffer + 8);
1658
0
      if (datum != 0x2)
1659
0
  goto fail;
1660
1661
0
      if (strcmp (buffer + 12, APUINFO_LABEL) != 0)
1662
0
  goto fail;
1663
1664
      /* Get the number of bytes used for apuinfo entries.  */
1665
0
      datum = bfd_get_32 (ibfd, buffer + 4);
1666
0
      if (datum + 20 != length)
1667
0
  goto fail;
1668
1669
      /* Scan the apuinfo section, building a list of apuinfo numbers.  */
1670
0
      for (i = 0; i < datum; i += 4)
1671
0
  apuinfo_list_add (bfd_get_32 (ibfd, buffer + 20 + i));
1672
0
    }
1673
1674
0
  error_message = NULL;
1675
1676
0
  if (apuinfo_set)
1677
0
    {
1678
      /* Compute the size of the output section.  */
1679
0
      unsigned num_entries = apuinfo_list_length ();
1680
1681
      /* Set the output section size, if it exists.  */
1682
0
      asec = bfd_get_section_by_name (abfd, APUINFO_SECTION_NAME);
1683
1684
0
      if (asec && !bfd_set_section_size (asec, 20 + num_entries * 4))
1685
0
  {
1686
0
    ibfd = abfd;
1687
    /* xgettext:c-format */
1688
0
    error_message = _("warning: unable to set size of %s section in %pB");
1689
0
  }
1690
0
    }
1691
1692
0
 fail:
1693
0
  free (buffer);
1694
1695
0
  if (error_message)
1696
0
    _bfd_error_handler (error_message, APUINFO_SECTION_NAME, ibfd);
1697
0
}
1698
1699
/* Prevent the output section from accumulating the input sections'
1700
   contents.  We have already stored this in our linked list structure.  */
1701
1702
static bool
1703
ppc_elf_write_section (bfd *abfd ATTRIBUTE_UNUSED,
1704
           struct bfd_link_info *link_info ATTRIBUTE_UNUSED,
1705
           asection *asec,
1706
           bfd_byte *contents ATTRIBUTE_UNUSED)
1707
0
{
1708
0
  return apuinfo_set && strcmp (asec->name, APUINFO_SECTION_NAME) == 0;
1709
0
}
1710
1711
/* Finally we can generate the output section.  */
1712
1713
static void
1714
ppc_final_write_processing (bfd *abfd)
1715
1
{
1716
1
  bfd_byte *buffer;
1717
1
  asection *asec;
1718
1
  unsigned i;
1719
1
  unsigned num_entries;
1720
1
  bfd_size_type length;
1721
1722
1
  asec = bfd_get_section_by_name (abfd, APUINFO_SECTION_NAME);
1723
1
  if (asec == NULL)
1724
1
    return;
1725
1726
0
  if (!apuinfo_set)
1727
0
    return;
1728
1729
0
  length = asec->size;
1730
0
  if (length < 20)
1731
0
    return;
1732
1733
0
  buffer = bfd_malloc (length);
1734
0
  if (buffer == NULL)
1735
0
    {
1736
0
      _bfd_error_handler
1737
0
  (_("failed to allocate space for new APUinfo section"));
1738
0
      return;
1739
0
    }
1740
1741
  /* Create the apuinfo header.  */
1742
0
  num_entries = apuinfo_list_length ();
1743
0
  bfd_put_32 (abfd, sizeof APUINFO_LABEL, buffer);
1744
0
  bfd_put_32 (abfd, num_entries * 4, buffer + 4);
1745
0
  bfd_put_32 (abfd, 0x2, buffer + 8);
1746
0
  strcpy ((char *) buffer + 12, APUINFO_LABEL);
1747
1748
0
  length = 20;
1749
0
  for (i = 0; i < num_entries; i++)
1750
0
    {
1751
0
      bfd_put_32 (abfd, apuinfo_list_element (i), buffer + length);
1752
0
      length += 4;
1753
0
    }
1754
1755
0
  if (length != asec->size)
1756
0
    _bfd_error_handler (_("failed to compute new APUinfo section"));
1757
1758
0
  if (! bfd_set_section_contents (abfd, asec, buffer, (file_ptr) 0, length))
1759
0
    _bfd_error_handler (_("failed to install new APUinfo section"));
1760
1761
0
  free (buffer);
1762
1763
0
  apuinfo_list_finish ();
1764
0
}
1765
1766
static bool
1767
ppc_elf_final_write_processing (bfd *abfd)
1768
1
{
1769
1
  ppc_final_write_processing (abfd);
1770
1
  return _bfd_elf_final_write_processing (abfd);
1771
1
}
1772

1773
static bool
1774
is_nonpic_glink_stub (bfd *abfd, asection *glink, bfd_vma off)
1775
4
{
1776
4
  bfd_byte buf[4 * 4];
1777
1778
4
  if (!bfd_get_section_contents (abfd, glink, buf, off, sizeof buf))
1779
0
    return false;
1780
1781
4
  return ((bfd_get_32 (abfd, buf + 0) & 0xffff0000) == LIS_11
1782
4
    && (bfd_get_32 (abfd, buf + 4) & 0xffff0000) == LWZ_11_11
1783
4
    && bfd_get_32 (abfd, buf + 8) == MTCTR_11
1784
4
    && bfd_get_32 (abfd, buf + 12) == BCTR);
1785
4
}
1786
1787
static bool
1788
section_covers_vma (bfd *abfd ATTRIBUTE_UNUSED, asection *section, void *ptr)
1789
24
{
1790
24
  bfd_vma vma = *(bfd_vma *) ptr;
1791
24
  return ((section->flags & SEC_ALLOC) != 0
1792
24
    && section->vma <= vma
1793
24
    && vma < section->vma + section->size);
1794
24
}
1795
1796
static long
1797
ppc_elf_get_synthetic_symtab (bfd *abfd, long symcount, asymbol **syms,
1798
            long dynsymcount, asymbol **dynsyms,
1799
            asymbol **ret)
1800
86
{
1801
86
  bool (*slurp_relocs) (bfd *, asection *, asymbol **, bool);
1802
86
  asection *plt, *relplt, *dynamic, *glink;
1803
86
  bfd_vma glink_vma = 0;
1804
86
  bfd_vma resolv_vma = 0;
1805
86
  bfd_vma stub_off;
1806
86
  asymbol *s;
1807
86
  arelent *p;
1808
86
  size_t count, i, stub_delta;
1809
86
  size_t size;
1810
86
  char *names;
1811
86
  bfd_byte buf[4];
1812
1813
86
  *ret = NULL;
1814
1815
86
  if ((abfd->flags & (DYNAMIC | EXEC_P)) == 0)
1816
84
    return 0;
1817
1818
2
  if (dynsymcount <= 0)
1819
0
    return 0;
1820
1821
2
  relplt = bfd_get_section_by_name (abfd, ".rela.plt");
1822
2
  if (relplt == NULL)
1823
0
    return 0;
1824
1825
2
  plt = bfd_get_section_by_name (abfd, ".plt");
1826
2
  if (plt == NULL)
1827
0
    return 0;
1828
1829
  /* Call common code to handle old-style executable PLTs.  */
1830
2
  if (elf_section_flags (plt) & SHF_EXECINSTR)
1831
0
    return _bfd_elf_get_synthetic_symtab (abfd, symcount, syms,
1832
0
            dynsymcount, dynsyms, ret);
1833
1834
  /* If this object was prelinked, the prelinker stored the address
1835
     of .glink at got[1].  If it wasn't prelinked, got[1] will be zero.  */
1836
2
  dynamic = bfd_get_section_by_name (abfd, ".dynamic");
1837
2
  if (dynamic != NULL
1838
2
      && (dynamic->flags & SEC_HAS_CONTENTS) != 0)
1839
2
    {
1840
2
      bfd_byte *dynbuf, *extdyn, *extdynend;
1841
2
      size_t extdynsize;
1842
2
      void (*swap_dyn_in) (bfd *, const void *, Elf_Internal_Dyn *);
1843
1844
2
      if (!bfd_malloc_and_get_section (abfd, dynamic, &dynbuf))
1845
0
  return -1;
1846
1847
2
      extdynsize = get_elf_backend_data (abfd)->s->sizeof_dyn;
1848
2
      swap_dyn_in = get_elf_backend_data (abfd)->s->swap_dyn_in;
1849
1850
2
      for (extdyn = dynbuf, extdynend = dynbuf + dynamic->size;
1851
40
     (size_t) (extdynend - extdyn) >= extdynsize;
1852
38
     extdyn += extdynsize)
1853
40
  {
1854
40
    Elf_Internal_Dyn dyn;
1855
40
    (*swap_dyn_in) (abfd, extdyn, &dyn);
1856
1857
40
    if (dyn.d_tag == DT_NULL)
1858
0
      break;
1859
1860
40
    if (dyn.d_tag == DT_PPC_GOT)
1861
2
      {
1862
2
        unsigned int g_o_t = dyn.d_un.d_val;
1863
2
        asection *got = bfd_get_section_by_name (abfd, ".got");
1864
2
        if (got != NULL
1865
2
      && bfd_get_section_contents (abfd, got, buf,
1866
2
                 g_o_t - got->vma + 4, 4))
1867
2
    glink_vma = bfd_get_32 (abfd, buf);
1868
2
        break;
1869
2
      }
1870
40
  }
1871
2
      free (dynbuf);
1872
2
    }
1873
1874
  /* Otherwise we read the first plt entry.  */
1875
2
  if (glink_vma == 0)
1876
2
    {
1877
2
      if (bfd_get_section_contents (abfd, plt, buf, 0, 4))
1878
2
  glink_vma = bfd_get_32 (abfd, buf);
1879
2
    }
1880
1881
2
  if (glink_vma == 0)
1882
0
    return 0;
1883
1884
  /* The .glink section usually does not survive the final
1885
     link; search for the section (usually .text) where the
1886
     glink stubs now reside.  */
1887
2
  glink = bfd_sections_find_if (abfd, section_covers_vma, &glink_vma);
1888
2
  if (glink == NULL)
1889
0
    return 0;
1890
1891
  /* Determine glink PLT resolver by reading the relative branch
1892
     from the first glink stub.  */
1893
2
  if (bfd_get_section_contents (abfd, glink, buf,
1894
2
        glink_vma - glink->vma, 4))
1895
2
    {
1896
2
      unsigned int insn = bfd_get_32 (abfd, buf);
1897
1898
      /* The first glink stub may either branch to the resolver ...  */
1899
2
      insn ^= B;
1900
2
      if ((insn & ~0x3fffffc) == 0)
1901
1
  resolv_vma = glink_vma + (insn ^ 0x2000000) - 0x2000000;
1902
1903
      /* ... or fall through a bunch of NOPs.  */
1904
1
      else if ((insn ^ B ^ NOP) == 0)
1905
0
  for (i = 4;
1906
0
       bfd_get_section_contents (abfd, glink, buf,
1907
0
               glink_vma - glink->vma + i, 4);
1908
0
       i += 4)
1909
0
    if (bfd_get_32 (abfd, buf) != NOP)
1910
0
      {
1911
0
        resolv_vma = glink_vma + i;
1912
0
        break;
1913
0
      }
1914
2
    }
1915
1916
2
  count = NUM_SHDR_ENTRIES (&elf_section_data (relplt)->this_hdr);
1917
  /* If the stubs are those for -shared/-pie then we might have
1918
     multiple stubs for each plt entry.  If that is the case then
1919
     there is no way to associate stubs with their plt entries short
1920
     of figuring out the GOT pointer value used in the stub.
1921
     The offsets tested here need to cover all possible values of
1922
     GLINK_ENTRY_SIZE for other than __tls_get_addr_opt.  */
1923
2
  stub_off = glink_vma - glink->vma;
1924
5
  for (stub_delta = 16; stub_delta <= 32; stub_delta += 8)
1925
4
    if (is_nonpic_glink_stub (abfd, glink, stub_off - stub_delta))
1926
1
      break;
1927
2
  if (stub_delta > 32)
1928
1
    return 0;
1929
1930
1
  slurp_relocs = get_elf_backend_data (abfd)->s->slurp_reloc_table;
1931
1
  if (! (*slurp_relocs) (abfd, relplt, dynsyms, true))
1932
0
    return -1;
1933
1934
1
  size = count * sizeof (asymbol);
1935
1
  p = relplt->relocation;
1936
203
  for (i = 0; i < count; i++, p++)
1937
202
    {
1938
202
      size += strlen ((*p->sym_ptr_ptr)->name) + sizeof ("@plt");
1939
202
      if (p->addend != 0)
1940
0
  size += sizeof ("+0x") - 1 + 8;
1941
202
    }
1942
1943
1
  size += sizeof (asymbol) + sizeof ("__glink");
1944
1945
1
  if (resolv_vma)
1946
1
    size += sizeof (asymbol) + sizeof ("__glink_PLTresolve");
1947
1948
1
  s = *ret = bfd_malloc (size);
1949
1
  if (s == NULL)
1950
0
    return -1;
1951
1952
1
  stub_off = glink_vma - glink->vma;
1953
1
  names = (char *) (s + count + 1 + (resolv_vma != 0));
1954
1
  p = relplt->relocation + count - 1;
1955
203
  for (i = 0; i < count; i++)
1956
202
    {
1957
202
      size_t len;
1958
1959
202
      stub_off -= stub_delta;
1960
202
      if (strcmp ((*p->sym_ptr_ptr)->name, "__tls_get_addr_opt") == 0)
1961
0
  stub_off -= 32;
1962
202
      *s = **p->sym_ptr_ptr;
1963
      /* Undefined syms won't have BSF_LOCAL or BSF_GLOBAL set.  Since
1964
   we are defining a symbol, ensure one of them is set.  */
1965
202
      if ((s->flags & BSF_LOCAL) == 0)
1966
202
  s->flags |= BSF_GLOBAL;
1967
202
      s->flags |= BSF_SYNTHETIC;
1968
202
      s->section = glink;
1969
202
      s->value = stub_off;
1970
202
      s->name = names;
1971
202
      s->udata.p = NULL;
1972
202
      len = strlen ((*p->sym_ptr_ptr)->name);
1973
202
      memcpy (names, (*p->sym_ptr_ptr)->name, len);
1974
202
      names += len;
1975
202
      if (p->addend != 0)
1976
0
  {
1977
0
    memcpy (names, "+0x", sizeof ("+0x") - 1);
1978
0
    names += sizeof ("+0x") - 1;
1979
0
    bfd_sprintf_vma (abfd, names, p->addend);
1980
0
    names += strlen (names);
1981
0
  }
1982
202
      memcpy (names, "@plt", sizeof ("@plt"));
1983
202
      names += sizeof ("@plt");
1984
202
      ++s;
1985
202
      --p;
1986
202
    }
1987
1988
  /* Add a symbol at the start of the glink branch table.  */
1989
1
  memset (s, 0, sizeof *s);
1990
1
  s->the_bfd = abfd;
1991
1
  s->flags = BSF_GLOBAL | BSF_SYNTHETIC;
1992
1
  s->section = glink;
1993
1
  s->value = glink_vma - glink->vma;
1994
1
  s->name = names;
1995
1
  memcpy (names, "__glink", sizeof ("__glink"));
1996
1
  names += sizeof ("__glink");
1997
1
  s++;
1998
1
  count++;
1999
2000
1
  if (resolv_vma)
2001
1
    {
2002
      /* Add a symbol for the glink PLT resolver.  */
2003
1
      memset (s, 0, sizeof *s);
2004
1
      s->the_bfd = abfd;
2005
1
      s->flags = BSF_GLOBAL | BSF_SYNTHETIC;
2006
1
      s->section = glink;
2007
1
      s->value = resolv_vma - glink->vma;
2008
1
      s->name = names;
2009
1
      memcpy (names, "__glink_PLTresolve", sizeof ("__glink_PLTresolve"));
2010
1
      names += sizeof ("__glink_PLTresolve");
2011
1
      s++;
2012
1
      count++;
2013
1
    }
2014
2015
1
  return count;
2016
1
}
2017

2018
/* The following functions are specific to the ELF linker, while
2019
   functions above are used generally.  They appear in this file more
2020
   or less in the order in which they are called.  eg.
2021
   ppc_elf_check_relocs is called early in the link process,
2022
   ppc_elf_finish_dynamic_sections is one of the last functions
2023
   called.  */
2024
2025
/* Track PLT entries needed for a given symbol.  We might need more
2026
   than one glink entry per symbol when generating a pic binary.  */
2027
struct plt_entry
2028
{
2029
  struct plt_entry *next;
2030
2031
  /* -fPIC uses multiple GOT sections, one per file, called ".got2".
2032
     This field stores the offset into .got2 used to initialise the
2033
     GOT pointer reg.  It will always be at least 32768.  (Current
2034
     gcc always uses an offset of 32768, but ld -r will pack .got2
2035
     sections together resulting in larger offsets).  */
2036
  bfd_vma addend;
2037
2038
  /* The .got2 section.  */
2039
  asection *sec;
2040
2041
  /* PLT refcount or offset.  */
2042
  union
2043
    {
2044
      bfd_signed_vma refcount;
2045
      bfd_vma offset;
2046
    } plt;
2047
2048
  /* .glink stub offset.  */
2049
  bfd_vma glink_offset;
2050
};
2051
2052
/* Of those relocs that might be copied as dynamic relocs, this
2053
   function selects those that must be copied when linking a shared
2054
   library or PIE, even when the symbol is local.  */
2055
2056
static int
2057
must_be_dyn_reloc (struct bfd_link_info *info,
2058
       enum elf_ppc_reloc_type r_type)
2059
0
{
2060
0
  switch (r_type)
2061
0
    {
2062
0
    default:
2063
      /* Only relative relocs can be resolved when the object load
2064
   address isn't fixed.  DTPREL32 is excluded because the
2065
   dynamic linker needs to differentiate global dynamic from
2066
   local dynamic __tls_index pairs when PPC_OPT_TLS is set.  */
2067
0
      return 1;
2068
2069
0
    case R_PPC_REL24:
2070
0
    case R_PPC_REL14:
2071
0
    case R_PPC_REL14_BRTAKEN:
2072
0
    case R_PPC_REL14_BRNTAKEN:
2073
0
    case R_PPC_REL32:
2074
0
      return 0;
2075
2076
0
    case R_PPC_TPREL32:
2077
0
    case R_PPC_TPREL16:
2078
0
    case R_PPC_TPREL16_LO:
2079
0
    case R_PPC_TPREL16_HI:
2080
0
    case R_PPC_TPREL16_HA:
2081
      /* These relocations are relative but in a shared library the
2082
   linker doesn't know the thread pointer base.  */
2083
0
      return bfd_link_dll (info);
2084
0
    }
2085
0
}
2086
2087
/* If ELIMINATE_COPY_RELOCS is non-zero, the linker will try to avoid
2088
   copying dynamic variables from a shared lib into an app's dynbss
2089
   section, and instead use a dynamic relocation to point into the
2090
   shared lib.  */
2091
0
#define ELIMINATE_COPY_RELOCS 1
2092
2093
/* Used to track dynamic relocations for local symbols.  */
2094
struct ppc_dyn_relocs
2095
{
2096
  struct ppc_dyn_relocs *next;
2097
2098
  /* The input section of the reloc.  */
2099
  asection *sec;
2100
2101
  /* Total number of relocs copied for the input section.  */
2102
  unsigned int count : 31;
2103
2104
  /* Whether this entry is for STT_GNU_IFUNC symbols.  */
2105
  unsigned int ifunc : 1;
2106
};
2107
2108
/* PPC ELF linker hash entry.  */
2109
2110
struct ppc_elf_link_hash_entry
2111
{
2112
  struct elf_link_hash_entry elf;
2113
2114
  /* If this symbol is used in the linker created sections, the processor
2115
     specific backend uses this field to map the field into the offset
2116
     from the beginning of the section.  */
2117
  elf_linker_section_pointers_t *linker_section_pointer;
2118
2119
  /* Contexts in which symbol is used in the GOT.
2120
     Bits are or'd into the mask as the corresponding relocs are
2121
     encountered during check_relocs, with TLS_TLS being set when any
2122
     of the other TLS bits are set.  tls_optimize clears bits when
2123
     optimizing to indicate the corresponding GOT entry type is not
2124
     needed.  If set, TLS_TLS is never cleared.  tls_optimize may also
2125
     set TLS_GDIE when a GD reloc turns into an IE one.
2126
     These flags are also kept for local symbols.  */
2127
0
#define TLS_TLS    1  /* Any TLS reloc.  */
2128
0
#define TLS_GD     2  /* GD reloc. */
2129
0
#define TLS_LD     4  /* LD reloc. */
2130
0
#define TLS_TPREL  8  /* TPREL reloc, => IE. */
2131
0
#define TLS_DTPREL  16  /* DTPREL reloc, => LD. */
2132
0
#define TLS_MARK  32  /* __tls_get_addr call marked. */
2133
0
#define TLS_GDIE  64  /* GOT TPREL reloc resulting from GD->IE. */
2134
  unsigned char tls_mask;
2135
2136
  /* The above field is also used to mark function symbols.  In which
2137
     case TLS_TLS will be 0.  */
2138
0
#define PLT_IFUNC  2  /* STT_GNU_IFUNC.  */
2139
0
#define PLT_KEEP   4  /* inline plt call requires plt entry.  */
2140
0
#define NON_GOT        256  /* local symbol plt, not stored.  */
2141
2142
  /* Nonzero if we have seen a small data relocation referring to this
2143
     symbol.  */
2144
  unsigned char has_sda_refs : 1;
2145
2146
  /* Flag use of given relocations.  */
2147
  unsigned char has_addr16_ha : 1;
2148
  unsigned char has_addr16_lo : 1;
2149
};
2150
2151
0
#define ppc_elf_hash_entry(ent) ((struct ppc_elf_link_hash_entry *) (ent))
2152
2153
/* PPC ELF linker hash table.  */
2154
2155
struct ppc_elf_link_hash_table
2156
{
2157
  struct elf_link_hash_table elf;
2158
2159
  /* Various options passed from the linker.  */
2160
  struct ppc_elf_params *params;
2161
2162
  /* Short-cuts to get to dynamic linker sections.  */
2163
  asection *glink;
2164
  asection *dynsbss;
2165
  asection *relsbss;
2166
  elf_linker_section_t sdata[2];
2167
  asection *sbss;
2168
  asection *glink_eh_frame;
2169
  asection *pltlocal;
2170
  asection *relpltlocal;
2171
2172
  /* The (unloaded but important) .rela.plt.unloaded on VxWorks.  */
2173
  asection *srelplt2;
2174
2175
  /* Shortcut to __tls_get_addr.  */
2176
  struct elf_link_hash_entry *tls_get_addr;
2177
2178
  /* The bfd that forced an old-style PLT.  */
2179
  bfd *old_bfd;
2180
2181
  /* TLS local dynamic got entry handling.  */
2182
  union {
2183
    bfd_signed_vma refcount;
2184
    bfd_vma offset;
2185
  } tlsld_got;
2186
2187
  /* Offset of branch table to PltResolve function in glink.  */
2188
  bfd_vma glink_pltresolve;
2189
2190
  /* Size of reserved GOT entries.  */
2191
  unsigned int got_header_size;
2192
  /* Non-zero if allocating the header left a gap.  */
2193
  unsigned int got_gap;
2194
2195
  /* The type of PLT we have chosen to use.  */
2196
  enum ppc_elf_plt_type plt_type;
2197
2198
  /* Whether there exist local gnu indirect function resolvers,
2199
     referenced by dynamic relocations.  */
2200
  unsigned int local_ifunc_resolver:1;
2201
  unsigned int maybe_local_ifunc_resolver:1;
2202
2203
  /* Set if tls optimization is enabled.  */
2204
  unsigned int do_tls_opt:1;
2205
2206
  /* Set if inline plt calls should be converted to direct calls.  */
2207
  unsigned int can_convert_all_inline_plt:1;
2208
2209
  /* The size of PLT entries.  */
2210
  int plt_entry_size;
2211
  /* The distance between adjacent PLT slots.  */
2212
  int plt_slot_size;
2213
  /* The size of the first PLT entry.  */
2214
  int plt_initial_entry_size;
2215
};
2216
2217
/* Rename some of the generic section flags to better document how they
2218
   are used for ppc32.  The flags are only valid for ppc32 elf objects.  */
2219
2220
/* Nonzero if this section has TLS related relocations.  */
2221
0
#define has_tls_reloc sec_flg0
2222
2223
/* Nonzero if this section has a call to __tls_get_addr lacking marker
2224
   relocs.  */
2225
0
#define nomark_tls_get_addr sec_flg1
2226
2227
  /* Flag set when PLTCALL relocs are detected.  */
2228
0
#define has_pltcall sec_flg2
2229
2230
/* Get the PPC ELF linker hash table from a link_info structure.  */
2231
2232
#define ppc_elf_hash_table(p) \
2233
0
  ((is_elf_hash_table ((p)->hash)          \
2234
0
    && elf_hash_table_id (elf_hash_table (p)) == PPC32_ELF_DATA) \
2235
0
   ? (struct ppc_elf_link_hash_table *) (p)->hash : NULL)
2236
2237
/* Create an entry in a PPC ELF linker hash table.  */
2238
2239
static struct bfd_hash_entry *
2240
ppc_elf_link_hash_newfunc (struct bfd_hash_entry *entry,
2241
         struct bfd_hash_table *table,
2242
         const char *string)
2243
0
{
2244
  /* Allocate the structure if it has not already been allocated by a
2245
     subclass.  */
2246
0
  if (entry == NULL)
2247
0
    {
2248
0
      entry = bfd_hash_allocate (table,
2249
0
         sizeof (struct ppc_elf_link_hash_entry));
2250
0
      if (entry == NULL)
2251
0
  return entry;
2252
0
    }
2253
2254
  /* Call the allocation method of the superclass.  */
2255
0
  entry = _bfd_elf_link_hash_newfunc (entry, table, string);
2256
0
  if (entry != NULL)
2257
0
    {
2258
0
      ppc_elf_hash_entry (entry)->linker_section_pointer = NULL;
2259
0
      ppc_elf_hash_entry (entry)->tls_mask = 0;
2260
0
      ppc_elf_hash_entry (entry)->has_sda_refs = 0;
2261
0
    }
2262
2263
0
  return entry;
2264
0
}
2265
2266
/* Create a PPC ELF linker hash table.  */
2267
2268
static struct bfd_link_hash_table *
2269
ppc_elf_link_hash_table_create (bfd *abfd)
2270
0
{
2271
0
  struct ppc_elf_link_hash_table *ret;
2272
0
  static struct ppc_elf_params default_params
2273
0
    = { PLT_OLD, 0, 0, 1, 0, 0, 12, 0, 0, 0 };
2274
2275
0
  ret = bfd_zmalloc (sizeof (struct ppc_elf_link_hash_table));
2276
0
  if (ret == NULL)
2277
0
    return NULL;
2278
2279
0
  if (!_bfd_elf_link_hash_table_init (&ret->elf, abfd,
2280
0
              ppc_elf_link_hash_newfunc,
2281
0
              sizeof (struct ppc_elf_link_hash_entry)))
2282
0
    {
2283
0
      free (ret);
2284
0
      return NULL;
2285
0
    }
2286
2287
0
  ret->elf.init_plt_refcount.refcount = 0;
2288
0
  ret->elf.init_plt_refcount.glist = NULL;
2289
0
  ret->elf.init_plt_offset.offset = 0;
2290
0
  ret->elf.init_plt_offset.glist = NULL;
2291
2292
0
  ret->params = &default_params;
2293
2294
0
  ret->sdata[0].name = ".sdata";
2295
0
  ret->sdata[0].sym_name = "_SDA_BASE_";
2296
0
  ret->sdata[0].bss_name = ".sbss";
2297
2298
0
  ret->sdata[1].name = ".sdata2";
2299
0
  ret->sdata[1].sym_name = "_SDA2_BASE_";
2300
0
  ret->sdata[1].bss_name = ".sbss2";
2301
2302
0
  ret->plt_entry_size = 12;
2303
0
  ret->plt_slot_size = 8;
2304
0
  ret->plt_initial_entry_size = 72;
2305
2306
0
  return &ret->elf.root;
2307
0
}
2308
2309
/* Hook linker params into hash table.  */
2310
2311
void
2312
ppc_elf_link_params (struct bfd_link_info *info, struct ppc_elf_params *params)
2313
0
{
2314
0
  struct ppc_elf_link_hash_table *htab = ppc_elf_hash_table (info);
2315
2316
0
  if (htab)
2317
0
    htab->params = params;
2318
0
  params->pagesize_p2 = bfd_log2 (params->pagesize);
2319
0
}
2320
2321
/* Create .got and the related sections.  */
2322
2323
static bool
2324
ppc_elf_create_got (bfd *abfd, struct bfd_link_info *info)
2325
0
{
2326
0
  struct ppc_elf_link_hash_table *htab;
2327
2328
0
  if (!_bfd_elf_create_got_section (abfd, info))
2329
0
    return false;
2330
2331
0
  htab = ppc_elf_hash_table (info);
2332
0
  if (htab->elf.target_os != is_vxworks)
2333
0
    {
2334
      /* The powerpc .got has a blrl instruction in it.  Mark it
2335
   executable.  */
2336
0
      flagword flags = (SEC_ALLOC | SEC_LOAD | SEC_CODE | SEC_HAS_CONTENTS
2337
0
      | SEC_IN_MEMORY | SEC_LINKER_CREATED);
2338
0
      if (!bfd_set_section_flags (htab->elf.sgot, flags))
2339
0
  return false;
2340
0
    }
2341
2342
0
  return true;
2343
0
}
2344
2345
/* Create a special linker section, used for R_PPC_EMB_SDAI16 and
2346
   R_PPC_EMB_SDA2I16 pointers.  These sections become part of .sdata
2347
   and .sdata2.  Create _SDA_BASE_ and _SDA2_BASE too.  */
2348
2349
static bool
2350
ppc_elf_create_linker_section (bfd *abfd,
2351
             struct bfd_link_info *info,
2352
             flagword flags,
2353
             elf_linker_section_t *lsect)
2354
0
{
2355
0
  asection *s;
2356
2357
0
  flags |= (SEC_ALLOC | SEC_LOAD | SEC_HAS_CONTENTS | SEC_IN_MEMORY
2358
0
      | SEC_LINKER_CREATED);
2359
2360
0
  s = bfd_make_section_anyway_with_flags (abfd, lsect->name, flags);
2361
0
  if (s == NULL)
2362
0
    return false;
2363
0
  lsect->section = s;
2364
2365
  /* Define the sym on the first section of this name.  */
2366
0
  s = bfd_get_section_by_name (abfd, lsect->name);
2367
2368
0
  lsect->sym = _bfd_elf_define_linkage_sym (abfd, info, s, lsect->sym_name);
2369
0
  if (lsect->sym == NULL)
2370
0
    return false;
2371
0
  lsect->sym->root.u.def.value = 0x8000;
2372
0
  return true;
2373
0
}
2374
2375
static bool
2376
ppc_elf_create_glink (bfd *abfd, struct bfd_link_info *info)
2377
0
{
2378
0
  struct ppc_elf_link_hash_table *htab = ppc_elf_hash_table (info);
2379
0
  asection *s;
2380
0
  flagword flags;
2381
0
  int p2align;
2382
2383
0
  flags = (SEC_ALLOC | SEC_LOAD | SEC_CODE | SEC_READONLY | SEC_HAS_CONTENTS
2384
0
     | SEC_IN_MEMORY | SEC_LINKER_CREATED);
2385
0
  s = bfd_make_section_anyway_with_flags (abfd, ".glink", flags);
2386
0
  htab->glink = s;
2387
0
  p2align = htab->params->ppc476_workaround ? 6 : 4;
2388
0
  if (p2align < htab->params->plt_stub_align)
2389
0
    p2align = htab->params->plt_stub_align;
2390
0
  if (s == NULL
2391
0
      || !bfd_set_section_alignment (s, p2align))
2392
0
    return false;
2393
2394
0
  if (!info->no_ld_generated_unwind_info)
2395
0
    {
2396
0
      flags = (SEC_ALLOC | SEC_LOAD | SEC_READONLY | SEC_HAS_CONTENTS
2397
0
         | SEC_IN_MEMORY | SEC_LINKER_CREATED);
2398
0
      s = bfd_make_section_anyway_with_flags (abfd, ".eh_frame", flags);
2399
0
      htab->glink_eh_frame = s;
2400
0
      if (s == NULL
2401
0
    || !bfd_set_section_alignment (s, 2))
2402
0
  return false;
2403
0
    }
2404
2405
0
  flags = SEC_ALLOC | SEC_LINKER_CREATED;
2406
0
  s = bfd_make_section_anyway_with_flags (abfd, ".iplt", flags);
2407
0
  htab->elf.iplt = s;
2408
0
  if (s == NULL
2409
0
      || !bfd_set_section_alignment (s, 4))
2410
0
    return false;
2411
2412
0
  flags = (SEC_ALLOC | SEC_LOAD | SEC_READONLY | SEC_HAS_CONTENTS
2413
0
     | SEC_IN_MEMORY | SEC_LINKER_CREATED);
2414
0
  s = bfd_make_section_anyway_with_flags (abfd, ".rela.iplt", flags);
2415
0
  htab->elf.irelplt = s;
2416
0
  if (s == NULL
2417
0
      || ! bfd_set_section_alignment (s, 2))
2418
0
    return false;
2419
2420
  /* Local plt entries.  */
2421
0
  flags = (SEC_ALLOC | SEC_LOAD
2422
0
     | SEC_HAS_CONTENTS | SEC_IN_MEMORY | SEC_LINKER_CREATED);
2423
0
  htab->pltlocal = bfd_make_section_anyway_with_flags (abfd, ".branch_lt",
2424
0
                   flags);
2425
0
  if (htab->pltlocal == NULL
2426
0
      || !bfd_set_section_alignment (htab->pltlocal, 2))
2427
0
    return false;
2428
2429
0
  if (bfd_link_pic (info))
2430
0
    {
2431
0
      flags = (SEC_ALLOC | SEC_LOAD | SEC_READONLY
2432
0
         | SEC_HAS_CONTENTS | SEC_IN_MEMORY | SEC_LINKER_CREATED);
2433
0
      htab->relpltlocal
2434
0
  = bfd_make_section_anyway_with_flags (abfd, ".rela.branch_lt", flags);
2435
0
      if (htab->relpltlocal == NULL
2436
0
    || !bfd_set_section_alignment (htab->relpltlocal, 2))
2437
0
  return false;
2438
0
    }
2439
2440
0
  if (!ppc_elf_create_linker_section (abfd, info, 0,
2441
0
              &htab->sdata[0]))
2442
0
    return false;
2443
2444
0
  if (!ppc_elf_create_linker_section (abfd, info, SEC_READONLY,
2445
0
              &htab->sdata[1]))
2446
0
    return false;
2447
2448
0
  return true;
2449
0
}
2450
2451
/* We have to create .dynsbss and .rela.sbss here so that they get mapped
2452
   to output sections (just like _bfd_elf_create_dynamic_sections has
2453
   to create .dynbss and .rela.bss).  */
2454
2455
static bool
2456
ppc_elf_create_dynamic_sections (bfd *abfd, struct bfd_link_info *info)
2457
0
{
2458
0
  struct ppc_elf_link_hash_table *htab;
2459
0
  asection *s;
2460
0
  flagword flags;
2461
2462
0
  htab = ppc_elf_hash_table (info);
2463
2464
0
  if (htab->elf.sgot == NULL
2465
0
      && !ppc_elf_create_got (abfd, info))
2466
0
    return false;
2467
2468
0
  if (!_bfd_elf_create_dynamic_sections (abfd, info))
2469
0
    return false;
2470
2471
0
  if (htab->glink == NULL
2472
0
      && !ppc_elf_create_glink (abfd, info))
2473
0
    return false;
2474
2475
0
  s = bfd_make_section_anyway_with_flags (abfd, ".dynsbss",
2476
0
            SEC_ALLOC | SEC_LINKER_CREATED);
2477
0
  htab->dynsbss = s;
2478
0
  if (s == NULL)
2479
0
    return false;
2480
2481
0
  if (! bfd_link_pic (info))
2482
0
    {
2483
0
      flags = (SEC_ALLOC | SEC_LOAD | SEC_READONLY | SEC_HAS_CONTENTS
2484
0
         | SEC_IN_MEMORY | SEC_LINKER_CREATED);
2485
0
      s = bfd_make_section_anyway_with_flags (abfd, ".rela.sbss", flags);
2486
0
      htab->relsbss = s;
2487
0
      if (s == NULL
2488
0
    || !bfd_set_section_alignment (s, 2))
2489
0
  return false;
2490
0
    }
2491
2492
0
  if (htab->elf.target_os == is_vxworks
2493
0
      && !elf_vxworks_create_dynamic_sections (abfd, info, &htab->srelplt2))
2494
0
    return false;
2495
2496
0
  s = htab->elf.splt;
2497
0
  flags = SEC_ALLOC | SEC_CODE | SEC_LINKER_CREATED;
2498
0
  if (htab->plt_type == PLT_VXWORKS)
2499
    /* The VxWorks PLT is a loaded section with contents.  */
2500
0
    flags |= SEC_HAS_CONTENTS | SEC_LOAD | SEC_READONLY;
2501
0
  return bfd_set_section_flags (s, flags);
2502
0
}
2503
2504
/* Copy the extra info we tack onto an elf_link_hash_entry.  */
2505
2506
static void
2507
ppc_elf_copy_indirect_symbol (struct bfd_link_info *info,
2508
            struct elf_link_hash_entry *dir,
2509
            struct elf_link_hash_entry *ind)
2510
0
{
2511
0
  struct ppc_elf_link_hash_entry *edir, *eind;
2512
2513
0
  edir = (struct ppc_elf_link_hash_entry *) dir;
2514
0
  eind = (struct ppc_elf_link_hash_entry *) ind;
2515
2516
0
  edir->tls_mask |= eind->tls_mask;
2517
0
  edir->has_sda_refs |= eind->has_sda_refs;
2518
2519
0
  if (edir->elf.versioned != versioned_hidden)
2520
0
    edir->elf.ref_dynamic |= eind->elf.ref_dynamic;
2521
0
  edir->elf.ref_regular |= eind->elf.ref_regular;
2522
0
  edir->elf.ref_regular_nonweak |= eind->elf.ref_regular_nonweak;
2523
0
  edir->elf.non_got_ref |= eind->elf.non_got_ref;
2524
0
  edir->elf.needs_plt |= eind->elf.needs_plt;
2525
0
  edir->elf.pointer_equality_needed |= eind->elf.pointer_equality_needed;
2526
2527
  /* If we were called to copy over info for a weak sym, that's all.  */
2528
0
  if (eind->elf.root.type != bfd_link_hash_indirect)
2529
0
    return;
2530
2531
0
  if (ind->dyn_relocs != NULL)
2532
0
    {
2533
0
      if (dir->dyn_relocs != NULL)
2534
0
  {
2535
0
    struct elf_dyn_relocs **pp;
2536
0
    struct elf_dyn_relocs *p;
2537
2538
    /* Add reloc counts against the indirect sym to the direct sym
2539
       list.  Merge any entries against the same section.  */
2540
0
    for (pp = &ind->dyn_relocs; (p = *pp) != NULL; )
2541
0
      {
2542
0
        struct elf_dyn_relocs *q;
2543
2544
0
        for (q = dir->dyn_relocs; q != NULL; q = q->next)
2545
0
    if (q->sec == p->sec)
2546
0
      {
2547
0
        q->pc_count += p->pc_count;
2548
0
        q->count += p->count;
2549
0
        *pp = p->next;
2550
0
        break;
2551
0
      }
2552
0
        if (q == NULL)
2553
0
    pp = &p->next;
2554
0
      }
2555
0
    *pp = dir->dyn_relocs;
2556
0
  }
2557
2558
0
      dir->dyn_relocs = ind->dyn_relocs;
2559
0
      ind->dyn_relocs = NULL;
2560
0
    }
2561
2562
  /* Copy over the GOT refcount entries that we may have already seen to
2563
     the symbol which just became indirect.  */
2564
0
  edir->elf.got.refcount += eind->elf.got.refcount;
2565
0
  eind->elf.got.refcount = 0;
2566
2567
  /* And plt entries.  */
2568
0
  if (eind->elf.plt.plist != NULL)
2569
0
    {
2570
0
      if (edir->elf.plt.plist != NULL)
2571
0
  {
2572
0
    struct plt_entry **entp;
2573
0
    struct plt_entry *ent;
2574
2575
0
    for (entp = &eind->elf.plt.plist; (ent = *entp) != NULL; )
2576
0
      {
2577
0
        struct plt_entry *dent;
2578
2579
0
        for (dent = edir->elf.plt.plist; dent != NULL; dent = dent->next)
2580
0
    if (dent->sec == ent->sec && dent->addend == ent->addend)
2581
0
      {
2582
0
        dent->plt.refcount += ent->plt.refcount;
2583
0
        *entp = ent->next;
2584
0
        break;
2585
0
      }
2586
0
        if (dent == NULL)
2587
0
    entp = &ent->next;
2588
0
      }
2589
0
    *entp = edir->elf.plt.plist;
2590
0
  }
2591
2592
0
      edir->elf.plt.plist = eind->elf.plt.plist;
2593
0
      eind->elf.plt.plist = NULL;
2594
0
    }
2595
2596
0
  if (eind->elf.dynindx != -1)
2597
0
    {
2598
0
      if (edir->elf.dynindx != -1)
2599
0
  _bfd_elf_strtab_delref (elf_hash_table (info)->dynstr,
2600
0
        edir->elf.dynstr_index);
2601
0
      edir->elf.dynindx = eind->elf.dynindx;
2602
0
      edir->elf.dynstr_index = eind->elf.dynstr_index;
2603
0
      eind->elf.dynindx = -1;
2604
0
      eind->elf.dynstr_index = 0;
2605
0
    }
2606
0
}
2607
2608
/* Hook called by the linker routine which adds symbols from an object
2609
   file.  We use it to put .comm items in .sbss, and not .bss.  */
2610
2611
static bool
2612
ppc_elf_add_symbol_hook (bfd *abfd,
2613
       struct bfd_link_info *info,
2614
       Elf_Internal_Sym *sym,
2615
       const char **namep ATTRIBUTE_UNUSED,
2616
       flagword *flagsp ATTRIBUTE_UNUSED,
2617
       asection **secp,
2618
       bfd_vma *valp)
2619
0
{
2620
0
  if (sym->st_shndx == SHN_COMMON
2621
0
      && !bfd_link_relocatable (info)
2622
0
      && is_ppc_elf (info->output_bfd)
2623
0
      && sym->st_size <= elf_gp_size (abfd))
2624
0
    {
2625
      /* Common symbols less than or equal to -G nn bytes are automatically
2626
   put into .sbss.  */
2627
0
      struct ppc_elf_link_hash_table *htab;
2628
2629
0
      htab = ppc_elf_hash_table (info);
2630
0
      if (htab->sbss == NULL)
2631
0
  {
2632
0
    flagword flags = SEC_IS_COMMON | SEC_SMALL_DATA | SEC_LINKER_CREATED;
2633
2634
0
    if (!htab->elf.dynobj)
2635
0
      htab->elf.dynobj = abfd;
2636
2637
0
    htab->sbss = bfd_make_section_anyway_with_flags (htab->elf.dynobj,
2638
0
                 ".sbss",
2639
0
                 flags);
2640
0
    if (htab->sbss == NULL)
2641
0
      return false;
2642
0
  }
2643
2644
0
      *secp = htab->sbss;
2645
0
      *valp = sym->st_size;
2646
0
    }
2647
2648
0
  return true;
2649
0
}
2650

2651
/* Find a linker generated pointer with a given addend and type.  */
2652
2653
static elf_linker_section_pointers_t *
2654
elf_find_pointer_linker_section
2655
  (elf_linker_section_pointers_t *linker_pointers,
2656
   bfd_vma addend,
2657
   elf_linker_section_t *lsect)
2658
0
{
2659
0
  for ( ; linker_pointers != NULL; linker_pointers = linker_pointers->next)
2660
0
    if (lsect == linker_pointers->lsect && addend == linker_pointers->addend)
2661
0
      return linker_pointers;
2662
2663
0
  return NULL;
2664
0
}
2665
2666
/* Allocate a pointer to live in a linker created section.  */
2667
2668
static bool
2669
elf_allocate_pointer_linker_section (bfd *abfd,
2670
             elf_linker_section_t *lsect,
2671
             struct elf_link_hash_entry *h,
2672
             const Elf_Internal_Rela *rel)
2673
0
{
2674
0
  elf_linker_section_pointers_t **ptr_linker_section_ptr = NULL;
2675
0
  elf_linker_section_pointers_t *linker_section_ptr;
2676
0
  unsigned long r_symndx = ELF32_R_SYM (rel->r_info);
2677
0
  bfd_size_type amt;
2678
2679
0
  BFD_ASSERT (lsect != NULL);
2680
2681
  /* Is this a global symbol?  */
2682
0
  if (h != NULL)
2683
0
    {
2684
0
      struct ppc_elf_link_hash_entry *eh;
2685
2686
      /* Has this symbol already been allocated?  If so, our work is done.  */
2687
0
      eh = (struct ppc_elf_link_hash_entry *) h;
2688
0
      if (elf_find_pointer_linker_section (eh->linker_section_pointer,
2689
0
             rel->r_addend,
2690
0
             lsect))
2691
0
  return true;
2692
2693
0
      ptr_linker_section_ptr = &eh->linker_section_pointer;
2694
0
    }
2695
0
  else
2696
0
    {
2697
0
      BFD_ASSERT (is_ppc_elf (abfd));
2698
2699
      /* Allocation of a pointer to a local symbol.  */
2700
0
      elf_linker_section_pointers_t **ptr = elf_local_ptr_offsets (abfd);
2701
2702
      /* Allocate a table to hold the local symbols if first time.  */
2703
0
      if (!ptr)
2704
0
  {
2705
0
    unsigned int num_symbols = elf_symtab_hdr (abfd).sh_info;
2706
2707
0
    amt = num_symbols;
2708
0
    amt *= sizeof (elf_linker_section_pointers_t *);
2709
0
    ptr = bfd_zalloc (abfd, amt);
2710
2711
0
    if (!ptr)
2712
0
      return false;
2713
2714
0
    elf_local_ptr_offsets (abfd) = ptr;
2715
0
  }
2716
2717
      /* Has this symbol already been allocated?  If so, our work is done.  */
2718
0
      if (elf_find_pointer_linker_section (ptr[r_symndx],
2719
0
             rel->r_addend,
2720
0
             lsect))
2721
0
  return true;
2722
2723
0
      ptr_linker_section_ptr = &ptr[r_symndx];
2724
0
    }
2725
2726
  /* Allocate space for a pointer in the linker section, and allocate
2727
     a new pointer record from internal memory.  */
2728
0
  BFD_ASSERT (ptr_linker_section_ptr != NULL);
2729
0
  amt = sizeof (elf_linker_section_pointers_t);
2730
0
  linker_section_ptr = bfd_alloc (abfd, amt);
2731
2732
0
  if (!linker_section_ptr)
2733
0
    return false;
2734
2735
0
  linker_section_ptr->next = *ptr_linker_section_ptr;
2736
0
  linker_section_ptr->addend = rel->r_addend;
2737
0
  linker_section_ptr->lsect = lsect;
2738
0
  *ptr_linker_section_ptr = linker_section_ptr;
2739
2740
0
  if (!bfd_set_section_alignment (lsect->section, 2))
2741
0
    return false;
2742
0
  linker_section_ptr->offset = lsect->section->size;
2743
0
  lsect->section->size += 4;
2744
2745
#ifdef DEBUG
2746
  fprintf (stderr,
2747
     "Create pointer in linker section %s, offset = %ld, section size = %ld\n",
2748
     lsect->name, (long) linker_section_ptr->offset,
2749
     (long) lsect->section->size);
2750
#endif
2751
2752
0
  return true;
2753
0
}
2754
2755
static struct plt_entry **
2756
update_local_sym_info (bfd *abfd,
2757
           Elf_Internal_Shdr *symtab_hdr,
2758
           unsigned long r_symndx,
2759
           int tls_type)
2760
0
{
2761
0
  bfd_signed_vma *local_got_refcounts = elf_local_got_refcounts (abfd);
2762
0
  struct plt_entry **local_plt;
2763
0
  unsigned char *local_got_tls_masks;
2764
2765
0
  if (local_got_refcounts == NULL)
2766
0
    {
2767
0
      bfd_size_type size = symtab_hdr->sh_info;
2768
2769
0
      size *= (sizeof (*local_got_refcounts)
2770
0
         + sizeof (*local_plt)
2771
0
         + sizeof (*local_got_tls_masks));
2772
0
      local_got_refcounts = bfd_zalloc (abfd, size);
2773
0
      if (local_got_refcounts == NULL)
2774
0
  return NULL;
2775
0
      elf_local_got_refcounts (abfd) = local_got_refcounts;
2776
0
    }
2777
2778
0
  local_plt = (struct plt_entry **) (local_got_refcounts + symtab_hdr->sh_info);
2779
0
  local_got_tls_masks = (unsigned char *) (local_plt + symtab_hdr->sh_info);
2780
0
  local_got_tls_masks[r_symndx] |= tls_type & 0xff;
2781
0
  if ((tls_type & NON_GOT) == 0)
2782
0
    local_got_refcounts[r_symndx] += 1;
2783
0
  return local_plt + r_symndx;
2784
0
}
2785
2786
static bool
2787
update_plt_info (bfd *abfd, struct plt_entry **plist,
2788
     asection *sec, bfd_vma addend)
2789
0
{
2790
0
  struct plt_entry *ent;
2791
2792
0
  if (addend < 32768)
2793
0
    sec = NULL;
2794
0
  for (ent = *plist; ent != NULL; ent = ent->next)
2795
0
    if (ent->sec == sec && ent->addend == addend)
2796
0
      break;
2797
0
  if (ent == NULL)
2798
0
    {
2799
0
      size_t amt = sizeof (*ent);
2800
0
      ent = bfd_alloc (abfd, amt);
2801
0
      if (ent == NULL)
2802
0
  return false;
2803
0
      ent->next = *plist;
2804
0
      ent->sec = sec;
2805
0
      ent->addend = addend;
2806
0
      ent->plt.refcount = 0;
2807
0
      *plist = ent;
2808
0
    }
2809
0
  ent->plt.refcount += 1;
2810
0
  return true;
2811
0
}
2812
2813
static struct plt_entry *
2814
find_plt_ent (struct plt_entry **plist, asection *sec, bfd_vma addend)
2815
0
{
2816
0
  struct plt_entry *ent;
2817
2818
0
  if (addend < 32768)
2819
0
    sec = NULL;
2820
0
  for (ent = *plist; ent != NULL; ent = ent->next)
2821
0
    if (ent->sec == sec && ent->addend == addend)
2822
0
      break;
2823
0
  return ent;
2824
0
}
2825
2826
static bool
2827
is_branch_reloc (enum elf_ppc_reloc_type r_type)
2828
0
{
2829
0
  return (r_type == R_PPC_PLTREL24
2830
0
    || r_type == R_PPC_LOCAL24PC
2831
0
    || r_type == R_PPC_REL24
2832
0
    || r_type == R_PPC_REL14
2833
0
    || r_type == R_PPC_REL14_BRTAKEN
2834
0
    || r_type == R_PPC_REL14_BRNTAKEN
2835
0
    || r_type == R_PPC_ADDR24
2836
0
    || r_type == R_PPC_ADDR14
2837
0
    || r_type == R_PPC_ADDR14_BRTAKEN
2838
0
    || r_type == R_PPC_ADDR14_BRNTAKEN
2839
0
    || r_type == R_PPC_VLE_REL24);
2840
0
}
2841
2842
/* Relocs on inline plt call sequence insns prior to the call.  */
2843
2844
static bool
2845
is_plt_seq_reloc (enum elf_ppc_reloc_type r_type)
2846
0
{
2847
0
  return (r_type == R_PPC_PLT16_HA
2848
0
    || r_type == R_PPC_PLT16_HI
2849
0
    || r_type == R_PPC_PLT16_LO
2850
0
    || r_type == R_PPC_PLTSEQ);
2851
0
}
2852
2853
/* Like bfd_reloc_offset_in_range but without a howto.  Return true
2854
   iff a field of SIZE bytes at OFFSET is within SEC limits.  */
2855
2856
static bool
2857
offset_in_range (asection *sec, bfd_vma offset, size_t size)
2858
0
{
2859
0
  return offset <= sec->size && size <= sec->size - offset;
2860
0
}
2861
2862
static void
2863
bad_shared_reloc (bfd *abfd, enum elf_ppc_reloc_type r_type)
2864
0
{
2865
0
  _bfd_error_handler
2866
    /* xgettext:c-format */
2867
0
    (_("%pB: relocation %s cannot be used when making a shared object"),
2868
0
     abfd,
2869
0
     ppc_elf_howto_table[r_type]->name);
2870
0
  bfd_set_error (bfd_error_bad_value);
2871
0
}
2872
2873
/* Look through the relocs for a section during the first phase, and
2874
   allocate space in the global offset table or procedure linkage
2875
   table.  */
2876
2877
static bool
2878
ppc_elf_check_relocs (bfd *abfd,
2879
          struct bfd_link_info *info,
2880
          asection *sec,
2881
          const Elf_Internal_Rela *relocs)
2882
0
{
2883
0
  struct ppc_elf_link_hash_table *htab;
2884
0
  Elf_Internal_Shdr *symtab_hdr;
2885
0
  struct elf_link_hash_entry **sym_hashes;
2886
0
  const Elf_Internal_Rela *rel;
2887
0
  const Elf_Internal_Rela *rel_end;
2888
0
  asection *got2, *sreloc;
2889
0
  struct elf_link_hash_entry *tga;
2890
2891
0
  if (bfd_link_relocatable (info))
2892
0
    return true;
2893
2894
#ifdef DEBUG
2895
  _bfd_error_handler ("ppc_elf_check_relocs called for section %pA in %pB",
2896
          sec, abfd);
2897
#endif
2898
2899
0
  BFD_ASSERT (is_ppc_elf (abfd));
2900
2901
  /* Initialize howto table if not already done.  */
2902
0
  if (!ppc_elf_howto_table[R_PPC_ADDR32])
2903
0
    ppc_elf_howto_init ();
2904
2905
0
  htab = ppc_elf_hash_table (info);
2906
0
  if (htab->glink == NULL)
2907
0
    {
2908
0
      if (htab->elf.dynobj == NULL)
2909
0
  htab->elf.dynobj = abfd;
2910
0
      if (!ppc_elf_create_glink (htab->elf.dynobj, info))
2911
0
  return false;
2912
0
    }
2913
0
  tga = elf_link_hash_lookup (&htab->elf, "__tls_get_addr",
2914
0
            false, false, true);
2915
0
  symtab_hdr = &elf_symtab_hdr (abfd);
2916
0
  sym_hashes = elf_sym_hashes (abfd);
2917
0
  got2 = bfd_get_section_by_name (abfd, ".got2");
2918
0
  sreloc = NULL;
2919
2920
0
  rel_end = relocs + sec->reloc_count;
2921
0
  for (rel = relocs; rel < rel_end; rel++)
2922
0
    {
2923
0
      unsigned long r_symndx;
2924
0
      enum elf_ppc_reloc_type r_type;
2925
0
      struct elf_link_hash_entry *h;
2926
0
      Elf_Internal_Sym *isym;
2927
0
      int tls_type;
2928
0
      struct plt_entry **ifunc;
2929
0
      struct plt_entry **pltent;
2930
0
      bfd_vma addend;
2931
2932
0
      r_symndx = ELF32_R_SYM (rel->r_info);
2933
0
      if (r_symndx < symtab_hdr->sh_info)
2934
0
  {
2935
0
    h = NULL;
2936
0
    isym = bfd_sym_from_r_symndx (&htab->elf.sym_cache, abfd, r_symndx);
2937
0
    if (isym == NULL)
2938
0
      return false;
2939
0
  }
2940
0
      else
2941
0
  {
2942
0
    h = sym_hashes[r_symndx - symtab_hdr->sh_info];
2943
0
    while (h->root.type == bfd_link_hash_indirect
2944
0
     || h->root.type == bfd_link_hash_warning)
2945
0
      h = (struct elf_link_hash_entry *) h->root.u.i.link;
2946
0
    isym = NULL;
2947
0
  }
2948
2949
      /* If a relocation refers to _GLOBAL_OFFSET_TABLE_, create the .got.
2950
   This shows up in particular in an R_PPC_ADDR32 in the eabi
2951
   startup code.  */
2952
0
      if (h != NULL
2953
0
    && htab->elf.sgot == NULL
2954
0
    && strcmp (h->root.root.string, "_GLOBAL_OFFSET_TABLE_") == 0)
2955
0
  {
2956
0
    if (htab->elf.dynobj == NULL)
2957
0
      htab->elf.dynobj = abfd;
2958
0
    if (!ppc_elf_create_got (htab->elf.dynobj, info))
2959
0
      return false;
2960
0
    BFD_ASSERT (h == htab->elf.hgot);
2961
0
  }
2962
2963
0
      tls_type = 0;
2964
0
      r_type = ELF32_R_TYPE (rel->r_info);
2965
0
      ifunc = NULL;
2966
0
      if (h != NULL)
2967
0
  {
2968
0
    if (h->type == STT_GNU_IFUNC)
2969
0
      {
2970
0
        h->needs_plt = 1;
2971
0
        ifunc = &h->plt.plist;
2972
0
      }
2973
0
  }
2974
0
      else if (htab->elf.target_os != is_vxworks)
2975
0
  {
2976
0
    if (ELF_ST_TYPE (isym->st_info) == STT_GNU_IFUNC)
2977
0
      {
2978
        /* Set PLT_IFUNC flag for this sym, no GOT entry yet.  */
2979
0
        ifunc = update_local_sym_info (abfd, symtab_hdr, r_symndx,
2980
0
               NON_GOT | PLT_IFUNC);
2981
0
        if (ifunc == NULL)
2982
0
    return false;
2983
2984
        /* STT_GNU_IFUNC symbols must have a PLT entry;
2985
     In a non-pie executable even when there are
2986
     no plt calls.  */
2987
0
        if (!bfd_link_pic (info)
2988
0
      || is_branch_reloc (r_type)
2989
0
      || r_type == R_PPC_PLT16_LO
2990
0
      || r_type == R_PPC_PLT16_HI
2991
0
      || r_type == R_PPC_PLT16_HA)
2992
0
    {
2993
0
      addend = 0;
2994
0
      if (r_type == R_PPC_PLTREL24)
2995
0
        ppc_elf_tdata (abfd)->makes_plt_call = 1;
2996
0
      if (bfd_link_pic (info)
2997
0
          && (r_type == R_PPC_PLTREL24
2998
0
        || r_type == R_PPC_PLT16_LO
2999
0
        || r_type == R_PPC_PLT16_HI
3000
0
        || r_type == R_PPC_PLT16_HA))
3001
0
        addend = rel->r_addend;
3002
0
      if (!update_plt_info (abfd, ifunc, got2, addend))
3003
0
        return false;
3004
0
    }
3005
0
      }
3006
0
  }
3007
3008
0
      if (htab->elf.target_os != is_vxworks
3009
0
    && is_branch_reloc (r_type)
3010
0
    && h != NULL
3011
0
    && h == tga)
3012
0
  {
3013
0
    if (rel != relocs
3014
0
        && (ELF32_R_TYPE (rel[-1].r_info) == R_PPC_TLSGD
3015
0
      || ELF32_R_TYPE (rel[-1].r_info) == R_PPC_TLSLD))
3016
      /* We have a new-style __tls_get_addr call with a marker
3017
         reloc.  */
3018
0
      ;
3019
0
    else
3020
      /* Mark this section as having an old-style call.  */
3021
0
      sec->nomark_tls_get_addr = 1;
3022
0
  }
3023
3024
0
      switch (r_type)
3025
0
  {
3026
0
  case R_PPC_TLSGD:
3027
0
  case R_PPC_TLSLD:
3028
    /* These special tls relocs tie a call to __tls_get_addr with
3029
       its parameter symbol.  */
3030
0
    if (h != NULL)
3031
0
      ppc_elf_hash_entry (h)->tls_mask |= TLS_TLS | TLS_MARK;
3032
0
    else
3033
0
      if (!update_local_sym_info (abfd, symtab_hdr, r_symndx,
3034
0
          NON_GOT | TLS_TLS | TLS_MARK))
3035
0
        return false;
3036
0
    break;
3037
3038
0
  case R_PPC_PLTSEQ:
3039
0
    break;
3040
3041
0
  case R_PPC_GOT_TLSLD16:
3042
0
  case R_PPC_GOT_TLSLD16_LO:
3043
0
  case R_PPC_GOT_TLSLD16_HI:
3044
0
  case R_PPC_GOT_TLSLD16_HA:
3045
0
    tls_type = TLS_TLS | TLS_LD;
3046
0
    goto dogottls;
3047
3048
0
  case R_PPC_GOT_TLSGD16:
3049
0
  case R_PPC_GOT_TLSGD16_LO:
3050
0
  case R_PPC_GOT_TLSGD16_HI:
3051
0
  case R_PPC_GOT_TLSGD16_HA:
3052
0
    tls_type = TLS_TLS | TLS_GD;
3053
0
    goto dogottls;
3054
3055
0
  case R_PPC_GOT_TPREL16:
3056
0
  case R_PPC_GOT_TPREL16_LO:
3057
0
  case R_PPC_GOT_TPREL16_HI:
3058
0
  case R_PPC_GOT_TPREL16_HA:
3059
0
    if (bfd_link_dll (info))
3060
0
      info->flags |= DF_STATIC_TLS;
3061
0
    tls_type = TLS_TLS | TLS_TPREL;
3062
0
    goto dogottls;
3063
3064
0
  case R_PPC_GOT_DTPREL16:
3065
0
  case R_PPC_GOT_DTPREL16_LO:
3066
0
  case R_PPC_GOT_DTPREL16_HI:
3067
0
  case R_PPC_GOT_DTPREL16_HA:
3068
0
    tls_type = TLS_TLS | TLS_DTPREL;
3069
0
  dogottls:
3070
0
    sec->has_tls_reloc = 1;
3071
    /* Fall through.  */
3072
3073
    /* GOT16 relocations */
3074
0
  case R_PPC_GOT16:
3075
0
  case R_PPC_GOT16_LO:
3076
0
  case R_PPC_GOT16_HI:
3077
0
  case R_PPC_GOT16_HA:
3078
    /* This symbol requires a global offset table entry.  */
3079
0
    if (htab->elf.sgot == NULL)
3080
0
      {
3081
0
        if (htab->elf.dynobj == NULL)
3082
0
    htab->elf.dynobj = abfd;
3083
0
        if (!ppc_elf_create_got (htab->elf.dynobj, info))
3084
0
    return false;
3085
0
      }
3086
0
    if (h != NULL)
3087
0
      {
3088
0
        h->got.refcount += 1;
3089
0
        ppc_elf_hash_entry (h)->tls_mask |= tls_type;
3090
0
      }
3091
0
    else
3092
      /* This is a global offset table entry for a local symbol.  */
3093
0
      if (!update_local_sym_info (abfd, symtab_hdr, r_symndx, tls_type))
3094
0
        return false;
3095
3096
    /* We may also need a plt entry if the symbol turns out to be
3097
       an ifunc.  */
3098
0
    if (h != NULL && !bfd_link_pic (info))
3099
0
      {
3100
0
        if (!update_plt_info (abfd, &h->plt.plist, NULL, 0))
3101
0
    return false;
3102
0
      }
3103
0
    break;
3104
3105
    /* Indirect .sdata relocation.  */
3106
0
  case R_PPC_EMB_SDAI16:
3107
0
    htab->sdata[0].sym->ref_regular = 1;
3108
0
    if (!elf_allocate_pointer_linker_section (abfd, &htab->sdata[0],
3109
0
                h, rel))
3110
0
      return false;
3111
0
    if (h != NULL)
3112
0
      {
3113
0
        ppc_elf_hash_entry (h)->has_sda_refs = true;
3114
0
        h->non_got_ref = true;
3115
0
      }
3116
0
    break;
3117
3118
    /* Indirect .sdata2 relocation.  */
3119
0
  case R_PPC_EMB_SDA2I16:
3120
0
    if (!bfd_link_executable (info))
3121
0
      {
3122
0
        bad_shared_reloc (abfd, r_type);
3123
0
        return false;
3124
0
      }
3125
0
    htab->sdata[1].sym->ref_regular = 1;
3126
0
    if (!elf_allocate_pointer_linker_section (abfd, &htab->sdata[1],
3127
0
                h, rel))
3128
0
      return false;
3129
0
    if (h != NULL)
3130
0
      {
3131
0
        ppc_elf_hash_entry (h)->has_sda_refs = true;
3132
0
        h->non_got_ref = true;
3133
0
      }
3134
0
    break;
3135
3136
0
  case R_PPC_SDAREL16:
3137
0
    htab->sdata[0].sym->ref_regular = 1;
3138
    /* Fall through.  */
3139
3140
0
  case R_PPC_VLE_SDAREL_LO16A:
3141
0
  case R_PPC_VLE_SDAREL_LO16D:
3142
0
  case R_PPC_VLE_SDAREL_HI16A:
3143
0
  case R_PPC_VLE_SDAREL_HI16D:
3144
0
  case R_PPC_VLE_SDAREL_HA16A:
3145
0
  case R_PPC_VLE_SDAREL_HA16D:
3146
0
    if (h != NULL)
3147
0
      {
3148
0
        ppc_elf_hash_entry (h)->has_sda_refs = true;
3149
0
        h->non_got_ref = true;
3150
0
      }
3151
0
    break;
3152
3153
0
  case R_PPC_VLE_REL8:
3154
0
  case R_PPC_VLE_REL15:
3155
0
  case R_PPC_VLE_REL24:
3156
0
  case R_PPC_VLE_LO16A:
3157
0
  case R_PPC_VLE_LO16D:
3158
0
  case R_PPC_VLE_HI16A:
3159
0
  case R_PPC_VLE_HI16D:
3160
0
  case R_PPC_VLE_HA16A:
3161
0
  case R_PPC_VLE_HA16D:
3162
0
  case R_PPC_VLE_ADDR20:
3163
0
    break;
3164
3165
0
  case R_PPC_EMB_SDA2REL:
3166
0
    if (!bfd_link_executable (info))
3167
0
      {
3168
0
        bad_shared_reloc (abfd, r_type);
3169
0
        return false;
3170
0
      }
3171
0
    htab->sdata[1].sym->ref_regular = 1;
3172
0
    if (h != NULL)
3173
0
      {
3174
0
        ppc_elf_hash_entry (h)->has_sda_refs = true;
3175
0
        h->non_got_ref = true;
3176
0
      }
3177
0
    break;
3178
3179
0
  case R_PPC_VLE_SDA21_LO:
3180
0
  case R_PPC_VLE_SDA21:
3181
0
  case R_PPC_EMB_SDA21:
3182
0
  case R_PPC_EMB_RELSDA:
3183
0
    if (h != NULL)
3184
0
      {
3185
0
        ppc_elf_hash_entry (h)->has_sda_refs = true;
3186
0
        h->non_got_ref = true;
3187
0
      }
3188
0
    break;
3189
3190
0
  case R_PPC_EMB_NADDR32:
3191
0
  case R_PPC_EMB_NADDR16:
3192
0
  case R_PPC_EMB_NADDR16_LO:
3193
0
  case R_PPC_EMB_NADDR16_HI:
3194
0
  case R_PPC_EMB_NADDR16_HA:
3195
0
    if (h != NULL)
3196
0
      h->non_got_ref = true;
3197
0
    break;
3198
3199
0
  case R_PPC_PLTREL24:
3200
0
    if (h == NULL)
3201
0
      break;
3202
0
    ppc_elf_tdata (abfd)->makes_plt_call = 1;
3203
0
    goto pltentry;
3204
3205
0
  case R_PPC_PLTCALL:
3206
0
    sec->has_pltcall = 1;
3207
    /* Fall through.  */
3208
3209
0
  case R_PPC_PLT32:
3210
0
  case R_PPC_PLTREL32:
3211
0
  case R_PPC_PLT16_LO:
3212
0
  case R_PPC_PLT16_HI:
3213
0
  case R_PPC_PLT16_HA:
3214
0
  pltentry:
3215
#ifdef DEBUG
3216
    fprintf (stderr, "Reloc requires a PLT entry\n");
3217
#endif
3218
    /* This symbol requires a procedure linkage table entry.  */
3219
0
    if (h == NULL)
3220
0
      {
3221
0
        pltent = update_local_sym_info (abfd, symtab_hdr, r_symndx,
3222
0
                NON_GOT | PLT_KEEP);
3223
0
        if (pltent == NULL)
3224
0
    return false;
3225
0
      }
3226
0
    else
3227
0
      {
3228
0
        if (r_type != R_PPC_PLTREL24)
3229
0
    ppc_elf_hash_entry (h)->tls_mask |= PLT_KEEP;
3230
0
        h->needs_plt = 1;
3231
0
        pltent = &h->plt.plist;
3232
0
      }
3233
0
    addend = 0;
3234
0
    if (bfd_link_pic (info)
3235
0
        && (r_type == R_PPC_PLTREL24
3236
0
      || r_type == R_PPC_PLT16_LO
3237
0
      || r_type == R_PPC_PLT16_HI
3238
0
      || r_type == R_PPC_PLT16_HA))
3239
0
      addend = rel->r_addend;
3240
0
    if (!update_plt_info (abfd, pltent, got2, addend))
3241
0
      return false;
3242
0
    break;
3243
3244
    /* The following relocations don't need to propagate the
3245
       relocation if linking a shared object since they are
3246
       section relative.  */
3247
0
  case R_PPC_SECTOFF:
3248
0
  case R_PPC_SECTOFF_LO:
3249
0
  case R_PPC_SECTOFF_HI:
3250
0
  case R_PPC_SECTOFF_HA:
3251
0
  case R_PPC_DTPREL16:
3252
0
  case R_PPC_DTPREL16_LO:
3253
0
  case R_PPC_DTPREL16_HI:
3254
0
  case R_PPC_DTPREL16_HA:
3255
0
  case R_PPC_TOC16:
3256
0
    break;
3257
3258
0
  case R_PPC_REL16:
3259
0
  case R_PPC_REL16_LO:
3260
0
  case R_PPC_REL16_HI:
3261
0
  case R_PPC_REL16_HA:
3262
0
  case R_PPC_REL16DX_HA:
3263
0
    ppc_elf_tdata (abfd)->has_rel16 = 1;
3264
0
    break;
3265
3266
    /* These are just markers.  */
3267
0
  case R_PPC_TLS:
3268
0
  case R_PPC_EMB_MRKREF:
3269
0
  case R_PPC_NONE:
3270
0
  case R_PPC_max:
3271
0
  case R_PPC_RELAX:
3272
0
  case R_PPC_RELAX_PLT:
3273
0
  case R_PPC_RELAX_PLTREL24:
3274
0
  case R_PPC_16DX_HA:
3275
0
    break;
3276
3277
    /* These should only appear in dynamic objects.  */
3278
0
  case R_PPC_COPY:
3279
0
  case R_PPC_GLOB_DAT:
3280
0
  case R_PPC_JMP_SLOT:
3281
0
  case R_PPC_RELATIVE:
3282
0
  case R_PPC_IRELATIVE:
3283
0
    break;
3284
3285
    /* These aren't handled yet.  We'll report an error later.  */
3286
0
  case R_PPC_ADDR30:
3287
0
  case R_PPC_EMB_RELSEC16:
3288
0
  case R_PPC_EMB_RELST_LO:
3289
0
  case R_PPC_EMB_RELST_HI:
3290
0
  case R_PPC_EMB_RELST_HA:
3291
0
  case R_PPC_EMB_BIT_FLD:
3292
0
    break;
3293
3294
    /* This refers only to functions defined in the shared library.  */
3295
0
  case R_PPC_LOCAL24PC:
3296
0
    if (h != NULL && h == htab->elf.hgot && htab->plt_type == PLT_UNSET)
3297
0
      {
3298
0
        htab->plt_type = PLT_OLD;
3299
0
        htab->old_bfd = abfd;
3300
0
      }
3301
0
    if (h != NULL
3302
0
        && ifunc != NULL
3303
0
        && !update_plt_info (abfd, ifunc, NULL, 0))
3304
0
      return false;
3305
0
    break;
3306
3307
    /* This relocation describes the C++ object vtable hierarchy.
3308
       Reconstruct it for later use during GC.  */
3309
0
  case R_PPC_GNU_VTINHERIT:
3310
0
    if (!bfd_elf_gc_record_vtinherit (abfd, sec, h, rel->r_offset))
3311
0
      return false;
3312
0
    break;
3313
3314
    /* This relocation describes which C++ vtable entries are actually
3315
       used.  Record for later use during GC.  */
3316
0
  case R_PPC_GNU_VTENTRY:
3317
0
    if (!bfd_elf_gc_record_vtentry (abfd, sec, h, rel->r_addend))
3318
0
      return false;
3319
0
    break;
3320
3321
0
  case R_PPC_TPREL16_HI:
3322
0
  case R_PPC_TPREL16_HA:
3323
0
    sec->has_tls_reloc = 1;
3324
    /* Fall through.  */
3325
    /* We shouldn't really be seeing TPREL32.  */
3326
0
  case R_PPC_TPREL32:
3327
0
  case R_PPC_TPREL16:
3328
0
  case R_PPC_TPREL16_LO:
3329
0
    if (bfd_link_dll (info))
3330
0
      info->flags |= DF_STATIC_TLS;
3331
0
    goto dodyn;
3332
3333
    /* Nor these.  */
3334
0
  case R_PPC_DTPMOD32:
3335
0
  case R_PPC_DTPREL32:
3336
0
    goto dodyn;
3337
3338
0
  case R_PPC_REL32:
3339
0
    if (h == NULL
3340
0
        && got2 != NULL
3341
0
        && (sec->flags & SEC_CODE) != 0
3342
0
        && bfd_link_pic (info)
3343
0
        && htab->plt_type == PLT_UNSET)
3344
0
      {
3345
        /* Old -fPIC gcc code has .long LCTOC1-LCFx just before
3346
     the start of a function, which assembles to a REL32
3347
     reference to .got2.  If we detect one of these, then
3348
     force the old PLT layout because the linker cannot
3349
     reliably deduce the GOT pointer value needed for
3350
     PLT call stubs.  */
3351
0
        asection *s;
3352
3353
0
        s = bfd_section_from_elf_index (abfd, isym->st_shndx);
3354
0
        if (s == got2)
3355
0
    {
3356
0
      htab->plt_type = PLT_OLD;
3357
0
      htab->old_bfd = abfd;
3358
0
    }
3359
0
      }
3360
0
    if (h == NULL || h == htab->elf.hgot)
3361
0
      break;
3362
    /* fall through */
3363
3364
0
  case R_PPC_ADDR32:
3365
0
  case R_PPC_ADDR16:
3366
0
  case R_PPC_ADDR16_LO:
3367
0
  case R_PPC_ADDR16_HI:
3368
0
  case R_PPC_ADDR16_HA:
3369
0
  case R_PPC_UADDR32:
3370
0
  case R_PPC_UADDR16:
3371
0
    if (h != NULL && !bfd_link_pic (info))
3372
0
      {
3373
        /* We may need a plt entry if the symbol turns out to be
3374
     a function defined in a dynamic object.  */
3375
0
        if (!update_plt_info (abfd, &h->plt.plist, NULL, 0))
3376
0
    return false;
3377
3378
        /* We may need a copy reloc too.  */
3379
0
        h->non_got_ref = 1;
3380
0
        h->pointer_equality_needed = 1;
3381
0
        if (r_type == R_PPC_ADDR16_HA)
3382
0
    ppc_elf_hash_entry (h)->has_addr16_ha = 1;
3383
0
        if (r_type == R_PPC_ADDR16_LO)
3384
0
    ppc_elf_hash_entry (h)->has_addr16_lo = 1;
3385
0
      }
3386
0
    goto dodyn;
3387
3388
0
  case R_PPC_REL24:
3389
0
  case R_PPC_REL14:
3390
0
  case R_PPC_REL14_BRTAKEN:
3391
0
  case R_PPC_REL14_BRNTAKEN:
3392
0
    if (h == NULL)
3393
0
      break;
3394
0
    if (h == htab->elf.hgot)
3395
0
      {
3396
0
        if (htab->plt_type == PLT_UNSET)
3397
0
    {
3398
0
      htab->plt_type = PLT_OLD;
3399
0
      htab->old_bfd = abfd;
3400
0
    }
3401
0
        break;
3402
0
      }
3403
    /* fall through */
3404
3405
0
  case R_PPC_ADDR24:
3406
0
  case R_PPC_ADDR14:
3407
0
  case R_PPC_ADDR14_BRTAKEN:
3408
0
  case R_PPC_ADDR14_BRNTAKEN:
3409
0
    if (h != NULL && !bfd_link_pic (info))
3410
0
      {
3411
        /* We may need a plt entry if the symbol turns out to be
3412
     a function defined in a dynamic object.  */
3413
0
        h->needs_plt = 1;
3414
0
        if (!update_plt_info (abfd, &h->plt.plist, NULL, 0))
3415
0
    return false;
3416
0
        break;
3417
0
      }
3418
3419
0
  dodyn:
3420
    /* Set up information for symbols that might need dynamic
3421
       relocations.  At this point in linking we have read all
3422
       the input files and resolved most symbols, but have not
3423
       yet decided whether symbols are dynamic or finalized
3424
       symbol flags.  In some cases we might be setting dynamic
3425
       reloc info for symbols that do not end up needing such.
3426
       That's OK, adjust_dynamic_symbol and allocate_dynrelocs
3427
       work together with this code.  */
3428
0
    if ((h != NULL
3429
0
         && !SYMBOL_REFERENCES_LOCAL (info, h))
3430
0
        || (bfd_link_pic (info)
3431
0
      && (h != NULL
3432
0
          ? !bfd_is_abs_symbol (&h->root)
3433
0
          : isym->st_shndx != SHN_ABS)
3434
0
      && must_be_dyn_reloc (info, r_type)))
3435
0
      {
3436
#ifdef DEBUG
3437
        fprintf (stderr,
3438
           "ppc_elf_check_relocs needs to "
3439
           "create relocation for %s\n",
3440
           (h && h->root.root.string
3441
      ? h->root.root.string : "<unknown>"));
3442
#endif
3443
0
        if (sreloc == NULL)
3444
0
    {
3445
0
      if (htab->elf.dynobj == NULL)
3446
0
        htab->elf.dynobj = abfd;
3447
3448
0
      sreloc = _bfd_elf_make_dynamic_reloc_section
3449
0
        (sec, htab->elf.dynobj, 2, abfd, /*rela?*/ true);
3450
3451
0
      if (sreloc == NULL)
3452
0
        return false;
3453
0
    }
3454
3455
        /* If this is a global symbol, we count the number of
3456
     relocations we need for this symbol.  */
3457
0
        if (h != NULL)
3458
0
    {
3459
0
      struct elf_dyn_relocs *p;
3460
0
      struct elf_dyn_relocs **rel_head;
3461
3462
0
      rel_head = &h->dyn_relocs;
3463
0
      p = *rel_head;
3464
0
      if (p == NULL || p->sec != sec)
3465
0
        {
3466
0
          p = bfd_alloc (htab->elf.dynobj, sizeof *p);
3467
0
          if (p == NULL)
3468
0
      return false;
3469
0
          p->next = *rel_head;
3470
0
          *rel_head = p;
3471
0
          p->sec = sec;
3472
0
          p->count = 0;
3473
0
          p->pc_count = 0;
3474
0
        }
3475
0
      p->count += 1;
3476
0
      if (!must_be_dyn_reloc (info, r_type))
3477
0
        p->pc_count += 1;
3478
0
    }
3479
0
        else
3480
0
    {
3481
      /* Track dynamic relocs needed for local syms too.
3482
         We really need local syms available to do this
3483
         easily.  Oh well.  */
3484
0
      struct ppc_dyn_relocs *p;
3485
0
      struct ppc_dyn_relocs **rel_head;
3486
0
      bool is_ifunc;
3487
0
      asection *s;
3488
0
      void *vpp;
3489
3490
0
      s = bfd_section_from_elf_index (abfd, isym->st_shndx);
3491
0
      if (s == NULL)
3492
0
        s = sec;
3493
3494
0
      vpp = &elf_section_data (s)->local_dynrel;
3495
0
      rel_head = (struct ppc_dyn_relocs **) vpp;
3496
0
      is_ifunc = ifunc != NULL;
3497
0
      p = *rel_head;
3498
0
      if (p != NULL && p->sec == sec && p->ifunc != is_ifunc)
3499
0
        p = p->next;
3500
0
      if (p == NULL || p->sec != sec || p->ifunc != is_ifunc)
3501
0
        {
3502
0
          p = bfd_alloc (htab->elf.dynobj, sizeof *p);
3503
0
          if (p == NULL)
3504
0
      return false;
3505
0
          p->next = *rel_head;
3506
0
          *rel_head = p;
3507
0
          p->sec = sec;
3508
0
          p->ifunc = is_ifunc;
3509
0
          p->count = 0;
3510
0
        }
3511
0
      p->count += 1;
3512
0
    }
3513
0
      }
3514
3515
0
    break;
3516
0
  }
3517
0
    }
3518
3519
0
  return true;
3520
0
}
3521

3522
/* Warn for conflicting Tag_GNU_Power_ABI_FP attributes between IBFD
3523
   and OBFD, and merge non-conflicting ones.  */
3524
bool
3525
_bfd_elf_ppc_merge_fp_attributes (bfd *ibfd, struct bfd_link_info *info)
3526
0
{
3527
0
  bfd *obfd = info->output_bfd;
3528
0
  obj_attribute *in_attr, *in_attrs;
3529
0
  obj_attribute *out_attr, *out_attrs;
3530
0
  bool ret = true;
3531
0
  bool warn_only;
3532
3533
  /* We only warn about shared library mismatches, because common
3534
     libraries advertise support for a particular long double variant
3535
     but actually support more than one variant.  For example, glibc
3536
     typically supports 128-bit IBM long double in the shared library
3537
     but has a compatibility static archive for 64-bit long double.
3538
     The linker doesn't have the smarts to see that an app using
3539
     object files marked as 64-bit long double call the compatibility
3540
     layer objects and only from there call into the shared library.  */
3541
0
  warn_only = (ibfd->flags & DYNAMIC) != 0;
3542
3543
0
  in_attrs = elf_known_obj_attributes (ibfd)[OBJ_ATTR_GNU];
3544
0
  out_attrs = elf_known_obj_attributes (obfd)[OBJ_ATTR_GNU];
3545
3546
0
  in_attr = &in_attrs[Tag_GNU_Power_ABI_FP];
3547
0
  out_attr = &out_attrs[Tag_GNU_Power_ABI_FP];
3548
3549
0
  if (in_attr->i != out_attr->i)
3550
0
    {
3551
0
      int in_fp = in_attr->i & 3;
3552
0
      int out_fp = out_attr->i & 3;
3553
0
      static bfd *last_fp, *last_ld;
3554
3555
0
      if (in_fp == 0)
3556
0
  ;
3557
0
      else if (out_fp == 0)
3558
0
  {
3559
0
    if (!warn_only)
3560
0
      {
3561
0
        out_attr->type = ATTR_TYPE_FLAG_INT_VAL;
3562
0
        out_attr->i ^= in_fp;
3563
0
        last_fp = ibfd;
3564
0
      }
3565
0
  }
3566
0
      else if (out_fp != 2 && in_fp == 2)
3567
0
  {
3568
0
    _bfd_error_handler
3569
      /* xgettext:c-format */
3570
0
      (_("%pB uses hard float, %pB uses soft float"),
3571
0
       last_fp, ibfd);
3572
0
    ret = warn_only;
3573
0
  }
3574
0
      else if (out_fp == 2 && in_fp != 2)
3575
0
  {
3576
0
    _bfd_error_handler
3577
      /* xgettext:c-format */
3578
0
      (_("%pB uses hard float, %pB uses soft float"),
3579
0
       ibfd, last_fp);
3580
0
    ret = warn_only;
3581
0
  }
3582
0
      else if (out_fp == 1 && in_fp == 3)
3583
0
  {
3584
0
    _bfd_error_handler
3585
      /* xgettext:c-format */
3586
0
      (_("%pB uses double-precision hard float, "
3587
0
         "%pB uses single-precision hard float"), last_fp, ibfd);
3588
0
    ret = warn_only;
3589
0
  }
3590
0
      else if (out_fp == 3 && in_fp == 1)
3591
0
  {
3592
0
    _bfd_error_handler
3593
      /* xgettext:c-format */
3594
0
      (_("%pB uses double-precision hard float, "
3595
0
         "%pB uses single-precision hard float"), ibfd, last_fp);
3596
0
    ret = warn_only;
3597
0
  }
3598
3599
0
      in_fp = in_attr->i & 0xc;
3600
0
      out_fp = out_attr->i & 0xc;
3601
0
      if (in_fp == 0)
3602
0
  ;
3603
0
      else if (out_fp == 0)
3604
0
  {
3605
0
    if (!warn_only)
3606
0
      {
3607
0
        out_attr->type = ATTR_TYPE_FLAG_INT_VAL;
3608
0
        out_attr->i ^= in_fp;
3609
0
        last_ld = ibfd;
3610
0
      }
3611
0
  }
3612
0
      else if (out_fp != 2 * 4 && in_fp == 2 * 4)
3613
0
  {
3614
0
    _bfd_error_handler
3615
      /* xgettext:c-format */
3616
0
      (_("%pB uses 64-bit long double, "
3617
0
         "%pB uses 128-bit long double"), ibfd, last_ld);
3618
0
    ret = warn_only;
3619
0
  }
3620
0
      else if (in_fp != 2 * 4 && out_fp == 2 * 4)
3621
0
  {
3622
0
    _bfd_error_handler
3623
      /* xgettext:c-format */
3624
0
      (_("%pB uses 64-bit long double, "
3625
0
         "%pB uses 128-bit long double"), last_ld, ibfd);
3626
0
    ret = warn_only;
3627
0
  }
3628
0
      else if (out_fp == 1 * 4 && in_fp == 3 * 4)
3629
0
  {
3630
0
    _bfd_error_handler
3631
      /* xgettext:c-format */
3632
0
      (_("%pB uses IBM long double, "
3633
0
         "%pB uses IEEE long double"), last_ld, ibfd);
3634
0
    ret = warn_only;
3635
0
  }
3636
0
      else if (out_fp == 3 * 4 && in_fp == 1 * 4)
3637
0
  {
3638
0
    _bfd_error_handler
3639
      /* xgettext:c-format */
3640
0
      (_("%pB uses IBM long double, "
3641
0
         "%pB uses IEEE long double"), ibfd, last_ld);
3642
0
    ret = warn_only;
3643
0
  }
3644
0
    }
3645
3646
0
  if (!ret)
3647
0
    {
3648
0
      out_attr->type = ATTR_TYPE_FLAG_INT_VAL | ATTR_TYPE_FLAG_ERROR;
3649
0
      bfd_set_error (bfd_error_bad_value);
3650
0
    }
3651
0
  return ret;
3652
0
}
3653
3654
/* Merge object attributes from IBFD into OBFD.  Warn if
3655
   there are conflicting attributes.  */
3656
static bool
3657
ppc_elf_merge_obj_attributes (bfd *ibfd, struct bfd_link_info *info)
3658
0
{
3659
0
  bfd *obfd;
3660
0
  obj_attribute *in_attr, *in_attrs;
3661
0
  obj_attribute *out_attr, *out_attrs;
3662
0
  bool ret;
3663
3664
0
  if (!_bfd_elf_ppc_merge_fp_attributes (ibfd, info))
3665
0
    return false;
3666
3667
0
  obfd = info->output_bfd;
3668
0
  in_attrs = elf_known_obj_attributes (ibfd)[OBJ_ATTR_GNU];
3669
0
  out_attrs = elf_known_obj_attributes (obfd)[OBJ_ATTR_GNU];
3670
3671
  /* Check for conflicting Tag_GNU_Power_ABI_Vector attributes and
3672
     merge non-conflicting ones.  */
3673
0
  in_attr = &in_attrs[Tag_GNU_Power_ABI_Vector];
3674
0
  out_attr = &out_attrs[Tag_GNU_Power_ABI_Vector];
3675
0
  ret = true;
3676
0
  if (in_attr->i != out_attr->i)
3677
0
    {
3678
0
      int in_vec = in_attr->i & 3;
3679
0
      int out_vec = out_attr->i & 3;
3680
0
      static bfd *last_vec;
3681
3682
0
      if (in_vec == 0)
3683
0
  ;
3684
0
      else if (out_vec == 0)
3685
0
  {
3686
0
    out_attr->type = ATTR_TYPE_FLAG_INT_VAL;
3687
0
    out_attr->i = in_vec;
3688
0
    last_vec = ibfd;
3689
0
  }
3690
      /* For now, allow generic to transition to AltiVec or SPE
3691
   without a warning.  If GCC marked files with their stack
3692
   alignment and used don't-care markings for files which are
3693
   not affected by the vector ABI, we could warn about this
3694
   case too.  */
3695
0
      else if (in_vec == 1)
3696
0
  ;
3697
0
      else if (out_vec == 1)
3698
0
  {
3699
0
    out_attr->type = ATTR_TYPE_FLAG_INT_VAL;
3700
0
    out_attr->i = in_vec;
3701
0
    last_vec = ibfd;
3702
0
  }
3703
0
      else if (out_vec < in_vec)
3704
0
  {
3705
0
    _bfd_error_handler
3706
      /* xgettext:c-format */
3707
0
      (_("%pB uses AltiVec vector ABI, %pB uses SPE vector ABI"),
3708
0
       last_vec, ibfd);
3709
0
    out_attr->type = ATTR_TYPE_FLAG_INT_VAL | ATTR_TYPE_FLAG_ERROR;
3710
0
    ret = false;
3711
0
  }
3712
0
      else if (out_vec > in_vec)
3713
0
  {
3714
0
    _bfd_error_handler
3715
      /* xgettext:c-format */
3716
0
      (_("%pB uses AltiVec vector ABI, %pB uses SPE vector ABI"),
3717
0
       ibfd, last_vec);
3718
0
    out_attr->type = ATTR_TYPE_FLAG_INT_VAL | ATTR_TYPE_FLAG_ERROR;
3719
0
    ret = false;
3720
0
  }
3721
0
    }
3722
3723
  /* Check for conflicting Tag_GNU_Power_ABI_Struct_Return attributes
3724
     and merge non-conflicting ones.  */
3725
0
  in_attr = &in_attrs[Tag_GNU_Power_ABI_Struct_Return];
3726
0
  out_attr = &out_attrs[Tag_GNU_Power_ABI_Struct_Return];
3727
0
  if (in_attr->i != out_attr->i)
3728
0
    {
3729
0
      int in_struct = in_attr->i & 3;
3730
0
      int out_struct = out_attr->i & 3;
3731
0
      static bfd *last_struct;
3732
3733
0
      if (in_struct == 0 || in_struct == 3)
3734
0
       ;
3735
0
      else if (out_struct == 0)
3736
0
  {
3737
0
    out_attr->type = ATTR_TYPE_FLAG_INT_VAL;
3738
0
    out_attr->i = in_struct;
3739
0
    last_struct = ibfd;
3740
0
  }
3741
0
      else if (out_struct < in_struct)
3742
0
  {
3743
0
    _bfd_error_handler
3744
      /* xgettext:c-format */
3745
0
      (_("%pB uses r3/r4 for small structure returns, "
3746
0
         "%pB uses memory"), last_struct, ibfd);
3747
0
    out_attr->type = ATTR_TYPE_FLAG_INT_VAL | ATTR_TYPE_FLAG_ERROR;
3748
0
    ret = false;
3749
0
  }
3750
0
      else if (out_struct > in_struct)
3751
0
  {
3752
0
    _bfd_error_handler
3753
      /* xgettext:c-format */
3754
0
      (_("%pB uses r3/r4 for small structure returns, "
3755
0
         "%pB uses memory"), ibfd, last_struct);
3756
0
    out_attr->type = ATTR_TYPE_FLAG_INT_VAL | ATTR_TYPE_FLAG_ERROR;
3757
0
    ret = false;
3758
0
  }
3759
0
    }
3760
0
  if (!ret)
3761
0
    {
3762
0
      bfd_set_error (bfd_error_bad_value);
3763
0
      return false;
3764
0
    }
3765
3766
  /* Merge Tag_compatibility attributes and any common GNU ones.  */
3767
0
  return _bfd_elf_merge_object_attributes (ibfd, info);
3768
0
}
3769
3770
/* Merge backend specific data from an object file to the output
3771
   object file when linking.  */
3772
3773
static bool
3774
ppc_elf_merge_private_bfd_data (bfd *ibfd, struct bfd_link_info *info)
3775
0
{
3776
0
  bfd *obfd = info->output_bfd;
3777
0
  flagword old_flags;
3778
0
  flagword new_flags;
3779
0
  bool error;
3780
3781
0
  if (!is_ppc_elf (ibfd) || !is_ppc_elf (obfd))
3782
0
    return true;
3783
3784
  /* Check if we have the same endianness.  */
3785
0
  if (! _bfd_generic_verify_endian_match (ibfd, info))
3786
0
    return false;
3787
3788
0
  if (!ppc_elf_merge_obj_attributes (ibfd, info))
3789
0
    return false;
3790
3791
0
  if ((ibfd->flags & DYNAMIC) != 0)
3792
0
    return true;
3793
3794
0
  new_flags = elf_elfheader (ibfd)->e_flags;
3795
0
  old_flags = elf_elfheader (obfd)->e_flags;
3796
0
  if (!elf_flags_init (obfd))
3797
0
    {
3798
      /* First call, no flags set.  */
3799
0
      elf_flags_init (obfd) = true;
3800
0
      elf_elfheader (obfd)->e_flags = new_flags;
3801
0
    }
3802
3803
  /* Compatible flags are ok.  */
3804
0
  else if (new_flags == old_flags)
3805
0
    ;
3806
3807
  /* Incompatible flags.  */
3808
0
  else
3809
0
    {
3810
      /* Warn about -mrelocatable mismatch.  Allow -mrelocatable-lib
3811
   to be linked with either.  */
3812
0
      error = false;
3813
0
      if ((new_flags & EF_PPC_RELOCATABLE) != 0
3814
0
    && (old_flags & (EF_PPC_RELOCATABLE | EF_PPC_RELOCATABLE_LIB)) == 0)
3815
0
  {
3816
0
    error = true;
3817
0
    _bfd_error_handler
3818
0
      (_("%pB: compiled with -mrelocatable and linked with "
3819
0
         "modules compiled normally"), ibfd);
3820
0
  }
3821
0
      else if ((new_flags & (EF_PPC_RELOCATABLE | EF_PPC_RELOCATABLE_LIB)) == 0
3822
0
         && (old_flags & EF_PPC_RELOCATABLE) != 0)
3823
0
  {
3824
0
    error = true;
3825
0
    _bfd_error_handler
3826
0
      (_("%pB: compiled normally and linked with "
3827
0
         "modules compiled with -mrelocatable"), ibfd);
3828
0
  }
3829
3830
      /* The output is -mrelocatable-lib iff both the input files are.  */
3831
0
      if (! (new_flags & EF_PPC_RELOCATABLE_LIB))
3832
0
  elf_elfheader (obfd)->e_flags &= ~EF_PPC_RELOCATABLE_LIB;
3833
3834
      /* The output is -mrelocatable iff it can't be -mrelocatable-lib,
3835
   but each input file is either -mrelocatable or -mrelocatable-lib.  */
3836
0
      if (! (elf_elfheader (obfd)->e_flags & EF_PPC_RELOCATABLE_LIB)
3837
0
    && (new_flags & (EF_PPC_RELOCATABLE_LIB | EF_PPC_RELOCATABLE))
3838
0
    && (old_flags & (EF_PPC_RELOCATABLE_LIB | EF_PPC_RELOCATABLE)))
3839
0
  elf_elfheader (obfd)->e_flags |= EF_PPC_RELOCATABLE;
3840
3841
      /* Do not warn about eabi vs. V.4 mismatch, just or in the bit if
3842
   any module uses it.  */
3843
0
      elf_elfheader (obfd)->e_flags |= (new_flags & EF_PPC_EMB);
3844
3845
0
      new_flags &= ~(EF_PPC_RELOCATABLE | EF_PPC_RELOCATABLE_LIB | EF_PPC_EMB);
3846
0
      old_flags &= ~(EF_PPC_RELOCATABLE | EF_PPC_RELOCATABLE_LIB | EF_PPC_EMB);
3847
3848
      /* Warn about any other mismatches.  */
3849
0
      if (new_flags != old_flags)
3850
0
  {
3851
0
    error = true;
3852
0
    _bfd_error_handler
3853
      /* xgettext:c-format */
3854
0
      (_("%pB: uses different e_flags (%#x) fields "
3855
0
         "than previous modules (%#x)"),
3856
0
       ibfd, new_flags, old_flags);
3857
0
  }
3858
3859
0
      if (error)
3860
0
  {
3861
0
    bfd_set_error (bfd_error_bad_value);
3862
0
    return false;
3863
0
  }
3864
0
    }
3865
3866
0
  return true;
3867
0
}
3868
3869
static bfd_reloc_status_type
3870
ppc_elf_vle_split16 (bfd *input_bfd,
3871
         asection *input_section,
3872
         unsigned long offset,
3873
         bfd_byte *loc,
3874
         bfd_vma value,
3875
         split16_format_type split16_format,
3876
         bool fixup)
3877
0
{
3878
0
  unsigned int insn, opcode;
3879
3880
0
  if (!offset_in_range (input_section, offset, 4))
3881
0
    return bfd_reloc_outofrange;
3882
0
  insn = bfd_get_32 (input_bfd, loc);
3883
0
  opcode = insn & E_OPCODE_MASK;
3884
0
  if (opcode == E_OR2I_INSN
3885
0
      || opcode == E_AND2I_DOT_INSN
3886
0
      || opcode == E_OR2IS_INSN
3887
0
      || opcode == E_LIS_INSN
3888
0
      || opcode == E_AND2IS_DOT_INSN)
3889
0
    {
3890
0
      if (split16_format != split16a_type)
3891
0
  {
3892
0
    if (fixup)
3893
0
      split16_format = split16a_type;
3894
0
    else
3895
0
      _bfd_error_handler
3896
        /* xgettext:c-format */
3897
0
        (_("%pB(%pA+0x%lx): expected 16A style relocation on 0x%08x insn"),
3898
0
         input_bfd, input_section, offset, opcode);
3899
0
  }
3900
0
    }
3901
0
  else if (opcode == E_ADD2I_DOT_INSN
3902
0
     || opcode == E_ADD2IS_INSN
3903
0
     || opcode == E_CMP16I_INSN
3904
0
     || opcode == E_MULL2I_INSN
3905
0
     || opcode == E_CMPL16I_INSN
3906
0
     || opcode == E_CMPH16I_INSN
3907
0
     || opcode == E_CMPHL16I_INSN)
3908
0
    {
3909
0
      if (split16_format != split16d_type)
3910
0
  {
3911
0
    if (fixup)
3912
0
      split16_format = split16d_type;
3913
0
    else
3914
0
      _bfd_error_handler
3915
        /* xgettext:c-format */
3916
0
        (_("%pB(%pA+0x%lx): expected 16D style relocation on 0x%08x insn"),
3917
0
         input_bfd, input_section, offset, opcode);
3918
0
  }
3919
0
    }
3920
0
  if (split16_format == split16a_type)
3921
0
    {
3922
0
      insn &= ~((0xf800 << 5) | 0x7ff);
3923
0
      insn |= (value & 0xf800) << 5;
3924
0
      if ((insn & E_LI_MASK) == E_LI_INSN)
3925
0
  {
3926
    /* Hack for e_li.  Extend sign.  */
3927
0
    insn &= ~(0xf0000 >> 5);
3928
0
    insn |= (-(value & 0x8000) & 0xf0000) >> 5;
3929
0
  }
3930
0
    }
3931
0
  else
3932
0
    {
3933
0
      insn &= ~((0xf800 << 10) | 0x7ff);
3934
0
      insn |= (value & 0xf800) << 10;
3935
0
    }
3936
0
  insn |= value & 0x7ff;
3937
0
  bfd_put_32 (input_bfd, insn, loc);
3938
0
  return bfd_reloc_ok;
3939
0
}
3940
3941
static void
3942
ppc_elf_vle_split20 (bfd *output_bfd, bfd_byte *loc, bfd_vma value)
3943
0
{
3944
0
  unsigned int insn;
3945
3946
0
  insn = bfd_get_32 (output_bfd, loc);
3947
  /* We have an li20 field, bits 17..20, 11..15, 21..31.  */
3948
  /* Top 4 bits of value to 17..20.  */
3949
0
  insn |= (value & 0xf0000) >> 5;
3950
  /* Next 5 bits of the value to 11..15.  */
3951
0
  insn |= (value & 0xf800) << 5;
3952
  /* And the final 11 bits of the value to bits 21 to 31.  */
3953
0
  insn |= value & 0x7ff;
3954
0
  bfd_put_32 (output_bfd, insn, loc);
3955
0
}
3956
3957

3958
/* Choose which PLT scheme to use, and set .plt flags appropriately.
3959
   Returns -1 on error, 0 for old PLT, 1 for new PLT.  */
3960
int
3961
ppc_elf_select_plt_layout (bfd *output_bfd ATTRIBUTE_UNUSED,
3962
         struct bfd_link_info *info)
3963
0
{
3964
0
  struct ppc_elf_link_hash_table *htab;
3965
0
  flagword flags;
3966
3967
0
  htab = ppc_elf_hash_table (info);
3968
3969
0
  if (htab->plt_type == PLT_UNSET)
3970
0
    {
3971
0
      struct elf_link_hash_entry *h;
3972
3973
0
      if (htab->params->plt_style == PLT_OLD)
3974
0
  htab->plt_type = PLT_OLD;
3975
0
      else if (bfd_link_pic (info)
3976
0
         && htab->elf.dynamic_sections_created
3977
0
         && (h = elf_link_hash_lookup (&htab->elf, "_mcount",
3978
0
               false, false, true)) != NULL
3979
0
         && (h->type == STT_FUNC
3980
0
       || h->needs_plt)
3981
0
         && h->ref_regular
3982
0
         && !(SYMBOL_CALLS_LOCAL (info, h)
3983
0
        || UNDEFWEAK_NO_DYNAMIC_RELOC (info, h)))
3984
0
  {
3985
    /* Profiling of shared libs (and pies) is not supported with
3986
       secure plt, because ppc32 does profiling before a
3987
       function prologue and a secure plt pic call stubs needs
3988
       r30 to be set up.  */
3989
0
    htab->plt_type = PLT_OLD;
3990
0
  }
3991
0
      else
3992
0
  {
3993
0
    bfd *ibfd;
3994
0
    enum ppc_elf_plt_type plt_type = htab->params->plt_style;
3995
3996
    /* Look through the reloc flags left by ppc_elf_check_relocs.
3997
       Use the old style bss plt if a file makes plt calls
3998
       without using the new relocs, and if ld isn't given
3999
       --secure-plt and we never see REL16 relocs.  */
4000
0
    if (plt_type == PLT_UNSET)
4001
0
      plt_type = PLT_OLD;
4002
0
    for (ibfd = info->input_bfds; ibfd; ibfd = ibfd->link.next)
4003
0
      if (is_ppc_elf (ibfd))
4004
0
        {
4005
0
    if (ppc_elf_tdata (ibfd)->has_rel16)
4006
0
      plt_type = PLT_NEW;
4007
0
    else if (ppc_elf_tdata (ibfd)->makes_plt_call)
4008
0
      {
4009
0
        plt_type = PLT_OLD;
4010
0
        htab->old_bfd = ibfd;
4011
0
        break;
4012
0
      }
4013
0
        }
4014
0
    htab->plt_type = plt_type;
4015
0
  }
4016
0
    }
4017
0
  if (htab->plt_type == PLT_OLD)
4018
0
    {
4019
0
      if (!info->user_warn_rwx_segments)
4020
0
  info->no_warn_rwx_segments = 1;
4021
0
      if (htab->params->plt_style == PLT_NEW
4022
0
    || (htab->params->plt_style != PLT_OLD
4023
0
        && !info->no_warn_rwx_segments))
4024
0
  {
4025
0
    if (htab->old_bfd != NULL)
4026
0
      _bfd_error_handler (_("bss-plt forced due to %pB"), htab->old_bfd);
4027
0
    else
4028
0
      _bfd_error_handler (_("bss-plt forced by profiling"));
4029
0
  }
4030
0
    }
4031
4032
0
  BFD_ASSERT (htab->plt_type != PLT_VXWORKS);
4033
4034
0
  if (htab->plt_type == PLT_NEW)
4035
0
    {
4036
0
      flags = (SEC_ALLOC | SEC_LOAD | SEC_HAS_CONTENTS
4037
0
         | SEC_IN_MEMORY | SEC_LINKER_CREATED);
4038
4039
      /* The new PLT is a loaded section.  */
4040
0
      if (htab->elf.splt != NULL
4041
0
    && !bfd_set_section_flags (htab->elf.splt, flags))
4042
0
  return -1;
4043
4044
      /* The new GOT is not executable.  */
4045
0
      if (htab->elf.sgot != NULL
4046
0
    && !bfd_set_section_flags (htab->elf.sgot, flags))
4047
0
  return -1;
4048
0
    }
4049
0
  else
4050
0
    {
4051
      /* Stop an unused .glink section from affecting .text alignment.  */
4052
0
      if (htab->glink != NULL
4053
0
    && !bfd_set_section_alignment (htab->glink, 0))
4054
0
  return -1;
4055
0
    }
4056
0
  return htab->plt_type == PLT_NEW;
4057
0
}
4058

4059
/* Return the section that should be marked against GC for a given
4060
   relocation.  */
4061
4062
static asection *
4063
ppc_elf_gc_mark_hook (asection *sec,
4064
          struct bfd_link_info *info,
4065
          Elf_Internal_Rela *rel,
4066
          struct elf_link_hash_entry *h,
4067
          Elf_Internal_Sym *sym)
4068
0
{
4069
0
  if (h != NULL)
4070
0
    switch (ELF32_R_TYPE (rel->r_info))
4071
0
      {
4072
0
      case R_PPC_GNU_VTINHERIT:
4073
0
      case R_PPC_GNU_VTENTRY:
4074
0
  return NULL;
4075
0
      }
4076
4077
0
  return _bfd_elf_gc_mark_hook (sec, info, rel, h, sym);
4078
0
}
4079
4080
static bool
4081
get_sym_h (struct elf_link_hash_entry **hp,
4082
     Elf_Internal_Sym **symp,
4083
     asection **symsecp,
4084
     unsigned char **tls_maskp,
4085
     Elf_Internal_Sym **locsymsp,
4086
     unsigned long r_symndx,
4087
     bfd *ibfd)
4088
0
{
4089
0
  Elf_Internal_Shdr *symtab_hdr = &elf_symtab_hdr (ibfd);
4090
4091
0
  if (r_symndx >= symtab_hdr->sh_info)
4092
0
    {
4093
0
      struct elf_link_hash_entry **sym_hashes = elf_sym_hashes (ibfd);
4094
0
      struct elf_link_hash_entry *h;
4095
4096
0
      h = sym_hashes[r_symndx - symtab_hdr->sh_info];
4097
0
      while (h->root.type == bfd_link_hash_indirect
4098
0
       || h->root.type == bfd_link_hash_warning)
4099
0
  h = (struct elf_link_hash_entry *) h->root.u.i.link;
4100
4101
0
      if (hp != NULL)
4102
0
  *hp = h;
4103
4104
0
      if (symp != NULL)
4105
0
  *symp = NULL;
4106
4107
0
      if (symsecp != NULL)
4108
0
  {
4109
0
    asection *symsec = NULL;
4110
0
    if (h->root.type == bfd_link_hash_defined
4111
0
        || h->root.type == bfd_link_hash_defweak)
4112
0
      symsec = h->root.u.def.section;
4113
0
    *symsecp = symsec;
4114
0
  }
4115
4116
0
      if (tls_maskp != NULL)
4117
0
  *tls_maskp = &ppc_elf_hash_entry (h)->tls_mask;
4118
0
    }
4119
0
  else
4120
0
    {
4121
0
      Elf_Internal_Sym *sym;
4122
0
      Elf_Internal_Sym *locsyms = *locsymsp;
4123
4124
0
      if (locsyms == NULL)
4125
0
  {
4126
0
    locsyms = (Elf_Internal_Sym *) symtab_hdr->contents;
4127
0
    if (locsyms == NULL)
4128
0
      locsyms = bfd_elf_get_elf_syms (ibfd, symtab_hdr,
4129
0
              symtab_hdr->sh_info,
4130
0
              0, NULL, NULL, NULL);
4131
0
    if (locsyms == NULL)
4132
0
      return false;
4133
0
    *locsymsp = locsyms;
4134
0
  }
4135
0
      sym = locsyms + r_symndx;
4136
4137
0
      if (hp != NULL)
4138
0
  *hp = NULL;
4139
4140
0
      if (symp != NULL)
4141
0
  *symp = sym;
4142
4143
0
      if (symsecp != NULL)
4144
0
  *symsecp = bfd_section_from_elf_index (ibfd, sym->st_shndx);
4145
4146
0
      if (tls_maskp != NULL)
4147
0
  {
4148
0
    bfd_signed_vma *local_got;
4149
0
    unsigned char *tls_mask;
4150
4151
0
    tls_mask = NULL;
4152
0
    local_got = elf_local_got_refcounts (ibfd);
4153
0
    if (local_got != NULL)
4154
0
      {
4155
0
        struct plt_entry **local_plt = (struct plt_entry **)
4156
0
    (local_got + symtab_hdr->sh_info);
4157
0
        unsigned char *lgot_masks = (unsigned char *)
4158
0
    (local_plt + symtab_hdr->sh_info);
4159
0
        tls_mask = &lgot_masks[r_symndx];
4160
0
      }
4161
0
    *tls_maskp = tls_mask;
4162
0
  }
4163
0
    }
4164
0
  return true;
4165
0
}
4166

4167
/* Analyze inline PLT call relocations to see whether calls to locally
4168
   defined functions can be converted to direct calls.  */
4169
4170
bool
4171
ppc_elf_inline_plt (struct bfd_link_info *info)
4172
0
{
4173
0
  struct ppc_elf_link_hash_table *htab;
4174
0
  bfd *ibfd;
4175
0
  asection *sec;
4176
0
  bfd_vma low_vma, high_vma, limit;
4177
4178
0
  htab = ppc_elf_hash_table (info);
4179
0
  if (htab == NULL)
4180
0
    return false;
4181
4182
  /* A bl insn can reach -0x2000000 to 0x1fffffc.  The limit is
4183
     reduced somewhat to cater for possible stubs that might be added
4184
     between the call and its destination.  */
4185
0
  limit = 0x1e00000;
4186
0
  low_vma = -1;
4187
0
  high_vma = 0;
4188
0
  for (sec = info->output_bfd->sections; sec != NULL; sec = sec->next)
4189
0
    if ((sec->flags & (SEC_ALLOC | SEC_CODE)) == (SEC_ALLOC | SEC_CODE))
4190
0
      {
4191
0
  if (low_vma > sec->vma)
4192
0
    low_vma = sec->vma;
4193
0
  if (high_vma < sec->vma + sec->size)
4194
0
    high_vma = sec->vma + sec->size;
4195
0
      }
4196
4197
  /* If a "bl" can reach anywhere in local code sections, then we can
4198
     convert all inline PLT sequences to direct calls when the symbol
4199
     is local.  */
4200
0
  if (high_vma - low_vma < limit)
4201
0
    {
4202
0
      htab->can_convert_all_inline_plt = 1;
4203
0
      return true;
4204
0
    }
4205
4206
  /* Otherwise, go looking through relocs for cases where a direct
4207
     call won't reach.  Mark the symbol on any such reloc to disable
4208
     the optimization and keep the PLT entry as it seems likely that
4209
     this will be better than creating trampolines.  Note that this
4210
     will disable the optimization for all inline PLT calls to a
4211
     particular symbol, not just those that won't reach.  The
4212
     difficulty in doing a more precise optimization is that the
4213
     linker needs to make a decision depending on whether a
4214
     particular R_PPC_PLTCALL insn can be turned into a direct
4215
     call, for each of the R_PPC_PLTSEQ and R_PPC_PLT16* insns in
4216
     the sequence, and there is nothing that ties those relocs
4217
     together except their symbol.  */
4218
4219
0
  for (ibfd = info->input_bfds; ibfd != NULL; ibfd = ibfd->link.next)
4220
0
    {
4221
0
      Elf_Internal_Shdr *symtab_hdr;
4222
0
      Elf_Internal_Sym *local_syms;
4223
4224
0
      if (!is_ppc_elf (ibfd))
4225
0
  continue;
4226
4227
0
      local_syms = NULL;
4228
0
      symtab_hdr = &elf_symtab_hdr (ibfd);
4229
4230
0
      for (sec = ibfd->sections; sec != NULL; sec = sec->next)
4231
0
  if (sec->has_pltcall
4232
0
      && !bfd_is_abs_section (sec->output_section))
4233
0
    {
4234
0
      Elf_Internal_Rela *relstart, *rel, *relend;
4235
4236
      /* Read the relocations.  */
4237
0
      relstart = _bfd_elf_link_read_relocs (ibfd, sec, NULL, NULL,
4238
0
              info->keep_memory);
4239
0
      if (relstart == NULL)
4240
0
        return false;
4241
4242
0
      relend = relstart + sec->reloc_count;
4243
0
      for (rel = relstart; rel < relend; rel++)
4244
0
        {
4245
0
    enum elf_ppc_reloc_type r_type;
4246
0
    unsigned long r_symndx;
4247
0
    asection *sym_sec;
4248
0
    struct elf_link_hash_entry *h;
4249
0
    Elf_Internal_Sym *sym;
4250
0
    unsigned char *tls_maskp;
4251
4252
0
    r_type = ELF32_R_TYPE (rel->r_info);
4253
0
    if (r_type != R_PPC_PLTCALL)
4254
0
      continue;
4255
4256
0
    r_symndx = ELF32_R_SYM (rel->r_info);
4257
0
    if (!get_sym_h (&h, &sym, &sym_sec, &tls_maskp, &local_syms,
4258
0
        r_symndx, ibfd))
4259
0
      {
4260
0
        if (elf_section_data (sec)->relocs != relstart)
4261
0
          free (relstart);
4262
0
        if (symtab_hdr->contents != (unsigned char *) local_syms)
4263
0
          free (local_syms);
4264
0
        return false;
4265
0
      }
4266
4267
0
    if (sym_sec != NULL && sym_sec->output_section != NULL)
4268
0
      {
4269
0
        bfd_vma from, to;
4270
0
        if (h != NULL)
4271
0
          to = h->root.u.def.value;
4272
0
        else
4273
0
          to = sym->st_value;
4274
0
        to += (rel->r_addend
4275
0
         + sym_sec->output_offset
4276
0
         + sym_sec->output_section->vma);
4277
0
        from = (rel->r_offset
4278
0
          + sec->output_offset
4279
0
          + sec->output_section->vma);
4280
0
        if (to - from + limit < 2 * limit)
4281
0
          *tls_maskp &= ~PLT_KEEP;
4282
0
      }
4283
0
        }
4284
0
      if (elf_section_data (sec)->relocs != relstart)
4285
0
        free (relstart);
4286
0
    }
4287
4288
0
      if (local_syms != NULL
4289
0
    && symtab_hdr->contents != (unsigned char *) local_syms)
4290
0
  {
4291
0
    if (!info->keep_memory)
4292
0
      free (local_syms);
4293
0
    else
4294
0
      symtab_hdr->contents = (unsigned char *) local_syms;
4295
0
  }
4296
0
    }
4297
4298
0
  return true;
4299
0
}
4300
4301
/* Set plt output section type, htab->tls_get_addr, and call the
4302
   generic ELF tls_setup function.  */
4303
4304
asection *
4305
ppc_elf_tls_setup (bfd *obfd, struct bfd_link_info *info)
4306
0
{
4307
0
  struct ppc_elf_link_hash_table *htab;
4308
4309
0
  htab = ppc_elf_hash_table (info);
4310
0
  htab->tls_get_addr = elf_link_hash_lookup (&htab->elf, "__tls_get_addr",
4311
0
               false, false, true);
4312
0
  if (htab->plt_type != PLT_NEW)
4313
0
    htab->params->no_tls_get_addr_opt = true;
4314
4315
0
  if (!htab->params->no_tls_get_addr_opt)
4316
0
    {
4317
0
      struct elf_link_hash_entry *opt, *tga;
4318
0
      opt = elf_link_hash_lookup (&htab->elf, "__tls_get_addr_opt",
4319
0
          false, false, true);
4320
0
      if (opt != NULL
4321
0
    && (opt->root.type == bfd_link_hash_defined
4322
0
        || opt->root.type == bfd_link_hash_defweak))
4323
0
  {
4324
    /* If glibc supports an optimized __tls_get_addr call stub,
4325
       signalled by the presence of __tls_get_addr_opt, and we'll
4326
       be calling __tls_get_addr via a plt call stub, then
4327
       make __tls_get_addr point to __tls_get_addr_opt.  */
4328
0
    tga = htab->tls_get_addr;
4329
0
    if (htab->elf.dynamic_sections_created
4330
0
        && tga != NULL
4331
0
        && (tga->type == STT_FUNC
4332
0
      || tga->needs_plt)
4333
0
        && !(SYMBOL_CALLS_LOCAL (info, tga)
4334
0
       || UNDEFWEAK_NO_DYNAMIC_RELOC (info, tga)))
4335
0
      {
4336
0
        struct plt_entry *ent;
4337
0
        for (ent = tga->plt.plist; ent != NULL; ent = ent->next)
4338
0
    if (ent->plt.refcount > 0)
4339
0
      break;
4340
0
        if (ent != NULL)
4341
0
    {
4342
0
      tga->root.type = bfd_link_hash_indirect;
4343
0
      tga->root.u.i.link = &opt->root;
4344
0
      ppc_elf_copy_indirect_symbol (info, opt, tga);
4345
0
      opt->mark = 1;
4346
0
      if (opt->dynindx != -1)
4347
0
        {
4348
          /* Use __tls_get_addr_opt in dynamic relocations.  */
4349
0
          opt->dynindx = -1;
4350
0
          _bfd_elf_strtab_delref (elf_hash_table (info)->dynstr,
4351
0
                opt->dynstr_index);
4352
0
          if (!bfd_elf_link_record_dynamic_symbol (info, opt))
4353
0
      return NULL;
4354
0
        }
4355
0
      htab->tls_get_addr = opt;
4356
0
    }
4357
0
      }
4358
0
  }
4359
0
      else
4360
0
  htab->params->no_tls_get_addr_opt = true;
4361
0
    }
4362
0
  if (htab->plt_type == PLT_NEW
4363
0
      && htab->elf.splt != NULL
4364
0
      && htab->elf.splt->output_section != NULL)
4365
0
    {
4366
0
      elf_section_type (htab->elf.splt->output_section) = SHT_PROGBITS;
4367
0
      elf_section_flags (htab->elf.splt->output_section) = SHF_ALLOC + SHF_WRITE;
4368
0
    }
4369
4370
0
  return _bfd_elf_tls_setup (obfd, info);
4371
0
}
4372
4373
/* Return TRUE iff REL is a branch reloc with a global symbol matching
4374
   HASH.  */
4375
4376
static bool
4377
branch_reloc_hash_match (const bfd *ibfd,
4378
       const Elf_Internal_Rela *rel,
4379
       const struct elf_link_hash_entry *hash)
4380
0
{
4381
0
  Elf_Internal_Shdr *symtab_hdr = &elf_symtab_hdr (ibfd);
4382
0
  enum elf_ppc_reloc_type r_type = ELF32_R_TYPE (rel->r_info);
4383
0
  unsigned int r_symndx = ELF32_R_SYM (rel->r_info);
4384
4385
0
  if (r_symndx >= symtab_hdr->sh_info && is_branch_reloc (r_type))
4386
0
    {
4387
0
      struct elf_link_hash_entry **sym_hashes = elf_sym_hashes (ibfd);
4388
0
      struct elf_link_hash_entry *h;
4389
4390
0
      h = sym_hashes[r_symndx - symtab_hdr->sh_info];
4391
0
      while (h->root.type == bfd_link_hash_indirect
4392
0
       || h->root.type == bfd_link_hash_warning)
4393
0
  h = (struct elf_link_hash_entry *) h->root.u.i.link;
4394
0
      if (h == hash)
4395
0
  return true;
4396
0
    }
4397
0
  return false;
4398
0
}
4399
4400
/* Run through all the TLS relocs looking for optimization
4401
   opportunities.  */
4402
4403
bool
4404
ppc_elf_tls_optimize (bfd *obfd ATTRIBUTE_UNUSED,
4405
          struct bfd_link_info *info)
4406
0
{
4407
0
  bfd *ibfd;
4408
0
  asection *sec;
4409
0
  struct ppc_elf_link_hash_table *htab;
4410
0
  int pass;
4411
4412
0
  if (!bfd_link_executable (info))
4413
0
    return true;
4414
4415
0
  htab = ppc_elf_hash_table (info);
4416
0
  if (htab == NULL)
4417
0
    return false;
4418
4419
0
  htab->do_tls_opt = 1;
4420
4421
  /* Make two passes through the relocs.  First time check that tls
4422
     relocs involved in setting up a tls_get_addr call are indeed
4423
     followed by such a call.  If they are not, don't do any tls
4424
     optimization.  On the second pass twiddle tls_mask flags to
4425
     notify relocate_section that optimization can be done, and
4426
     adjust got and plt refcounts.  */
4427
0
  for (pass = 0; pass < 2; ++pass)
4428
0
    for (ibfd = info->input_bfds; ibfd != NULL; ibfd = ibfd->link.next)
4429
0
      {
4430
0
  Elf_Internal_Shdr *symtab_hdr = &elf_symtab_hdr (ibfd);
4431
0
  asection *got2 = bfd_get_section_by_name (ibfd, ".got2");
4432
4433
0
  for (sec = ibfd->sections; sec != NULL; sec = sec->next)
4434
0
    if (sec->has_tls_reloc && !bfd_is_abs_section (sec->output_section))
4435
0
      {
4436
0
        Elf_Internal_Rela *relstart, *rel, *relend;
4437
0
        int expecting_tls_get_addr = 0;
4438
4439
        /* Read the relocations.  */
4440
0
        relstart = _bfd_elf_link_read_relocs (ibfd, sec, NULL, NULL,
4441
0
                info->keep_memory);
4442
0
        if (relstart == NULL)
4443
0
    return false;
4444
4445
0
        relend = relstart + sec->reloc_count;
4446
0
        for (rel = relstart; rel < relend; rel++)
4447
0
    {
4448
0
      enum elf_ppc_reloc_type r_type;
4449
0
      unsigned long r_symndx;
4450
0
      struct elf_link_hash_entry *h = NULL;
4451
0
      unsigned char *tls_mask;
4452
0
      unsigned char tls_set, tls_clear;
4453
0
      bool is_local;
4454
0
      bfd_signed_vma *got_count;
4455
4456
0
      r_symndx = ELF32_R_SYM (rel->r_info);
4457
0
      if (r_symndx >= symtab_hdr->sh_info)
4458
0
        {
4459
0
          struct elf_link_hash_entry **sym_hashes;
4460
4461
0
          sym_hashes = elf_sym_hashes (ibfd);
4462
0
          h = sym_hashes[r_symndx - symtab_hdr->sh_info];
4463
0
          while (h->root.type == bfd_link_hash_indirect
4464
0
           || h->root.type == bfd_link_hash_warning)
4465
0
      h = (struct elf_link_hash_entry *) h->root.u.i.link;
4466
0
        }
4467
4468
0
      is_local = SYMBOL_REFERENCES_LOCAL (info, h);
4469
0
      r_type = ELF32_R_TYPE (rel->r_info);
4470
      /* If this section has old-style __tls_get_addr calls
4471
         without marker relocs, then check that each
4472
         __tls_get_addr call reloc is preceded by a reloc
4473
         that conceivably belongs to the __tls_get_addr arg
4474
         setup insn.  If we don't find matching arg setup
4475
         relocs, don't do any tls optimization.  */
4476
0
      if (pass == 0
4477
0
          && sec->nomark_tls_get_addr
4478
0
          && h != NULL
4479
0
          && h == htab->tls_get_addr
4480
0
          && !expecting_tls_get_addr
4481
0
          && is_branch_reloc (r_type))
4482
0
        {
4483
0
          info->callbacks->minfo ("%H __tls_get_addr lost arg, "
4484
0
                "TLS optimization disabled\n",
4485
0
                ibfd, sec, rel->r_offset);
4486
0
          if (elf_section_data (sec)->relocs != relstart)
4487
0
      free (relstart);
4488
0
          return true;
4489
0
        }
4490
4491
0
      expecting_tls_get_addr = 0;
4492
0
      switch (r_type)
4493
0
        {
4494
0
        case R_PPC_GOT_TLSLD16:
4495
0
        case R_PPC_GOT_TLSLD16_LO:
4496
0
          expecting_tls_get_addr = 1;
4497
          /* Fall through.  */
4498
4499
0
        case R_PPC_GOT_TLSLD16_HI:
4500
0
        case R_PPC_GOT_TLSLD16_HA:
4501
          /* These relocs should never be against a symbol
4502
       defined in a shared lib.  Leave them alone if
4503
       that turns out to be the case.  */
4504
0
          if (!is_local)
4505
0
      continue;
4506
4507
          /* LD -> LE */
4508
0
          tls_set = 0;
4509
0
          tls_clear = TLS_LD;
4510
0
          break;
4511
4512
0
        case R_PPC_GOT_TLSGD16:
4513
0
        case R_PPC_GOT_TLSGD16_LO:
4514
0
          expecting_tls_get_addr = 1;
4515
          /* Fall through.  */
4516
4517
0
        case R_PPC_GOT_TLSGD16_HI:
4518
0
        case R_PPC_GOT_TLSGD16_HA:
4519
0
          if (is_local)
4520
      /* GD -> LE */
4521
0
      tls_set = 0;
4522
0
          else
4523
      /* GD -> IE */
4524
0
      tls_set = TLS_TLS | TLS_GDIE;
4525
0
          tls_clear = TLS_GD;
4526
0
          break;
4527
4528
0
        case R_PPC_GOT_TPREL16:
4529
0
        case R_PPC_GOT_TPREL16_LO:
4530
0
        case R_PPC_GOT_TPREL16_HI:
4531
0
        case R_PPC_GOT_TPREL16_HA:
4532
0
          if (is_local)
4533
0
      {
4534
        /* IE -> LE */
4535
0
        tls_set = 0;
4536
0
        tls_clear = TLS_TPREL;
4537
0
        break;
4538
0
      }
4539
0
          else
4540
0
      continue;
4541
4542
0
        case R_PPC_TLSLD:
4543
0
          if (!is_local)
4544
0
      continue;
4545
          /* Fall through.  */
4546
0
        case R_PPC_TLSGD:
4547
0
          if (rel + 1 < relend
4548
0
        && is_plt_seq_reloc (ELF32_R_TYPE (rel[1].r_info)))
4549
0
      {
4550
0
        if (pass != 0
4551
0
            && ELF32_R_TYPE (rel[1].r_info) != R_PPC_PLTSEQ)
4552
0
          {
4553
0
            r_type = ELF32_R_TYPE (rel[1].r_info);
4554
0
            r_symndx = ELF32_R_SYM (rel[1].r_info);
4555
0
            if (r_symndx >= symtab_hdr->sh_info)
4556
0
        {
4557
0
          struct elf_link_hash_entry **sym_hashes;
4558
4559
0
          sym_hashes = elf_sym_hashes (ibfd);
4560
0
          h = sym_hashes[r_symndx - symtab_hdr->sh_info];
4561
0
          while (h->root.type == bfd_link_hash_indirect
4562
0
           || h->root.type == bfd_link_hash_warning)
4563
0
            h = (struct elf_link_hash_entry *) h->root.u.i.link;
4564
0
          if (h != NULL)
4565
0
            {
4566
0
              struct plt_entry *ent = NULL;
4567
0
              bfd_vma addend = 0;
4568
4569
0
              if (bfd_link_pic (info))
4570
0
          addend = rel->r_addend;
4571
0
              ent = find_plt_ent (&h->plt.plist,
4572
0
                got2, addend);
4573
0
              if (ent != NULL
4574
0
            && ent->plt.refcount > 0)
4575
0
          ent->plt.refcount -= 1;
4576
0
            }
4577
0
        }
4578
0
          }
4579
0
        continue;
4580
0
      }
4581
0
          expecting_tls_get_addr = 2;
4582
0
          tls_set = 0;
4583
0
          tls_clear = 0;
4584
0
          break;
4585
4586
0
        case R_PPC_TPREL16_HA:
4587
0
          if (pass == 0)
4588
0
      {
4589
0
        unsigned char buf[4];
4590
0
        unsigned int insn;
4591
0
        bfd_vma off = rel->r_offset & ~3;
4592
0
        if (!bfd_get_section_contents (ibfd, sec, buf,
4593
0
               off, 4))
4594
0
          {
4595
0
            if (elf_section_data (sec)->relocs != relstart)
4596
0
        free (relstart);
4597
0
            return false;
4598
0
          }
4599
0
        insn = bfd_get_32 (ibfd, buf);
4600
        /* addis rt,2,imm */
4601
0
        if ((insn & ((0x3fu << 26) | 0x1f << 16))
4602
0
            != ((15u << 26) | (2 << 16)))
4603
0
          {
4604
            /* xgettext:c-format */
4605
0
            info->callbacks->minfo
4606
0
        (_("%H: warning: %s unexpected insn %#x.\n"),
4607
0
         ibfd, sec, off, "R_PPC_TPREL16_HA", insn);
4608
0
            htab->do_tls_opt = 0;
4609
0
          }
4610
0
      }
4611
0
          continue;
4612
4613
0
        case R_PPC_TPREL16_HI:
4614
0
          htab->do_tls_opt = 0;
4615
0
          continue;
4616
4617
0
        default:
4618
0
          continue;
4619
0
        }
4620
4621
0
      if (pass == 0)
4622
0
        {
4623
0
          if (!expecting_tls_get_addr
4624
0
        || !sec->nomark_tls_get_addr)
4625
0
      continue;
4626
4627
0
          if (rel + 1 < relend
4628
0
        && branch_reloc_hash_match (ibfd, rel + 1,
4629
0
                  htab->tls_get_addr))
4630
0
      continue;
4631
4632
          /* Uh oh, we didn't find the expected call.  We
4633
       could just mark this symbol to exclude it
4634
       from tls optimization but it's safer to skip
4635
       the entire optimization.  */
4636
0
          info->callbacks->minfo (_("%H arg lost __tls_get_addr, "
4637
0
            "TLS optimization disabled\n"),
4638
0
                ibfd, sec, rel->r_offset);
4639
0
          if (elf_section_data (sec)->relocs != relstart)
4640
0
      free (relstart);
4641
0
          return true;
4642
0
        }
4643
4644
0
      if (h != NULL)
4645
0
        {
4646
0
          tls_mask = &ppc_elf_hash_entry (h)->tls_mask;
4647
0
          got_count = &h->got.refcount;
4648
0
        }
4649
0
      else
4650
0
        {
4651
0
          bfd_signed_vma *lgot_refs;
4652
0
          struct plt_entry **local_plt;
4653
0
          unsigned char *lgot_masks;
4654
4655
0
          lgot_refs = elf_local_got_refcounts (ibfd);
4656
0
          if (lgot_refs == NULL)
4657
0
      abort ();
4658
0
          local_plt = (struct plt_entry **)
4659
0
      (lgot_refs + symtab_hdr->sh_info);
4660
0
          lgot_masks = (unsigned char *)
4661
0
      (local_plt + symtab_hdr->sh_info);
4662
0
          tls_mask = &lgot_masks[r_symndx];
4663
0
          got_count = &lgot_refs[r_symndx];
4664
0
        }
4665
4666
      /* If we don't have old-style __tls_get_addr calls
4667
         without TLSGD/TLSLD marker relocs, and we haven't
4668
         found a new-style __tls_get_addr call with a
4669
         marker for this symbol, then we either have a
4670
         broken object file or an -mlongcall style
4671
         indirect call to __tls_get_addr without a marker.
4672
         Disable optimization in this case.  */
4673
0
      if ((tls_clear & (TLS_GD | TLS_LD)) != 0
4674
0
          && !sec->nomark_tls_get_addr
4675
0
          && ((*tls_mask & (TLS_TLS | TLS_MARK))
4676
0
        != (TLS_TLS | TLS_MARK)))
4677
0
        continue;
4678
4679
0
      if (expecting_tls_get_addr == 1 + !sec->nomark_tls_get_addr)
4680
0
        {
4681
0
          struct plt_entry *ent;
4682
0
          bfd_vma addend = 0;
4683
4684
0
          if (bfd_link_pic (info)
4685
0
        && (ELF32_R_TYPE (rel[1].r_info) == R_PPC_PLTREL24
4686
0
            || ELF32_R_TYPE (rel[1].r_info) == R_PPC_PLTCALL))
4687
0
      addend = rel[1].r_addend;
4688
0
          ent = find_plt_ent (&htab->tls_get_addr->plt.plist,
4689
0
            got2, addend);
4690
0
          if (ent != NULL && ent->plt.refcount > 0)
4691
0
      ent->plt.refcount -= 1;
4692
0
        }
4693
0
      if (tls_clear == 0)
4694
0
        continue;
4695
4696
0
      if (tls_set == 0)
4697
0
        {
4698
          /* We managed to get rid of a got entry.  */
4699
0
          if (*got_count > 0)
4700
0
      *got_count -= 1;
4701
0
        }
4702
4703
0
      *tls_mask |= tls_set;
4704
0
      *tls_mask &= ~tls_clear;
4705
0
    }
4706
4707
0
        if (elf_section_data (sec)->relocs != relstart)
4708
0
    free (relstart);
4709
0
      }
4710
0
      }
4711
0
  return true;
4712
0
}
4713

4714
/* Return true if we have dynamic relocs against H or any of its weak
4715
   aliases, that apply to read-only sections.  Cannot be used after
4716
   size_dynamic_sections.  */
4717
4718
static bool
4719
alias_readonly_dynrelocs (struct elf_link_hash_entry *h)
4720
0
{
4721
0
  struct ppc_elf_link_hash_entry *eh = ppc_elf_hash_entry (h);
4722
0
  do
4723
0
    {
4724
0
      if (_bfd_elf_readonly_dynrelocs (&eh->elf))
4725
0
  return true;
4726
0
      eh = ppc_elf_hash_entry (eh->elf.u.alias);
4727
0
    } while (eh != NULL && &eh->elf != h);
4728
4729
0
  return false;
4730
0
}
4731
4732
/* Return whether H has pc-relative dynamic relocs.  */
4733
4734
static bool
4735
pc_dynrelocs (struct elf_link_hash_entry *h)
4736
0
{
4737
0
  struct elf_dyn_relocs *p;
4738
4739
0
  for (p = h->dyn_relocs; p != NULL; p = p->next)
4740
0
    if (p->pc_count != 0)
4741
0
      return true;
4742
0
  return false;
4743
0
}
4744
4745
/* Adjust a symbol defined by a dynamic object and referenced by a
4746
   regular object.  The current definition is in some section of the
4747
   dynamic object, but we're not including those sections.  We have to
4748
   change the definition to something the rest of the link can
4749
   understand.  */
4750
4751
static bool
4752
ppc_elf_adjust_dynamic_symbol (struct bfd_link_info *info,
4753
             struct elf_link_hash_entry *h)
4754
0
{
4755
0
  struct ppc_elf_link_hash_table *htab;
4756
0
  asection *s;
4757
4758
#ifdef DEBUG
4759
  fprintf (stderr, "ppc_elf_adjust_dynamic_symbol called for %s\n",
4760
     h->root.root.string);
4761
#endif
4762
4763
  /* Make sure we know what is going on here.  */
4764
0
  htab = ppc_elf_hash_table (info);
4765
0
  BFD_ASSERT (htab->elf.dynobj != NULL
4766
0
        && (h->needs_plt
4767
0
      || h->type == STT_GNU_IFUNC
4768
0
      || h->is_weakalias
4769
0
      || (h->def_dynamic
4770
0
          && h->ref_regular
4771
0
          && !h->def_regular)));
4772
4773
  /* Deal with function syms.  */
4774
0
  if (h->type == STT_FUNC
4775
0
      || h->type == STT_GNU_IFUNC
4776
0
      || h->needs_plt)
4777
0
    {
4778
0
      bool local = (SYMBOL_CALLS_LOCAL (info, h)
4779
0
         || UNDEFWEAK_NO_DYNAMIC_RELOC (info, h));
4780
      /* Discard dyn_relocs when non-pic if we've decided that a
4781
   function symbol is local.  */
4782
0
      if (!bfd_link_pic (info) && local)
4783
0
  h->dyn_relocs = NULL;
4784
4785
      /* Clear procedure linkage table information for any symbol that
4786
   won't need a .plt entry.  */
4787
0
      struct plt_entry *ent;
4788
0
      for (ent = h->plt.plist; ent != NULL; ent = ent->next)
4789
0
  if (ent->plt.refcount > 0)
4790
0
    break;
4791
0
      if (ent == NULL
4792
0
    || (h->type != STT_GNU_IFUNC
4793
0
        && local
4794
0
        && (htab->can_convert_all_inline_plt
4795
0
      || (ppc_elf_hash_entry (h)->tls_mask
4796
0
          & (TLS_TLS | PLT_KEEP)) != PLT_KEEP)))
4797
0
  {
4798
    /* A PLT entry is not required/allowed when:
4799
4800
       1. We are not using ld.so; because then the PLT entry
4801
       can't be set up, so we can't use one.  In this case,
4802
       ppc_elf_adjust_dynamic_symbol won't even be called.
4803
4804
       2. GC has rendered the entry unused.
4805
4806
       3. We know for certain that a call to this symbol
4807
       will go to this object, or will remain undefined.  */
4808
0
    h->plt.plist = NULL;
4809
0
    h->needs_plt = 0;
4810
0
    h->pointer_equality_needed = 0;
4811
0
  }
4812
0
      else
4813
0
  {
4814
    /* Taking a function's address in a read/write section
4815
       doesn't require us to define the function symbol in the
4816
       executable on a plt call stub.  A dynamic reloc can
4817
       be used instead, giving better runtime performance.
4818
       (Calls via that function pointer don't need to bounce
4819
       through the plt call stub.)  Similarly, use a dynamic
4820
       reloc for a weak reference when possible, allowing the
4821
       resolution of the symbol to be set at load time rather
4822
       than link time.  */
4823
0
    if ((h->pointer_equality_needed
4824
0
         || (h->non_got_ref
4825
0
       && !h->ref_regular_nonweak
4826
0
       && !UNDEFWEAK_NO_DYNAMIC_RELOC (info, h)))
4827
0
        && htab->elf.target_os != is_vxworks
4828
0
        && !ppc_elf_hash_entry (h)->has_sda_refs
4829
0
        && !_bfd_elf_readonly_dynrelocs (h))
4830
0
      {
4831
0
        h->pointer_equality_needed = 0;
4832
        /* If we haven't seen a branch reloc and the symbol
4833
     isn't an ifunc then we don't need a plt entry.  */
4834
0
        if (!h->needs_plt && h->type != STT_GNU_IFUNC)
4835
0
    h->plt.plist = NULL;
4836
0
      }
4837
0
    else if (!bfd_link_pic (info))
4838
      /* We are going to be defining the function symbol on the
4839
         plt stub, so no dyn_relocs needed when non-pic.  */
4840
0
      h->dyn_relocs = NULL;
4841
0
  }
4842
0
      h->protected_def = 0;
4843
      /* Function symbols can't have copy relocs.  */
4844
0
      return true;
4845
0
    }
4846
0
  else
4847
0
    h->plt.plist = NULL;
4848
4849
  /* If this is a weak symbol, and there is a real definition, the
4850
     processor independent code will have arranged for us to see the
4851
     real definition first, and we can just use the same value.  */
4852
0
  if (h->is_weakalias)
4853
0
    {
4854
0
      struct elf_link_hash_entry *def = weakdef (h);
4855
0
      BFD_ASSERT (def->root.type == bfd_link_hash_defined);
4856
0
      h->root.u.def.section = def->root.u.def.section;
4857
0
      h->root.u.def.value = def->root.u.def.value;
4858
0
      if (def->root.u.def.section == htab->elf.sdynbss
4859
0
    || def->root.u.def.section == htab->elf.sdynrelro
4860
0
    || def->root.u.def.section == htab->dynsbss)
4861
0
  h->dyn_relocs = NULL;
4862
0
      return true;
4863
0
    }
4864
4865
  /* This is a reference to a symbol defined by a dynamic object which
4866
     is not a function.  */
4867
4868
  /* If we are creating a shared library, we must presume that the
4869
     only references to the symbol are via the global offset table.
4870
     For such cases we need not do anything here; the relocations will
4871
     be handled correctly by relocate_section.  */
4872
0
  if (bfd_link_pic (info))
4873
0
    {
4874
0
      h->protected_def = 0;
4875
0
      return true;
4876
0
    }
4877
4878
  /* If there are no references to this symbol that do not use the
4879
     GOT, we don't need to generate a copy reloc.  */
4880
0
  if (!h->non_got_ref)
4881
0
    {
4882
0
      h->protected_def = 0;
4883
0
      return true;
4884
0
    }
4885
4886
  /* Protected variables do not work with .dynbss.  The copy in
4887
     .dynbss won't be used by the shared library with the protected
4888
     definition for the variable.  Editing to PIC, or text relocations
4889
     are preferable to an incorrect program.  */
4890
0
  if (h->protected_def)
4891
0
    {
4892
0
      if (ELIMINATE_COPY_RELOCS
4893
0
    && ppc_elf_hash_entry (h)->has_addr16_ha
4894
0
    && ppc_elf_hash_entry (h)->has_addr16_lo
4895
0
    && htab->params->pic_fixup == 0
4896
0
    && info->disable_target_specific_optimizations <= 1)
4897
0
  htab->params->pic_fixup = 1;
4898
0
      return true;
4899
0
    }
4900
4901
  /* If -z nocopyreloc was given, we won't generate them either.  */
4902
0
  if (info->nocopyreloc)
4903
0
    return true;
4904
4905
   /* If we don't find any dynamic relocs in read-only sections, then
4906
      we'll be keeping the dynamic relocs and avoiding the copy reloc.
4907
      We can't do this if there are any small data relocations.  This
4908
      doesn't work on VxWorks, where we can not have dynamic
4909
      relocations (other than copy and jump slot relocations) in an
4910
      executable.  */
4911
0
  if (ELIMINATE_COPY_RELOCS
4912
0
      && !ppc_elf_hash_entry (h)->has_sda_refs
4913
0
      && htab->elf.target_os != is_vxworks
4914
0
      && !h->def_regular
4915
0
      && !alias_readonly_dynrelocs (h))
4916
0
    return true;
4917
4918
  /* We must allocate the symbol in our .dynbss section, which will
4919
     become part of the .bss section of the executable.  There will be
4920
     an entry for this symbol in the .dynsym section.  The dynamic
4921
     object will contain position independent code, so all references
4922
     from the dynamic object to this symbol will go through the global
4923
     offset table.  The dynamic linker will use the .dynsym entry to
4924
     determine the address it must put in the global offset table, so
4925
     both the dynamic object and the regular object will refer to the
4926
     same memory location for the variable.
4927
4928
     Of course, if the symbol is referenced using SDAREL relocs, we
4929
     must instead allocate it in .sbss.  */
4930
0
  if (ppc_elf_hash_entry (h)->has_sda_refs)
4931
0
    s = htab->dynsbss;
4932
0
  else if ((h->root.u.def.section->flags & SEC_READONLY) != 0)
4933
0
    s = htab->elf.sdynrelro;
4934
0
  else
4935
0
    s = htab->elf.sdynbss;
4936
0
  BFD_ASSERT (s != NULL);
4937
4938
0
  if ((h->root.u.def.section->flags & SEC_ALLOC) != 0 && h->size != 0)
4939
0
    {
4940
0
      asection *srel;
4941
4942
      /* We must generate a R_PPC_COPY reloc to tell the dynamic
4943
   linker to copy the initial value out of the dynamic object
4944
   and into the runtime process image.  */
4945
0
      if (ppc_elf_hash_entry (h)->has_sda_refs)
4946
0
  srel = htab->relsbss;
4947
0
      else if ((h->root.u.def.section->flags & SEC_READONLY) != 0)
4948
0
  srel = htab->elf.sreldynrelro;
4949
0
      else
4950
0
  srel = htab->elf.srelbss;
4951
0
      BFD_ASSERT (srel != NULL);
4952
0
      srel->size += sizeof (Elf32_External_Rela);
4953
0
      h->needs_copy = 1;
4954
0
    }
4955
4956
  /* We no longer want dyn_relocs.  */
4957
0
  h->dyn_relocs = NULL;
4958
0
  return _bfd_elf_adjust_dynamic_copy (info, h, s);
4959
0
}
4960

4961
/* Generate a symbol to mark plt call stubs.  For non-PIC code the sym is
4962
   xxxxxxxx.plt_call32.<callee> where xxxxxxxx is a hex number, usually 0,
4963
   specifying the addend on the plt relocation.  For -fpic code, the sym
4964
   is xxxxxxxx.plt_pic32.<callee>, and for -fPIC
4965
   xxxxxxxx.got2.plt_pic32.<callee>.  */
4966
4967
static bool
4968
add_stub_sym (struct plt_entry *ent,
4969
        struct elf_link_hash_entry *h,
4970
        struct bfd_link_info *info)
4971
0
{
4972
0
  struct elf_link_hash_entry *sh;
4973
0
  size_t len1, len2, len3;
4974
0
  char *name;
4975
0
  const char *stub;
4976
0
  struct ppc_elf_link_hash_table *htab = ppc_elf_hash_table (info);
4977
4978
0
  if (bfd_link_pic (info))
4979
0
    stub = ".plt_pic32.";
4980
0
  else
4981
0
    stub = ".plt_call32.";
4982
4983
0
  len1 = strlen (h->root.root.string);
4984
0
  len2 = strlen (stub);
4985
0
  len3 = 0;
4986
0
  if (ent->sec)
4987
0
    len3 = strlen (ent->sec->name);
4988
0
  name = bfd_alloc (info->output_bfd, len1 + len2 + len3 + 9);
4989
0
  if (name == NULL)
4990
0
    return false;
4991
0
  sprintf (name, "%08x", (unsigned) ent->addend & 0xffffffff);
4992
0
  if (ent->sec)
4993
0
    memcpy (name + 8, ent->sec->name, len3);
4994
0
  memcpy (name + 8 + len3, stub, len2);
4995
0
  memcpy (name + 8 + len3 + len2, h->root.root.string, len1 + 1);
4996
0
  sh = elf_link_hash_lookup (&htab->elf, name, true, false, false);
4997
0
  if (sh == NULL)
4998
0
    return false;
4999
0
  if (sh->root.type == bfd_link_hash_new)
5000
0
    {
5001
0
      sh->root.type = bfd_link_hash_defined;
5002
0
      sh->root.u.def.section = htab->glink;
5003
0
      sh->root.u.def.value = ent->glink_offset;
5004
0
      sh->ref_regular = 1;
5005
0
      sh->def_regular = 1;
5006
0
      sh->ref_regular_nonweak = 1;
5007
0
      sh->forced_local = 1;
5008
0
      sh->non_elf = 0;
5009
0
      sh->root.linker_def = 1;
5010
0
    }
5011
0
  return true;
5012
0
}
5013
5014
/* Allocate NEED contiguous space in .got, and return the offset.
5015
   Handles allocation of the got header when crossing 32k.  */
5016
5017
static bfd_vma
5018
allocate_got (struct ppc_elf_link_hash_table *htab, unsigned int need)
5019
0
{
5020
0
  bfd_vma where;
5021
0
  unsigned int max_before_header;
5022
5023
0
  if (htab->plt_type == PLT_VXWORKS)
5024
0
    {
5025
0
      where = htab->elf.sgot->size;
5026
0
      htab->elf.sgot->size += need;
5027
0
    }
5028
0
  else
5029
0
    {
5030
0
      max_before_header = htab->plt_type == PLT_NEW ? 32768 : 32764;
5031
0
      if (need <= htab->got_gap)
5032
0
  {
5033
0
    where = max_before_header - htab->got_gap;
5034
0
    htab->got_gap -= need;
5035
0
  }
5036
0
      else
5037
0
  {
5038
0
    if (htab->elf.sgot->size + need > max_before_header
5039
0
        && htab->elf.sgot->size <= max_before_header)
5040
0
      {
5041
0
        htab->got_gap = max_before_header - htab->elf.sgot->size;
5042
0
        htab->elf.sgot->size = max_before_header + htab->got_header_size;
5043
0
      }
5044
0
    where = htab->elf.sgot->size;
5045
0
    htab->elf.sgot->size += need;
5046
0
  }
5047
0
    }
5048
0
  return where;
5049
0
}
5050
5051
/* Calculate size of GOT entries for symbol given its TLS_MASK.
5052
   TLS_LD is excluded because those go in a special GOT slot.  */
5053
5054
static inline unsigned int
5055
got_entries_needed (int tls_mask)
5056
0
{
5057
0
  unsigned int need;
5058
0
  if ((tls_mask & TLS_TLS) == 0)
5059
0
    need = 4;
5060
0
  else
5061
0
    {
5062
0
      need = 0;
5063
0
      if ((tls_mask & TLS_GD) != 0)
5064
0
  need += 8;
5065
0
      if ((tls_mask & (TLS_TPREL | TLS_GDIE)) != 0)
5066
0
  need += 4;
5067
0
      if ((tls_mask & TLS_DTPREL) != 0)
5068
0
  need += 4;
5069
0
    }
5070
0
  return need;
5071
0
}
5072
5073
/* If H is undefined, make it dynamic if that makes sense.  */
5074
5075
static bool
5076
ensure_undef_dynamic (struct bfd_link_info *info,
5077
          struct elf_link_hash_entry *h)
5078
0
{
5079
0
  struct elf_link_hash_table *htab = elf_hash_table (info);
5080
5081
0
  if (htab->dynamic_sections_created
5082
0
      && ((info->dynamic_undefined_weak != 0
5083
0
     && h->root.type == bfd_link_hash_undefweak)
5084
0
    || h->root.type == bfd_link_hash_undefined)
5085
0
      && h->dynindx == -1
5086
0
      && !h->forced_local
5087
0
      && ELF_ST_VISIBILITY (h->other) == STV_DEFAULT)
5088
0
    return bfd_elf_link_record_dynamic_symbol (info, h);
5089
0
  return true;
5090
0
}
5091
5092
/* Choose whether to use htab->iplt or htab->pltlocal rather than the
5093
   usual htab->elf.splt section for a PLT entry.  */
5094
5095
static inline
5096
bool use_local_plt (struct bfd_link_info *info,
5097
         struct elf_link_hash_entry *h)
5098
0
{
5099
0
  return (h == NULL
5100
0
    || h->dynindx == -1
5101
0
    || !elf_hash_table (info)->dynamic_sections_created);
5102
0
}
5103
5104
/* Allocate space in associated reloc sections for dynamic relocs.  */
5105
5106
static bool
5107
allocate_dynrelocs (struct elf_link_hash_entry *h, void *inf)
5108
0
{
5109
0
  struct bfd_link_info *info = inf;
5110
0
  struct ppc_elf_link_hash_entry *eh;
5111
0
  struct ppc_elf_link_hash_table *htab;
5112
0
  struct elf_dyn_relocs *p;
5113
5114
0
  if (h->root.type == bfd_link_hash_indirect)
5115
0
    return true;
5116
5117
0
  htab = ppc_elf_hash_table (info);
5118
0
  eh = (struct ppc_elf_link_hash_entry *) h;
5119
0
  if (eh->elf.got.refcount > 0
5120
0
      || (ELIMINATE_COPY_RELOCS
5121
0
    && !eh->elf.def_regular
5122
0
    && eh->elf.protected_def
5123
0
    && eh->has_addr16_ha
5124
0
    && eh->has_addr16_lo
5125
0
    && htab->params->pic_fixup > 0))
5126
0
    {
5127
      /* Make sure this symbol is output as a dynamic symbol.  */
5128
0
      if (!ensure_undef_dynamic (info, &eh->elf))
5129
0
  return false;
5130
5131
0
      unsigned int need = got_entries_needed (eh->tls_mask);
5132
0
      unsigned int rel_need = need * sizeof (Elf32_External_Rela) / 4;
5133
0
      if ((eh->tls_mask & (TLS_TLS | TLS_LD)) == (TLS_TLS | TLS_LD))
5134
0
  {
5135
0
    if (SYMBOL_REFERENCES_LOCAL (info, &eh->elf))
5136
      /* We'll just use htab->tlsld_got.offset.  This should
5137
         always be the case.  It's a little odd if we have
5138
         a local dynamic reloc against a non-local symbol.  */
5139
0
      htab->tlsld_got.refcount += 1;
5140
0
    else
5141
0
      {
5142
0
        need += 8;
5143
0
        rel_need += sizeof (Elf32_External_Rela);
5144
0
      }
5145
0
  }
5146
0
      if (need == 0)
5147
0
  eh->elf.got.offset = (bfd_vma) -1;
5148
0
      else
5149
0
  {
5150
0
    eh->elf.got.offset = allocate_got (htab, need);
5151
0
    if (((bfd_link_pic (info)
5152
0
    && !((eh->tls_mask & TLS_TLS) != 0
5153
0
         && bfd_link_executable (info)
5154
0
         && SYMBOL_REFERENCES_LOCAL (info, &eh->elf))
5155
0
    && !bfd_is_abs_symbol (&h->root))
5156
0
         || (htab->elf.dynamic_sections_created
5157
0
       && eh->elf.dynindx != -1
5158
0
       && !SYMBOL_REFERENCES_LOCAL (info, &eh->elf)))
5159
0
        && !UNDEFWEAK_NO_DYNAMIC_RELOC (info, &eh->elf))
5160
0
      {
5161
0
        asection *rsec;
5162
5163
0
        rsec = htab->elf.srelgot;
5164
0
        if (eh->elf.type == STT_GNU_IFUNC)
5165
0
    rsec = htab->elf.irelplt;
5166
0
        rsec->size += rel_need;
5167
0
      }
5168
0
  }
5169
0
    }
5170
0
  else
5171
0
    eh->elf.got.offset = (bfd_vma) -1;
5172
5173
  /* If no dynamic sections we can't have dynamic relocs, except for
5174
     IFUNCs which are handled even in static executables.  */
5175
0
  if (!htab->elf.dynamic_sections_created
5176
0
      && h->type != STT_GNU_IFUNC)
5177
0
    h->dyn_relocs = NULL;
5178
5179
  /* Discard relocs on undefined symbols that must be local.  */
5180
0
  else if (h->root.type == bfd_link_hash_undefined
5181
0
     && ELF_ST_VISIBILITY (h->other) != STV_DEFAULT)
5182
0
    h->dyn_relocs = NULL;
5183
5184
  /* Also discard relocs on undefined weak syms with non-default
5185
     visibility, or when dynamic_undefined_weak says so.  */
5186
0
  else if (UNDEFWEAK_NO_DYNAMIC_RELOC (info, h))
5187
0
    h->dyn_relocs = NULL;
5188
5189
0
  if (h->dyn_relocs == NULL)
5190
0
    ;
5191
5192
  /* In the shared -Bsymbolic case, discard space allocated for
5193
     dynamic pc-relative relocs against symbols which turn out to be
5194
     defined in regular objects.  For the normal shared case, discard
5195
     space for relocs that have become local due to symbol visibility
5196
     changes.  */
5197
0
  else if (bfd_link_pic (info))
5198
0
    {
5199
      /* Relocs that use pc_count are those that appear on a call insn,
5200
   or certain REL relocs (see must_be_dyn_reloc) that can be
5201
   generated via assembly.  We want calls to protected symbols to
5202
   resolve directly to the function rather than going via the plt.
5203
   If people want function pointer comparisons to work as expected
5204
   then they should avoid writing weird assembly.  */
5205
0
      if (SYMBOL_CALLS_LOCAL (info, h))
5206
0
  {
5207
0
    struct elf_dyn_relocs **pp;
5208
5209
0
    for (pp = &h->dyn_relocs; (p = *pp) != NULL; )
5210
0
      {
5211
0
        p->count -= p->pc_count;
5212
0
        p->pc_count = 0;
5213
0
        if (p->count == 0)
5214
0
    *pp = p->next;
5215
0
        else
5216
0
    pp = &p->next;
5217
0
      }
5218
0
  }
5219
5220
0
      if (htab->elf.target_os == is_vxworks)
5221
0
  {
5222
0
    struct elf_dyn_relocs **pp;
5223
5224
0
    for (pp = &h->dyn_relocs; (p = *pp) != NULL; )
5225
0
      {
5226
0
        if (strcmp (p->sec->output_section->name, ".tls_vars") == 0)
5227
0
    *pp = p->next;
5228
0
        else
5229
0
    pp = &p->next;
5230
0
      }
5231
0
  }
5232
5233
0
      if (h->dyn_relocs != NULL)
5234
0
  {
5235
    /* Make sure this symbol is output as a dynamic symbol.  */
5236
0
    if (!ensure_undef_dynamic (info, h))
5237
0
      return false;
5238
0
  }
5239
0
    }
5240
0
  else if (ELIMINATE_COPY_RELOCS)
5241
0
    {
5242
      /* For the non-pic case, discard space for relocs against
5243
   symbols which turn out to need copy relocs or are not
5244
   dynamic.  */
5245
0
      if ((h->dynamic_adjusted
5246
0
     || (h->ref_regular
5247
0
         && h->root.type == bfd_link_hash_undefweak
5248
0
         && (info->dynamic_undefined_weak > 0
5249
0
       || !_bfd_elf_readonly_dynrelocs (h))))
5250
0
    && !h->def_regular
5251
0
    && !ELF_COMMON_DEF_P (h)
5252
0
    && !(h->protected_def
5253
0
         && eh->has_addr16_ha
5254
0
         && eh->has_addr16_lo
5255
0
         && htab->params->pic_fixup > 0))
5256
0
  {
5257
    /* Make sure this symbol is output as a dynamic symbol.  */
5258
0
    if (!ensure_undef_dynamic (info, h))
5259
0
      return false;
5260
5261
0
    if (h->dynindx == -1)
5262
0
      h->dyn_relocs = NULL;
5263
0
  }
5264
0
      else
5265
0
  h->dyn_relocs = NULL;
5266
0
    }
5267
5268
  /* Allocate space.  */
5269
0
  for (p = h->dyn_relocs; p != NULL; p = p->next)
5270
0
    if (!discarded_section (p->sec))
5271
0
      {
5272
0
  asection *sreloc = elf_section_data (p->sec)->sreloc;
5273
0
  if (eh->elf.type == STT_GNU_IFUNC)
5274
0
    sreloc = htab->elf.irelplt;
5275
0
  sreloc->size += p->count * sizeof (Elf32_External_Rela);
5276
0
      }
5277
5278
  /* Handle PLT relocs.  Done last, after dynindx has settled.
5279
     We might need a PLT entry when the symbol
5280
     a) is dynamic, or
5281
     b) is an ifunc, or
5282
     c) has plt16 relocs and has been processed by adjust_dynamic_symbol, or
5283
     d) has plt16 relocs and we are linking statically.  */
5284
0
  if ((htab->elf.dynamic_sections_created && h->dynindx != -1)
5285
0
      || h->type == STT_GNU_IFUNC
5286
0
      || (h->needs_plt && h->dynamic_adjusted)
5287
0
      || (h->needs_plt
5288
0
    && h->def_regular
5289
0
    && !htab->elf.dynamic_sections_created
5290
0
    && !htab->can_convert_all_inline_plt
5291
0
    && (ppc_elf_hash_entry (h)->tls_mask
5292
0
        & (TLS_TLS | PLT_KEEP)) == PLT_KEEP))
5293
0
    {
5294
0
      struct plt_entry *ent;
5295
0
      bool doneone = false;
5296
0
      bfd_vma plt_offset = 0, glink_offset = (bfd_vma) -1;
5297
5298
0
      for (ent = h->plt.plist; ent != NULL; ent = ent->next)
5299
0
  if (ent->plt.refcount > 0)
5300
0
    {
5301
0
      asection *s;
5302
0
      bool dyn;
5303
5304
0
      if (!ensure_undef_dynamic (info, h))
5305
0
        return false;
5306
5307
0
      dyn = !use_local_plt (info, h);
5308
0
      s = htab->elf.splt;
5309
0
      if (!dyn)
5310
0
        {
5311
0
    if (h->type == STT_GNU_IFUNC)
5312
0
      s = htab->elf.iplt;
5313
0
    else
5314
0
      s = htab->pltlocal;
5315
0
        }
5316
5317
0
      if (htab->plt_type == PLT_NEW || !dyn)
5318
0
        {
5319
0
    if (!doneone)
5320
0
      {
5321
0
        plt_offset = s->size;
5322
0
        s->size += 4;
5323
0
      }
5324
0
    ent->plt.offset = plt_offset;
5325
5326
0
    if (s == htab->pltlocal)
5327
0
      ent->glink_offset = glink_offset;
5328
0
    else
5329
0
      {
5330
0
        s = htab->glink;
5331
0
        if (!doneone || bfd_link_pic (info))
5332
0
          {
5333
0
      glink_offset = s->size;
5334
0
      s->size += GLINK_ENTRY_SIZE (htab, h);
5335
0
          }
5336
0
        if (!doneone
5337
0
      && !bfd_link_pic (info)
5338
0
      && h->def_dynamic
5339
0
      && !h->def_regular)
5340
0
          {
5341
0
      h->root.u.def.section = s;
5342
0
      h->root.u.def.value = glink_offset;
5343
0
          }
5344
0
        ent->glink_offset = glink_offset;
5345
5346
0
        if (htab->params->emit_stub_syms
5347
0
      && !add_stub_sym (ent, h, info))
5348
0
          return false;
5349
0
      }
5350
0
        }
5351
0
      else
5352
0
        {
5353
0
    if (!doneone)
5354
0
      {
5355
        /* If this is the first .plt entry, make room
5356
           for the special first entry.  */
5357
0
        if (s->size == 0)
5358
0
          s->size += htab->plt_initial_entry_size;
5359
5360
        /* The PowerPC PLT is actually composed of two
5361
           parts, the first part is 2 words (for a load
5362
           and a jump), and then there is a remaining
5363
           word available at the end.  */
5364
0
        plt_offset = (htab->plt_initial_entry_size
5365
0
          + (htab->plt_slot_size
5366
0
             * ((s->size
5367
0
           - htab->plt_initial_entry_size)
5368
0
          / htab->plt_entry_size)));
5369
5370
        /* If this symbol is not defined in a regular
5371
           file, and we are not generating a shared
5372
           library, then set the symbol to this location
5373
           in the .plt.  This is to avoid text
5374
           relocations, and is required to make
5375
           function pointers compare as equal between
5376
           the normal executable and the shared library.  */
5377
0
        if (! bfd_link_pic (info)
5378
0
      && h->def_dynamic
5379
0
      && !h->def_regular)
5380
0
          {
5381
0
      h->root.u.def.section = s;
5382
0
      h->root.u.def.value = plt_offset;
5383
0
          }
5384
5385
        /* Make room for this entry.  */
5386
0
        s->size += htab->plt_entry_size;
5387
        /* After the 8192nd entry, room for two entries
5388
           is allocated.  */
5389
0
        if (htab->plt_type == PLT_OLD
5390
0
      && (s->size - htab->plt_initial_entry_size)
5391
0
      / htab->plt_entry_size
5392
0
      > PLT_NUM_SINGLE_ENTRIES)
5393
0
          s->size += htab->plt_entry_size;
5394
0
      }
5395
0
    ent->plt.offset = plt_offset;
5396
0
        }
5397
5398
      /* We also need to make an entry in the .rela.plt section.  */
5399
0
      if (!doneone)
5400
0
        {
5401
0
    if (!dyn)
5402
0
      {
5403
0
        if (h->type == STT_GNU_IFUNC)
5404
0
          {
5405
0
      s = htab->elf.irelplt;
5406
0
      s->size += sizeof (Elf32_External_Rela);
5407
0
          }
5408
0
        else if (bfd_link_pic (info))
5409
0
          {
5410
0
      s = htab->relpltlocal;
5411
0
      s->size += sizeof (Elf32_External_Rela);
5412
0
          }
5413
0
      }
5414
0
    else
5415
0
      {
5416
0
        htab->elf.srelplt->size += sizeof (Elf32_External_Rela);
5417
5418
0
        if (htab->plt_type == PLT_VXWORKS)
5419
0
          {
5420
      /* Allocate space for the unloaded relocations.  */
5421
0
      if (!bfd_link_pic (info)
5422
0
          && htab->elf.dynamic_sections_created)
5423
0
        {
5424
0
          if (ent->plt.offset
5425
0
        == (bfd_vma) htab->plt_initial_entry_size)
5426
0
            {
5427
0
        htab->srelplt2->size
5428
0
          += (sizeof (Elf32_External_Rela)
5429
0
              * VXWORKS_PLTRESOLVE_RELOCS);
5430
0
            }
5431
5432
0
          htab->srelplt2->size
5433
0
            += (sizeof (Elf32_External_Rela)
5434
0
          * VXWORKS_PLT_NON_JMP_SLOT_RELOCS);
5435
0
        }
5436
5437
      /* Every PLT entry has an associated GOT entry in
5438
         .got.plt.  */
5439
0
      htab->elf.sgotplt->size += 4;
5440
0
          }
5441
0
      }
5442
0
    doneone = true;
5443
0
        }
5444
0
    }
5445
0
  else
5446
0
    ent->plt.offset = (bfd_vma) -1;
5447
5448
0
      if (!doneone)
5449
0
  {
5450
0
    h->plt.plist = NULL;
5451
0
    h->needs_plt = 0;
5452
0
  }
5453
0
    }
5454
0
  else
5455
0
    {
5456
0
      h->plt.plist = NULL;
5457
0
      h->needs_plt = 0;
5458
0
    }
5459
5460
0
  return true;
5461
0
}
5462
5463
static const unsigned char glink_eh_frame_cie[] =
5464
{
5465
  0, 0, 0, 16,        /* length.  */
5466
  0, 0, 0, 0,       /* id.  */
5467
  1,          /* CIE version.  */
5468
  'z', 'R', 0,        /* Augmentation string.  */
5469
  4,          /* Code alignment.  */
5470
  0x7c,         /* Data alignment.  */
5471
  65,         /* RA reg.  */
5472
  1,          /* Augmentation size.  */
5473
  DW_EH_PE_pcrel | DW_EH_PE_sdata4, /* FDE encoding.  */
5474
  DW_CFA_def_cfa, 1, 0      /* def_cfa: r1 offset 0.  */
5475
};
5476
5477
/* Set the sizes of the dynamic sections.  */
5478
5479
static bool
5480
ppc_elf_late_size_sections (bfd *output_bfd,
5481
          struct bfd_link_info *info)
5482
0
{
5483
0
  struct ppc_elf_link_hash_table *htab;
5484
0
  asection *s;
5485
0
  bool relocs;
5486
0
  bfd *ibfd;
5487
5488
#ifdef DEBUG
5489
  fprintf (stderr, "ppc_elf_late_size_sections called\n");
5490
#endif
5491
5492
0
  htab = ppc_elf_hash_table (info);
5493
0
  if (htab->elf.dynobj == NULL)
5494
0
    return true;
5495
5496
0
  if (elf_hash_table (info)->dynamic_sections_created)
5497
0
    {
5498
      /* Set the contents of the .interp section to the interpreter.  */
5499
0
      if (bfd_link_executable (info) && !info->nointerp)
5500
0
  {
5501
0
    s = bfd_get_linker_section (htab->elf.dynobj, ".interp");
5502
0
    BFD_ASSERT (s != NULL);
5503
0
    s->size = sizeof ELF_DYNAMIC_INTERPRETER;
5504
0
    s->contents = (unsigned char *) ELF_DYNAMIC_INTERPRETER;
5505
0
    s->alloced = 1;
5506
0
  }
5507
0
    }
5508
5509
0
  if (htab->plt_type == PLT_OLD)
5510
0
    htab->got_header_size = 16;
5511
0
  else if (htab->plt_type == PLT_NEW)
5512
0
    htab->got_header_size = 12;
5513
5514
  /* Set up .got offsets for local syms, and space for local dynamic
5515
     relocs.  */
5516
0
  for (ibfd = info->input_bfds; ibfd != NULL; ibfd = ibfd->link.next)
5517
0
    {
5518
0
      bfd_signed_vma *local_got;
5519
0
      bfd_signed_vma *end_local_got;
5520
0
      struct plt_entry **local_plt;
5521
0
      struct plt_entry **end_local_plt;
5522
0
      char *lgot_masks;
5523
0
      bfd_size_type locsymcount;
5524
0
      Elf_Internal_Shdr *symtab_hdr;
5525
0
      Elf_Internal_Sym *local_syms;
5526
0
      Elf_Internal_Sym *isym;
5527
5528
0
      if (!is_ppc_elf (ibfd))
5529
0
  continue;
5530
5531
0
      for (s = ibfd->sections; s != NULL; s = s->next)
5532
0
  {
5533
0
    struct ppc_dyn_relocs *p;
5534
5535
0
    for (p = ((struct ppc_dyn_relocs *)
5536
0
        elf_section_data (s)->local_dynrel);
5537
0
         p != NULL;
5538
0
         p = p->next)
5539
0
      {
5540
0
        if (discarded_section (p->sec))
5541
0
    {
5542
      /* Input section has been discarded, either because
5543
         it is a copy of a linkonce section or due to
5544
         linker script /DISCARD/, so we'll be discarding
5545
         the relocs too.  */
5546
0
    }
5547
0
        else if (htab->elf.target_os == is_vxworks
5548
0
           && strcmp (p->sec->output_section->name,
5549
0
          ".tls_vars") == 0)
5550
0
    {
5551
      /* Relocations in vxworks .tls_vars sections are
5552
         handled specially by the loader.  */
5553
0
    }
5554
0
        else if (p->count != 0)
5555
0
    {
5556
0
      asection *sreloc = elf_section_data (p->sec)->sreloc;
5557
0
      if (p->ifunc)
5558
0
        sreloc = htab->elf.irelplt;
5559
0
      sreloc->size += p->count * sizeof (Elf32_External_Rela);
5560
0
      if ((p->sec->output_section->flags
5561
0
           & (SEC_READONLY | SEC_ALLOC))
5562
0
          == (SEC_READONLY | SEC_ALLOC))
5563
0
        {
5564
0
          info->flags |= DF_TEXTREL;
5565
0
          info->callbacks->minfo (_("%pB: dynamic relocation in read-only section `%pA'\n"),
5566
0
                p->sec->owner, p->sec);
5567
0
        }
5568
0
    }
5569
0
      }
5570
0
  }
5571
5572
0
      local_got = elf_local_got_refcounts (ibfd);
5573
0
      if (!local_got)
5574
0
  continue;
5575
5576
0
      symtab_hdr = &elf_symtab_hdr (ibfd);
5577
0
      locsymcount = symtab_hdr->sh_info;
5578
0
      end_local_got = local_got + locsymcount;
5579
0
      local_plt = (struct plt_entry **) end_local_got;
5580
0
      end_local_plt = local_plt + locsymcount;
5581
0
      lgot_masks = (char *) end_local_plt;
5582
0
      local_syms = (Elf_Internal_Sym *) symtab_hdr->contents;
5583
0
      if (local_syms == NULL && locsymcount != 0)
5584
0
  {
5585
0
    local_syms = bfd_elf_get_elf_syms (ibfd, symtab_hdr, locsymcount,
5586
0
               0, NULL, NULL, NULL);
5587
0
    if (local_syms == NULL)
5588
0
      return false;
5589
0
  }
5590
5591
0
      for (isym = local_syms;
5592
0
     local_got < end_local_got;
5593
0
     ++local_got, ++lgot_masks, ++isym)
5594
0
  if (*local_got > 0)
5595
0
    {
5596
0
      unsigned int need;
5597
0
      if ((*lgot_masks & (TLS_TLS | TLS_LD)) == (TLS_TLS | TLS_LD))
5598
0
        htab->tlsld_got.refcount += 1;
5599
0
      need = got_entries_needed (*lgot_masks);
5600
0
      if (need == 0)
5601
0
        *local_got = (bfd_vma) -1;
5602
0
      else
5603
0
        {
5604
0
    *local_got = allocate_got (htab, need);
5605
0
    if (bfd_link_pic (info)
5606
0
        && !((*lgot_masks & TLS_TLS) != 0
5607
0
       && bfd_link_executable (info))
5608
0
        && isym->st_shndx != SHN_ABS)
5609
0
      {
5610
0
        asection *srel;
5611
5612
0
        need *= sizeof (Elf32_External_Rela) / 4;
5613
0
        srel = htab->elf.srelgot;
5614
0
        if ((*lgot_masks & (TLS_TLS | PLT_IFUNC)) == PLT_IFUNC)
5615
0
          srel = htab->elf.irelplt;
5616
0
        srel->size += need;
5617
0
      }
5618
0
        }
5619
0
    }
5620
0
  else
5621
0
    *local_got = (bfd_vma) -1;
5622
5623
0
      if (htab->elf.target_os == is_vxworks)
5624
0
  continue;
5625
5626
      /* Allocate space for calls to local STT_GNU_IFUNC syms in .iplt.  */
5627
0
      lgot_masks = (char *) end_local_plt;
5628
0
      for (; local_plt < end_local_plt; ++local_plt, ++lgot_masks)
5629
0
  {
5630
0
    struct plt_entry *ent;
5631
0
    bool doneone = false;
5632
0
    bfd_vma plt_offset = 0, glink_offset = (bfd_vma) -1;
5633
5634
0
    for (ent = *local_plt; ent != NULL; ent = ent->next)
5635
0
      if (ent->plt.refcount > 0)
5636
0
        {
5637
0
    if ((*lgot_masks & (TLS_TLS | PLT_IFUNC)) == PLT_IFUNC)
5638
0
      s = htab->elf.iplt;
5639
0
    else if (htab->can_convert_all_inline_plt
5640
0
       || (*lgot_masks & (TLS_TLS | PLT_KEEP)) != PLT_KEEP)
5641
0
      {
5642
0
        ent->plt.offset = (bfd_vma) -1;
5643
0
        continue;
5644
0
      }
5645
0
    else
5646
0
      s = htab->pltlocal;
5647
5648
0
    if (!doneone)
5649
0
      {
5650
0
        plt_offset = s->size;
5651
0
        s->size += 4;
5652
0
      }
5653
0
    ent->plt.offset = plt_offset;
5654
5655
0
    if (s != htab->pltlocal && (!doneone || bfd_link_pic (info)))
5656
0
      {
5657
0
        s = htab->glink;
5658
0
        glink_offset = s->size;
5659
0
        s->size += GLINK_ENTRY_SIZE (htab, NULL);
5660
0
      }
5661
0
    ent->glink_offset = glink_offset;
5662
5663
0
    if (!doneone)
5664
0
      {
5665
0
        if ((*lgot_masks & (TLS_TLS | PLT_IFUNC)) == PLT_IFUNC)
5666
0
          {
5667
0
      s = htab->elf.irelplt;
5668
0
      s->size += sizeof (Elf32_External_Rela);
5669
0
          }
5670
0
        else if (bfd_link_pic (info))
5671
0
          {
5672
0
      s = htab->relpltlocal;
5673
0
      s->size += sizeof (Elf32_External_Rela);
5674
0
          }
5675
0
        doneone = true;
5676
0
      }
5677
0
        }
5678
0
      else
5679
0
        ent->plt.offset = (bfd_vma) -1;
5680
0
  }
5681
5682
0
      if (local_syms != NULL
5683
0
    && symtab_hdr->contents != (unsigned char *) local_syms)
5684
0
  {
5685
0
    if (!info->keep_memory)
5686
0
      free (local_syms);
5687
0
    else
5688
0
      symtab_hdr->contents = (unsigned char *) local_syms;
5689
0
  }
5690
0
    }
5691
5692
  /* Allocate space for global sym dynamic relocs.  */
5693
0
  elf_link_hash_traverse (elf_hash_table (info), allocate_dynrelocs, info);
5694
5695
0
  if (htab->tlsld_got.refcount > 0)
5696
0
    {
5697
0
      htab->tlsld_got.offset = allocate_got (htab, 8);
5698
0
      if (bfd_link_dll (info))
5699
0
  htab->elf.srelgot->size += sizeof (Elf32_External_Rela);
5700
0
    }
5701
0
  else
5702
0
    htab->tlsld_got.offset = (bfd_vma) -1;
5703
5704
0
  if (htab->elf.sgot != NULL && htab->plt_type != PLT_VXWORKS)
5705
0
    {
5706
0
      unsigned int g_o_t = 32768;
5707
5708
      /* If we haven't allocated the header, do so now.  When we get here,
5709
   for old plt/got the got size will be 0 to 32764 (not allocated),
5710
   or 32780 to 65536 (header allocated).  For new plt/got, the
5711
   corresponding ranges are 0 to 32768 and 32780 to 65536.  */
5712
0
      if (htab->elf.sgot->size <= 32768)
5713
0
  {
5714
0
    g_o_t = htab->elf.sgot->size;
5715
0
    if (htab->plt_type == PLT_OLD)
5716
0
      g_o_t += 4;
5717
0
    htab->elf.sgot->size += htab->got_header_size;
5718
0
  }
5719
5720
0
      htab->elf.hgot->root.u.def.value = g_o_t;
5721
0
    }
5722
0
  if (bfd_link_pic (info))
5723
0
    {
5724
0
      struct elf_link_hash_entry *sda = htab->sdata[0].sym;
5725
5726
0
      sda->root.u.def.section = htab->elf.hgot->root.u.def.section;
5727
0
      sda->root.u.def.value = htab->elf.hgot->root.u.def.value;
5728
0
    }
5729
0
  if (info->emitrelocations)
5730
0
    {
5731
0
      struct elf_link_hash_entry *sda = htab->sdata[0].sym;
5732
5733
0
      if (sda != NULL && sda->ref_regular)
5734
0
  sda->root.u.def.section->flags |= SEC_KEEP;
5735
0
      sda = htab->sdata[1].sym;
5736
0
      if (sda != NULL && sda->ref_regular)
5737
0
  sda->root.u.def.section->flags |= SEC_KEEP;
5738
0
    }
5739
5740
0
  if (htab->glink != NULL
5741
0
      && htab->glink->size != 0
5742
0
      && htab->elf.dynamic_sections_created)
5743
0
    {
5744
0
      htab->glink_pltresolve = htab->glink->size;
5745
      /* Space for the branch table.  */
5746
0
      htab->glink->size
5747
0
  += htab->elf.srelplt->size / (sizeof (Elf32_External_Rela) / 4) - 4;
5748
      /* Pad out to align the start of PLTresolve.  */
5749
0
      htab->glink->size += -htab->glink->size & (htab->params->ppc476_workaround
5750
0
             ? 63 : 15);
5751
0
      htab->glink->size += GLINK_PLTRESOLVE;
5752
5753
0
      if (htab->params->emit_stub_syms)
5754
0
  {
5755
0
    struct elf_link_hash_entry *sh;
5756
0
    sh = elf_link_hash_lookup (&htab->elf, "__glink",
5757
0
             true, false, false);
5758
0
    if (sh == NULL)
5759
0
      return false;
5760
0
    if (sh->root.type == bfd_link_hash_new)
5761
0
      {
5762
0
        sh->root.type = bfd_link_hash_defined;
5763
0
        sh->root.u.def.section = htab->glink;
5764
0
        sh->root.u.def.value = htab->glink_pltresolve;
5765
0
        sh->ref_regular = 1;
5766
0
        sh->def_regular = 1;
5767
0
        sh->ref_regular_nonweak = 1;
5768
0
        sh->forced_local = 1;
5769
0
        sh->non_elf = 0;
5770
0
        sh->root.linker_def = 1;
5771
0
      }
5772
0
    sh = elf_link_hash_lookup (&htab->elf, "__glink_PLTresolve",
5773
0
             true, false, false);
5774
0
    if (sh == NULL)
5775
0
      return false;
5776
0
    if (sh->root.type == bfd_link_hash_new)
5777
0
      {
5778
0
        sh->root.type = bfd_link_hash_defined;
5779
0
        sh->root.u.def.section = htab->glink;
5780
0
        sh->root.u.def.value = htab->glink->size - GLINK_PLTRESOLVE;
5781
0
        sh->ref_regular = 1;
5782
0
        sh->def_regular = 1;
5783
0
        sh->ref_regular_nonweak = 1;
5784
0
        sh->forced_local = 1;
5785
0
        sh->non_elf = 0;
5786
0
        sh->root.linker_def = 1;
5787
0
      }
5788
0
  }
5789
0
    }
5790
5791
0
  if (htab->glink != NULL
5792
0
      && htab->glink->size != 0
5793
0
      && htab->glink_eh_frame != NULL
5794
0
      && !bfd_is_abs_section (htab->glink_eh_frame->output_section)
5795
0
      && _bfd_elf_eh_frame_present (info))
5796
0
    {
5797
0
      s = htab->glink_eh_frame;
5798
0
      s->size = sizeof (glink_eh_frame_cie) + 20;
5799
0
      if (bfd_link_pic (info))
5800
0
  {
5801
0
    s->size += 4;
5802
0
    if (htab->glink->size - GLINK_PLTRESOLVE + 8 >= 256)
5803
0
      s->size += 4;
5804
0
  }
5805
0
    }
5806
5807
  /* We've now determined the sizes of the various dynamic sections.
5808
     Allocate memory for them.  */
5809
0
  relocs = false;
5810
0
  for (s = htab->elf.dynobj->sections; s != NULL; s = s->next)
5811
0
    {
5812
0
      bool strip_section = true;
5813
5814
0
      if ((s->flags & SEC_LINKER_CREATED) == 0)
5815
0
  continue;
5816
5817
0
      if (s == htab->elf.splt
5818
0
    || s == htab->elf.sgot)
5819
0
  {
5820
    /* We'd like to strip these sections if they aren't needed, but if
5821
       we've exported dynamic symbols from them we must leave them.
5822
       It's too late to tell BFD to get rid of the symbols.  */
5823
0
    if (htab->elf.hplt != NULL)
5824
0
      strip_section = false;
5825
    /* Strip this section if we don't need it; see the
5826
       comment below.  */
5827
0
  }
5828
0
      else if (s == htab->elf.iplt
5829
0
         || s == htab->pltlocal
5830
0
         || s == htab->glink
5831
0
         || s == htab->glink_eh_frame
5832
0
         || s == htab->elf.sgotplt
5833
0
         || s == htab->sbss
5834
0
         || s == htab->elf.sdynbss
5835
0
         || s == htab->elf.sdynrelro
5836
0
         || s == htab->dynsbss)
5837
0
  {
5838
    /* Strip these too.  */
5839
0
  }
5840
0
      else if (s == htab->sdata[0].section
5841
0
         || s == htab->sdata[1].section)
5842
0
  {
5843
0
    strip_section = (s->flags & SEC_KEEP) == 0;
5844
0
  }
5845
0
      else if (startswith (bfd_section_name (s), ".rela"))
5846
0
  {
5847
0
    if (s->size != 0)
5848
0
      {
5849
        /* Remember whether there are any relocation sections.  */
5850
0
        relocs = true;
5851
5852
        /* We use the reloc_count field as a counter if we need
5853
     to copy relocs into the output file.  */
5854
0
        s->reloc_count = 0;
5855
0
      }
5856
0
  }
5857
0
      else
5858
0
  {
5859
    /* It's not one of our sections, so don't allocate space.  */
5860
0
    continue;
5861
0
  }
5862
5863
0
      if (s->size == 0 && strip_section)
5864
0
  {
5865
    /* If we don't need this section, strip it from the
5866
       output file.  This is mostly to handle .rela.bss and
5867
       .rela.plt.  We must create both sections in
5868
       create_dynamic_sections, because they must be created
5869
       before the linker maps input sections to output
5870
       sections.  The linker does that before
5871
       adjust_dynamic_symbol is called, and it is that
5872
       function which decides whether anything needs to go
5873
       into these sections.  */
5874
0
    s->flags |= SEC_EXCLUDE;
5875
0
    continue;
5876
0
  }
5877
5878
0
      if ((s->flags & SEC_HAS_CONTENTS) == 0)
5879
0
  continue;
5880
5881
      /* Allocate memory for the section contents.  */
5882
0
      s->contents = bfd_zalloc (htab->elf.dynobj, s->size);
5883
0
      if (s->contents == NULL)
5884
0
  return false;
5885
0
      s->alloced = 1;
5886
0
    }
5887
5888
0
  if (htab->elf.dynamic_sections_created)
5889
0
    {
5890
      /* Add some entries to the .dynamic section.  We fill in the
5891
   values later, in ppc_elf_finish_dynamic_sections, but we
5892
   must add the entries now so that we get the correct size for
5893
   the .dynamic section.  The DT_DEBUG entry is filled in by the
5894
   dynamic linker and used by the debugger.  */
5895
0
#define add_dynamic_entry(TAG, VAL) \
5896
0
  _bfd_elf_add_dynamic_entry (info, TAG, VAL)
5897
5898
0
      if (!_bfd_elf_maybe_vxworks_add_dynamic_tags (output_bfd, info,
5899
0
                relocs))
5900
0
  return false;
5901
5902
0
      if (htab->plt_type == PLT_NEW
5903
0
    && htab->glink != NULL
5904
0
    && htab->glink->size != 0)
5905
0
  {
5906
0
    if (!add_dynamic_entry (DT_PPC_GOT, 0))
5907
0
      return false;
5908
0
    if (!htab->params->no_tls_get_addr_opt
5909
0
        && htab->tls_get_addr != NULL
5910
0
        && htab->tls_get_addr->plt.plist != NULL
5911
0
        && !add_dynamic_entry (DT_PPC_OPT, PPC_OPT_TLS))
5912
0
      return false;
5913
0
  }
5914
0
   }
5915
0
#undef add_dynamic_entry
5916
5917
0
  if (htab->glink_eh_frame != NULL
5918
0
      && htab->glink_eh_frame->contents != NULL)
5919
0
    {
5920
0
      unsigned char *p = htab->glink_eh_frame->contents;
5921
0
      bfd_vma val;
5922
5923
0
      memcpy (p, glink_eh_frame_cie, sizeof (glink_eh_frame_cie));
5924
      /* CIE length (rewrite in case little-endian).  */
5925
0
      bfd_put_32 (htab->elf.dynobj, sizeof (glink_eh_frame_cie) - 4, p);
5926
0
      p += sizeof (glink_eh_frame_cie);
5927
      /* FDE length.  */
5928
0
      val = htab->glink_eh_frame->size - 4 - sizeof (glink_eh_frame_cie);
5929
0
      bfd_put_32 (htab->elf.dynobj, val, p);
5930
0
      p += 4;
5931
      /* CIE pointer.  */
5932
0
      val = p - htab->glink_eh_frame->contents;
5933
0
      bfd_put_32 (htab->elf.dynobj, val, p);
5934
0
      p += 4;
5935
      /* Offset to .glink.  Set later.  */
5936
0
      p += 4;
5937
      /* .glink size.  */
5938
0
      bfd_put_32 (htab->elf.dynobj, htab->glink->size, p);
5939
0
      p += 4;
5940
      /* Augmentation.  */
5941
0
      p += 1;
5942
5943
0
      if (bfd_link_pic (info)
5944
0
    && htab->elf.dynamic_sections_created)
5945
0
  {
5946
0
    bfd_vma adv = (htab->glink->size - GLINK_PLTRESOLVE + 8) >> 2;
5947
0
    if (adv < 64)
5948
0
      *p++ = DW_CFA_advance_loc + adv;
5949
0
    else if (adv < 256)
5950
0
      {
5951
0
        *p++ = DW_CFA_advance_loc1;
5952
0
        *p++ = adv;
5953
0
      }
5954
0
    else if (adv < 65536)
5955
0
      {
5956
0
        *p++ = DW_CFA_advance_loc2;
5957
0
        bfd_put_16 (htab->elf.dynobj, adv, p);
5958
0
        p += 2;
5959
0
      }
5960
0
    else
5961
0
      {
5962
0
        *p++ = DW_CFA_advance_loc4;
5963
0
        bfd_put_32 (htab->elf.dynobj, adv, p);
5964
0
        p += 4;
5965
0
      }
5966
0
    *p++ = DW_CFA_register;
5967
0
    *p++ = 65;
5968
0
    p++;
5969
0
    *p++ = DW_CFA_advance_loc + 4;
5970
0
    *p++ = DW_CFA_restore_extended;
5971
0
    *p++ = 65;
5972
0
  }
5973
0
      BFD_ASSERT ((bfd_vma) ((p + 3 - htab->glink_eh_frame->contents) & -4)
5974
0
      == htab->glink_eh_frame->size);
5975
0
    }
5976
5977
0
  return true;
5978
0
}
5979
5980
/* Arrange to have _SDA_BASE_ or _SDA2_BASE_ stripped from the output
5981
   if it looks like nothing is using them.  */
5982
5983
static void
5984
maybe_strip_sdasym (bfd *output_bfd, elf_linker_section_t *lsect)
5985
0
{
5986
0
  struct elf_link_hash_entry *sda = lsect->sym;
5987
5988
0
  if (sda != NULL && !sda->ref_regular && sda->dynindx == -1)
5989
0
    {
5990
0
      asection *s;
5991
5992
0
      s = bfd_get_section_by_name (output_bfd, lsect->name);
5993
0
      if (s == NULL || bfd_section_removed_from_list (output_bfd, s))
5994
0
  {
5995
0
    s = bfd_get_section_by_name (output_bfd, lsect->bss_name);
5996
0
    if (s == NULL || bfd_section_removed_from_list (output_bfd, s))
5997
0
      {
5998
0
        sda->def_regular = 0;
5999
        /* This is somewhat magic.  See elf_link_output_extsym.  */
6000
0
        sda->ref_dynamic = 1;
6001
0
        sda->forced_local = 0;
6002
0
      }
6003
0
  }
6004
0
    }
6005
0
}
6006
6007
void
6008
ppc_elf_maybe_strip_sdata_syms (struct bfd_link_info *info)
6009
0
{
6010
0
  struct ppc_elf_link_hash_table *htab = ppc_elf_hash_table (info);
6011
6012
0
  if (htab != NULL)
6013
0
    {
6014
0
      maybe_strip_sdasym (info->output_bfd, &htab->sdata[0]);
6015
0
      maybe_strip_sdasym (info->output_bfd, &htab->sdata[1]);
6016
0
    }
6017
0
}
6018
6019
6020
/* Return TRUE if symbol should be hashed in the `.gnu.hash' section.  */
6021
6022
static bool
6023
ppc_elf_hash_symbol (struct elf_link_hash_entry *h)
6024
0
{
6025
0
  if (h->plt.plist != NULL
6026
0
      && !h->def_regular
6027
0
      && (!h->pointer_equality_needed
6028
0
    || !h->ref_regular_nonweak))
6029
0
    return false;
6030
6031
0
  return _bfd_elf_hash_symbol (h);
6032
0
}
6033

6034
0
#define ARRAY_SIZE(a) (sizeof (a) / sizeof ((a)[0]))
6035
6036
/* Relaxation trampolines.  r12 is available for clobbering (r11, is
6037
   used for some functions that are allowed to break the ABI).  */
6038
static const int shared_stub_entry[] =
6039
  {
6040
    0x7c0802a6, /* mflr 0 */
6041
    0x429f0005, /* bcl 20, 31, .Lxxx */
6042
    0x7d8802a6, /* mflr 12 */
6043
    0x3d8c0000, /* addis 12, 12, (xxx-.Lxxx)@ha */
6044
    0x398c0000, /* addi 12, 12, (xxx-.Lxxx)@l */
6045
    0x7c0803a6, /* mtlr 0 */
6046
    0x7d8903a6, /* mtctr 12 */
6047
    0x4e800420, /* bctr */
6048
  };
6049
6050
static const int stub_entry[] =
6051
  {
6052
    0x3d800000, /* lis 12,xxx@ha */
6053
    0x398c0000, /* addi 12,12,xxx@l */
6054
    0x7d8903a6, /* mtctr 12 */
6055
    0x4e800420, /* bctr */
6056
  };
6057
6058
struct ppc_elf_relax_info
6059
{
6060
  unsigned int workaround_size;
6061
  unsigned int picfixup_size;
6062
};
6063
6064
/* This function implements long branch trampolines, and the ppc476
6065
   icache bug workaround.  Any section needing trampolines or patch
6066
   space for the workaround has its size extended so that we can
6067
   add trampolines at the end of the section.  */
6068
6069
static bool
6070
ppc_elf_relax_section (bfd *abfd,
6071
           asection *isec,
6072
           struct bfd_link_info *link_info,
6073
           bool *again)
6074
0
{
6075
0
  struct one_branch_fixup
6076
0
  {
6077
0
    struct one_branch_fixup *next;
6078
0
    asection *tsec;
6079
    /* Final link, can use the symbol offset.  For a
6080
       relocatable link we use the symbol's index.  */
6081
0
    bfd_vma toff;
6082
0
    bfd_vma trampoff;
6083
0
  };
6084
6085
0
  Elf_Internal_Shdr *symtab_hdr;
6086
0
  bfd_byte *contents = NULL;
6087
0
  Elf_Internal_Sym *isymbuf = NULL;
6088
0
  Elf_Internal_Rela *internal_relocs = NULL;
6089
0
  Elf_Internal_Rela *irel, *irelend = NULL;
6090
0
  struct one_branch_fixup *branch_fixups = NULL;
6091
0
  struct ppc_elf_relax_info *relax_info = NULL;
6092
0
  unsigned changes = 0;
6093
0
  bool workaround_change;
6094
0
  struct ppc_elf_link_hash_table *htab;
6095
0
  bfd_size_type trampbase, trampoff, newsize, picfixup_size;
6096
0
  asection *got2;
6097
0
  bool maybe_pasted;
6098
6099
0
  *again = false;
6100
6101
  /* No need to do anything with non-alloc or non-code sections.  */
6102
0
  if ((isec->flags & SEC_ALLOC) == 0
6103
0
      || (isec->flags & SEC_CODE) == 0
6104
0
      || (isec->flags & SEC_HAS_CONTENTS) == 0
6105
0
      || (isec->flags & SEC_LINKER_CREATED) != 0
6106
0
      || isec->size < 4)
6107
0
    return true;
6108
6109
  /* We cannot represent the required PIC relocs in the output, so don't
6110
     do anything.  The linker doesn't support mixing -shared and -r
6111
     anyway.  */
6112
0
  if (bfd_link_relocatable (link_info) && bfd_link_pic (link_info))
6113
0
    return true;
6114
6115
0
  htab = ppc_elf_hash_table (link_info);
6116
0
  if (htab == NULL)
6117
0
    return true;
6118
6119
0
  isec->size = (isec->size + 3) & -4;
6120
0
  if (isec->rawsize == 0)
6121
0
    isec->rawsize = isec->size;
6122
0
  trampbase = isec->size;
6123
6124
0
  BFD_ASSERT (isec->sec_info_type == SEC_INFO_TYPE_NONE
6125
0
        || isec->sec_info_type == SEC_INFO_TYPE_TARGET);
6126
0
  isec->sec_info_type = SEC_INFO_TYPE_TARGET;
6127
6128
0
  if (htab->params->ppc476_workaround
6129
0
      || htab->params->pic_fixup > 0)
6130
0
    {
6131
0
      if (elf_section_data (isec)->sec_info == NULL)
6132
0
  {
6133
0
    elf_section_data (isec)->sec_info
6134
0
      = bfd_zalloc (abfd, sizeof (struct ppc_elf_relax_info));
6135
0
    if (elf_section_data (isec)->sec_info == NULL)
6136
0
      return false;
6137
0
  }
6138
0
      relax_info = elf_section_data (isec)->sec_info;
6139
0
      trampbase -= relax_info->workaround_size;
6140
0
    }
6141
6142
0
  maybe_pasted = (strcmp (isec->output_section->name, ".init") == 0
6143
0
      || strcmp (isec->output_section->name, ".fini") == 0);
6144
  /* Space for a branch around any trampolines.  */
6145
0
  trampoff = trampbase;
6146
0
  if (maybe_pasted && trampbase == isec->rawsize)
6147
0
    trampoff += 4;
6148
6149
0
  symtab_hdr = &elf_symtab_hdr (abfd);
6150
0
  picfixup_size = 0;
6151
0
  if (htab->params->branch_trampolines
6152
0
      || htab->params->pic_fixup > 0)
6153
0
    {
6154
      /* Get a copy of the native relocations.  */
6155
0
      if (isec->reloc_count != 0)
6156
0
  {
6157
0
    internal_relocs = _bfd_elf_link_read_relocs (abfd, isec, NULL, NULL,
6158
0
                   link_info->keep_memory);
6159
0
    if (internal_relocs == NULL)
6160
0
      goto error_return;
6161
0
  }
6162
6163
0
      got2 = bfd_get_section_by_name (abfd, ".got2");
6164
6165
0
      irelend = internal_relocs + isec->reloc_count;
6166
0
      for (irel = internal_relocs; irel < irelend; irel++)
6167
0
  {
6168
0
    unsigned long r_type = ELF32_R_TYPE (irel->r_info);
6169
0
    bfd_vma toff, roff;
6170
0
    asection *tsec;
6171
0
    struct one_branch_fixup *f;
6172
0
    size_t insn_offset = 0;
6173
0
    bfd_vma max_branch_offset = 0, val, reladdr;
6174
0
    bfd_byte *hit_addr;
6175
0
    unsigned long t0;
6176
0
    struct elf_link_hash_entry *h;
6177
0
    Elf_Internal_Sym *isym;
6178
0
    struct plt_entry **plist;
6179
0
    unsigned char sym_type;
6180
6181
0
    switch (r_type)
6182
0
      {
6183
0
      case R_PPC_REL24:
6184
0
      case R_PPC_LOCAL24PC:
6185
0
      case R_PPC_PLTREL24:
6186
0
      case R_PPC_PLTCALL:
6187
0
        max_branch_offset = 1 << 25;
6188
0
        break;
6189
6190
0
      case R_PPC_REL14:
6191
0
      case R_PPC_REL14_BRTAKEN:
6192
0
      case R_PPC_REL14_BRNTAKEN:
6193
0
        max_branch_offset = 1 << 15;
6194
0
        break;
6195
6196
0
      case R_PPC_ADDR16_HA:
6197
0
        if (htab->params->pic_fixup > 0)
6198
0
    break;
6199
0
        continue;
6200
6201
0
      default:
6202
0
        continue;
6203
0
      }
6204
6205
    /* Get the value of the symbol referred to by the reloc.  */
6206
0
    if (!get_sym_h (&h, &isym, &tsec, NULL, &isymbuf,
6207
0
        ELF32_R_SYM (irel->r_info), abfd))
6208
0
      goto error_return;
6209
6210
0
    if (isym != NULL)
6211
0
      {
6212
0
        if (tsec != NULL)
6213
0
    ;
6214
0
        else if (isym->st_shndx == SHN_ABS)
6215
0
    tsec = bfd_abs_section_ptr;
6216
0
        else
6217
0
    continue;
6218
6219
0
        toff = isym->st_value;
6220
0
        sym_type = ELF_ST_TYPE (isym->st_info);
6221
0
      }
6222
0
    else
6223
0
      {
6224
0
        if (tsec != NULL)
6225
0
    toff = h->root.u.def.value;
6226
0
        else if (h->root.type == bfd_link_hash_undefined
6227
0
           || h->root.type == bfd_link_hash_undefweak)
6228
0
    {
6229
0
      unsigned long indx;
6230
6231
0
      indx = ELF32_R_SYM (irel->r_info) - symtab_hdr->sh_info;
6232
0
      tsec = bfd_und_section_ptr;
6233
0
      toff = bfd_link_relocatable (link_info) ? indx : 0;
6234
0
    }
6235
0
        else
6236
0
    continue;
6237
6238
        /* If this branch is to __tls_get_addr then we may later
6239
     optimise away the call.  We won't be needing a long-
6240
     branch stub in that case.  */
6241
0
        if (bfd_link_executable (link_info)
6242
0
      && h == htab->tls_get_addr
6243
0
      && irel != internal_relocs)
6244
0
    {
6245
0
      unsigned long t_symndx = ELF32_R_SYM (irel[-1].r_info);
6246
0
      unsigned long t_rtype = ELF32_R_TYPE (irel[-1].r_info);
6247
0
      unsigned int tls_mask = 0;
6248
6249
      /* The previous reloc should be one of R_PPC_TLSGD or
6250
         R_PPC_TLSLD, or for older object files, a reloc
6251
         on the __tls_get_addr arg setup insn.  Get tls
6252
         mask bits from the symbol on that reloc.  */
6253
0
      if (t_symndx < symtab_hdr->sh_info)
6254
0
        {
6255
0
          bfd_vma *local_got_offsets = elf_local_got_offsets (abfd);
6256
6257
0
          if (local_got_offsets != NULL)
6258
0
      {
6259
0
        struct plt_entry **local_plt = (struct plt_entry **)
6260
0
          (local_got_offsets + symtab_hdr->sh_info);
6261
0
        char *lgot_masks = (char *)
6262
0
          (local_plt + symtab_hdr->sh_info);
6263
0
        tls_mask = lgot_masks[t_symndx];
6264
0
      }
6265
0
        }
6266
0
      else
6267
0
        {
6268
0
          struct elf_link_hash_entry *th
6269
0
      = elf_sym_hashes (abfd)[t_symndx - symtab_hdr->sh_info];
6270
6271
0
          while (th->root.type == bfd_link_hash_indirect
6272
0
           || th->root.type == bfd_link_hash_warning)
6273
0
      th = (struct elf_link_hash_entry *) th->root.u.i.link;
6274
6275
0
          tls_mask
6276
0
      = ((struct ppc_elf_link_hash_entry *) th)->tls_mask;
6277
0
        }
6278
6279
      /* The mask bits tell us if the call will be
6280
         optimised away.  */
6281
0
      if ((tls_mask & TLS_TLS) != 0 && (tls_mask & TLS_GD) == 0
6282
0
          && (t_rtype == R_PPC_TLSGD
6283
0
        || t_rtype == R_PPC_GOT_TLSGD16
6284
0
        || t_rtype == R_PPC_GOT_TLSGD16_LO))
6285
0
        continue;
6286
0
      if ((tls_mask & TLS_TLS) != 0 && (tls_mask & TLS_LD) == 0
6287
0
          && (t_rtype == R_PPC_TLSLD
6288
0
        || t_rtype == R_PPC_GOT_TLSLD16
6289
0
        || t_rtype == R_PPC_GOT_TLSLD16_LO))
6290
0
        continue;
6291
0
    }
6292
6293
0
        sym_type = h->type;
6294
0
      }
6295
6296
0
    if (r_type == R_PPC_ADDR16_HA)
6297
0
      {
6298
0
        if (h != NULL
6299
0
      && !h->def_regular
6300
0
      && h->protected_def
6301
0
      && ppc_elf_hash_entry (h)->has_addr16_ha
6302
0
      && ppc_elf_hash_entry (h)->has_addr16_lo)
6303
0
    picfixup_size += 12;
6304
0
        continue;
6305
0
      }
6306
6307
    /* The condition here under which we call find_plt_ent must
6308
       match that in relocate_section.  If we call find_plt_ent here
6309
       but not in relocate_section, or vice versa, then the branch
6310
       destination used here may be incorrect.  */
6311
0
    plist = NULL;
6312
0
    if (h != NULL)
6313
0
      {
6314
        /* We know is_branch_reloc (r_type) is true.  */
6315
0
        if (h->type == STT_GNU_IFUNC
6316
0
      || r_type == R_PPC_PLTREL24)
6317
0
    plist = &h->plt.plist;
6318
0
      }
6319
0
    else if (sym_type == STT_GNU_IFUNC
6320
0
       && elf_local_got_offsets (abfd) != NULL)
6321
0
      {
6322
0
        bfd_vma *local_got_offsets = elf_local_got_offsets (abfd);
6323
0
        struct plt_entry **local_plt = (struct plt_entry **)
6324
0
    (local_got_offsets + symtab_hdr->sh_info);
6325
0
        plist = local_plt + ELF32_R_SYM (irel->r_info);
6326
0
      }
6327
0
    if (plist != NULL)
6328
0
      {
6329
0
        bfd_vma addend = 0;
6330
0
        struct plt_entry *ent;
6331
6332
0
        if (r_type == R_PPC_PLTREL24 && bfd_link_pic (link_info))
6333
0
    addend = irel->r_addend;
6334
0
        ent = find_plt_ent (plist, got2, addend);
6335
0
        if (ent != NULL)
6336
0
    {
6337
0
      if (htab->plt_type == PLT_NEW
6338
0
          || h == NULL
6339
0
          || !htab->elf.dynamic_sections_created
6340
0
          || h->dynindx == -1)
6341
0
        {
6342
0
          tsec = htab->glink;
6343
0
          toff = ent->glink_offset;
6344
0
        }
6345
0
      else
6346
0
        {
6347
0
          tsec = htab->elf.splt;
6348
0
          toff = ent->plt.offset;
6349
0
        }
6350
0
    }
6351
0
      }
6352
6353
    /* If the branch and target are in the same section, you have
6354
       no hope of adding stubs.  We'll error out later should the
6355
       branch overflow.  */
6356
0
    if (tsec == isec)
6357
0
      continue;
6358
6359
    /* toff is used for the symbol index when the symbol is
6360
       undefined and we're doing a relocatable link, so we can't
6361
       support addends.  It would be possible to do so by
6362
       putting the addend in one_branch_fixup but addends on
6363
       branches are rare so it hardly seems worth supporting.  */
6364
0
    if (bfd_link_relocatable (link_info)
6365
0
        && tsec == bfd_und_section_ptr
6366
0
        && r_type != R_PPC_PLTREL24
6367
0
        && irel->r_addend != 0)
6368
0
      continue;
6369
6370
    /* There probably isn't any reason to handle symbols in
6371
       SEC_MERGE sections;  SEC_MERGE doesn't seem a likely
6372
       attribute for a code section, and we are only looking at
6373
       branches.  However, implement it correctly here as a
6374
       reference for other target relax_section functions.  */
6375
0
    if (0 && tsec->sec_info_type == SEC_INFO_TYPE_MERGE)
6376
0
      {
6377
        /* At this stage in linking, no SEC_MERGE symbol has been
6378
     adjusted, so all references to such symbols need to be
6379
     passed through _bfd_merged_section_offset.  (Later, in
6380
     relocate_section, all SEC_MERGE symbols *except* for
6381
     section symbols have been adjusted.)
6382
6383
     gas may reduce relocations against symbols in SEC_MERGE
6384
     sections to a relocation against the section symbol when
6385
     the original addend was zero.  When the reloc is against
6386
     a section symbol we should include the addend in the
6387
     offset passed to _bfd_merged_section_offset, since the
6388
     location of interest is the original symbol.  On the
6389
     other hand, an access to "sym+addend" where "sym" is not
6390
     a section symbol should not include the addend;  Such an
6391
     access is presumed to be an offset from "sym";  The
6392
     location of interest is just "sym".  */
6393
0
        if (sym_type == STT_SECTION
6394
0
      && r_type != R_PPC_PLTREL24)
6395
0
    toff += irel->r_addend;
6396
6397
0
        toff
6398
0
    = _bfd_merged_section_offset (abfd, &tsec,
6399
0
                elf_section_data (tsec)->sec_info,
6400
0
                toff);
6401
6402
0
        if (sym_type != STT_SECTION
6403
0
      && r_type != R_PPC_PLTREL24)
6404
0
    toff += irel->r_addend;
6405
0
      }
6406
    /* PLTREL24 addends are special.  */
6407
0
    else if (r_type != R_PPC_PLTREL24)
6408
0
      toff += irel->r_addend;
6409
6410
    /* Attempted -shared link of non-pic code loses.  */
6411
0
    if ((!bfd_link_relocatable (link_info)
6412
0
         && tsec == bfd_und_section_ptr)
6413
0
        || tsec->output_section == NULL
6414
0
        || (tsec->owner != NULL
6415
0
      && (tsec->owner->flags & BFD_PLUGIN) != 0))
6416
0
      continue;
6417
6418
0
    roff = irel->r_offset;
6419
0
    reladdr = isec->output_section->vma + isec->output_offset + roff;
6420
6421
    /* Avoid creating a lot of unnecessary fixups when
6422
       relocatable if the output section size is such that a
6423
       fixup can be created at final link.
6424
       The max_branch_offset adjustment allows for some number
6425
       of other fixups being needed at final link.  */
6426
0
    if (bfd_link_relocatable (link_info)
6427
0
        && (isec->output_section->rawsize - (isec->output_offset + roff)
6428
0
      < max_branch_offset - (max_branch_offset >> 4)))
6429
0
      continue;
6430
6431
    /* If the branch is in range, no need to do anything.  */
6432
0
    if (tsec != bfd_und_section_ptr
6433
0
        && (!bfd_link_relocatable (link_info)
6434
      /* A relocatable link may have sections moved during
6435
         final link, so do not presume they remain in range.  */
6436
0
      || tsec->output_section == isec->output_section))
6437
0
      {
6438
0
        bfd_vma symaddr;
6439
6440
0
        symaddr = tsec->output_section->vma + tsec->output_offset + toff;
6441
0
        if (symaddr - reladdr + max_branch_offset
6442
0
      < 2 * max_branch_offset)
6443
0
    continue;
6444
0
      }
6445
6446
    /* Look for an existing fixup to this address.  */
6447
0
    for (f = branch_fixups; f ; f = f->next)
6448
0
      if (f->tsec == tsec && f->toff == toff)
6449
0
        break;
6450
6451
0
    if (f == NULL)
6452
0
      {
6453
0
        size_t size;
6454
0
        unsigned long stub_rtype;
6455
6456
0
        val = trampoff - roff;
6457
0
        if (val >= max_branch_offset)
6458
    /* Oh dear, we can't reach a trampoline.  Don't try to add
6459
       one.  We'll report an error later.  */
6460
0
    continue;
6461
6462
0
        if (bfd_link_pic (link_info))
6463
0
    {
6464
0
      size = 4 * ARRAY_SIZE (shared_stub_entry);
6465
0
      insn_offset = 12;
6466
0
    }
6467
0
        else
6468
0
    {
6469
0
      size = 4 * ARRAY_SIZE (stub_entry);
6470
0
      insn_offset = 0;
6471
0
    }
6472
0
        stub_rtype = R_PPC_RELAX;
6473
0
        if (tsec == htab->elf.splt
6474
0
      || tsec == htab->glink)
6475
0
    {
6476
0
      stub_rtype = R_PPC_RELAX_PLT;
6477
0
      if (r_type == R_PPC_PLTREL24)
6478
0
        stub_rtype = R_PPC_RELAX_PLTREL24;
6479
0
    }
6480
6481
        /* Hijack the old relocation.  Since we need two
6482
     relocations for this use a "composite" reloc.  */
6483
0
        irel->r_info = ELF32_R_INFO (ELF32_R_SYM (irel->r_info),
6484
0
             stub_rtype);
6485
0
        irel->r_offset = trampoff + insn_offset;
6486
0
        if (r_type == R_PPC_PLTREL24
6487
0
      && stub_rtype != R_PPC_RELAX_PLTREL24)
6488
0
    irel->r_addend = 0;
6489
6490
        /* Record the fixup so we don't do it again this section.  */
6491
0
        f = bfd_malloc (sizeof (*f));
6492
0
        f->next = branch_fixups;
6493
0
        f->tsec = tsec;
6494
0
        f->toff = toff;
6495
0
        f->trampoff = trampoff;
6496
0
        branch_fixups = f;
6497
6498
0
        trampoff += size;
6499
0
        changes++;
6500
0
      }
6501
0
    else
6502
0
      {
6503
0
        val = f->trampoff - roff;
6504
0
        if (val >= max_branch_offset)
6505
0
    continue;
6506
6507
        /* Nop out the reloc, since we're finalizing things here.  */
6508
0
        irel->r_info = ELF32_R_INFO (0, R_PPC_NONE);
6509
0
      }
6510
6511
0
    link_info->callbacks->minfo
6512
0
      (_("%pB: Adjusting branch at 0x%V towards \"%s\" in section %s\n"),
6513
0
       abfd, reladdr,
6514
0
       (h && h->root.root.string? h->root.root.string : "<unknown>"),
6515
0
       f->tsec->name);
6516
6517
    /* Get the section contents.  */
6518
0
    if (contents == NULL)
6519
0
      {
6520
        /* Get cached copy if it exists.  */
6521
0
        if (elf_section_data (isec)->this_hdr.contents != NULL)
6522
0
    contents = elf_section_data (isec)->this_hdr.contents;
6523
        /* Go get them off disk.  */
6524
0
        else if (!bfd_malloc_and_get_section (abfd, isec, &contents))
6525
0
    goto error_return;
6526
0
      }
6527
6528
    /* Fix up the existing branch to hit the trampoline.  */
6529
0
    hit_addr = contents + roff;
6530
0
    switch (r_type)
6531
0
      {
6532
0
      case R_PPC_REL24:
6533
0
      case R_PPC_LOCAL24PC:
6534
0
      case R_PPC_PLTREL24:
6535
0
        t0 = bfd_get_32 (abfd, hit_addr);
6536
0
        t0 &= ~0x3fffffc;
6537
0
        t0 |= val & 0x3fffffc;
6538
0
        bfd_put_32 (abfd, t0, hit_addr);
6539
0
        break;
6540
6541
0
      case R_PPC_REL14:
6542
0
      case R_PPC_REL14_BRTAKEN:
6543
0
      case R_PPC_REL14_BRNTAKEN:
6544
0
        t0 = bfd_get_32 (abfd, hit_addr);
6545
0
        t0 &= ~0xfffc;
6546
0
        t0 |= val & 0xfffc;
6547
0
        bfd_put_32 (abfd, t0, hit_addr);
6548
0
        break;
6549
0
      }
6550
0
  }
6551
6552
0
      while (branch_fixups != NULL)
6553
0
  {
6554
0
    struct one_branch_fixup *f = branch_fixups;
6555
0
    branch_fixups = branch_fixups->next;
6556
0
    free (f);
6557
0
  }
6558
0
    }
6559
6560
0
  workaround_change = false;
6561
0
  newsize = trampoff;
6562
0
  if (htab->params->ppc476_workaround
6563
0
      && (!bfd_link_relocatable (link_info)
6564
0
    || isec->output_section->alignment_power >= htab->params->pagesize_p2))
6565
0
    {
6566
0
      bfd_vma addr, end_addr;
6567
0
      unsigned int crossings;
6568
0
      bfd_vma pagesize = (bfd_vma) 1 << htab->params->pagesize_p2;
6569
6570
0
      addr = isec->output_section->vma + isec->output_offset;
6571
0
      end_addr = addr + trampoff;
6572
0
      addr &= -pagesize;
6573
0
      crossings = ((end_addr & -pagesize) - addr) >> htab->params->pagesize_p2;
6574
0
      if (crossings != 0)
6575
0
  {
6576
    /* Keep space aligned, to ensure the patch code itself does
6577
       not cross a page.  Don't decrease size calculated on a
6578
       previous pass as otherwise we might never settle on a layout.  */
6579
0
    newsize = 15 - ((end_addr - 1) & 15);
6580
0
    newsize += crossings * 16;
6581
0
    if (relax_info->workaround_size < newsize)
6582
0
      {
6583
0
        relax_info->workaround_size = newsize;
6584
0
        workaround_change = true;
6585
0
      }
6586
    /* Ensure relocate_section is called.  */
6587
0
    isec->flags |= SEC_RELOC;
6588
0
  }
6589
0
      newsize = trampoff + relax_info->workaround_size;
6590
0
    }
6591
6592
0
  if (htab->params->pic_fixup > 0)
6593
0
    {
6594
0
      picfixup_size -= relax_info->picfixup_size;
6595
0
      if (picfixup_size != 0)
6596
0
  relax_info->picfixup_size += picfixup_size;
6597
0
      newsize += relax_info->picfixup_size;
6598
0
    }
6599
6600
0
  if (changes != 0 || picfixup_size != 0 || workaround_change)
6601
0
    isec->size = newsize;
6602
6603
0
  if (isymbuf != NULL
6604
0
      && symtab_hdr->contents != (unsigned char *) isymbuf)
6605
0
    {
6606
0
      if (! link_info->keep_memory)
6607
0
  free (isymbuf);
6608
0
      else
6609
0
  {
6610
    /* Cache the symbols for elf_link_input_bfd.  */
6611
0
    symtab_hdr->contents = (unsigned char *) isymbuf;
6612
0
  }
6613
0
    }
6614
6615
0
  if (contents != NULL
6616
0
      && elf_section_data (isec)->this_hdr.contents != contents)
6617
0
    {
6618
0
      if (!changes && !link_info->keep_memory)
6619
0
  free (contents);
6620
0
      else
6621
0
  {
6622
    /* Cache the section contents for elf_link_input_bfd.  */
6623
0
    elf_section_data (isec)->this_hdr.contents = contents;
6624
0
  }
6625
0
    }
6626
6627
0
  changes += picfixup_size;
6628
0
  if (changes != 0)
6629
0
    {
6630
      /* Append sufficient NOP relocs so we can write out relocation
6631
   information for the trampolines.  */
6632
0
      size_t old_size = isec->reloc_count * sizeof (*internal_relocs);
6633
0
      size_t extra_size = changes * sizeof (*internal_relocs);
6634
0
      internal_relocs = bfd_realloc (internal_relocs, old_size + extra_size);
6635
0
      elf_section_data (isec)->relocs = internal_relocs;
6636
0
      if (!internal_relocs)
6637
0
  goto error_return;
6638
0
      memset ((char *) internal_relocs + old_size, 0, extra_size);
6639
0
      isec->reloc_count += changes;
6640
0
      Elf_Internal_Shdr *rel_hdr = _bfd_elf_single_rel_hdr (isec);
6641
0
      rel_hdr->sh_size += changes * rel_hdr->sh_entsize;
6642
0
    }
6643
0
  else if (elf_section_data (isec)->relocs != internal_relocs)
6644
0
    free (internal_relocs);
6645
6646
0
  *again = changes != 0 || workaround_change;
6647
0
  return true;
6648
6649
0
 error_return:
6650
0
  while (branch_fixups != NULL)
6651
0
    {
6652
0
      struct one_branch_fixup *f = branch_fixups;
6653
0
      branch_fixups = branch_fixups->next;
6654
0
      free (f);
6655
0
    }
6656
0
  if ((unsigned char *) isymbuf != symtab_hdr->contents)
6657
0
    free (isymbuf);
6658
0
  if (elf_section_data (isec)->this_hdr.contents != contents)
6659
0
    free (contents);
6660
0
  if (elf_section_data (isec)->relocs != internal_relocs)
6661
0
    free (internal_relocs);
6662
0
  return false;
6663
0
}
6664

6665
/* What to do when ld finds relocations against symbols defined in
6666
   discarded sections.  */
6667
6668
static unsigned int
6669
ppc_elf_action_discarded (asection *sec)
6670
0
{
6671
0
  if (strcmp (".fixup", sec->name) == 0)
6672
0
    return 0;
6673
6674
0
  if (strcmp (".got2", sec->name) == 0)
6675
0
    return 0;
6676
6677
0
  return _bfd_elf_default_action_discarded (sec);
6678
0
}
6679

6680
/* Fill in the address for a pointer generated in a linker section.  */
6681
6682
static bfd_vma
6683
elf_finish_pointer_linker_section (bfd *input_bfd,
6684
           elf_linker_section_t *lsect,
6685
           struct elf_link_hash_entry *h,
6686
           bfd_vma relocation,
6687
           const Elf_Internal_Rela *rel)
6688
0
{
6689
0
  elf_linker_section_pointers_t *linker_section_ptr;
6690
6691
0
  BFD_ASSERT (lsect != NULL);
6692
6693
0
  if (h != NULL)
6694
0
    {
6695
      /* Handle global symbol.  */
6696
0
      struct ppc_elf_link_hash_entry *eh;
6697
6698
0
      eh = (struct ppc_elf_link_hash_entry *) h;
6699
0
      BFD_ASSERT (eh->elf.def_regular);
6700
0
      linker_section_ptr = eh->linker_section_pointer;
6701
0
    }
6702
0
  else
6703
0
    {
6704
      /* Handle local symbol.  */
6705
0
      unsigned long r_symndx = ELF32_R_SYM (rel->r_info);
6706
6707
0
      BFD_ASSERT (is_ppc_elf (input_bfd));
6708
0
      BFD_ASSERT (elf_local_ptr_offsets (input_bfd) != NULL);
6709
0
      linker_section_ptr = elf_local_ptr_offsets (input_bfd)[r_symndx];
6710
0
    }
6711
6712
0
  linker_section_ptr = elf_find_pointer_linker_section (linker_section_ptr,
6713
0
              rel->r_addend,
6714
0
              lsect);
6715
0
  BFD_ASSERT (linker_section_ptr != NULL);
6716
6717
  /* Offset will always be a multiple of four, so use the bottom bit
6718
     as a "written" flag.  */
6719
0
  if ((linker_section_ptr->offset & 1) == 0)
6720
0
    {
6721
0
      bfd_put_32 (lsect->section->owner,
6722
0
      relocation + linker_section_ptr->addend,
6723
0
      lsect->section->contents + linker_section_ptr->offset);
6724
0
      linker_section_ptr->offset += 1;
6725
0
    }
6726
6727
0
  relocation = (lsect->section->output_section->vma
6728
0
    + lsect->section->output_offset
6729
0
    + linker_section_ptr->offset - 1
6730
0
    - SYM_VAL (lsect->sym));
6731
6732
#ifdef DEBUG
6733
  fprintf (stderr,
6734
     "Finish pointer in linker section %s, offset = %ld (0x%lx)\n",
6735
     lsect->name, (long) relocation, (long) relocation);
6736
#endif
6737
6738
0
  return relocation;
6739
0
}
6740
6741
#define PPC_LO(v) ((v) & 0xffff)
6742
0
#define PPC_HI(v) (((v) >> 16) & 0xffff)
6743
0
#define PPC_HA(v) PPC_HI ((v) + 0x8000)
6744
6745
static void
6746
write_glink_stub (struct elf_link_hash_entry *h, struct plt_entry *ent,
6747
      asection *plt_sec, unsigned char *p,
6748
      struct bfd_link_info *info)
6749
0
{
6750
0
  struct ppc_elf_link_hash_table *htab = ppc_elf_hash_table (info);
6751
0
  bfd *output_bfd = info->output_bfd;
6752
0
  bfd_vma plt;
6753
0
  unsigned char *end = p + GLINK_ENTRY_SIZE (htab, h);
6754
6755
0
  if (h != NULL
6756
0
      && h == htab->tls_get_addr
6757
0
      && !htab->params->no_tls_get_addr_opt)
6758
0
    {
6759
0
      bfd_put_32 (output_bfd, LWZ_11_3, p);
6760
0
      p += 4;
6761
0
      bfd_put_32 (output_bfd, LWZ_12_3 + 4, p);
6762
0
      p += 4;
6763
0
      bfd_put_32 (output_bfd, MR_0_3, p);
6764
0
      p += 4;
6765
0
      bfd_put_32 (output_bfd, CMPWI_11_0, p);
6766
0
      p += 4;
6767
0
      bfd_put_32 (output_bfd, ADD_3_12_2, p);
6768
0
      p += 4;
6769
0
      bfd_put_32 (output_bfd, BEQLR, p);
6770
0
      p += 4;
6771
0
      bfd_put_32 (output_bfd, MR_3_0, p);
6772
0
      p += 4;
6773
0
      bfd_put_32 (output_bfd, NOP, p);
6774
0
      p += 4;
6775
0
    }
6776
6777
0
  plt = ((ent->plt.offset & ~1)
6778
0
   + plt_sec->output_section->vma
6779
0
   + plt_sec->output_offset);
6780
6781
0
  if (bfd_link_pic (info))
6782
0
    {
6783
0
      bfd_vma got = 0;
6784
6785
0
      if (ent->addend >= 32768)
6786
0
  got = (ent->addend
6787
0
         + ent->sec->output_section->vma
6788
0
         + ent->sec->output_offset);
6789
0
      else if (htab->elf.hgot != NULL)
6790
0
  got = SYM_VAL (htab->elf.hgot);
6791
6792
0
      plt -= got;
6793
6794
0
      if (plt + 0x8000 < 0x10000)
6795
0
  bfd_put_32 (output_bfd, LWZ_11_30 + PPC_LO (plt), p);
6796
0
      else
6797
0
  {
6798
0
    bfd_put_32 (output_bfd, ADDIS_11_30 + PPC_HA (plt), p);
6799
0
    p += 4;
6800
0
    bfd_put_32 (output_bfd, LWZ_11_11 + PPC_LO (plt), p);
6801
0
  }
6802
0
    }
6803
0
  else
6804
0
    {
6805
0
      bfd_put_32 (output_bfd, LIS_11 + PPC_HA (plt), p);
6806
0
      p += 4;
6807
0
      bfd_put_32 (output_bfd, LWZ_11_11 + PPC_LO (plt), p);
6808
0
    }
6809
0
  p += 4;
6810
0
  bfd_put_32 (output_bfd, MTCTR_11, p);
6811
0
  p += 4;
6812
0
  bfd_put_32 (output_bfd, BCTR, p);
6813
0
  p += 4;
6814
0
  while (p < end)
6815
0
    {
6816
0
      bfd_put_32 (output_bfd, htab->params->ppc476_workaround ? BA : NOP, p);
6817
0
      p += 4;
6818
0
    }
6819
0
}
6820
6821
/* Return true if symbol is defined statically.  */
6822
6823
static bool
6824
is_static_defined (struct elf_link_hash_entry *h)
6825
0
{
6826
0
  return ((h->root.type == bfd_link_hash_defined
6827
0
     || h->root.type == bfd_link_hash_defweak)
6828
0
    && h->root.u.def.section != NULL
6829
0
    && h->root.u.def.section->output_section != NULL);
6830
0
}
6831
6832
/* If INSN is an opcode that may be used with an @tls operand, return
6833
   the transformed insn for TLS optimisation, otherwise return 0.  If
6834
   REG is non-zero only match an insn with RB or RA equal to REG.  */
6835
6836
unsigned int
6837
_bfd_elf_ppc_at_tls_transform (unsigned int insn, unsigned int reg)
6838
0
{
6839
0
  unsigned int rtra;
6840
6841
0
  if ((insn & (0x3fu << 26)) != 31 << 26)
6842
0
    return 0;
6843
6844
0
  if (reg == 0 || ((insn >> 11) & 0x1f) == reg)
6845
0
    rtra = insn & ((1 << 26) - (1 << 16));
6846
0
  else if (((insn >> 16) & 0x1f) == reg)
6847
0
    rtra = (insn & (0x1f << 21)) | ((insn & (0x1f << 11)) << 5);
6848
0
  else
6849
0
    return 0;
6850
6851
0
  if ((insn & (0x3ff << 1)) == 266 << 1)
6852
    /* add -> addi.  */
6853
0
    insn = 14 << 26;
6854
0
  else if ((insn & (0x1f << 1)) == 23 << 1
6855
0
     && ((insn & (0x1f << 6)) < 14 << 6
6856
0
         || ((insn & (0x1f << 6)) >= 16 << 6
6857
0
       && (insn & (0x1f << 6)) < 24 << 6)))
6858
    /* load and store indexed -> dform.  */
6859
0
    insn = (32u | ((insn >> 6) & 0x1f)) << 26;
6860
0
  else if ((insn & (((0x1a << 5) | 0x1f) << 1)) == 21 << 1)
6861
    /* ldx, ldux, stdx, stdux -> ld, ldu, std, stdu.  */
6862
0
    insn = ((58u | ((insn >> 6) & 4)) << 26) | ((insn >> 6) & 1);
6863
0
  else if ((insn & (((0x1f << 5) | 0x1f) << 1)) == 341 << 1)
6864
    /* lwax -> lwa.  */
6865
0
    insn = (58u << 26) | 2;
6866
0
  else
6867
0
    return 0;
6868
0
  insn |= rtra;
6869
0
  return insn;
6870
0
}
6871
6872
/* If INSN is an opcode that may be used with an @tprel operand, return
6873
   the transformed insn for an undefined weak symbol, ie. with the
6874
   thread pointer REG operand removed.  Otherwise return 0.  */
6875
6876
unsigned int
6877
_bfd_elf_ppc_at_tprel_transform (unsigned int insn, unsigned int reg)
6878
0
{
6879
0
  if ((insn & (0x1f << 16)) == reg << 16
6880
0
      && ((insn & (0x3fu << 26)) == 14u << 26 /* addi */
6881
0
    || (insn & (0x3fu << 26)) == 15u << 26 /* addis */
6882
0
    || (insn & (0x3fu << 26)) == 32u << 26 /* lwz */
6883
0
    || (insn & (0x3fu << 26)) == 34u << 26 /* lbz */
6884
0
    || (insn & (0x3fu << 26)) == 36u << 26 /* stw */
6885
0
    || (insn & (0x3fu << 26)) == 38u << 26 /* stb */
6886
0
    || (insn & (0x3fu << 26)) == 40u << 26 /* lhz */
6887
0
    || (insn & (0x3fu << 26)) == 42u << 26 /* lha */
6888
0
    || (insn & (0x3fu << 26)) == 44u << 26 /* sth */
6889
0
    || (insn & (0x3fu << 26)) == 46u << 26 /* lmw */
6890
0
    || (insn & (0x3fu << 26)) == 47u << 26 /* stmw */
6891
0
    || (insn & (0x3fu << 26)) == 48u << 26 /* lfs */
6892
0
    || (insn & (0x3fu << 26)) == 50u << 26 /* lfd */
6893
0
    || (insn & (0x3fu << 26)) == 52u << 26 /* stfs */
6894
0
    || (insn & (0x3fu << 26)) == 54u << 26 /* stfd */
6895
0
    || ((insn & (0x3fu << 26)) == 58u << 26 /* lwa,ld,lmd */
6896
0
        && (insn & 3) != 1)
6897
0
    || ((insn & (0x3fu << 26)) == 62u << 26 /* std, stmd */
6898
0
        && ((insn & 3) == 0 || (insn & 3) == 3))))
6899
0
    {
6900
0
      insn &= ~(0x1f << 16);
6901
0
    }
6902
0
  else if ((insn & (0x1f << 21)) == reg << 21
6903
0
     && ((insn & (0x3eu << 26)) == 24u << 26 /* ori, oris */
6904
0
         || (insn & (0x3eu << 26)) == 26u << 26 /* xori,xoris */
6905
0
         || (insn & (0x3eu << 26)) == 28u << 26 /* andi,andis */))
6906
0
    {
6907
0
      insn &= ~(0x1f << 21);
6908
0
      insn |= (insn & (0x1f << 16)) << 5;
6909
0
      if ((insn & (0x3eu << 26)) == 26u << 26 /* xori,xoris */)
6910
0
  insn -= 2 >> 26;  /* convert to ori,oris */
6911
0
    }
6912
0
  else
6913
0
    insn = 0;
6914
0
  return insn;
6915
0
}
6916
6917
static bool
6918
is_insn_ds_form (unsigned int insn)
6919
0
{
6920
0
  return ((insn & (0x3fu << 26)) == 58u << 26 /* ld,ldu,lwa */
6921
0
    || (insn & (0x3fu << 26)) == 62u << 26 /* std,stdu,stq */
6922
0
    || (insn & (0x3fu << 26)) == 57u << 26 /* lfdp */
6923
0
    || (insn & (0x3fu << 26)) == 61u << 26 /* stfdp */);
6924
0
}
6925
6926
static bool
6927
is_insn_dq_form (unsigned int insn)
6928
0
{
6929
0
  return ((insn & (0x3fu << 26)) == 56u << 26 /* lq */
6930
0
    || ((insn & (0x3fu << 26)) == (61u << 26) /* lxv, stxv */
6931
0
        && (insn & 3) == 1));
6932
0
}
6933
6934
static bool
6935
swap_reloc_out (bfd *obfd, Elf_Internal_Rela *rel, bfd_byte *loc, asection *s)
6936
0
{
6937
0
  if ((size_t) (loc - s->contents) >= s->size)
6938
0
    return false;
6939
0
  bfd_elf32_swap_reloca_out (obfd, rel, loc);
6940
0
  return true;
6941
0
}
6942
6943
static bool
6944
count_and_swap_reloc_out (bfd *obfd, Elf_Internal_Rela *rel, asection *s)
6945
0
{
6946
0
  bfd_byte *loc = s->contents;
6947
0
  loc += s->reloc_count++ * sizeof (Elf32_External_Rela);
6948
0
  return swap_reloc_out (obfd, rel, loc, s);
6949
0
}
6950
6951
/* The RELOCATE_SECTION function is called by the ELF backend linker
6952
   to handle the relocations for a section.
6953
6954
   The relocs are always passed as Rela structures; if the section
6955
   actually uses Rel structures, the r_addend field will always be
6956
   zero.
6957
6958
   This function is responsible for adjust the section contents as
6959
   necessary, and (if using Rela relocs and generating a
6960
   relocatable output file) adjusting the reloc addend as
6961
   necessary.
6962
6963
   This function does not have to worry about setting the reloc
6964
   address or the reloc symbol index.
6965
6966
   LOCAL_SYMS is a pointer to the swapped in local symbols.
6967
6968
   LOCAL_SECTIONS is an array giving the section in the input file
6969
   corresponding to the st_shndx field of each local symbol.
6970
6971
   The global hash table entry for the global symbols can be found
6972
   via elf_sym_hashes (input_bfd).
6973
6974
   When generating relocatable output, this function must handle
6975
   STB_LOCAL/STT_SECTION symbols specially.  The output symbol is
6976
   going to be the section symbol corresponding to the output
6977
   section, which means that the addend must be adjusted
6978
   accordingly.  */
6979
6980
static int
6981
ppc_elf_relocate_section (bfd *output_bfd,
6982
        struct bfd_link_info *info,
6983
        bfd *input_bfd,
6984
        asection *input_section,
6985
        bfd_byte *contents,
6986
        Elf_Internal_Rela *relocs,
6987
        Elf_Internal_Sym *local_syms,
6988
        asection **local_sections)
6989
0
{
6990
0
  Elf_Internal_Shdr *symtab_hdr;
6991
0
  struct elf_link_hash_entry **sym_hashes;
6992
0
  struct ppc_elf_link_hash_table *htab;
6993
0
  Elf_Internal_Rela *rel;
6994
0
  Elf_Internal_Rela *wrel;
6995
0
  Elf_Internal_Rela *relend;
6996
0
  Elf_Internal_Rela outrel;
6997
0
  asection *got2;
6998
0
  bfd_vma *local_got_offsets;
6999
0
  bool ret = true;
7000
0
  bfd_vma d_offset = (bfd_big_endian (input_bfd) ? 2 : 0);
7001
0
  bool is_vxworks_tls;
7002
0
  unsigned int picfixup_size = 0;
7003
0
  struct ppc_elf_relax_info *relax_info = NULL;
7004
7005
#ifdef DEBUG
7006
  _bfd_error_handler ("ppc_elf_relocate_section called for %pB section %pA, "
7007
          "%ld relocations%s",
7008
          input_bfd, input_section,
7009
          (long) input_section->reloc_count,
7010
          (bfd_link_relocatable (info)) ? " (relocatable)" : "");
7011
#endif
7012
7013
0
  if (!is_ppc_elf (input_bfd))
7014
0
    {
7015
0
      bfd_set_error (bfd_error_wrong_format);
7016
0
      return false;
7017
0
    }
7018
7019
0
  got2 = bfd_get_section_by_name (input_bfd, ".got2");
7020
7021
  /* Initialize howto table if not already done.  */
7022
0
  if (!ppc_elf_howto_table[R_PPC_ADDR32])
7023
0
    ppc_elf_howto_init ();
7024
7025
0
  htab = ppc_elf_hash_table (info);
7026
0
  local_got_offsets = elf_local_got_offsets (input_bfd);
7027
0
  symtab_hdr = &elf_symtab_hdr (input_bfd);
7028
0
  sym_hashes = elf_sym_hashes (input_bfd);
7029
  /* We have to handle relocations in vxworks .tls_vars sections
7030
     specially, because the dynamic loader is 'weird'.  */
7031
0
  is_vxworks_tls = (htab->elf.target_os == is_vxworks && bfd_link_pic (info)
7032
0
        && !strcmp (input_section->output_section->name,
7033
0
        ".tls_vars"));
7034
0
  if (input_section->sec_info_type == SEC_INFO_TYPE_TARGET)
7035
0
    relax_info = elf_section_data (input_section)->sec_info;
7036
0
  rel = wrel = relocs;
7037
0
  relend = relocs + input_section->reloc_count;
7038
0
  for (; rel < relend; wrel++, rel++)
7039
0
    {
7040
0
      enum elf_ppc_reloc_type r_type;
7041
0
      bfd_vma addend;
7042
0
      bfd_reloc_status_type r;
7043
0
      Elf_Internal_Sym *sym;
7044
0
      asection *sec;
7045
0
      struct elf_link_hash_entry *h;
7046
0
      const char *sym_name;
7047
0
      reloc_howto_type *howto;
7048
0
      unsigned long r_symndx;
7049
0
      bfd_vma relocation;
7050
0
      bfd_vma branch_bit, from;
7051
0
      bool unresolved_reloc, save_unresolved_reloc;
7052
0
      bool warned;
7053
0
      unsigned int tls_type, tls_mask, tls_gd;
7054
0
      struct plt_entry **ifunc, **plt_list;
7055
0
      struct reloc_howto_struct alt_howto;
7056
7057
0
    again:
7058
0
      r_type = ELF32_R_TYPE (rel->r_info);
7059
0
      sym = NULL;
7060
0
      sec = NULL;
7061
0
      h = NULL;
7062
0
      unresolved_reloc = false;
7063
0
      warned = false;
7064
0
      r_symndx = ELF32_R_SYM (rel->r_info);
7065
7066
0
      if (r_symndx < symtab_hdr->sh_info)
7067
0
  {
7068
0
    sym = local_syms + r_symndx;
7069
0
    sec = local_sections[r_symndx];
7070
0
    sym_name = bfd_elf_sym_name (input_bfd, symtab_hdr, sym, sec);
7071
7072
0
    relocation = _bfd_elf_rela_local_sym (output_bfd, sym, &sec, rel);
7073
0
  }
7074
0
      else
7075
0
  {
7076
0
    bool ignored;
7077
7078
0
    RELOC_FOR_GLOBAL_SYMBOL (info, input_bfd, input_section, rel,
7079
0
           r_symndx, symtab_hdr, sym_hashes,
7080
0
           h, sec, relocation,
7081
0
           unresolved_reloc, warned, ignored);
7082
7083
0
    sym_name = h->root.root.string;
7084
0
  }
7085
7086
0
      if (sec != NULL && discarded_section (sec))
7087
0
  {
7088
    /* For relocs against symbols from removed linkonce sections,
7089
       or sections discarded by a linker script, we just want the
7090
       section contents zeroed.  Avoid any special processing.  */
7091
0
    howto = NULL;
7092
0
    if (r_type < R_PPC_max)
7093
0
      howto = ppc_elf_howto_table[r_type];
7094
7095
0
    _bfd_clear_contents (howto, input_bfd, input_section,
7096
0
             contents, rel->r_offset);
7097
0
    wrel->r_offset = rel->r_offset;
7098
0
    wrel->r_info = 0;
7099
0
    wrel->r_addend = 0;
7100
7101
    /* For ld -r, remove relocations in debug sections against
7102
       symbols defined in discarded sections.  Not done for
7103
       non-debug to preserve relocs in .eh_frame which the
7104
       eh_frame editing code expects to be present.  */
7105
0
    if (bfd_link_relocatable (info)
7106
0
        && (input_section->flags & SEC_DEBUGGING))
7107
0
      wrel--;
7108
7109
0
    continue;
7110
0
  }
7111
7112
0
      if (bfd_link_relocatable (info))
7113
0
  {
7114
0
    if (got2 != NULL
7115
0
        && r_type == R_PPC_PLTREL24
7116
0
        && rel->r_addend != 0)
7117
0
      {
7118
        /* R_PPC_PLTREL24 is rather special.  If non-zero, the
7119
     addend specifies the GOT pointer offset within .got2.  */
7120
0
        rel->r_addend += got2->output_offset;
7121
0
      }
7122
0
    if (r_type != R_PPC_RELAX_PLT
7123
0
        && r_type != R_PPC_RELAX_PLTREL24
7124
0
        && r_type != R_PPC_RELAX)
7125
0
      goto copy_reloc;
7126
0
  }
7127
7128
      /* TLS optimizations.  Replace instruction sequences and relocs
7129
   based on information we collected in tls_optimize.  We edit
7130
   RELOCS so that --emit-relocs will output something sensible
7131
   for the final instruction stream.  */
7132
0
      tls_mask = 0;
7133
0
      tls_gd = 0;
7134
0
      if (h != NULL)
7135
0
  tls_mask = ((struct ppc_elf_link_hash_entry *) h)->tls_mask;
7136
0
      else if (local_got_offsets != NULL)
7137
0
  {
7138
0
    struct plt_entry **local_plt;
7139
0
    char *lgot_masks;
7140
0
    local_plt
7141
0
      = (struct plt_entry **) (local_got_offsets + symtab_hdr->sh_info);
7142
0
    lgot_masks = (char *) (local_plt + symtab_hdr->sh_info);
7143
0
    tls_mask = lgot_masks[r_symndx];
7144
0
  }
7145
7146
      /* Ensure reloc mapping code below stays sane.  */
7147
0
      if ((R_PPC_GOT_TLSLD16 & 3)    != (R_PPC_GOT_TLSGD16 & 3)
7148
0
    || (R_PPC_GOT_TLSLD16_LO & 3) != (R_PPC_GOT_TLSGD16_LO & 3)
7149
0
    || (R_PPC_GOT_TLSLD16_HI & 3) != (R_PPC_GOT_TLSGD16_HI & 3)
7150
0
    || (R_PPC_GOT_TLSLD16_HA & 3) != (R_PPC_GOT_TLSGD16_HA & 3)
7151
0
    || (R_PPC_GOT_TLSLD16 & 3)    != (R_PPC_GOT_TPREL16 & 3)
7152
0
    || (R_PPC_GOT_TLSLD16_LO & 3) != (R_PPC_GOT_TPREL16_LO & 3)
7153
0
    || (R_PPC_GOT_TLSLD16_HI & 3) != (R_PPC_GOT_TPREL16_HI & 3)
7154
0
    || (R_PPC_GOT_TLSLD16_HA & 3) != (R_PPC_GOT_TPREL16_HA & 3))
7155
0
  abort ();
7156
0
      switch (r_type)
7157
0
  {
7158
0
  default:
7159
0
    break;
7160
7161
0
  case R_PPC_GOT_TPREL16:
7162
0
  case R_PPC_GOT_TPREL16_LO:
7163
0
    if ((tls_mask & TLS_TLS) != 0
7164
0
        && (tls_mask & TLS_TPREL) == 0
7165
0
        && offset_in_range (input_section, rel->r_offset - d_offset, 4))
7166
0
      {
7167
0
        bfd_vma insn;
7168
7169
0
        insn = bfd_get_32 (input_bfd,
7170
0
         contents + rel->r_offset - d_offset);
7171
0
        insn &= 31 << 21;
7172
0
        insn |= 0x3c020000; /* addis 0,2,0 */
7173
0
        bfd_put_32 (input_bfd, insn,
7174
0
        contents + rel->r_offset - d_offset);
7175
0
        r_type = R_PPC_TPREL16_HA;
7176
0
        rel->r_info = ELF32_R_INFO (r_symndx, r_type);
7177
0
      }
7178
0
    break;
7179
7180
0
  case R_PPC_TLS:
7181
0
    if ((tls_mask & TLS_TLS) != 0
7182
0
        && (tls_mask & TLS_TPREL) == 0
7183
0
        && offset_in_range (input_section, rel->r_offset, 4))
7184
0
      {
7185
0
        bfd_vma insn;
7186
7187
0
        insn = bfd_get_32 (input_bfd, contents + rel->r_offset);
7188
0
        insn = _bfd_elf_ppc_at_tls_transform (insn, 2);
7189
0
        if (insn == 0)
7190
0
    abort ();
7191
0
        bfd_put_32 (input_bfd, insn, contents + rel->r_offset);
7192
0
        r_type = R_PPC_TPREL16_LO;
7193
0
        rel->r_info = ELF32_R_INFO (r_symndx, r_type);
7194
7195
        /* Was PPC_TLS which sits on insn boundary, now
7196
     PPC_TPREL16_LO which is at low-order half-word.  */
7197
0
        rel->r_offset += d_offset;
7198
0
      }
7199
0
    break;
7200
7201
0
  case R_PPC_GOT_TLSGD16_HI:
7202
0
  case R_PPC_GOT_TLSGD16_HA:
7203
0
    tls_gd = TLS_GDIE;
7204
0
    if ((tls_mask & TLS_TLS) != 0 && (tls_mask & TLS_GD) == 0
7205
0
        && offset_in_range (input_section, rel->r_offset - d_offset, 4))
7206
0
      goto tls_gdld_hi;
7207
0
    break;
7208
7209
0
  case R_PPC_GOT_TLSLD16_HI:
7210
0
  case R_PPC_GOT_TLSLD16_HA:
7211
0
    if ((tls_mask & TLS_TLS) != 0 && (tls_mask & TLS_LD) == 0
7212
0
        && offset_in_range (input_section, rel->r_offset - d_offset, 4))
7213
0
      {
7214
0
      tls_gdld_hi:
7215
0
        if ((tls_mask & tls_gd) != 0)
7216
0
    r_type = (((r_type - (R_PPC_GOT_TLSGD16 & 3)) & 3)
7217
0
        + R_PPC_GOT_TPREL16);
7218
0
        else
7219
0
    {
7220
0
      rel->r_offset -= d_offset;
7221
0
      bfd_put_32 (input_bfd, NOP, contents + rel->r_offset);
7222
0
      r_type = R_PPC_NONE;
7223
0
    }
7224
0
        rel->r_info = ELF32_R_INFO (r_symndx, r_type);
7225
0
      }
7226
0
    break;
7227
7228
0
  case R_PPC_GOT_TLSGD16:
7229
0
  case R_PPC_GOT_TLSGD16_LO:
7230
0
    tls_gd = TLS_GDIE;
7231
0
    if ((tls_mask & TLS_TLS) != 0 && (tls_mask & TLS_GD) == 0
7232
0
        && offset_in_range (input_section, rel->r_offset - d_offset, 4))
7233
0
      goto tls_ldgd_opt;
7234
0
    break;
7235
7236
0
  case R_PPC_GOT_TLSLD16:
7237
0
  case R_PPC_GOT_TLSLD16_LO:
7238
0
    if ((tls_mask & TLS_TLS) != 0 && (tls_mask & TLS_LD) == 0
7239
0
        && offset_in_range (input_section, rel->r_offset - d_offset, 4))
7240
0
      {
7241
0
        unsigned int insn1, insn2;
7242
0
        bfd_vma offset;
7243
7244
0
      tls_ldgd_opt:
7245
0
        offset = (bfd_vma) -1;
7246
        /* If not using the newer R_PPC_TLSGD/LD to mark
7247
     __tls_get_addr calls, we must trust that the call
7248
     stays with its arg setup insns, ie. that the next
7249
     reloc is the __tls_get_addr call associated with
7250
     the current reloc.  Edit both insns.  */
7251
0
        if (input_section->nomark_tls_get_addr
7252
0
      && rel + 1 < relend
7253
0
      && branch_reloc_hash_match (input_bfd, rel + 1,
7254
0
                htab->tls_get_addr))
7255
0
    offset = rel[1].r_offset;
7256
        /* We read the low GOT_TLS insn because we need to keep
7257
     the destination reg.  It may be something other than
7258
     the usual r3, and moved to r3 before the call by
7259
     intervening code.  */
7260
0
        insn1 = bfd_get_32 (input_bfd,
7261
0
          contents + rel->r_offset - d_offset);
7262
0
        if ((tls_mask & tls_gd) != 0)
7263
0
    {
7264
      /* IE */
7265
0
      insn1 &= (0x1f << 21) | (0x1f << 16);
7266
0
      insn1 |= 32u << 26; /* lwz */
7267
0
      if (offset != (bfd_vma) -1
7268
0
          && offset_in_range (input_section, offset, 4))
7269
0
        {
7270
0
          rel[1].r_info = ELF32_R_INFO (STN_UNDEF, R_PPC_NONE);
7271
0
          insn2 = 0x7c631214; /* add 3,3,2 */
7272
0
          bfd_put_32 (input_bfd, insn2, contents + offset);
7273
0
        }
7274
0
      r_type = (((r_type - (R_PPC_GOT_TLSGD16 & 3)) & 3)
7275
0
          + R_PPC_GOT_TPREL16);
7276
0
      rel->r_info = ELF32_R_INFO (r_symndx, r_type);
7277
0
    }
7278
0
        else
7279
0
    {
7280
      /* LE */
7281
0
      insn1 &= 0x1f << 21;
7282
0
      insn1 |= 0x3c020000;  /* addis r,2,0 */
7283
0
      if (tls_gd == 0)
7284
0
        {
7285
          /* Was an LD reloc.  */
7286
0
          for (r_symndx = 0;
7287
0
         r_symndx < symtab_hdr->sh_info;
7288
0
         r_symndx++)
7289
0
      if (local_sections[r_symndx] == sec)
7290
0
        break;
7291
0
          if (r_symndx >= symtab_hdr->sh_info)
7292
0
      r_symndx = STN_UNDEF;
7293
0
          rel->r_addend = htab->elf.tls_sec->vma + DTP_OFFSET;
7294
0
          if (r_symndx != STN_UNDEF)
7295
0
      rel->r_addend -= (local_syms[r_symndx].st_value
7296
0
            + sec->output_offset
7297
0
            + sec->output_section->vma);
7298
0
        }
7299
0
      r_type = R_PPC_TPREL16_HA;
7300
0
      rel->r_info = ELF32_R_INFO (r_symndx, r_type);
7301
0
      if (offset != (bfd_vma) -1
7302
0
          && offset_in_range (input_section, offset, 4))
7303
0
        {
7304
0
          rel[1].r_info = ELF32_R_INFO (r_symndx, R_PPC_TPREL16_LO);
7305
0
          rel[1].r_offset = offset + d_offset;
7306
0
          rel[1].r_addend = rel->r_addend;
7307
0
          insn2 = 0x38630000; /* addi 3,3,0 */
7308
0
          bfd_put_32 (input_bfd, insn2, contents + offset);
7309
0
        }
7310
0
    }
7311
0
        bfd_put_32 (input_bfd, insn1,
7312
0
        contents + rel->r_offset - d_offset);
7313
0
        if (tls_gd == 0)
7314
0
    {
7315
      /* We changed the symbol on an LD reloc.  Start over
7316
         in order to get h, sym, sec etc. right.  */
7317
0
      goto again;
7318
0
    }
7319
0
      }
7320
0
    break;
7321
7322
0
  case R_PPC_TLSGD:
7323
0
    if ((tls_mask & TLS_TLS) != 0 && (tls_mask & TLS_GD) == 0
7324
0
        && rel + 1 < relend
7325
0
        && offset_in_range (input_section, rel->r_offset, 4))
7326
0
      {
7327
0
        unsigned int insn2;
7328
0
        bfd_vma offset = rel->r_offset;
7329
7330
0
        if (is_plt_seq_reloc (ELF32_R_TYPE (rel[1].r_info)))
7331
0
    {
7332
0
      bfd_put_32 (input_bfd, NOP, contents + offset);
7333
0
      rel[1].r_info = ELF32_R_INFO (STN_UNDEF, R_PPC_NONE);
7334
0
      break;
7335
0
    }
7336
7337
0
        if ((tls_mask & TLS_GDIE) != 0)
7338
0
    {
7339
      /* IE */
7340
0
      r_type = R_PPC_NONE;
7341
0
      insn2 = 0x7c631214; /* add 3,3,2 */
7342
0
    }
7343
0
        else
7344
0
    {
7345
      /* LE */
7346
0
      r_type = R_PPC_TPREL16_LO;
7347
0
      rel->r_offset += d_offset;
7348
0
      insn2 = 0x38630000; /* addi 3,3,0 */
7349
0
    }
7350
0
        rel->r_info = ELF32_R_INFO (r_symndx, r_type);
7351
0
        bfd_put_32 (input_bfd, insn2, contents + offset);
7352
        /* Zap the reloc on the _tls_get_addr call too.  */
7353
0
        BFD_ASSERT (offset == rel[1].r_offset);
7354
0
        rel[1].r_info = ELF32_R_INFO (STN_UNDEF, R_PPC_NONE);
7355
0
      }
7356
0
    break;
7357
7358
0
  case R_PPC_TLSLD:
7359
0
    if ((tls_mask & TLS_TLS) != 0 && (tls_mask & TLS_LD) == 0
7360
0
        && rel + 1 < relend
7361
0
        && offset_in_range (input_section, rel->r_offset, 4))
7362
0
      {
7363
0
        unsigned int insn2;
7364
7365
0
        if (is_plt_seq_reloc (ELF32_R_TYPE (rel[1].r_info)))
7366
0
    {
7367
0
      bfd_put_32 (input_bfd, NOP, contents + rel->r_offset);
7368
0
      rel[1].r_info = ELF32_R_INFO (STN_UNDEF, R_PPC_NONE);
7369
0
      break;
7370
0
    }
7371
7372
0
        for (r_symndx = 0;
7373
0
       r_symndx < symtab_hdr->sh_info;
7374
0
       r_symndx++)
7375
0
    if (local_sections[r_symndx] == sec)
7376
0
      break;
7377
0
        if (r_symndx >= symtab_hdr->sh_info)
7378
0
    r_symndx = STN_UNDEF;
7379
0
        rel->r_addend = htab->elf.tls_sec->vma + DTP_OFFSET;
7380
0
        if (r_symndx != STN_UNDEF)
7381
0
    rel->r_addend -= (local_syms[r_symndx].st_value
7382
0
          + sec->output_offset
7383
0
          + sec->output_section->vma);
7384
7385
0
        rel->r_info = ELF32_R_INFO (r_symndx, R_PPC_TPREL16_LO);
7386
0
        rel->r_offset += d_offset;
7387
0
        insn2 = 0x38630000; /* addi 3,3,0 */
7388
0
        bfd_put_32 (input_bfd, insn2,
7389
0
        contents + rel->r_offset - d_offset);
7390
        /* Zap the reloc on the _tls_get_addr call too.  */
7391
0
        BFD_ASSERT (rel->r_offset - d_offset == rel[1].r_offset);
7392
0
        rel[1].r_info = ELF32_R_INFO (STN_UNDEF, R_PPC_NONE);
7393
0
        goto again;
7394
0
      }
7395
0
    break;
7396
0
  }
7397
7398
      /* Handle other relocations that tweak non-addend part of insn.  */
7399
0
      branch_bit = 0;
7400
0
      switch (r_type)
7401
0
  {
7402
0
  default:
7403
0
    break;
7404
7405
    /* Branch taken prediction relocations.  */
7406
0
  case R_PPC_ADDR14_BRTAKEN:
7407
0
  case R_PPC_REL14_BRTAKEN:
7408
0
    branch_bit = BRANCH_PREDICT_BIT;
7409
    /* Fall through.  */
7410
7411
    /* Branch not taken prediction relocations.  */
7412
0
  case R_PPC_ADDR14_BRNTAKEN:
7413
0
  case R_PPC_REL14_BRNTAKEN:
7414
0
    if (offset_in_range (input_section, rel->r_offset, 4))
7415
0
      {
7416
0
        unsigned int insn;
7417
7418
0
        insn = bfd_get_32 (input_bfd, contents + rel->r_offset);
7419
0
        insn &= ~BRANCH_PREDICT_BIT;
7420
0
        insn |= branch_bit;
7421
7422
0
        from = (rel->r_offset
7423
0
          + input_section->output_offset
7424
0
          + input_section->output_section->vma);
7425
7426
        /* Invert 'y' bit if not the default.  */
7427
0
        if ((bfd_signed_vma) (relocation + rel->r_addend - from) < 0)
7428
0
    insn ^= BRANCH_PREDICT_BIT;
7429
7430
0
        bfd_put_32 (input_bfd, insn, contents + rel->r_offset);
7431
0
      }
7432
0
    break;
7433
7434
0
  case R_PPC_PLT16_HA:
7435
0
    if (offset_in_range (input_section, rel->r_offset - d_offset, 4))
7436
0
      {
7437
0
        unsigned int insn;
7438
7439
0
        insn = bfd_get_32 (input_bfd,
7440
0
         contents + rel->r_offset - d_offset);
7441
0
        if ((insn & (0x3fu << 26)) == 15u << 26
7442
0
      && (insn & (0x1f << 16)) != 0)
7443
0
    {
7444
0
      if (!bfd_link_pic (info))
7445
0
        {
7446
          /* Convert addis to lis.  */
7447
0
          insn &= ~(0x1f << 16);
7448
0
          bfd_put_32 (input_bfd, insn,
7449
0
          contents + rel->r_offset - d_offset);
7450
0
        }
7451
0
    }
7452
0
        else if (bfd_link_pic (info))
7453
0
    info->callbacks->einfo
7454
0
      (_("%P: %H: error: %s with unexpected instruction %x\n"),
7455
0
       input_bfd, input_section, rel->r_offset,
7456
0
       "R_PPC_PLT16_HA", insn);
7457
0
      }
7458
0
    break;
7459
0
  }
7460
7461
0
      if (ELIMINATE_COPY_RELOCS
7462
0
    && h != NULL
7463
0
    && !h->def_regular
7464
0
    && h->protected_def
7465
0
    && ppc_elf_hash_entry (h)->has_addr16_ha
7466
0
    && ppc_elf_hash_entry (h)->has_addr16_lo
7467
0
    && htab->params->pic_fixup > 0)
7468
0
  {
7469
    /* Convert lis;addi or lis;load/store accessing a protected
7470
       variable defined in a shared library to PIC.  */
7471
0
    unsigned int insn;
7472
7473
0
    if (r_type == R_PPC_ADDR16_HA
7474
0
        && offset_in_range (input_section, rel->r_offset - d_offset, 4))
7475
0
      {
7476
0
        insn = bfd_get_32 (input_bfd,
7477
0
         contents + rel->r_offset - d_offset);
7478
0
        if ((insn & (0x3fu << 26)) == (15u << 26)
7479
0
      && (insn & (0x1f << 16)) == 0 /* lis */)
7480
0
    {
7481
0
      bfd_byte *p;
7482
0
      bfd_vma off;
7483
0
      bfd_vma got_addr;
7484
7485
0
      p = (contents + input_section->size
7486
0
           - relax_info->workaround_size
7487
0
           - relax_info->picfixup_size
7488
0
           + picfixup_size);
7489
0
      off = (p - contents) - (rel->r_offset - d_offset);
7490
0
      if (off > 0x1fffffc || (off & 3) != 0)
7491
0
        info->callbacks->einfo
7492
0
          (_("%H: fixup branch overflow\n"),
7493
0
           input_bfd, input_section, rel->r_offset);
7494
7495
0
      bfd_put_32 (input_bfd, B | off,
7496
0
            contents + rel->r_offset - d_offset);
7497
0
      got_addr = (htab->elf.sgot->output_section->vma
7498
0
            + htab->elf.sgot->output_offset
7499
0
            + (h->got.offset & ~1));
7500
0
      wrel->r_offset = (p - contents) + d_offset;
7501
0
      wrel->r_info = ELF32_R_INFO (0, R_PPC_ADDR16_HA);
7502
0
      wrel->r_addend = got_addr;
7503
0
      insn &= ~0xffff;
7504
0
      insn |= ((unsigned int) (got_addr + 0x8000) >> 16) & 0xffff;
7505
0
      bfd_put_32 (input_bfd, insn, p);
7506
7507
      /* Convert lis to lwz, loading address from GOT.  */
7508
0
      insn &= ~0xffff;
7509
0
      insn ^= (32u ^ 15u) << 26;
7510
0
      insn |= (insn & (0x1f << 21)) >> 5;
7511
0
      insn |= got_addr & 0xffff;
7512
0
      bfd_put_32 (input_bfd, insn, p + 4);
7513
7514
0
      bfd_put_32 (input_bfd, B | ((-4 - off) & 0x3ffffff), p + 8);
7515
0
      picfixup_size += 12;
7516
7517
      /* Use one of the spare relocs, so --emit-relocs
7518
         output is reasonable.  */
7519
0
      memmove (rel + 1, rel, (relend - rel - 1) * sizeof (*rel));
7520
0
      wrel++, rel++;
7521
0
      rel->r_offset = wrel[-1].r_offset + 4;
7522
0
      rel->r_info = ELF32_R_INFO (0, R_PPC_ADDR16_LO);
7523
0
      rel->r_addend = wrel[-1].r_addend;
7524
7525
      /* Continue on as if we had a got reloc, to output
7526
         dynamic reloc.  */
7527
0
      r_type = R_PPC_GOT16_LO;
7528
0
    }
7529
0
        else
7530
0
    _bfd_error_handler
7531
      /* xgettext:c-format */
7532
0
      (_("%pB(%pA+%#" PRIx64 "): error: "
7533
0
         "%s with unexpected instruction %#x"),
7534
0
       input_bfd, input_section, (uint64_t) rel->r_offset,
7535
0
       "R_PPC_ADDR16_HA", insn);
7536
0
      }
7537
0
    else if (r_type == R_PPC_ADDR16_LO
7538
0
       && offset_in_range (input_section,
7539
0
               rel->r_offset - d_offset, 4))
7540
0
      {
7541
0
        insn = bfd_get_32 (input_bfd,
7542
0
         contents + rel->r_offset - d_offset);
7543
0
        if ((insn & (0x3fu << 26)) == 14u << 26    /* addi */
7544
0
      || (insn & (0x3fu << 26)) == 32u << 26 /* lwz */
7545
0
      || (insn & (0x3fu << 26)) == 34u << 26 /* lbz */
7546
0
      || (insn & (0x3fu << 26)) == 36u << 26 /* stw */
7547
0
      || (insn & (0x3fu << 26)) == 38u << 26 /* stb */
7548
0
      || (insn & (0x3fu << 26)) == 40u << 26 /* lhz */
7549
0
      || (insn & (0x3fu << 26)) == 42u << 26 /* lha */
7550
0
      || (insn & (0x3fu << 26)) == 44u << 26 /* sth */
7551
0
      || (insn & (0x3fu << 26)) == 46u << 26 /* lmw */
7552
0
      || (insn & (0x3fu << 26)) == 47u << 26 /* stmw */
7553
0
      || (insn & (0x3fu << 26)) == 48u << 26 /* lfs */
7554
0
      || (insn & (0x3fu << 26)) == 50u << 26 /* lfd */
7555
0
      || (insn & (0x3fu << 26)) == 52u << 26 /* stfs */
7556
0
      || (insn & (0x3fu << 26)) == 54u << 26 /* stfd */
7557
0
      || ((insn & (0x3fu << 26)) == 58u << 26 /* lwa,ld,lmd */
7558
0
          && (insn & 3) != 1)
7559
0
      || ((insn & (0x3fu << 26)) == 62u << 26 /* std, stmd */
7560
0
          && ((insn & 3) == 0 || (insn & 3) == 3)))
7561
0
    {
7562
      /* Arrange to apply the reloc addend, if any.  */
7563
0
      relocation = 0;
7564
0
      unresolved_reloc = false;
7565
0
      rel->r_info = ELF32_R_INFO (0, r_type);
7566
0
    }
7567
0
        else
7568
0
    _bfd_error_handler
7569
      /* xgettext:c-format */
7570
0
      (_("%pB(%pA+%#" PRIx64 "): error: "
7571
0
         "%s with unexpected instruction %#x"),
7572
0
       input_bfd, input_section, (uint64_t) rel->r_offset,
7573
0
       "R_PPC_ADDR16_LO", insn);
7574
0
      }
7575
0
  }
7576
7577
0
      ifunc = NULL;
7578
0
      if (htab->elf.target_os != is_vxworks)
7579
0
  {
7580
0
    struct plt_entry *ent;
7581
7582
0
    if (h != NULL)
7583
0
      {
7584
0
        if (h->type == STT_GNU_IFUNC)
7585
0
    ifunc = &h->plt.plist;
7586
0
      }
7587
0
    else if (local_got_offsets != NULL
7588
0
       && ELF_ST_TYPE (sym->st_info) == STT_GNU_IFUNC)
7589
0
      {
7590
0
        struct plt_entry **local_plt;
7591
7592
0
        local_plt = (struct plt_entry **) (local_got_offsets
7593
0
             + symtab_hdr->sh_info);
7594
0
        ifunc = local_plt + r_symndx;
7595
0
      }
7596
7597
0
    ent = NULL;
7598
0
    if (ifunc != NULL
7599
0
        && (!bfd_link_pic (info)
7600
0
      || is_branch_reloc (r_type)
7601
0
      || r_type == R_PPC_PLT16_LO
7602
0
      || r_type == R_PPC_PLT16_HI
7603
0
      || r_type == R_PPC_PLT16_HA))
7604
0
      {
7605
0
        addend = 0;
7606
0
        if (bfd_link_pic (info)
7607
0
      && (r_type == R_PPC_PLTREL24
7608
0
          || r_type == R_PPC_PLT16_LO
7609
0
          || r_type == R_PPC_PLT16_HI
7610
0
          || r_type == R_PPC_PLT16_HA))
7611
0
    addend = rel->r_addend;
7612
0
        ent = find_plt_ent (ifunc, got2, addend);
7613
0
      }
7614
0
    if (ent != NULL)
7615
0
      {
7616
0
        if (bfd_link_pic (info)
7617
0
      && ent->sec != got2
7618
0
      && htab->plt_type != PLT_NEW
7619
0
      && (!htab->elf.dynamic_sections_created
7620
0
          || h == NULL
7621
0
          || h->dynindx == -1))
7622
0
    {
7623
      /* Uh oh, we are going to create a pic glink stub
7624
         for an ifunc (here for h == NULL and later in
7625
         finish_dynamic_symbol for h != NULL), and
7626
         apparently are using code compiled with
7627
         -mbss-plt.  The difficulty is that -mbss-plt code
7628
         gives no indication via a magic PLTREL24 addend
7629
         whether r30 is equal to _GLOBAL_OFFSET_TABLE_ or
7630
         is pointing into a .got2 section (and how far
7631
         into .got2).  */
7632
0
        info->callbacks->einfo
7633
          /* xgettext:c-format */
7634
0
          (_("%X%H: unsupported bss-plt -fPIC ifunc %s\n"),
7635
0
           input_bfd, input_section, rel->r_offset, sym_name);
7636
0
    }
7637
7638
0
        unresolved_reloc = false;
7639
0
        if (htab->plt_type == PLT_NEW
7640
0
      || !htab->elf.dynamic_sections_created
7641
0
      || h == NULL
7642
0
      || h->dynindx == -1)
7643
0
    relocation = (htab->glink->output_section->vma
7644
0
            + htab->glink->output_offset
7645
0
            + (ent->glink_offset & ~1));
7646
0
        else
7647
0
    relocation = (htab->elf.splt->output_section->vma
7648
0
            + htab->elf.splt->output_offset
7649
0
            + ent->plt.offset);
7650
0
      }
7651
0
  }
7652
7653
0
      addend = rel->r_addend;
7654
0
      save_unresolved_reloc = unresolved_reloc;
7655
0
      howto = NULL;
7656
0
      if (r_type < R_PPC_max)
7657
0
  howto = ppc_elf_howto_table[r_type];
7658
7659
0
      tls_type = 0;
7660
0
      switch (r_type)
7661
0
  {
7662
0
  default:
7663
0
  de_fault:
7664
0
    if (howto)
7665
      /* xgettext:c-format */
7666
0
      _bfd_error_handler (_("%pB: %s unsupported"),
7667
0
        input_bfd, howto->name);
7668
0
    else
7669
      /* xgettext:c-format */
7670
0
      _bfd_error_handler (_("%pB: reloc %#x unsupported"),
7671
0
        input_bfd, r_type);
7672
7673
0
    bfd_set_error (bfd_error_bad_value);
7674
0
    ret = false;
7675
0
    goto copy_reloc;
7676
7677
0
  case R_PPC_NONE:
7678
0
  case R_PPC_TLS:
7679
0
  case R_PPC_TLSGD:
7680
0
  case R_PPC_TLSLD:
7681
0
  case R_PPC_EMB_MRKREF:
7682
0
  case R_PPC_GNU_VTINHERIT:
7683
0
  case R_PPC_GNU_VTENTRY:
7684
0
    goto copy_reloc;
7685
7686
    /* GOT16 relocations.  Like an ADDR16 using the symbol's
7687
       address in the GOT as relocation value instead of the
7688
       symbol's value itself.  Also, create a GOT entry for the
7689
       symbol and put the symbol value there.  */
7690
0
  case R_PPC_GOT_TLSGD16:
7691
0
  case R_PPC_GOT_TLSGD16_LO:
7692
0
  case R_PPC_GOT_TLSGD16_HI:
7693
0
  case R_PPC_GOT_TLSGD16_HA:
7694
0
    tls_type = TLS_TLS | TLS_GD;
7695
0
    goto dogot;
7696
7697
0
  case R_PPC_GOT_TLSLD16:
7698
0
  case R_PPC_GOT_TLSLD16_LO:
7699
0
  case R_PPC_GOT_TLSLD16_HI:
7700
0
  case R_PPC_GOT_TLSLD16_HA:
7701
0
    tls_type = TLS_TLS | TLS_LD;
7702
0
    goto dogot;
7703
7704
0
  case R_PPC_GOT_TPREL16:
7705
0
  case R_PPC_GOT_TPREL16_LO:
7706
0
  case R_PPC_GOT_TPREL16_HI:
7707
0
  case R_PPC_GOT_TPREL16_HA:
7708
0
    tls_type = TLS_TLS | TLS_TPREL;
7709
0
    goto dogot;
7710
7711
0
  case R_PPC_GOT_DTPREL16:
7712
0
  case R_PPC_GOT_DTPREL16_LO:
7713
0
  case R_PPC_GOT_DTPREL16_HI:
7714
0
  case R_PPC_GOT_DTPREL16_HA:
7715
0
    tls_type = TLS_TLS | TLS_DTPREL;
7716
0
    goto dogot;
7717
7718
0
  case R_PPC_GOT16:
7719
0
  case R_PPC_GOT16_LO:
7720
0
  case R_PPC_GOT16_HI:
7721
0
  case R_PPC_GOT16_HA:
7722
0
    tls_mask = 0;
7723
0
  dogot:
7724
0
    {
7725
      /* Relocation is to the entry for this symbol in the global
7726
         offset table.  */
7727
0
      bfd_vma off;
7728
0
      bfd_vma *offp;
7729
0
      unsigned long indx;
7730
7731
0
      if (htab->elf.sgot == NULL)
7732
0
        abort ();
7733
7734
0
      indx = 0;
7735
0
      if (tls_type == (TLS_TLS | TLS_LD)
7736
0
    && SYMBOL_REFERENCES_LOCAL (info, h))
7737
0
        offp = &htab->tlsld_got.offset;
7738
0
      else if (h != NULL)
7739
0
        {
7740
0
    if (!htab->elf.dynamic_sections_created
7741
0
        || h->dynindx == -1
7742
0
        || SYMBOL_REFERENCES_LOCAL (info, h)
7743
0
        || UNDEFWEAK_NO_DYNAMIC_RELOC (info, h))
7744
      /* This is actually a static link, or it is a
7745
         -Bsymbolic link and the symbol is defined
7746
         locally, or the symbol was forced to be local
7747
         because of a version file.  */
7748
0
      ;
7749
0
    else
7750
0
      {
7751
0
        indx = h->dynindx;
7752
0
        unresolved_reloc = false;
7753
0
      }
7754
0
    offp = &h->got.offset;
7755
0
        }
7756
0
      else
7757
0
        {
7758
0
    if (local_got_offsets == NULL)
7759
0
      abort ();
7760
0
    offp = &local_got_offsets[r_symndx];
7761
0
        }
7762
7763
      /* The offset must always be a multiple of 4.  We use the
7764
         least significant bit to record whether we have already
7765
         processed this entry.  */
7766
0
      off = *offp;
7767
0
      if ((off & 1) != 0)
7768
0
        off &= ~1;
7769
0
      else
7770
0
        {
7771
0
    unsigned int tls_m = ((tls_mask & TLS_TLS) != 0
7772
0
              ? tls_mask & (TLS_LD | TLS_GD | TLS_DTPREL
7773
0
                | TLS_TPREL | TLS_GDIE)
7774
0
              : 0);
7775
7776
0
    if (offp == &htab->tlsld_got.offset)
7777
0
      tls_m = TLS_LD;
7778
0
    else if ((tls_m & TLS_LD) != 0
7779
0
       && SYMBOL_REFERENCES_LOCAL (info, h))
7780
0
      tls_m &= ~TLS_LD;
7781
7782
    /* We might have multiple got entries for this sym.
7783
       Initialize them all.  */
7784
0
    do
7785
0
      {
7786
0
        int tls_ty = 0;
7787
7788
0
        if ((tls_m & TLS_LD) != 0)
7789
0
          {
7790
0
      tls_ty = TLS_TLS | TLS_LD;
7791
0
      tls_m &= ~TLS_LD;
7792
0
          }
7793
0
        else if ((tls_m & TLS_GD) != 0)
7794
0
          {
7795
0
      tls_ty = TLS_TLS | TLS_GD;
7796
0
      tls_m &= ~TLS_GD;
7797
0
          }
7798
0
        else if ((tls_m & TLS_DTPREL) != 0)
7799
0
          {
7800
0
      tls_ty = TLS_TLS | TLS_DTPREL;
7801
0
      tls_m &= ~TLS_DTPREL;
7802
0
          }
7803
0
        else if ((tls_m & (TLS_TPREL | TLS_GDIE)) != 0)
7804
0
          {
7805
0
      tls_ty = TLS_TLS | TLS_TPREL;
7806
0
      tls_m = 0;
7807
0
          }
7808
7809
        /* Generate relocs for the dynamic linker.  */
7810
0
        if (indx != 0
7811
0
      || (bfd_link_pic (info)
7812
0
          && (h == NULL
7813
0
        || !UNDEFWEAK_NO_DYNAMIC_RELOC (info, h))
7814
0
          && !(tls_ty != 0
7815
0
         && bfd_link_executable (info)
7816
0
         && SYMBOL_REFERENCES_LOCAL (info, h))
7817
0
          && (h != NULL
7818
0
        ? !bfd_is_abs_symbol (&h->root)
7819
0
        : sym->st_shndx != SHN_ABS)))
7820
0
          {
7821
0
      asection *rsec = htab->elf.srelgot;
7822
7823
0
      if (ifunc != NULL)
7824
0
        {
7825
0
          rsec = htab->elf.irelplt;
7826
0
          if (indx == 0)
7827
0
            htab->local_ifunc_resolver = 1;
7828
0
          else if (is_static_defined (h))
7829
0
            htab->maybe_local_ifunc_resolver = 1;
7830
0
        }
7831
0
      outrel.r_offset = (htab->elf.sgot->output_section->vma
7832
0
             + htab->elf.sgot->output_offset
7833
0
             + off);
7834
0
      outrel.r_addend = 0;
7835
0
      if (tls_ty & (TLS_LD | TLS_GD))
7836
0
        {
7837
0
          outrel.r_info = ELF32_R_INFO (indx, R_PPC_DTPMOD32);
7838
0
          if (tls_ty == (TLS_TLS | TLS_GD))
7839
0
            {
7840
0
        BFD_ASSERT (count_and_swap_reloc_out (output_bfd,
7841
0
                      &outrel,
7842
0
                      rsec));
7843
0
        outrel.r_offset += 4;
7844
0
        outrel.r_info
7845
0
          = ELF32_R_INFO (indx, R_PPC_DTPREL32);
7846
0
            }
7847
0
        }
7848
0
      else if (tls_ty == (TLS_TLS | TLS_DTPREL))
7849
0
        outrel.r_info = ELF32_R_INFO (indx, R_PPC_DTPREL32);
7850
0
      else if (tls_ty == (TLS_TLS | TLS_TPREL))
7851
0
        outrel.r_info = ELF32_R_INFO (indx, R_PPC_TPREL32);
7852
0
      else if (indx != 0)
7853
0
        outrel.r_info = ELF32_R_INFO (indx, R_PPC_GLOB_DAT);
7854
0
      else if (ifunc != NULL)
7855
0
        outrel.r_info = ELF32_R_INFO (0, R_PPC_IRELATIVE);
7856
0
      else
7857
0
        outrel.r_info = ELF32_R_INFO (0, R_PPC_RELATIVE);
7858
0
      if (indx == 0 && tls_ty != (TLS_TLS | TLS_LD))
7859
0
        {
7860
0
          outrel.r_addend += relocation;
7861
0
          if (tls_ty & (TLS_GD | TLS_DTPREL | TLS_TPREL))
7862
0
            {
7863
0
        if (htab->elf.tls_sec == NULL)
7864
0
          outrel.r_addend = 0;
7865
0
        else
7866
0
          outrel.r_addend -= htab->elf.tls_sec->vma;
7867
0
            }
7868
0
        }
7869
0
      BFD_ASSERT (count_and_swap_reloc_out (output_bfd,
7870
0
                    &outrel, rsec));
7871
0
          }
7872
7873
        /* Init the .got section contents if we're not
7874
           emitting a reloc.  */
7875
0
        else
7876
0
          {
7877
0
      bfd_vma value = relocation;
7878
7879
0
      if (tls_ty != 0)
7880
0
        {
7881
0
          if (htab->elf.tls_sec == NULL)
7882
0
            value = 0;
7883
0
          else
7884
0
            {
7885
0
        if (tls_ty & TLS_LD)
7886
0
          value = 0;
7887
0
        else
7888
0
          value -= htab->elf.tls_sec->vma + DTP_OFFSET;
7889
0
        if (tls_ty & TLS_TPREL)
7890
0
          value += DTP_OFFSET - TP_OFFSET;
7891
0
            }
7892
7893
0
          if (tls_ty & (TLS_LD | TLS_GD))
7894
0
            {
7895
0
        bfd_put_32 (input_bfd, value,
7896
0
              htab->elf.sgot->contents + off + 4);
7897
0
        value = 1;
7898
0
            }
7899
0
        }
7900
0
      bfd_put_32 (input_bfd, value,
7901
0
            htab->elf.sgot->contents + off);
7902
0
          }
7903
7904
0
        off += 4;
7905
0
        if (tls_ty & (TLS_LD | TLS_GD))
7906
0
          off += 4;
7907
0
      }
7908
0
    while (tls_m != 0);
7909
7910
0
    off = *offp;
7911
0
    *offp = off | 1;
7912
0
        }
7913
7914
0
      if (off >= (bfd_vma) -2)
7915
0
        abort ();
7916
7917
0
      if ((tls_type & TLS_TLS) != 0)
7918
0
        {
7919
0
    if (tls_type != (TLS_TLS | TLS_LD))
7920
0
      {
7921
0
        if ((tls_mask & TLS_LD) != 0
7922
0
      && !SYMBOL_REFERENCES_LOCAL (info, h))
7923
0
          off += 8;
7924
0
        if (tls_type != (TLS_TLS | TLS_GD))
7925
0
          {
7926
0
      if ((tls_mask & TLS_GD) != 0)
7927
0
        off += 8;
7928
0
      if (tls_type != (TLS_TLS | TLS_DTPREL))
7929
0
        {
7930
0
          if ((tls_mask & TLS_DTPREL) != 0)
7931
0
            off += 4;
7932
0
        }
7933
0
          }
7934
0
      }
7935
0
        }
7936
7937
      /* If here for a picfixup, we're done.  */
7938
0
      if (r_type != ELF32_R_TYPE (rel->r_info))
7939
0
        goto copy_reloc;
7940
7941
0
      relocation = (htab->elf.sgot->output_section->vma
7942
0
        + htab->elf.sgot->output_offset
7943
0
        + off
7944
0
        - SYM_VAL (htab->elf.hgot));
7945
7946
      /* Addends on got relocations don't make much sense.
7947
         x+off@got is actually x@got+off, and since the got is
7948
         generated by a hash table traversal, the value in the
7949
         got at entry m+n bears little relation to the entry m.  */
7950
0
      if (addend != 0)
7951
0
        info->callbacks->einfo
7952
    /* xgettext:c-format */
7953
0
    (_("%H: non-zero addend on %s reloc against `%s'\n"),
7954
0
     input_bfd, input_section, rel->r_offset,
7955
0
     howto->name,
7956
0
     sym_name);
7957
0
    }
7958
0
    break;
7959
7960
    /* Relocations that need no special processing.  */
7961
0
  case R_PPC_LOCAL24PC:
7962
    /* It makes no sense to point a local relocation
7963
       at a symbol not in this object.  */
7964
0
    if (unresolved_reloc)
7965
0
      {
7966
0
        (*info->callbacks->undefined_symbol) (info,
7967
0
                h->root.root.string,
7968
0
                input_bfd,
7969
0
                input_section,
7970
0
                rel->r_offset,
7971
0
                true);
7972
0
        goto copy_reloc;
7973
0
      }
7974
0
    if (h != NULL && h->type == STT_GNU_IFUNC && bfd_link_pic (info))
7975
0
      {
7976
        /* @local on an ifunc does not really make sense since
7977
     the ifunc resolver can take you anywhere.  More
7978
     seriously, calls to ifuncs must go through a plt call
7979
     stub, and for pic the plt call stubs uses r30 to
7980
     access the PLT.  The problem is that a call that is
7981
     local won't have the +32k reloc addend trick marking
7982
     -fPIC code, so the linker won't know whether r30 is
7983
     _GLOBAL_OFFSET_TABLE_ or pointing into a .got2 section.  */
7984
        /* xgettext:c-format */
7985
0
        info->callbacks->einfo (_("%X%H: @local call to ifunc %s\n"),
7986
0
              input_bfd, input_section, rel->r_offset,
7987
0
              h->root.root.string);
7988
0
      }
7989
0
    break;
7990
7991
0
  case R_PPC_DTPREL16:
7992
0
  case R_PPC_DTPREL16_LO:
7993
0
  case R_PPC_DTPREL16_HI:
7994
0
  case R_PPC_DTPREL16_HA:
7995
0
    if (htab->elf.tls_sec != NULL)
7996
0
      addend -= htab->elf.tls_sec->vma + DTP_OFFSET;
7997
0
    break;
7998
7999
    /* Relocations that may need to be propagated if this is a shared
8000
       object.  */
8001
0
  case R_PPC_TPREL16:
8002
0
  case R_PPC_TPREL16_LO:
8003
0
  case R_PPC_TPREL16_HI:
8004
0
  case R_PPC_TPREL16_HA:
8005
0
    if (h != NULL
8006
0
        && h->root.type == bfd_link_hash_undefweak
8007
0
        && h->dynindx == -1
8008
0
        && offset_in_range (input_section, rel->r_offset - d_offset, 4))
8009
0
      {
8010
        /* Make this relocation against an undefined weak symbol
8011
     resolve to zero.  This is really just a tweak, since
8012
     code using weak externs ought to check that they are
8013
     defined before using them.  */
8014
0
        bfd_byte *p = contents + rel->r_offset - d_offset;
8015
0
        unsigned int insn = bfd_get_32 (input_bfd, p);
8016
0
        insn = _bfd_elf_ppc_at_tprel_transform (insn, 2);
8017
0
        if (insn != 0)
8018
0
    bfd_put_32 (input_bfd, insn, p);
8019
0
        break;
8020
0
      }
8021
0
    if (htab->elf.tls_sec != NULL)
8022
0
      addend -= htab->elf.tls_sec->vma + TP_OFFSET;
8023
    /* The TPREL16 relocs shouldn't really be used in shared
8024
       libs or with non-local symbols as that will result in
8025
       DT_TEXTREL being set, but support them anyway.  */
8026
0
    goto dodyn;
8027
8028
0
  case R_PPC_TPREL32:
8029
0
    if (htab->elf.tls_sec != NULL)
8030
0
      addend -= htab->elf.tls_sec->vma + TP_OFFSET;
8031
0
    goto dodyn;
8032
8033
0
  case R_PPC_DTPREL32:
8034
0
    if (htab->elf.tls_sec != NULL)
8035
0
      addend -= htab->elf.tls_sec->vma + DTP_OFFSET;
8036
0
    goto dodyn;
8037
8038
0
  case R_PPC_DTPMOD32:
8039
0
    relocation = 1;
8040
0
    addend = 0;
8041
0
    goto dodyn;
8042
8043
0
  case R_PPC_REL16:
8044
0
  case R_PPC_REL16_LO:
8045
0
  case R_PPC_REL16_HI:
8046
0
  case R_PPC_REL16_HA:
8047
0
  case R_PPC_REL16DX_HA:
8048
0
    break;
8049
8050
0
  case R_PPC_REL32:
8051
0
    if (h == NULL || h == htab->elf.hgot)
8052
0
      break;
8053
    /* fall through */
8054
8055
0
  case R_PPC_ADDR32:
8056
0
  case R_PPC_ADDR16:
8057
0
  case R_PPC_ADDR16_LO:
8058
0
  case R_PPC_ADDR16_HI:
8059
0
  case R_PPC_ADDR16_HA:
8060
0
  case R_PPC_UADDR32:
8061
0
  case R_PPC_UADDR16:
8062
0
    goto dodyn;
8063
8064
0
  case R_PPC_VLE_REL8:
8065
0
  case R_PPC_VLE_REL15:
8066
0
  case R_PPC_VLE_REL24:
8067
0
  case R_PPC_REL24:
8068
0
  case R_PPC_REL14:
8069
0
  case R_PPC_REL14_BRTAKEN:
8070
0
  case R_PPC_REL14_BRNTAKEN:
8071
    /* If these relocations are not to a named symbol, they can be
8072
       handled right here, no need to bother the dynamic linker.  */
8073
0
    if (SYMBOL_CALLS_LOCAL (info, h)
8074
0
        || h == htab->elf.hgot)
8075
0
      break;
8076
    /* fall through */
8077
8078
0
  case R_PPC_ADDR24:
8079
0
  case R_PPC_ADDR14:
8080
0
  case R_PPC_ADDR14_BRTAKEN:
8081
0
  case R_PPC_ADDR14_BRNTAKEN:
8082
0
    if (h != NULL && !bfd_link_pic (info))
8083
0
      break;
8084
    /* fall through */
8085
8086
0
  dodyn:
8087
0
    if ((input_section->flags & SEC_ALLOC) == 0
8088
0
        || is_vxworks_tls)
8089
0
      break;
8090
8091
0
    if (bfd_link_pic (info)
8092
0
        ? ((h == NULL
8093
0
      || h->dyn_relocs != NULL)
8094
0
     && ((h != NULL && pc_dynrelocs (h))
8095
0
         || must_be_dyn_reloc (info, r_type)))
8096
0
        : (h != NULL
8097
0
     && h->dyn_relocs != NULL))
8098
0
      {
8099
0
        int skip;
8100
0
        asection *sreloc;
8101
0
        long indx = 0;
8102
8103
#ifdef DEBUG
8104
        fprintf (stderr, "ppc_elf_relocate_section needs to "
8105
           "create relocation for %s\n",
8106
           (h && h->root.root.string
8107
      ? h->root.root.string : "<unknown>"));
8108
#endif
8109
8110
        /* When generating a shared object, these relocations
8111
     are copied into the output file to be resolved at run
8112
     time.  */
8113
0
        skip = 0;
8114
0
        outrel.r_offset = _bfd_elf_section_offset (output_bfd, info,
8115
0
               input_section,
8116
0
               rel->r_offset);
8117
0
        if (outrel.r_offset == (bfd_vma) -1
8118
0
      || outrel.r_offset == (bfd_vma) -2)
8119
0
    skip = (int) outrel.r_offset;
8120
0
        outrel.r_offset += (input_section->output_section->vma
8121
0
          + input_section->output_offset);
8122
8123
        /* Optimize unaligned reloc use.  */
8124
0
        if ((r_type == R_PPC_ADDR32 && (outrel.r_offset & 3) != 0)
8125
0
      || (r_type == R_PPC_UADDR32 && (outrel.r_offset & 3) == 0))
8126
0
    r_type ^= R_PPC_ADDR32 ^ R_PPC_UADDR32;
8127
0
        if ((r_type == R_PPC_ADDR16 && (outrel.r_offset & 1) != 0)
8128
0
      || (r_type == R_PPC_UADDR16 && (outrel.r_offset & 1) == 0))
8129
0
    r_type ^= R_PPC_ADDR16 ^ R_PPC_UADDR16;
8130
8131
0
        if (skip)
8132
0
    memset (&outrel, 0, sizeof outrel);
8133
0
        else if (!SYMBOL_REFERENCES_LOCAL (info, h))
8134
0
    {
8135
0
      indx = h->dynindx;
8136
0
      BFD_ASSERT (indx != -1);
8137
0
      unresolved_reloc = false;
8138
0
      outrel.r_info = ELF32_R_INFO (indx, r_type);
8139
0
      outrel.r_addend = rel->r_addend;
8140
0
    }
8141
0
        else
8142
0
    {
8143
0
      outrel.r_addend = relocation + rel->r_addend;
8144
8145
0
      if (r_type != R_PPC_ADDR32)
8146
0
        {
8147
0
          if (ifunc != NULL)
8148
0
      {
8149
        /* If we get here when building a static
8150
           executable, then the libc startup function
8151
           responsible for applying indirect function
8152
           relocations is going to complain about
8153
           the reloc type.
8154
           If we get here when building a dynamic
8155
           executable, it will be because we have
8156
           a text relocation.  The dynamic loader
8157
           will set the text segment writable and
8158
           non-executable to apply text relocations.
8159
           So we'll segfault when trying to run the
8160
           indirection function to resolve the reloc.  */
8161
0
        info->callbacks->einfo
8162
          /* xgettext:c-format */
8163
0
          (_("%H: relocation %s for indirect "
8164
0
             "function %s unsupported\n"),
8165
0
           input_bfd, input_section, rel->r_offset,
8166
0
           howto->name,
8167
0
           sym_name);
8168
0
        ret = false;
8169
0
      }
8170
0
          else if (r_symndx == STN_UNDEF || bfd_is_abs_section (sec))
8171
0
      ;
8172
0
          else if (sec == NULL || sec->owner == NULL)
8173
0
      {
8174
0
        bfd_set_error (bfd_error_bad_value);
8175
0
        ret = false;
8176
0
      }
8177
0
          else
8178
0
      {
8179
0
        asection *osec;
8180
8181
        /* We are turning this relocation into one
8182
           against a section symbol.  It would be
8183
           proper to subtract the symbol's value,
8184
           osec->vma, from the emitted reloc addend,
8185
           but ld.so expects buggy relocs.
8186
           FIXME: Why not always use a zero index?  */
8187
0
        osec = sec->output_section;
8188
0
        if ((osec->flags & SEC_THREAD_LOCAL) != 0)
8189
0
          {
8190
0
            osec = htab->elf.tls_sec;
8191
0
            indx = 0;
8192
0
          }
8193
0
        else
8194
0
          {
8195
0
            indx = elf_section_data (osec)->dynindx;
8196
0
            if (indx == 0)
8197
0
        {
8198
0
          osec = htab->elf.text_index_section;
8199
0
          indx = elf_section_data (osec)->dynindx;
8200
0
        }
8201
0
            BFD_ASSERT (indx != 0);
8202
0
          }
8203
8204
        /* ld.so doesn't expect buggy TLS relocs.
8205
           Don't leave the symbol value in the
8206
           addend for them.  */
8207
0
        if (IS_PPC_TLS_RELOC (r_type))
8208
0
          outrel.r_addend -= osec->vma;
8209
0
      }
8210
8211
0
          outrel.r_info = ELF32_R_INFO (indx, r_type);
8212
0
        }
8213
0
      else if (ifunc != NULL)
8214
0
        outrel.r_info = ELF32_R_INFO (0, R_PPC_IRELATIVE);
8215
0
      else
8216
0
        outrel.r_info = ELF32_R_INFO (0, R_PPC_RELATIVE);
8217
0
    }
8218
8219
0
        sreloc = elf_section_data (input_section)->sreloc;
8220
0
        if (ifunc)
8221
0
    {
8222
0
      sreloc = htab->elf.irelplt;
8223
0
      if (indx == 0)
8224
0
        htab->local_ifunc_resolver = 1;
8225
0
      else if (is_static_defined (h))
8226
0
        htab->maybe_local_ifunc_resolver = 1;
8227
0
    }
8228
0
        if (sreloc == NULL)
8229
0
    return false;
8230
8231
0
        BFD_ASSERT (count_and_swap_reloc_out (output_bfd, &outrel,
8232
0
                sreloc));
8233
8234
0
        if (skip == -1)
8235
0
    goto copy_reloc;
8236
8237
        /* This reloc will be computed at runtime.  Clear the memory
8238
     so that it contains a predictable value for prelink.  */
8239
0
        if (!skip)
8240
0
    {
8241
0
      relocation = howto->pc_relative ? outrel.r_offset : 0;
8242
0
      addend = 0;
8243
0
      break;
8244
0
    }
8245
0
      }
8246
0
    break;
8247
8248
0
  case R_PPC_RELAX_PLT:
8249
0
  case R_PPC_RELAX_PLTREL24:
8250
0
    if (h != NULL)
8251
0
      {
8252
0
        struct plt_entry *ent;
8253
0
        bfd_vma got2_addend = 0;
8254
8255
0
        if (r_type == R_PPC_RELAX_PLTREL24)
8256
0
    {
8257
0
      if (bfd_link_pic (info))
8258
0
        got2_addend = addend;
8259
0
      addend = 0;
8260
0
    }
8261
0
        ent = find_plt_ent (&h->plt.plist, got2, got2_addend);
8262
0
        if (htab->plt_type == PLT_NEW)
8263
0
    relocation = (htab->glink->output_section->vma
8264
0
            + htab->glink->output_offset
8265
0
            + ent->glink_offset);
8266
0
        else
8267
0
    relocation = (htab->elf.splt->output_section->vma
8268
0
            + htab->elf.splt->output_offset
8269
0
            + ent->plt.offset);
8270
0
      }
8271
    /* Fall through.  */
8272
8273
0
  case R_PPC_RELAX:
8274
0
    if (bfd_link_pic (info)
8275
0
        ? offset_in_range (input_section, rel->r_offset - 12,
8276
0
         ARRAY_SIZE (shared_stub_entry) * 4)
8277
0
        : offset_in_range (input_section, rel->r_offset,
8278
0
         ARRAY_SIZE (stub_entry) * 4))
8279
0
      {
8280
0
        const int *stub;
8281
0
        size_t size;
8282
0
        size_t insn_offset = rel->r_offset;
8283
0
        unsigned int insn;
8284
8285
0
        if (bfd_link_pic (info))
8286
0
    {
8287
0
      relocation -= (input_section->output_section->vma
8288
0
         + input_section->output_offset
8289
0
         + rel->r_offset - 4);
8290
0
      stub = shared_stub_entry;
8291
0
      bfd_put_32 (input_bfd, stub[0], contents + insn_offset - 12);
8292
0
      bfd_put_32 (input_bfd, stub[1], contents + insn_offset - 8);
8293
0
      bfd_put_32 (input_bfd, stub[2], contents + insn_offset - 4);
8294
0
      stub += 3;
8295
0
      size = ARRAY_SIZE (shared_stub_entry) - 3;
8296
0
    }
8297
0
        else
8298
0
    {
8299
0
      stub = stub_entry;
8300
0
      size = ARRAY_SIZE (stub_entry);
8301
0
    }
8302
8303
0
        relocation += addend;
8304
0
        if (bfd_link_relocatable (info))
8305
0
    relocation = 0;
8306
8307
        /* First insn is HA, second is LO.  */
8308
0
        insn = *stub++;
8309
0
        insn |= ((relocation + 0x8000) >> 16) & 0xffff;
8310
0
        bfd_put_32 (input_bfd, insn, contents + insn_offset);
8311
0
        insn_offset += 4;
8312
8313
0
        insn = *stub++;
8314
0
        insn |= relocation & 0xffff;
8315
0
        bfd_put_32 (input_bfd, insn, contents + insn_offset);
8316
0
        insn_offset += 4;
8317
0
        size -= 2;
8318
8319
0
        while (size != 0)
8320
0
    {
8321
0
      insn = *stub++;
8322
0
      --size;
8323
0
      bfd_put_32 (input_bfd, insn, contents + insn_offset);
8324
0
      insn_offset += 4;
8325
0
    }
8326
8327
        /* Rewrite the reloc and convert one of the trailing nop
8328
     relocs to describe this relocation.  */
8329
0
        BFD_ASSERT (ELF32_R_TYPE (relend[-1].r_info) == R_PPC_NONE);
8330
        /* The relocs are at the bottom 2 bytes */
8331
0
        wrel->r_offset = rel->r_offset + d_offset;
8332
0
        wrel->r_info = ELF32_R_INFO (r_symndx, R_PPC_ADDR16_HA);
8333
0
        wrel->r_addend = rel->r_addend;
8334
0
        memmove (wrel + 1, wrel, (relend - wrel - 1) * sizeof (*wrel));
8335
0
        wrel++, rel++;
8336
0
        wrel->r_offset += 4;
8337
0
        wrel->r_info = ELF32_R_INFO (r_symndx, R_PPC_ADDR16_LO);
8338
0
      }
8339
0
    else
8340
0
      goto de_fault;
8341
0
    continue;
8342
8343
    /* Indirect .sdata relocation.  */
8344
0
  case R_PPC_EMB_SDAI16:
8345
0
    BFD_ASSERT (htab->sdata[0].section != NULL);
8346
0
    if (!is_static_defined (htab->sdata[0].sym))
8347
0
      {
8348
0
        unresolved_reloc = true;
8349
0
        break;
8350
0
      }
8351
0
    relocation
8352
0
      = elf_finish_pointer_linker_section (input_bfd, &htab->sdata[0],
8353
0
             h, relocation, rel);
8354
0
    addend = 0;
8355
0
    break;
8356
8357
    /* Indirect .sdata2 relocation.  */
8358
0
  case R_PPC_EMB_SDA2I16:
8359
0
    BFD_ASSERT (htab->sdata[1].section != NULL);
8360
0
    if (!is_static_defined (htab->sdata[1].sym))
8361
0
      {
8362
0
        unresolved_reloc = true;
8363
0
        break;
8364
0
      }
8365
0
    relocation
8366
0
      = elf_finish_pointer_linker_section (input_bfd, &htab->sdata[1],
8367
0
             h, relocation, rel);
8368
0
    addend = 0;
8369
0
    break;
8370
8371
    /* Handle the TOC16 reloc.  We want to use the offset within the .got
8372
       section, not the actual VMA.  This is appropriate when generating
8373
       an embedded ELF object, for which the .got section acts like the
8374
       AIX .toc section.  */
8375
0
  case R_PPC_TOC16:     /* phony GOT16 relocations */
8376
0
    if (sec == NULL || sec->output_section == NULL)
8377
0
      {
8378
0
        unresolved_reloc = true;
8379
0
        break;
8380
0
      }
8381
0
    BFD_ASSERT (strcmp (bfd_section_name (sec), ".got") == 0
8382
0
          || strcmp (bfd_section_name (sec), ".cgot") == 0);
8383
8384
0
    addend -= sec->output_section->vma + sec->output_offset + 0x8000;
8385
0
    break;
8386
8387
0
  case R_PPC_PLTREL24:
8388
0
    if (h != NULL && ifunc == NULL)
8389
0
      {
8390
0
        struct plt_entry *ent;
8391
8392
0
        ent = find_plt_ent (&h->plt.plist, got2,
8393
0
          bfd_link_pic (info) ? addend : 0);
8394
0
        if (ent == NULL
8395
0
      || htab->elf.splt == NULL)
8396
0
    {
8397
      /* We didn't make a PLT entry for this symbol.  This
8398
         happens when statically linking PIC code, or when
8399
         using -Bsymbolic.  */
8400
0
    }
8401
0
        else
8402
0
    {
8403
      /* Relocation is to the entry for this symbol in the
8404
         procedure linkage table.  */
8405
0
      unresolved_reloc = false;
8406
0
      if (htab->plt_type == PLT_NEW)
8407
0
        relocation = (htab->glink->output_section->vma
8408
0
          + htab->glink->output_offset
8409
0
          + ent->glink_offset);
8410
0
      else
8411
0
        relocation = (htab->elf.splt->output_section->vma
8412
0
          + htab->elf.splt->output_offset
8413
0
          + ent->plt.offset);
8414
0
    }
8415
0
      }
8416
8417
    /* R_PPC_PLTREL24 is rather special.  If non-zero, the
8418
       addend specifies the GOT pointer offset within .got2.
8419
       Don't apply it to the relocation field.  */
8420
0
    addend = 0;
8421
0
    break;
8422
8423
0
  case R_PPC_PLTSEQ:
8424
0
  case R_PPC_PLTCALL:
8425
0
  case R_PPC_PLT16_LO:
8426
0
  case R_PPC_PLT16_HI:
8427
0
  case R_PPC_PLT16_HA:
8428
0
    plt_list = NULL;
8429
0
    if (h != NULL)
8430
0
      plt_list = &h->plt.plist;
8431
0
    else if (ifunc != NULL)
8432
0
      plt_list = ifunc;
8433
0
    else if (local_got_offsets != NULL)
8434
0
      {
8435
0
        struct plt_entry **local_plt;
8436
0
        local_plt = (struct plt_entry **) (local_got_offsets
8437
0
             + symtab_hdr->sh_info);
8438
0
        plt_list = local_plt + r_symndx;
8439
0
      }
8440
0
    unresolved_reloc = true;
8441
0
    if (plt_list != NULL)
8442
0
      {
8443
0
        struct plt_entry *ent;
8444
8445
0
        ent = find_plt_ent (plt_list, got2,
8446
0
          bfd_link_pic (info) ? addend : 0);
8447
0
        if (ent != NULL && ent->plt.offset != (bfd_vma) -1)
8448
0
    {
8449
0
      asection *plt;
8450
8451
0
      unresolved_reloc = false;
8452
0
      plt = htab->elf.splt;
8453
0
      if (use_local_plt (info, h))
8454
0
        {
8455
0
          if (ifunc != NULL)
8456
0
      plt = htab->elf.iplt;
8457
0
          else
8458
0
      plt = htab->pltlocal;
8459
0
        }
8460
0
      relocation = (plt->output_section->vma
8461
0
        + plt->output_offset
8462
0
        + ent->plt.offset);
8463
0
      if (bfd_link_pic (info))
8464
0
        {
8465
0
          bfd_vma got = 0;
8466
8467
0
          if (ent->addend >= 32768)
8468
0
      got = (ent->addend
8469
0
             + ent->sec->output_section->vma
8470
0
             + ent->sec->output_offset);
8471
0
          else
8472
0
      got = SYM_VAL (htab->elf.hgot);
8473
0
          relocation -= got;
8474
0
        }
8475
0
    }
8476
0
      }
8477
0
    addend = 0;
8478
0
    break;
8479
8480
    /* Relocate against _SDA_BASE_.  */
8481
0
  case R_PPC_SDAREL16:
8482
0
    {
8483
0
      const char *name;
8484
0
      struct elf_link_hash_entry *sda = htab->sdata[0].sym;
8485
8486
0
      if (sec == NULL
8487
0
    || sec->output_section == NULL
8488
0
    || !is_static_defined (sda))
8489
0
        {
8490
0
    unresolved_reloc = true;
8491
0
    break;
8492
0
        }
8493
0
      addend -= SYM_VAL (sda);
8494
8495
0
      name = bfd_section_name (sec->output_section);
8496
0
      if (!(strcmp (name, ".sdata") == 0
8497
0
      || strcmp (name, ".sbss") == 0))
8498
0
        {
8499
0
    _bfd_error_handler
8500
      /* xgettext:c-format */
8501
0
      (_("%pB: the target (%s) of a %s relocation is "
8502
0
         "in the wrong output section (%s)"),
8503
0
       input_bfd,
8504
0
       sym_name,
8505
0
       howto->name,
8506
0
       name);
8507
0
        }
8508
0
    }
8509
0
    break;
8510
8511
    /* Relocate against _SDA2_BASE_.  */
8512
0
  case R_PPC_EMB_SDA2REL:
8513
0
    {
8514
0
      const char *name;
8515
0
      struct elf_link_hash_entry *sda = htab->sdata[1].sym;
8516
8517
0
      if (sec == NULL
8518
0
    || sec->output_section == NULL
8519
0
    || !is_static_defined (sda))
8520
0
        {
8521
0
    unresolved_reloc = true;
8522
0
    break;
8523
0
        }
8524
0
      addend -= SYM_VAL (sda);
8525
8526
0
      name = bfd_section_name (sec->output_section);
8527
0
      if (!(strcmp (name, ".sdata2") == 0
8528
0
      || strcmp (name, ".sbss2") == 0))
8529
0
        {
8530
0
    _bfd_error_handler
8531
      /* xgettext:c-format */
8532
0
      (_("%pB: the target (%s) of a %s relocation is "
8533
0
         "in the wrong output section (%s)"),
8534
0
       input_bfd,
8535
0
       sym_name,
8536
0
       howto->name,
8537
0
       name);
8538
0
        }
8539
0
    }
8540
0
    break;
8541
8542
0
  case R_PPC_VLE_LO16A:
8543
0
    relocation = relocation + addend;
8544
0
    r = ppc_elf_vle_split16 (input_bfd, input_section, rel->r_offset,
8545
0
           contents + rel->r_offset, relocation,
8546
0
           split16a_type,
8547
0
           htab->params->vle_reloc_fixup);
8548
0
    goto report_reloc;
8549
8550
0
  case R_PPC_VLE_LO16D:
8551
0
    relocation = relocation + addend;
8552
0
    r = ppc_elf_vle_split16 (input_bfd, input_section, rel->r_offset,
8553
0
           contents + rel->r_offset, relocation,
8554
0
           split16d_type,
8555
0
           htab->params->vle_reloc_fixup);
8556
0
    goto report_reloc;
8557
8558
0
  case R_PPC_VLE_HI16A:
8559
0
    relocation = (relocation + addend) >> 16;
8560
0
    r = ppc_elf_vle_split16 (input_bfd, input_section, rel->r_offset,
8561
0
           contents + rel->r_offset, relocation,
8562
0
           split16a_type,
8563
0
           htab->params->vle_reloc_fixup);
8564
0
    goto report_reloc;
8565
8566
0
  case R_PPC_VLE_HI16D:
8567
0
    relocation = (relocation + addend) >> 16;
8568
0
    r = ppc_elf_vle_split16 (input_bfd, input_section, rel->r_offset,
8569
0
           contents + rel->r_offset, relocation,
8570
0
           split16d_type,
8571
0
           htab->params->vle_reloc_fixup);
8572
0
    goto report_reloc;
8573
8574
0
  case R_PPC_VLE_HA16A:
8575
0
    relocation = (relocation + addend + 0x8000) >> 16;
8576
0
    r = ppc_elf_vle_split16 (input_bfd, input_section, rel->r_offset,
8577
0
           contents + rel->r_offset, relocation,
8578
0
           split16a_type,
8579
0
           htab->params->vle_reloc_fixup);
8580
0
    goto report_reloc;
8581
8582
0
  case R_PPC_VLE_HA16D:
8583
0
    relocation = (relocation + addend + 0x8000) >> 16;
8584
0
    r = ppc_elf_vle_split16 (input_bfd, input_section, rel->r_offset,
8585
0
           contents + rel->r_offset, relocation,
8586
0
           split16d_type,
8587
0
           htab->params->vle_reloc_fixup);
8588
0
    goto report_reloc;
8589
8590
    /* Relocate against either _SDA_BASE_, _SDA2_BASE_, or 0.  */
8591
0
  case R_PPC_EMB_SDA21:
8592
0
  case R_PPC_VLE_SDA21:
8593
0
  case R_PPC_EMB_RELSDA:
8594
0
  case R_PPC_VLE_SDA21_LO:
8595
0
    if (!offset_in_range (input_section, rel->r_offset, 4))
8596
0
      {
8597
0
        r = bfd_reloc_outofrange;
8598
0
        goto report_reloc;
8599
0
      }
8600
0
    else
8601
0
      {
8602
0
        const char *name;
8603
0
        int reg;
8604
0
        unsigned int insn;
8605
0
        struct elf_link_hash_entry *sda = NULL;
8606
8607
0
        if (sec == NULL || sec->output_section == NULL)
8608
0
    {
8609
0
      unresolved_reloc = true;
8610
0
      break;
8611
0
    }
8612
8613
0
        name = bfd_section_name (sec->output_section);
8614
0
        if (strcmp (name, ".sdata") == 0
8615
0
      || strcmp (name, ".sbss") == 0)
8616
0
    {
8617
0
      reg = 13;
8618
0
      sda = htab->sdata[0].sym;
8619
0
    }
8620
0
        else if (strcmp (name, ".sdata2") == 0
8621
0
           || strcmp (name, ".sbss2") == 0)
8622
0
    {
8623
0
      reg = 2;
8624
0
      sda = htab->sdata[1].sym;
8625
0
    }
8626
0
        else if (strcmp (name, ".PPC.EMB.sdata0") == 0
8627
0
           || strcmp (name, ".PPC.EMB.sbss0") == 0)
8628
0
    {
8629
0
      reg = 0;
8630
0
    }
8631
0
        else
8632
0
    {
8633
0
      _bfd_error_handler
8634
        /* xgettext:c-format */
8635
0
        (_("%pB: the target (%s) of a %s relocation is "
8636
0
           "in the wrong output section (%s)"),
8637
0
         input_bfd,
8638
0
         sym_name,
8639
0
         howto->name,
8640
0
         name);
8641
8642
0
      bfd_set_error (bfd_error_bad_value);
8643
0
      ret = false;
8644
0
      goto copy_reloc;
8645
0
    }
8646
8647
0
        if (sda != NULL)
8648
0
    {
8649
0
      if (!is_static_defined (sda))
8650
0
        {
8651
0
          unresolved_reloc = true;
8652
0
          break;
8653
0
        }
8654
0
      addend -= SYM_VAL (sda);
8655
0
    }
8656
8657
0
        if (r_type == R_PPC_EMB_RELSDA)
8658
0
    break;
8659
8660
        /* The PowerPC Embedded Application Binary Interface
8661
     version 1.0 insanely chose to specify R_PPC_EMB_SDA21
8662
     operating on a 24-bit field at r_offset.  GNU as and
8663
     GNU ld have always assumed R_PPC_EMB_SDA21 operates on
8664
     a 32-bit bit insn at r_offset.  Cope with object file
8665
     producers that possibly comply with the EABI in
8666
     generating an odd r_offset for big-endian objects.  */
8667
0
        if (r_type == R_PPC_EMB_SDA21)
8668
0
    rel->r_offset &= ~1;
8669
8670
0
        insn = bfd_get_32 (input_bfd, contents + rel->r_offset);
8671
0
        if (reg == 0
8672
0
      && (r_type == R_PPC_VLE_SDA21
8673
0
          || r_type == R_PPC_VLE_SDA21_LO))
8674
0
    {
8675
0
      relocation = relocation + addend;
8676
0
      addend = 0;
8677
8678
      /* Force e_li insn, keeping RT from original insn.  */
8679
0
      insn &= 0x1f << 21;
8680
0
      insn |= 28u << 26;
8681
8682
      /* We have an li20 field, bits 17..20, 11..15, 21..31.  */
8683
      /* Top 4 bits of value to 17..20.  */
8684
0
      insn |= (relocation & 0xf0000) >> 5;
8685
      /* Next 5 bits of the value to 11..15.  */
8686
0
      insn |= (relocation & 0xf800) << 5;
8687
      /* And the final 11 bits of the value to bits 21 to 31.  */
8688
0
      insn |= relocation & 0x7ff;
8689
8690
0
      bfd_put_32 (input_bfd, insn, contents + rel->r_offset);
8691
8692
0
      r = bfd_reloc_ok;
8693
0
      if (r_type == R_PPC_VLE_SDA21
8694
0
          && ((relocation + 0x80000) & 0xffffffff) > 0x100000)
8695
0
        r = bfd_reloc_overflow;
8696
0
      goto report_reloc;
8697
0
    }
8698
        /* Fill in register field.  */
8699
0
        insn = (insn & ~RA_REGISTER_MASK) | (reg << RA_REGISTER_SHIFT);
8700
0
        bfd_put_32 (input_bfd, insn, contents + rel->r_offset);
8701
0
      }
8702
0
    break;
8703
8704
0
  case R_PPC_VLE_SDAREL_LO16A:
8705
0
  case R_PPC_VLE_SDAREL_LO16D:
8706
0
  case R_PPC_VLE_SDAREL_HI16A:
8707
0
  case R_PPC_VLE_SDAREL_HI16D:
8708
0
  case R_PPC_VLE_SDAREL_HA16A:
8709
0
  case R_PPC_VLE_SDAREL_HA16D:
8710
0
    if (!offset_in_range (input_section, rel->r_offset, 4))
8711
0
      r = bfd_reloc_outofrange;
8712
0
    else
8713
0
      {
8714
0
        bfd_vma value;
8715
0
        const char *name;
8716
0
        struct elf_link_hash_entry *sda = NULL;
8717
8718
0
        if (sec == NULL || sec->output_section == NULL)
8719
0
    {
8720
0
      unresolved_reloc = true;
8721
0
      break;
8722
0
    }
8723
8724
0
        name = bfd_section_name (sec->output_section);
8725
0
        if (strcmp (name, ".sdata") == 0
8726
0
      || strcmp (name, ".sbss") == 0)
8727
0
    sda = htab->sdata[0].sym;
8728
0
        else if (strcmp (name, ".sdata2") == 0
8729
0
           || strcmp (name, ".sbss2") == 0)
8730
0
    sda = htab->sdata[1].sym;
8731
0
        else
8732
0
    {
8733
0
      _bfd_error_handler
8734
        /* xgettext:c-format */
8735
0
        (_("%pB: the target (%s) of a %s relocation is "
8736
0
           "in the wrong output section (%s)"),
8737
0
         input_bfd,
8738
0
         sym_name,
8739
0
         howto->name,
8740
0
         name);
8741
8742
0
      bfd_set_error (bfd_error_bad_value);
8743
0
      ret = false;
8744
0
      goto copy_reloc;
8745
0
    }
8746
8747
0
        if (sda == NULL || !is_static_defined (sda))
8748
0
    {
8749
0
      unresolved_reloc = true;
8750
0
      break;
8751
0
    }
8752
0
        value = relocation + addend - SYM_VAL (sda);
8753
8754
0
        if (r_type == R_PPC_VLE_SDAREL_LO16A)
8755
0
    r = ppc_elf_vle_split16 (input_bfd, input_section,
8756
0
           rel->r_offset,
8757
0
           contents + rel->r_offset, value,
8758
0
           split16a_type,
8759
0
           htab->params->vle_reloc_fixup);
8760
0
        else if (r_type == R_PPC_VLE_SDAREL_LO16D)
8761
0
    r = ppc_elf_vle_split16 (input_bfd, input_section,
8762
0
           rel->r_offset,
8763
0
           contents + rel->r_offset, value,
8764
0
           split16d_type,
8765
0
           htab->params->vle_reloc_fixup);
8766
0
        else if (r_type == R_PPC_VLE_SDAREL_HI16A)
8767
0
    {
8768
0
      value = value >> 16;
8769
0
      r = ppc_elf_vle_split16 (input_bfd, input_section,
8770
0
             rel->r_offset,
8771
0
             contents + rel->r_offset, value,
8772
0
             split16a_type,
8773
0
             htab->params->vle_reloc_fixup);
8774
0
    }
8775
0
        else if (r_type == R_PPC_VLE_SDAREL_HI16D)
8776
0
    {
8777
0
      value = value >> 16;
8778
0
      r = ppc_elf_vle_split16 (input_bfd, input_section,
8779
0
             rel->r_offset,
8780
0
             contents + rel->r_offset, value,
8781
0
             split16d_type,
8782
0
             htab->params->vle_reloc_fixup);
8783
0
    }
8784
0
        else if (r_type == R_PPC_VLE_SDAREL_HA16A)
8785
0
    {
8786
0
      value = (value + 0x8000) >> 16;
8787
0
      r = ppc_elf_vle_split16 (input_bfd, input_section,
8788
0
             rel->r_offset,
8789
0
             contents + rel->r_offset, value,
8790
0
             split16a_type,
8791
0
             htab->params->vle_reloc_fixup);
8792
0
    }
8793
0
        else if (r_type == R_PPC_VLE_SDAREL_HA16D)
8794
0
    {
8795
0
      value = (value + 0x8000) >> 16;
8796
0
      r = ppc_elf_vle_split16 (input_bfd, input_section,
8797
0
             rel->r_offset,
8798
0
             contents + rel->r_offset, value,
8799
0
             split16d_type,
8800
0
             htab->params->vle_reloc_fixup);
8801
0
    }
8802
0
        else
8803
0
    abort ();
8804
0
      }
8805
0
    goto report_reloc;
8806
8807
0
  case R_PPC_VLE_ADDR20:
8808
0
    if (!offset_in_range (input_section, rel->r_offset, 4))
8809
0
      r = bfd_reloc_outofrange;
8810
0
    else
8811
0
      {
8812
0
        ppc_elf_vle_split20 (output_bfd, contents + rel->r_offset,
8813
0
           relocation);
8814
0
        r = bfd_reloc_ok;
8815
0
      }
8816
0
    goto report_reloc;
8817
8818
    /* Relocate against the beginning of the section.  */
8819
0
  case R_PPC_SECTOFF:
8820
0
  case R_PPC_SECTOFF_LO:
8821
0
  case R_PPC_SECTOFF_HI:
8822
0
  case R_PPC_SECTOFF_HA:
8823
0
    if (sec == NULL || sec->output_section == NULL)
8824
0
      {
8825
0
        unresolved_reloc = true;
8826
0
        break;
8827
0
      }
8828
0
    addend -= sec->output_section->vma;
8829
0
    break;
8830
8831
    /* Negative relocations.  */
8832
0
  case R_PPC_EMB_NADDR32:
8833
0
  case R_PPC_EMB_NADDR16:
8834
0
  case R_PPC_EMB_NADDR16_LO:
8835
0
  case R_PPC_EMB_NADDR16_HI:
8836
0
  case R_PPC_EMB_NADDR16_HA:
8837
0
    addend -= 2 * relocation;
8838
0
    break;
8839
8840
0
  case R_PPC_COPY:
8841
0
  case R_PPC_GLOB_DAT:
8842
0
  case R_PPC_JMP_SLOT:
8843
0
  case R_PPC_RELATIVE:
8844
0
  case R_PPC_IRELATIVE:
8845
0
  case R_PPC_PLT32:
8846
0
  case R_PPC_PLTREL32:
8847
0
  case R_PPC_ADDR30:
8848
0
  case R_PPC_EMB_RELSEC16:
8849
0
  case R_PPC_EMB_RELST_LO:
8850
0
  case R_PPC_EMB_RELST_HI:
8851
0
  case R_PPC_EMB_RELST_HA:
8852
0
  case R_PPC_EMB_BIT_FLD:
8853
    /* xgettext:c-format */
8854
0
    _bfd_error_handler (_("%pB: %s unsupported"),
8855
0
            input_bfd, howto->name);
8856
8857
0
    bfd_set_error (bfd_error_invalid_operation);
8858
0
    ret = false;
8859
0
    goto copy_reloc;
8860
0
  }
8861
8862
0
      switch (r_type)
8863
0
  {
8864
0
  default:
8865
0
    break;
8866
8867
0
  case R_PPC_TPREL16_HA:
8868
0
    if (htab->do_tls_opt
8869
0
        && relocation + addend + 0x8000 < 0x10000
8870
0
        && offset_in_range (input_section, rel->r_offset & ~3, 4))
8871
8872
0
      {
8873
0
        bfd_byte *p = contents + (rel->r_offset & ~3);
8874
0
        bfd_put_32 (input_bfd, NOP, p);
8875
0
      }
8876
0
    break;
8877
8878
0
  case R_PPC_TPREL16_LO:
8879
0
    if (htab->do_tls_opt
8880
0
        && relocation + addend + 0x8000 < 0x10000
8881
0
        && offset_in_range (input_section, rel->r_offset & ~3, 4))
8882
0
      {
8883
0
        bfd_byte *p = contents + (rel->r_offset & ~3);
8884
0
        unsigned int insn = bfd_get_32 (input_bfd, p);
8885
0
        insn &= ~(0x1f << 16);
8886
0
        insn |= 2 << 16;
8887
0
        bfd_put_32 (input_bfd, insn, p);
8888
0
      }
8889
0
    break;
8890
0
  }
8891
8892
0
      switch (r_type)
8893
0
  {
8894
0
  default:
8895
0
    break;
8896
8897
0
  case R_PPC_PLTCALL:
8898
0
    if (unresolved_reloc)
8899
0
      {
8900
0
        if (offset_in_range (input_section, rel->r_offset, 4))
8901
0
    {
8902
0
      bfd_byte *p = contents + rel->r_offset;
8903
0
      unsigned int insn = bfd_get_32 (input_bfd, p);
8904
0
      insn &= 1;
8905
0
      bfd_put_32 (input_bfd, B | insn, p);
8906
0
      unresolved_reloc = save_unresolved_reloc;
8907
0
      r_type = R_PPC_REL24;
8908
0
      howto = ppc_elf_howto_table[r_type];
8909
0
    }
8910
0
      }
8911
0
    else if (htab->plt_type != PLT_NEW)
8912
0
      info->callbacks->einfo
8913
0
        (_("%X%P: %H: %s relocation unsupported for bss-plt\n"),
8914
0
         input_bfd, input_section, rel->r_offset,
8915
0
         howto->name);
8916
0
    break;
8917
8918
0
  case R_PPC_PLTSEQ:
8919
0
  case R_PPC_PLT16_HA:
8920
0
  case R_PPC_PLT16_LO:
8921
0
    if (unresolved_reloc)
8922
0
      {
8923
0
        if (offset_in_range (input_section, rel->r_offset & ~3, 4))
8924
0
    {
8925
0
      bfd_byte *p = contents + (rel->r_offset & ~3);
8926
0
      bfd_put_32 (input_bfd, NOP, p);
8927
0
      unresolved_reloc = false;
8928
0
      r_type = R_PPC_NONE;
8929
0
      howto = ppc_elf_howto_table[r_type];
8930
0
    }
8931
0
      }
8932
0
    else if (htab->plt_type != PLT_NEW)
8933
0
      info->callbacks->einfo
8934
0
        (_("%X%P: %H: %s relocation unsupported for bss-plt\n"),
8935
0
         input_bfd, input_section, rel->r_offset,
8936
0
         howto->name);
8937
0
    break;
8938
0
  }
8939
8940
      /* Do any further special processing.  */
8941
0
      switch (r_type)
8942
0
  {
8943
0
  default:
8944
0
    break;
8945
8946
0
  case R_PPC_ADDR16_HA:
8947
0
  case R_PPC_REL16_HA:
8948
0
  case R_PPC_REL16DX_HA:
8949
0
  case R_PPC_SECTOFF_HA:
8950
0
  case R_PPC_TPREL16_HA:
8951
0
  case R_PPC_DTPREL16_HA:
8952
0
  case R_PPC_EMB_NADDR16_HA:
8953
0
  case R_PPC_EMB_RELST_HA:
8954
    /* It's just possible that this symbol is a weak symbol
8955
       that's not actually defined anywhere.  In that case,
8956
       'sec' would be NULL, and we should leave the symbol
8957
       alone (it will be set to zero elsewhere in the link).  */
8958
0
    if (sec == NULL)
8959
0
      break;
8960
    /* Fall through.  */
8961
8962
0
  case R_PPC_PLT16_HA:
8963
0
  case R_PPC_GOT16_HA:
8964
0
  case R_PPC_GOT_TLSGD16_HA:
8965
0
  case R_PPC_GOT_TLSLD16_HA:
8966
0
  case R_PPC_GOT_TPREL16_HA:
8967
0
  case R_PPC_GOT_DTPREL16_HA:
8968
    /* Add 0x10000 if sign bit in 0:15 is set.
8969
       Bits 0:15 are not used.  */
8970
0
    addend += 0x8000;
8971
0
    break;
8972
8973
0
  case R_PPC_ADDR16:
8974
0
  case R_PPC_ADDR16_LO:
8975
0
  case R_PPC_GOT16:
8976
0
  case R_PPC_GOT16_LO:
8977
0
  case R_PPC_SDAREL16:
8978
0
  case R_PPC_SECTOFF:
8979
0
  case R_PPC_SECTOFF_LO:
8980
0
  case R_PPC_DTPREL16:
8981
0
  case R_PPC_DTPREL16_LO:
8982
0
  case R_PPC_TPREL16:
8983
0
  case R_PPC_TPREL16_LO:
8984
0
  case R_PPC_GOT_TLSGD16:
8985
0
  case R_PPC_GOT_TLSGD16_LO:
8986
0
  case R_PPC_GOT_TLSLD16:
8987
0
  case R_PPC_GOT_TLSLD16_LO:
8988
0
  case R_PPC_GOT_DTPREL16:
8989
0
  case R_PPC_GOT_DTPREL16_LO:
8990
0
  case R_PPC_GOT_TPREL16:
8991
0
  case R_PPC_GOT_TPREL16_LO:
8992
0
    if (offset_in_range (input_section, rel->r_offset - d_offset, 4))
8993
0
      {
8994
        /* The 32-bit ABI lacks proper relocations to deal with
8995
     certain 64-bit instructions.  Prevent damage to bits
8996
     that make up part of the insn opcode.  */
8997
0
        unsigned int insn, mask, lobit;
8998
8999
0
        insn = bfd_get_32 (input_bfd,
9000
0
         contents + rel->r_offset - d_offset);
9001
0
        mask = 0;
9002
0
        if (is_insn_ds_form (insn))
9003
0
    mask = 3;
9004
0
        else if (is_insn_dq_form (insn))
9005
0
    mask = 15;
9006
0
        else
9007
0
    break;
9008
0
        relocation += addend;
9009
0
        addend = insn & mask;
9010
0
        lobit = mask & relocation;
9011
0
        if (lobit != 0)
9012
0
    {
9013
0
      relocation ^= lobit;
9014
0
      info->callbacks->einfo
9015
        /* xgettext:c-format */
9016
0
        (_("%H: error: %s against `%s' not a multiple of %u\n"),
9017
0
         input_bfd, input_section, rel->r_offset,
9018
0
         howto->name, sym_name, mask + 1);
9019
0
      bfd_set_error (bfd_error_bad_value);
9020
0
      ret = false;
9021
0
    }
9022
0
      }
9023
0
    break;
9024
0
  }
9025
9026
#ifdef DEBUG
9027
      fprintf (stderr, "\ttype = %s (%d), name = %s, symbol index = %ld, "
9028
         "offset = %ld, addend = %ld\n",
9029
         howto->name,
9030
         (int) r_type,
9031
         sym_name,
9032
         r_symndx,
9033
         (long) rel->r_offset,
9034
         (long) addend);
9035
#endif
9036
9037
0
      if (unresolved_reloc
9038
0
    && !((input_section->flags & SEC_DEBUGGING) != 0
9039
0
         && h->def_dynamic)
9040
0
    && _bfd_elf_section_offset (output_bfd, info, input_section,
9041
0
              rel->r_offset) != (bfd_vma) -1)
9042
0
  {
9043
0
    info->callbacks->einfo
9044
      /* xgettext:c-format */
9045
0
      (_("%H: unresolvable %s relocation against symbol `%s'\n"),
9046
0
       input_bfd, input_section, rel->r_offset,
9047
0
       howto->name,
9048
0
       sym_name);
9049
0
    ret = false;
9050
0
  }
9051
9052
      /* 16-bit fields in insns mostly have signed values, but a
9053
   few insns have 16-bit unsigned values.  Really, we should
9054
   have different reloc types.  */
9055
0
      if (howto->complain_on_overflow != complain_overflow_dont
9056
0
    && howto->dst_mask == 0xffff
9057
0
    && (input_section->flags & SEC_CODE) != 0
9058
0
    && offset_in_range (input_section, rel->r_offset & ~3, 4))
9059
0
  {
9060
0
    enum complain_overflow complain = complain_overflow_signed;
9061
9062
0
    if ((elf_section_flags (input_section) & SHF_PPC_VLE) == 0)
9063
0
      {
9064
0
        unsigned int insn;
9065
9066
0
        insn = bfd_get_32 (input_bfd, contents + (rel->r_offset & ~3));
9067
0
        if ((insn & (0x3fu << 26)) == 10u << 26 /* cmpli */)
9068
0
    complain = complain_overflow_bitfield;
9069
0
        else if ((insn & (0x3fu << 26)) == 28u << 26 /* andi */
9070
0
           || (insn & (0x3fu << 26)) == 24u << 26 /* ori */
9071
0
           || (insn & (0x3fu << 26)) == 26u << 26 /* xori */)
9072
0
    complain = complain_overflow_unsigned;
9073
0
      }
9074
0
    if (howto->complain_on_overflow != complain)
9075
0
      {
9076
0
        alt_howto = *howto;
9077
0
        alt_howto.complain_on_overflow = complain;
9078
0
        howto = &alt_howto;
9079
0
      }
9080
0
  }
9081
9082
0
      if (r_type == R_PPC_REL16DX_HA)
9083
0
  {
9084
    /* Split field reloc isn't handled by _bfd_final_link_relocate.  */
9085
0
    if (offset_in_range (input_section, rel->r_offset, 4))
9086
0
      r = bfd_reloc_outofrange;
9087
0
    else
9088
0
      {
9089
0
        unsigned int insn;
9090
9091
0
        relocation += addend;
9092
0
        relocation -= (rel->r_offset
9093
0
           + input_section->output_offset
9094
0
           + input_section->output_section->vma);
9095
0
        relocation >>= 16;
9096
0
        insn = bfd_get_32 (input_bfd, contents + rel->r_offset);
9097
0
        insn &= ~0x1fffc1;
9098
0
        insn |= (relocation & 0xffc1) | ((relocation & 0x3e) << 15);
9099
0
        bfd_put_32 (input_bfd, insn, contents + rel->r_offset);
9100
0
        r = bfd_reloc_ok;
9101
0
      }
9102
0
  }
9103
0
      else
9104
0
  r = _bfd_final_link_relocate (howto, input_bfd, input_section, contents,
9105
0
              rel->r_offset, relocation, addend);
9106
9107
0
    report_reloc:
9108
0
      if (r != bfd_reloc_ok)
9109
0
  {
9110
0
    if (r == bfd_reloc_overflow)
9111
0
      {
9112
        /* On code like "if (foo) foo();" don't report overflow
9113
     on a branch to zero when foo is undefined.  */
9114
0
        if (!warned
9115
0
      && !(h != NULL
9116
0
           && (h->root.type == bfd_link_hash_undefweak
9117
0
         || h->root.type == bfd_link_hash_undefined)
9118
0
           && is_branch_reloc (r_type)))
9119
0
    info->callbacks->reloc_overflow
9120
0
      (info, (h ? &h->root : NULL), sym_name, howto->name,
9121
0
       rel->r_addend, input_bfd, input_section, rel->r_offset);
9122
0
      }
9123
0
    else
9124
0
      {
9125
0
        info->callbacks->einfo
9126
    /* xgettext:c-format */
9127
0
    (_("%H: %s reloc against `%s': error %d\n"),
9128
0
     input_bfd, input_section, rel->r_offset,
9129
0
     howto->name, sym_name, (int) r);
9130
0
        ret = false;
9131
0
      }
9132
0
  }
9133
0
    copy_reloc:
9134
0
      if (wrel != rel)
9135
0
  *wrel = *rel;
9136
0
    }
9137
9138
0
  if (wrel != rel)
9139
0
    {
9140
0
      Elf_Internal_Shdr *rel_hdr;
9141
0
      size_t deleted = rel - wrel;
9142
9143
0
      rel_hdr = _bfd_elf_single_rel_hdr (input_section->output_section);
9144
0
      rel_hdr->sh_size -= rel_hdr->sh_entsize * deleted;
9145
0
      if (rel_hdr->sh_size == 0)
9146
0
  {
9147
    /* It is too late to remove an empty reloc section.  Leave
9148
       one NONE reloc.
9149
       ??? What is wrong with an empty section???  */
9150
0
    rel_hdr->sh_size = rel_hdr->sh_entsize;
9151
0
    deleted -= 1;
9152
0
    wrel++;
9153
0
  }
9154
0
      relend = wrel;
9155
0
      rel_hdr = _bfd_elf_single_rel_hdr (input_section);
9156
0
      rel_hdr->sh_size -= rel_hdr->sh_entsize * deleted;
9157
0
      input_section->reloc_count -= deleted;
9158
0
    }
9159
9160
#ifdef DEBUG
9161
  fprintf (stderr, "\n");
9162
#endif
9163
9164
0
  if (input_section->sec_info_type == SEC_INFO_TYPE_TARGET
9165
0
      && input_section->size != input_section->rawsize
9166
0
      && (strcmp (input_section->output_section->name, ".init") == 0
9167
0
    || strcmp (input_section->output_section->name, ".fini") == 0))
9168
0
    {
9169
      /* Branch around the trampolines.  */
9170
0
      unsigned int insn = B + input_section->size - input_section->rawsize;
9171
0
      bfd_put_32 (input_bfd, insn, contents + input_section->rawsize);
9172
0
    }
9173
9174
0
  if (htab->params->ppc476_workaround
9175
0
      && input_section->sec_info_type == SEC_INFO_TYPE_TARGET
9176
0
      && (!bfd_link_relocatable (info)
9177
0
    || (input_section->output_section->alignment_power
9178
0
        >= htab->params->pagesize_p2)))
9179
0
    {
9180
0
      bfd_vma start_addr, end_addr, addr;
9181
0
      bfd_vma pagesize = (bfd_vma) 1 << htab->params->pagesize_p2;
9182
9183
0
      if (relax_info->workaround_size != 0)
9184
0
  {
9185
0
    bfd_byte *p;
9186
0
    unsigned int n;
9187
0
    bfd_byte fill[4];
9188
9189
0
    bfd_put_32 (input_bfd, BA, fill);
9190
0
    p = contents + input_section->size - relax_info->workaround_size;
9191
0
    n = relax_info->workaround_size >> 2;
9192
0
    while (n--)
9193
0
      {
9194
0
        memcpy (p, fill, 4);
9195
0
        p += 4;
9196
0
      }
9197
0
  }
9198
9199
      /* The idea is: Replace the last instruction on a page with a
9200
   branch to a patch area.  Put the insn there followed by a
9201
   branch back to the next page.  Complicated a little by
9202
   needing to handle moved conditional branches, and by not
9203
   wanting to touch data-in-text.  */
9204
9205
0
      start_addr = (input_section->output_section->vma
9206
0
        + input_section->output_offset);
9207
0
      end_addr = (start_addr + input_section->size
9208
0
      - relax_info->workaround_size);
9209
0
      for (addr = ((start_addr & -pagesize) + pagesize - 4);
9210
0
     addr < end_addr;
9211
0
     addr += pagesize)
9212
0
  {
9213
0
    bfd_vma offset = addr - start_addr;
9214
0
    Elf_Internal_Rela *lo, *hi;
9215
0
    bool is_data;
9216
0
    bfd_vma patch_off, patch_addr;
9217
0
    unsigned int insn;
9218
9219
    /* Do we have a data reloc at this offset?  If so, leave
9220
       the word alone.  */
9221
0
    is_data = false;
9222
0
    lo = relocs;
9223
0
    hi = relend;
9224
0
    rel = NULL;
9225
0
    while (lo < hi)
9226
0
      {
9227
0
        rel = lo + (hi - lo) / 2;
9228
0
        if (rel->r_offset < offset)
9229
0
    lo = rel + 1;
9230
0
        else if (rel->r_offset > offset + 3)
9231
0
    hi = rel;
9232
0
        else
9233
0
    {
9234
0
      switch (ELF32_R_TYPE (rel->r_info))
9235
0
        {
9236
0
        case R_PPC_ADDR32:
9237
0
        case R_PPC_UADDR32:
9238
0
        case R_PPC_REL32:
9239
0
        case R_PPC_ADDR30:
9240
0
          is_data = true;
9241
0
          break;
9242
0
        default:
9243
0
          break;
9244
0
        }
9245
0
      break;
9246
0
    }
9247
0
      }
9248
0
    if (is_data)
9249
0
      continue;
9250
9251
    /* Some instructions can be left alone too.  Unconditional
9252
       branches, except for bcctr with BO=0x14 (bctr, bctrl),
9253
       avoid the icache failure.
9254
9255
       The problem occurs due to prefetch across a page boundary
9256
       where stale instructions can be fetched from the next
9257
       page, and the mechanism for flushing these bad
9258
       instructions fails under certain circumstances.  The
9259
       unconditional branches:
9260
       1) Branch: b, bl, ba, bla,
9261
       2) Branch Conditional: bc, bca, bcl, bcla,
9262
       3) Branch Conditional to Link Register: bclr, bclrl,
9263
       where (2) and (3) have BO=0x14 making them unconditional,
9264
       prevent the bad prefetch because the prefetch itself is
9265
       affected by these instructions.  This happens even if the
9266
       instruction is not executed.
9267
9268
       A bctr example:
9269
       .
9270
       .  lis 9,new_page@ha
9271
       .  addi 9,9,new_page@l
9272
       .  mtctr 9
9273
       .  bctr
9274
       .  nop
9275
       .  nop
9276
       . new_page:
9277
       .
9278
       The bctr is not predicted taken due to ctr not being
9279
       ready, so prefetch continues on past the bctr into the
9280
       new page which might have stale instructions.  If they
9281
       fail to be flushed, then they will be executed after the
9282
       bctr executes.  Either of the following modifications
9283
       prevent the bad prefetch from happening in the first
9284
       place:
9285
       .
9286
       .  lis 9,new_page@ha  lis 9,new_page@ha
9287
       .  addi 9,9,new_page@l  addi 9,9,new_page@l
9288
       .  mtctr 9      mtctr 9
9289
       .  bctr       bctr
9290
       .  nop      b somewhere_else
9291
       .  b somewhere_else   nop
9292
       . new_page:    new_page:
9293
       .  */
9294
0
    insn = bfd_get_32 (input_bfd, contents + offset);
9295
0
    if ((insn & (0x3fu << 26)) == (18u << 26)      /* b,bl,ba,bla */
9296
0
        || ((insn & (0x3fu << 26)) == (16u << 26)      /* bc,bcl,bca,bcla*/
9297
0
      && (insn & (0x14 << 21)) == (0x14 << 21)) /*   with BO=0x14 */
9298
0
        || ((insn & (0x3fu << 26)) == (19u << 26)
9299
0
      && (insn & (0x3ff << 1)) == (16u << 1)    /* bclr,bclrl */
9300
0
      && (insn & (0x14 << 21)) == (0x14 << 21)))/*   with BO=0x14 */
9301
0
      continue;
9302
9303
0
    patch_addr = (start_addr + input_section->size
9304
0
      - relax_info->workaround_size);
9305
0
    patch_addr = (patch_addr + 15) & -16;
9306
0
    patch_off = patch_addr - start_addr;
9307
0
    bfd_put_32 (input_bfd, B + patch_off - offset, contents + offset);
9308
9309
0
    if (rel != NULL
9310
0
        && rel->r_offset >= offset
9311
0
        && rel->r_offset < offset + 4)
9312
0
      {
9313
0
        asection *sreloc;
9314
9315
        /* If the insn we are patching had a reloc, adjust the
9316
     reloc r_offset so that the reloc applies to the moved
9317
     location.  This matters for -r and --emit-relocs.  */
9318
0
        if (rel + 1 != relend)
9319
0
    {
9320
0
      Elf_Internal_Rela tmp = *rel;
9321
9322
      /* Keep the relocs sorted by r_offset.  */
9323
0
      memmove (rel, rel + 1, (relend - (rel + 1)) * sizeof (*rel));
9324
0
      relend[-1] = tmp;
9325
0
    }
9326
0
        relend[-1].r_offset += patch_off - offset;
9327
9328
        /* Adjust REL16 addends too.  */
9329
0
        switch (ELF32_R_TYPE (relend[-1].r_info))
9330
0
    {
9331
0
    case R_PPC_REL16:
9332
0
    case R_PPC_REL16_LO:
9333
0
    case R_PPC_REL16_HI:
9334
0
    case R_PPC_REL16_HA:
9335
0
      relend[-1].r_addend += patch_off - offset;
9336
0
      break;
9337
0
    default:
9338
0
      break;
9339
0
    }
9340
9341
        /* If we are building a PIE or shared library with
9342
     non-PIC objects, perhaps we had a dynamic reloc too?
9343
     If so, the dynamic reloc must move with the insn.  */
9344
0
        sreloc = elf_section_data (input_section)->sreloc;
9345
0
        if (sreloc != NULL)
9346
0
    {
9347
0
      Elf32_External_Rela *slo, *shi, *srelend;
9348
0
      bfd_vma soffset;
9349
9350
0
      slo = (Elf32_External_Rela *) sreloc->contents;
9351
0
      shi = srelend = slo + sreloc->reloc_count;
9352
0
      soffset = (offset + input_section->output_section->vma
9353
0
           + input_section->output_offset);
9354
0
      while (slo < shi)
9355
0
        {
9356
0
          Elf32_External_Rela *srel = slo + (shi - slo) / 2;
9357
0
          bfd_elf32_swap_reloca_in (output_bfd, (bfd_byte *) srel,
9358
0
            &outrel);
9359
0
          if (outrel.r_offset < soffset)
9360
0
      slo = srel + 1;
9361
0
          else if (outrel.r_offset > soffset + 3)
9362
0
      shi = srel;
9363
0
          else
9364
0
      {
9365
0
        if (srel + 1 != srelend)
9366
0
          {
9367
0
            memmove (srel, srel + 1,
9368
0
               (srelend - (srel + 1)) * sizeof (*srel));
9369
0
            srel = srelend - 1;
9370
0
          }
9371
0
        outrel.r_offset += patch_off - offset;
9372
0
        bfd_elf32_swap_reloca_out (output_bfd, &outrel,
9373
0
                 (bfd_byte *) srel);
9374
0
        break;
9375
0
      }
9376
0
        }
9377
0
    }
9378
0
      }
9379
0
    else
9380
0
      rel = NULL;
9381
9382
0
    if ((insn & (0x3fu << 26)) == (16u << 26) /* bc */
9383
0
        && (insn & 2) == 0 /* relative */)
9384
0
      {
9385
0
        bfd_vma delta = ((insn & 0xfffc) ^ 0x8000) - 0x8000;
9386
9387
0
        delta += offset - patch_off;
9388
0
        if (bfd_link_relocatable (info) && rel != NULL)
9389
0
    delta = 0;
9390
0
        if (!bfd_link_relocatable (info) && rel != NULL)
9391
0
    {
9392
0
      enum elf_ppc_reloc_type r_type;
9393
9394
0
      r_type = ELF32_R_TYPE (relend[-1].r_info);
9395
0
      if (r_type == R_PPC_REL14_BRTAKEN)
9396
0
        insn |= BRANCH_PREDICT_BIT;
9397
0
      else if (r_type == R_PPC_REL14_BRNTAKEN)
9398
0
        insn &= ~BRANCH_PREDICT_BIT;
9399
0
      else
9400
0
        BFD_ASSERT (r_type == R_PPC_REL14);
9401
9402
0
      if ((r_type == R_PPC_REL14_BRTAKEN
9403
0
           || r_type == R_PPC_REL14_BRNTAKEN)
9404
0
          && delta + 0x8000 < 0x10000
9405
0
          && (bfd_signed_vma) delta < 0)
9406
0
        insn ^= BRANCH_PREDICT_BIT;
9407
0
    }
9408
0
        if (delta + 0x8000 < 0x10000)
9409
0
    {
9410
0
      bfd_put_32 (input_bfd,
9411
0
            (insn & ~0xfffc) | (delta & 0xfffc),
9412
0
            contents + patch_off);
9413
0
      patch_off += 4;
9414
0
      bfd_put_32 (input_bfd,
9415
0
            B | ((offset + 4 - patch_off) & 0x3fffffc),
9416
0
            contents + patch_off);
9417
0
      patch_off += 4;
9418
0
    }
9419
0
        else
9420
0
    {
9421
0
      if (rel != NULL)
9422
0
        {
9423
0
          unsigned int r_sym = ELF32_R_SYM (relend[-1].r_info);
9424
9425
0
          relend[-1].r_offset += 8;
9426
0
          relend[-1].r_info = ELF32_R_INFO (r_sym, R_PPC_REL24);
9427
0
        }
9428
0
      bfd_put_32 (input_bfd,
9429
0
            (insn & ~0xfffc) | 8,
9430
0
            contents + patch_off);
9431
0
      patch_off += 4;
9432
0
      bfd_put_32 (input_bfd,
9433
0
            B | ((offset + 4 - patch_off) & 0x3fffffc),
9434
0
            contents + patch_off);
9435
0
      patch_off += 4;
9436
0
      bfd_put_32 (input_bfd,
9437
0
            B | ((delta - 8) & 0x3fffffc),
9438
0
            contents + patch_off);
9439
0
      patch_off += 4;
9440
0
    }
9441
0
      }
9442
0
    else
9443
0
      {
9444
0
        bfd_put_32 (input_bfd, insn, contents + patch_off);
9445
0
        patch_off += 4;
9446
0
        bfd_put_32 (input_bfd,
9447
0
        B | ((offset + 4 - patch_off) & 0x3fffffc),
9448
0
        contents + patch_off);
9449
0
        patch_off += 4;
9450
0
      }
9451
0
    BFD_ASSERT (patch_off <= input_section->size);
9452
0
    relax_info->workaround_size = input_section->size - patch_off;
9453
0
  }
9454
0
    }
9455
9456
0
  return ret;
9457
0
}
9458

9459
/* Write out the PLT relocs and entries for H.  */
9460
9461
static bool
9462
write_global_sym_plt (struct elf_link_hash_entry *h, void *inf)
9463
0
{
9464
0
  struct bfd_link_info *info = (struct bfd_link_info *) inf;
9465
0
  struct ppc_elf_link_hash_table *htab = ppc_elf_hash_table (info);
9466
0
  struct plt_entry *ent;
9467
0
  bool doneone;
9468
9469
0
  doneone = false;
9470
0
  for (ent = h->plt.plist; ent != NULL; ent = ent->next)
9471
0
    if (ent->plt.offset != (bfd_vma) -1)
9472
0
      {
9473
0
  bool dyn = !use_local_plt (info, h);
9474
9475
0
  if (!doneone)
9476
0
    {
9477
0
      Elf_Internal_Rela rela;
9478
0
      bfd_byte *loc;
9479
0
      bfd_vma reloc_index;
9480
0
      asection *plt = htab->elf.splt;
9481
0
      asection *relplt = htab->elf.srelplt;
9482
9483
0
      if (htab->plt_type == PLT_NEW || !dyn)
9484
0
        reloc_index = ent->plt.offset / 4;
9485
0
      else
9486
0
        {
9487
0
    reloc_index = ((ent->plt.offset - htab->plt_initial_entry_size)
9488
0
             / htab->plt_slot_size);
9489
0
    if (reloc_index > PLT_NUM_SINGLE_ENTRIES
9490
0
        && htab->plt_type == PLT_OLD)
9491
0
      reloc_index -= (reloc_index - PLT_NUM_SINGLE_ENTRIES) / 2;
9492
0
        }
9493
9494
      /* This symbol has an entry in the procedure linkage table.
9495
         Set it up.  */
9496
0
      if (htab->plt_type == PLT_VXWORKS && dyn)
9497
0
        {
9498
0
    bfd_vma got_offset;
9499
0
    const bfd_vma *plt_entry;
9500
9501
    /* The first three entries in .got.plt are reserved.  */
9502
0
    got_offset = (reloc_index + 3) * 4;
9503
9504
    /* Use the right PLT. */
9505
0
    plt_entry = bfd_link_pic (info) ? ppc_elf_vxworks_pic_plt_entry
9506
0
          : ppc_elf_vxworks_plt_entry;
9507
9508
    /* Fill in the .plt on VxWorks.  */
9509
0
    if (bfd_link_pic (info))
9510
0
      {
9511
0
        bfd_put_32 (info->output_bfd,
9512
0
        plt_entry[0] | PPC_HA (got_offset),
9513
0
        plt->contents + ent->plt.offset + 0);
9514
0
        bfd_put_32 (info->output_bfd,
9515
0
        plt_entry[1] | PPC_LO (got_offset),
9516
0
        plt->contents + ent->plt.offset + 4);
9517
0
      }
9518
0
    else
9519
0
      {
9520
0
        bfd_vma got_loc = got_offset + SYM_VAL (htab->elf.hgot);
9521
9522
0
        bfd_put_32 (info->output_bfd,
9523
0
        plt_entry[0] | PPC_HA (got_loc),
9524
0
        plt->contents + ent->plt.offset + 0);
9525
0
        bfd_put_32 (info->output_bfd,
9526
0
        plt_entry[1] | PPC_LO (got_loc),
9527
0
        plt->contents + ent->plt.offset + 4);
9528
0
      }
9529
9530
0
    bfd_put_32 (info->output_bfd, plt_entry[2],
9531
0
          plt->contents + ent->plt.offset + 8);
9532
0
    bfd_put_32 (info->output_bfd, plt_entry[3],
9533
0
          plt->contents + ent->plt.offset + 12);
9534
9535
    /* This instruction is an immediate load.  The value loaded is
9536
       the byte offset of the R_PPC_JMP_SLOT relocation from the
9537
       start of the .rela.plt section.  The value is stored in the
9538
       low-order 16 bits of the load instruction.  */
9539
    /* NOTE: It appears that this is now an index rather than a
9540
       prescaled offset.  */
9541
0
    bfd_put_32 (info->output_bfd,
9542
0
          plt_entry[4] | reloc_index,
9543
0
          plt->contents + ent->plt.offset + 16);
9544
    /* This instruction is a PC-relative branch whose target is
9545
       the start of the PLT section.  The address of this branch
9546
       instruction is 20 bytes beyond the start of this PLT entry.
9547
       The address is encoded in bits 6-29, inclusive.  The value
9548
       stored is right-shifted by two bits, permitting a 26-bit
9549
       offset.  */
9550
0
    bfd_put_32 (info->output_bfd,
9551
0
          (plt_entry[5]
9552
0
           | (-(ent->plt.offset + 20) & 0x03fffffc)),
9553
0
          plt->contents + ent->plt.offset + 20);
9554
0
    bfd_put_32 (info->output_bfd, plt_entry[6],
9555
0
          plt->contents + ent->plt.offset + 24);
9556
0
    bfd_put_32 (info->output_bfd, plt_entry[7],
9557
0
          plt->contents + ent->plt.offset + 28);
9558
9559
    /* Fill in the GOT entry corresponding to this PLT slot with
9560
       the address immediately after the "bctr" instruction
9561
       in this PLT entry.  */
9562
0
    bfd_put_32 (info->output_bfd, (plt->output_section->vma
9563
0
                 + plt->output_offset
9564
0
                 + ent->plt.offset + 16),
9565
0
          htab->elf.sgotplt->contents + got_offset);
9566
9567
0
    if (!bfd_link_pic (info))
9568
0
      {
9569
        /* Fill in a couple of entries in .rela.plt.unloaded.  */
9570
0
        loc = htab->srelplt2->contents
9571
0
          + ((VXWORKS_PLTRESOLVE_RELOCS + reloc_index
9572
0
        * VXWORKS_PLT_NON_JMP_SLOT_RELOCS)
9573
0
       * sizeof (Elf32_External_Rela));
9574
9575
        /* Provide the @ha relocation for the first instruction.  */
9576
0
        rela.r_offset = (plt->output_section->vma
9577
0
             + plt->output_offset
9578
0
             + ent->plt.offset + 2);
9579
0
        rela.r_info = ELF32_R_INFO (htab->elf.hgot->indx,
9580
0
            R_PPC_ADDR16_HA);
9581
0
        rela.r_addend = got_offset;
9582
0
        BFD_ASSERT (swap_reloc_out (info->output_bfd, &rela, loc,
9583
0
            htab->srelplt2));
9584
0
        loc += sizeof (Elf32_External_Rela);
9585
9586
        /* Provide the @l relocation for the second instruction.  */
9587
0
        rela.r_offset = (plt->output_section->vma
9588
0
             + plt->output_offset
9589
0
             + ent->plt.offset + 6);
9590
0
        rela.r_info = ELF32_R_INFO (htab->elf.hgot->indx,
9591
0
            R_PPC_ADDR16_LO);
9592
0
        rela.r_addend = got_offset;
9593
0
        BFD_ASSERT (swap_reloc_out (info->output_bfd, &rela, loc,
9594
0
            htab->srelplt2));
9595
0
        loc += sizeof (Elf32_External_Rela);
9596
9597
        /* Provide a relocation for the GOT entry corresponding to this
9598
           PLT slot.  Point it at the middle of the .plt entry.  */
9599
0
        rela.r_offset = (htab->elf.sgotplt->output_section->vma
9600
0
             + htab->elf.sgotplt->output_offset
9601
0
             + got_offset);
9602
0
        rela.r_info = ELF32_R_INFO (htab->elf.hplt->indx,
9603
0
            R_PPC_ADDR32);
9604
0
        rela.r_addend = ent->plt.offset + 16;
9605
0
        BFD_ASSERT (swap_reloc_out (info->output_bfd, &rela, loc,
9606
0
            htab->srelplt2));
9607
0
      }
9608
9609
    /* VxWorks uses non-standard semantics for R_PPC_JMP_SLOT.
9610
       In particular, the offset for the relocation is not the
9611
       address of the PLT entry for this function, as specified
9612
       by the ABI.  Instead, the offset is set to the address of
9613
       the GOT slot for this function.  See EABI 4.4.4.1.  */
9614
0
    rela.r_offset = (htab->elf.sgotplt->output_section->vma
9615
0
         + htab->elf.sgotplt->output_offset
9616
0
         + got_offset);
9617
0
    rela.r_addend = 0;
9618
0
        }
9619
0
      else
9620
0
        {
9621
0
    rela.r_addend = 0;
9622
0
    if (!dyn)
9623
0
      {
9624
0
        if (h->type == STT_GNU_IFUNC)
9625
0
          {
9626
0
      plt = htab->elf.iplt;
9627
0
      relplt = htab->elf.irelplt;
9628
0
          }
9629
0
        else
9630
0
          {
9631
0
      plt = htab->pltlocal;
9632
0
      relplt = bfd_link_pic (info) ? htab->relpltlocal : NULL;
9633
0
          }
9634
0
        if (h->def_regular
9635
0
      && (h->root.type == bfd_link_hash_defined
9636
0
          || h->root.type == bfd_link_hash_defweak))
9637
0
          rela.r_addend = SYM_VAL (h);
9638
0
      }
9639
9640
0
    if (relplt == NULL)
9641
0
      {
9642
0
        loc = plt->contents + ent->plt.offset;
9643
0
        bfd_put_32 (info->output_bfd, rela.r_addend, loc);
9644
0
      }
9645
0
    else
9646
0
      {
9647
0
        rela.r_offset = (plt->output_section->vma
9648
0
             + plt->output_offset
9649
0
             + ent->plt.offset);
9650
9651
0
        if (htab->plt_type == PLT_OLD || !dyn)
9652
0
          {
9653
      /* We don't need to fill in the .plt.  The ppc dynamic
9654
         linker will fill it in.  */
9655
0
          }
9656
0
        else
9657
0
          {
9658
0
      bfd_vma val = (htab->glink_pltresolve + ent->plt.offset
9659
0
               + htab->glink->output_section->vma
9660
0
               + htab->glink->output_offset);
9661
0
      bfd_put_32 (info->output_bfd, val,
9662
0
            plt->contents + ent->plt.offset);
9663
0
          }
9664
0
      }
9665
0
        }
9666
9667
0
      if (relplt != NULL)
9668
0
        {
9669
    /* Fill in the entry in the .rela.plt section.  */
9670
0
    if (!dyn)
9671
0
      {
9672
0
        if (h->type == STT_GNU_IFUNC)
9673
0
          rela.r_info = ELF32_R_INFO (0, R_PPC_IRELATIVE);
9674
0
        else
9675
0
          rela.r_info = ELF32_R_INFO (0, R_PPC_RELATIVE);
9676
0
        loc = relplt->contents + (relplt->reloc_count++
9677
0
                * sizeof (Elf32_External_Rela));
9678
0
        htab->local_ifunc_resolver = 1;
9679
0
      }
9680
0
    else
9681
0
      {
9682
0
        rela.r_info = ELF32_R_INFO (h->dynindx, R_PPC_JMP_SLOT);
9683
0
        loc = relplt->contents + (reloc_index
9684
0
                * sizeof (Elf32_External_Rela));
9685
0
        if (h->type == STT_GNU_IFUNC && is_static_defined (h))
9686
0
          htab->maybe_local_ifunc_resolver = 1;
9687
0
      }
9688
0
    BFD_ASSERT (swap_reloc_out (info->output_bfd, &rela,
9689
0
              loc, relplt));
9690
0
        }
9691
0
      doneone = true;
9692
0
    }
9693
9694
0
  if (htab->plt_type == PLT_NEW || !dyn)
9695
0
    {
9696
0
      unsigned char *p;
9697
0
      asection *plt = htab->elf.splt;
9698
9699
0
      if (!dyn)
9700
0
        {
9701
0
    if (h->type == STT_GNU_IFUNC)
9702
0
      plt = htab->elf.iplt;
9703
0
    else
9704
0
      break;
9705
0
        }
9706
9707
0
      p = (unsigned char *) htab->glink->contents + ent->glink_offset;
9708
0
      write_glink_stub (h, ent, plt, p, info);
9709
9710
0
      if (!bfd_link_pic (info))
9711
        /* We only need one non-PIC glink stub.  */
9712
0
        break;
9713
0
    }
9714
0
  else
9715
0
    break;
9716
0
      }
9717
0
  return true;
9718
0
}
9719
9720
/* Finish up PLT handling.  */
9721
9722
bool
9723
ppc_finish_symbols (struct bfd_link_info *info)
9724
0
{
9725
0
  struct ppc_elf_link_hash_table *htab = ppc_elf_hash_table (info);
9726
0
  bfd *ibfd;
9727
9728
0
  if (!htab)
9729
0
    return true;
9730
9731
0
  elf_link_hash_traverse (&htab->elf, write_global_sym_plt, info);
9732
9733
0
  for (ibfd = info->input_bfds; ibfd != NULL; ibfd = ibfd->link.next)
9734
0
    {
9735
0
      bfd_vma *local_got, *end_local_got;
9736
0
      struct plt_entry **local_plt, **lplt, **end_local_plt;
9737
0
      Elf_Internal_Shdr *symtab_hdr;
9738
0
      bfd_size_type locsymcount;
9739
0
      Elf_Internal_Sym *local_syms = NULL;
9740
0
      struct plt_entry *ent;
9741
9742
0
      if (!is_ppc_elf (ibfd))
9743
0
  continue;
9744
9745
0
      local_got = elf_local_got_offsets (ibfd);
9746
0
      if (!local_got)
9747
0
  continue;
9748
9749
0
      symtab_hdr = &elf_symtab_hdr (ibfd);
9750
0
      locsymcount = symtab_hdr->sh_info;
9751
0
      end_local_got = local_got + locsymcount;
9752
0
      local_plt = (struct plt_entry **) end_local_got;
9753
0
      end_local_plt = local_plt + locsymcount;
9754
0
      for (lplt = local_plt; lplt < end_local_plt; ++lplt)
9755
0
  for (ent = *lplt; ent != NULL; ent = ent->next)
9756
0
    {
9757
0
      if (ent->plt.offset != (bfd_vma) -1)
9758
0
        {
9759
0
    Elf_Internal_Sym *sym;
9760
0
    asection *sym_sec;
9761
0
    asection *plt, *relplt;
9762
0
    bfd_byte *loc;
9763
0
    bfd_vma val;
9764
0
    Elf_Internal_Rela rela;
9765
0
    unsigned char *p;
9766
9767
0
    if (!get_sym_h (NULL, &sym, &sym_sec, NULL, &local_syms,
9768
0
        lplt - local_plt, ibfd))
9769
0
      {
9770
0
        if (symtab_hdr->contents != (unsigned char *) local_syms)
9771
0
          free (local_syms);
9772
0
        return false;
9773
0
      }
9774
9775
0
    val = sym->st_value;
9776
0
    if (sym_sec != NULL && sym_sec->output_section != NULL)
9777
0
      val += sym_sec->output_offset + sym_sec->output_section->vma;
9778
9779
0
    if (ELF_ST_TYPE (sym->st_info) == STT_GNU_IFUNC)
9780
0
      {
9781
0
        htab->local_ifunc_resolver = 1;
9782
0
        plt = htab->elf.iplt;
9783
0
        relplt = htab->elf.irelplt;
9784
0
        rela.r_info = ELF32_R_INFO (0, R_PPC_IRELATIVE);
9785
0
      }
9786
0
    else
9787
0
      {
9788
0
        plt = htab->pltlocal;
9789
0
        if (bfd_link_pic (info))
9790
0
          {
9791
0
      relplt = htab->relpltlocal;
9792
0
      rela.r_info = ELF32_R_INFO (0, R_PPC_RELATIVE);
9793
0
          }
9794
0
        else
9795
0
          {
9796
0
      loc = plt->contents + ent->plt.offset;
9797
0
      bfd_put_32 (info->output_bfd, val, loc);
9798
0
      continue;
9799
0
          }
9800
0
      }
9801
9802
0
    rela.r_offset = (ent->plt.offset
9803
0
         + plt->output_offset
9804
0
         + plt->output_section->vma);
9805
0
    rela.r_addend = val;
9806
0
    BFD_ASSERT (count_and_swap_reloc_out (info->output_bfd, &rela,
9807
0
                  relplt));
9808
9809
0
    p = (unsigned char *) htab->glink->contents + ent->glink_offset;
9810
0
    write_glink_stub (NULL, ent, htab->elf.iplt, p, info);
9811
0
        }
9812
0
    }
9813
9814
0
      if (local_syms != NULL
9815
0
    && symtab_hdr->contents != (unsigned char *) local_syms)
9816
0
  {
9817
0
    if (!info->keep_memory)
9818
0
      free (local_syms);
9819
0
    else
9820
0
      symtab_hdr->contents = (unsigned char *) local_syms;
9821
0
  }
9822
0
    }
9823
0
  return true;
9824
0
}
9825
9826
/* Finish up dynamic symbol handling.  We set the contents of various
9827
   dynamic sections here.  */
9828
9829
static bool
9830
ppc_elf_finish_dynamic_symbol (bfd *output_bfd,
9831
             struct bfd_link_info *info,
9832
             struct elf_link_hash_entry *h,
9833
             Elf_Internal_Sym *sym)
9834
0
{
9835
0
  struct ppc_elf_link_hash_table *htab = ppc_elf_hash_table (info);
9836
0
  struct plt_entry *ent;
9837
9838
#ifdef DEBUG
9839
  fprintf (stderr, "ppc_elf_finish_dynamic_symbol called for %s",
9840
     h->root.root.string);
9841
#endif
9842
9843
0
  if (!h->def_regular
9844
0
      || (h->type == STT_GNU_IFUNC && !bfd_link_pic (info)))
9845
0
    for (ent = h->plt.plist; ent != NULL; ent = ent->next)
9846
0
      if (ent->plt.offset != (bfd_vma) -1)
9847
0
  {
9848
0
    if (!h->def_regular)
9849
0
      {
9850
        /* Mark the symbol as undefined, rather than as
9851
     defined in the .plt section.  Leave the value if
9852
     there were any relocations where pointer equality
9853
     matters (this is a clue for the dynamic linker, to
9854
     make function pointer comparisons work between an
9855
     application and shared library), otherwise set it
9856
     to zero.  */
9857
0
        sym->st_shndx = SHN_UNDEF;
9858
0
        if (!h->pointer_equality_needed)
9859
0
    sym->st_value = 0;
9860
0
        else if (!h->ref_regular_nonweak)
9861
0
    {
9862
      /* This breaks function pointer comparisons, but
9863
         that is better than breaking tests for a NULL
9864
         function pointer.  */
9865
0
      sym->st_value = 0;
9866
0
    }
9867
0
      }
9868
0
    else
9869
0
      {
9870
        /* Set the value of ifunc symbols in a non-pie
9871
     executable to the glink entry.  This is to avoid
9872
     text relocations.  We can't do this for ifunc in
9873
     allocate_dynrelocs, as we do for normal dynamic
9874
     function symbols with plt entries, because we need
9875
     to keep the original value around for the ifunc
9876
     relocation.  */
9877
0
        sym->st_shndx
9878
0
    = (_bfd_elf_section_from_bfd_section
9879
0
       (info->output_bfd, htab->glink->output_section));
9880
0
        sym->st_value = (ent->glink_offset
9881
0
             + htab->glink->output_offset
9882
0
             + htab->glink->output_section->vma);
9883
0
      }
9884
0
    break;
9885
0
  }
9886
9887
0
  if (h->needs_copy)
9888
0
    {
9889
0
      asection *s;
9890
0
      Elf_Internal_Rela rela;
9891
9892
      /* This symbols needs a copy reloc.  Set it up.  */
9893
9894
#ifdef DEBUG
9895
      fprintf (stderr, ", copy");
9896
#endif
9897
9898
0
      BFD_ASSERT (h->dynindx != -1);
9899
9900
0
      if (ppc_elf_hash_entry (h)->has_sda_refs)
9901
0
  s = htab->relsbss;
9902
0
      else if (h->root.u.def.section == htab->elf.sdynrelro)
9903
0
  s = htab->elf.sreldynrelro;
9904
0
      else
9905
0
  s = htab->elf.srelbss;
9906
0
      BFD_ASSERT (s != NULL);
9907
9908
0
      rela.r_offset = SYM_VAL (h);
9909
0
      rela.r_info = ELF32_R_INFO (h->dynindx, R_PPC_COPY);
9910
0
      rela.r_addend = 0;
9911
0
      BFD_ASSERT (count_and_swap_reloc_out (output_bfd, &rela, s));
9912
0
    }
9913
9914
#ifdef DEBUG
9915
  fprintf (stderr, "\n");
9916
#endif
9917
9918
0
  return true;
9919
0
}
9920

9921
static enum elf_reloc_type_class
9922
ppc_elf_reloc_type_class (const struct bfd_link_info *info,
9923
        const asection *rel_sec,
9924
        const Elf_Internal_Rela *rela)
9925
0
{
9926
0
  struct ppc_elf_link_hash_table *htab = ppc_elf_hash_table (info);
9927
9928
0
  if (rel_sec == htab->elf.irelplt)
9929
0
    return reloc_class_ifunc;
9930
9931
0
  switch (ELF32_R_TYPE (rela->r_info))
9932
0
    {
9933
0
    case R_PPC_RELATIVE:
9934
0
      return reloc_class_relative;
9935
0
    case R_PPC_JMP_SLOT:
9936
0
      return reloc_class_plt;
9937
0
    case R_PPC_COPY:
9938
0
      return reloc_class_copy;
9939
0
    default:
9940
0
      return reloc_class_normal;
9941
0
    }
9942
0
}
9943

9944
/* Finish up the dynamic sections.  */
9945
9946
static bool
9947
ppc_elf_finish_dynamic_sections (bfd *output_bfd,
9948
         struct bfd_link_info *info)
9949
0
{
9950
0
  asection *sdyn;
9951
0
  struct ppc_elf_link_hash_table *htab;
9952
0
  bfd_vma got;
9953
0
  bfd *dynobj;
9954
0
  bool ret = true;
9955
9956
#ifdef DEBUG
9957
  fprintf (stderr, "ppc_elf_finish_dynamic_sections called\n");
9958
#endif
9959
9960
0
  htab = ppc_elf_hash_table (info);
9961
0
  dynobj = htab->elf.dynobj;
9962
0
  sdyn = bfd_get_linker_section (dynobj, ".dynamic");
9963
9964
0
  got = 0;
9965
0
  if (htab->elf.hgot != NULL)
9966
0
    got = SYM_VAL (htab->elf.hgot);
9967
9968
0
  if (htab->elf.dynamic_sections_created)
9969
0
    {
9970
0
      Elf32_External_Dyn *dyncon, *dynconend;
9971
9972
0
      BFD_ASSERT (htab->elf.splt != NULL && sdyn != NULL);
9973
9974
0
      dyncon = (Elf32_External_Dyn *) sdyn->contents;
9975
0
      dynconend = (Elf32_External_Dyn *) (sdyn->contents + sdyn->size);
9976
0
      for (; dyncon < dynconend; dyncon++)
9977
0
  {
9978
0
    Elf_Internal_Dyn dyn;
9979
0
    asection *s;
9980
9981
0
    bfd_elf32_swap_dyn_in (dynobj, dyncon, &dyn);
9982
9983
0
    switch (dyn.d_tag)
9984
0
      {
9985
0
      case DT_PLTGOT:
9986
0
        if (htab->elf.target_os == is_vxworks)
9987
0
    s = htab->elf.sgotplt;
9988
0
        else
9989
0
    s = htab->elf.splt;
9990
0
        dyn.d_un.d_ptr = s->output_section->vma + s->output_offset;
9991
0
        break;
9992
9993
0
      case DT_PLTRELSZ:
9994
0
        dyn.d_un.d_val = htab->elf.srelplt->size;
9995
0
        break;
9996
9997
0
      case DT_JMPREL:
9998
0
        s = htab->elf.srelplt;
9999
0
        dyn.d_un.d_ptr = s->output_section->vma + s->output_offset;
10000
0
        break;
10001
10002
0
      case DT_PPC_GOT:
10003
0
        dyn.d_un.d_ptr = got;
10004
0
        break;
10005
10006
0
      case DT_TEXTREL:
10007
0
        if (htab->local_ifunc_resolver)
10008
0
    info->callbacks->einfo
10009
0
      (_("%X%P: text relocations and GNU indirect "
10010
0
         "functions will result in a segfault at runtime\n"));
10011
0
        else if (htab->maybe_local_ifunc_resolver)
10012
0
    info->callbacks->einfo
10013
0
      (_("%P: warning: text relocations and GNU indirect "
10014
0
         "functions may result in a segfault at runtime\n"));
10015
0
        continue;
10016
10017
0
      default:
10018
0
        if (htab->elf.target_os == is_vxworks
10019
0
      && elf_vxworks_finish_dynamic_entry (output_bfd, &dyn))
10020
0
    break;
10021
0
        continue;
10022
0
      }
10023
10024
0
    bfd_elf32_swap_dyn_out (output_bfd, &dyn, dyncon);
10025
0
  }
10026
0
    }
10027
10028
0
  if (htab->elf.sgot != NULL
10029
0
      && htab->elf.sgot->output_section != bfd_abs_section_ptr)
10030
0
    {
10031
0
      if (htab->elf.hgot->root.u.def.section == htab->elf.sgot
10032
0
    || htab->elf.hgot->root.u.def.section == htab->elf.sgotplt)
10033
0
  {
10034
0
    unsigned char *p = htab->elf.hgot->root.u.def.section->contents;
10035
10036
0
    p += htab->elf.hgot->root.u.def.value;
10037
0
    if (htab->plt_type == PLT_OLD)
10038
0
      {
10039
        /* Add a blrl instruction at _GLOBAL_OFFSET_TABLE_-4
10040
     so that a function can easily find the address of
10041
     _GLOBAL_OFFSET_TABLE_.  */
10042
0
        BFD_ASSERT (htab->elf.hgot->root.u.def.value - 4
10043
0
        < htab->elf.hgot->root.u.def.section->size);
10044
0
        bfd_put_32 (output_bfd, 0x4e800021, p - 4);
10045
0
      }
10046
10047
0
    if (sdyn != NULL)
10048
0
      {
10049
0
        bfd_vma val = sdyn->output_section->vma + sdyn->output_offset;
10050
0
        BFD_ASSERT (htab->elf.hgot->root.u.def.value
10051
0
        < htab->elf.hgot->root.u.def.section->size);
10052
0
        bfd_put_32 (output_bfd, val, p);
10053
0
      }
10054
0
  }
10055
0
      else
10056
0
  {
10057
    /* xgettext:c-format */
10058
0
    _bfd_error_handler (_("%s not defined in linker created %pA"),
10059
0
            htab->elf.hgot->root.root.string,
10060
0
            (htab->elf.sgotplt != NULL
10061
0
             ? htab->elf.sgotplt : htab->elf.sgot));
10062
0
    bfd_set_error (bfd_error_bad_value);
10063
0
    ret = false;
10064
0
  }
10065
10066
0
      elf_section_data (htab->elf.sgot->output_section)->this_hdr.sh_entsize = 4;
10067
0
    }
10068
10069
  /* Fill in the first entry in the VxWorks procedure linkage table.  */
10070
0
  if (htab->elf.target_os == is_vxworks
10071
0
      && htab->elf.splt != NULL
10072
0
      && htab->elf.splt->size != 0
10073
0
      && htab->elf.splt->output_section != bfd_abs_section_ptr)
10074
0
    {
10075
0
      asection *splt = htab->elf.splt;
10076
      /* Use the right PLT. */
10077
0
      const bfd_vma *plt_entry = (bfd_link_pic (info)
10078
0
          ? ppc_elf_vxworks_pic_plt0_entry
10079
0
          : ppc_elf_vxworks_plt0_entry);
10080
10081
0
      if (!bfd_link_pic (info))
10082
0
  {
10083
0
    bfd_vma got_value = SYM_VAL (htab->elf.hgot);
10084
10085
0
    bfd_put_32 (output_bfd, plt_entry[0] | PPC_HA (got_value),
10086
0
          splt->contents +  0);
10087
0
    bfd_put_32 (output_bfd, plt_entry[1] | PPC_LO (got_value),
10088
0
          splt->contents +  4);
10089
0
  }
10090
0
      else
10091
0
  {
10092
0
    bfd_put_32 (output_bfd, plt_entry[0], splt->contents +  0);
10093
0
    bfd_put_32 (output_bfd, plt_entry[1], splt->contents +  4);
10094
0
  }
10095
0
      bfd_put_32 (output_bfd, plt_entry[2], splt->contents +  8);
10096
0
      bfd_put_32 (output_bfd, plt_entry[3], splt->contents + 12);
10097
0
      bfd_put_32 (output_bfd, plt_entry[4], splt->contents + 16);
10098
0
      bfd_put_32 (output_bfd, plt_entry[5], splt->contents + 20);
10099
0
      bfd_put_32 (output_bfd, plt_entry[6], splt->contents + 24);
10100
0
      bfd_put_32 (output_bfd, plt_entry[7], splt->contents + 28);
10101
10102
0
      if (! bfd_link_pic (info))
10103
0
  {
10104
0
    Elf_Internal_Rela rela;
10105
0
    bfd_byte *loc;
10106
10107
0
    loc = htab->srelplt2->contents;
10108
10109
    /* Output the @ha relocation for the first instruction.  */
10110
0
    rela.r_offset = (htab->elf.splt->output_section->vma
10111
0
         + htab->elf.splt->output_offset
10112
0
         + 2);
10113
0
    rela.r_info = ELF32_R_INFO (htab->elf.hgot->indx, R_PPC_ADDR16_HA);
10114
0
    rela.r_addend = 0;
10115
0
    BFD_ASSERT (swap_reloc_out (output_bfd, &rela, loc, htab->srelplt2));
10116
0
    loc += sizeof (Elf32_External_Rela);
10117
10118
    /* Output the @l relocation for the second instruction.  */
10119
0
    rela.r_offset = (htab->elf.splt->output_section->vma
10120
0
         + htab->elf.splt->output_offset
10121
0
         + 6);
10122
0
    rela.r_info = ELF32_R_INFO (htab->elf.hgot->indx, R_PPC_ADDR16_LO);
10123
0
    rela.r_addend = 0;
10124
0
    BFD_ASSERT (swap_reloc_out (output_bfd, &rela, loc, htab->srelplt2));
10125
0
    loc += sizeof (Elf32_External_Rela);
10126
10127
    /* Fix up the remaining relocations.  They may have the wrong
10128
       symbol index for _G_O_T_ or _P_L_T_ depending on the order
10129
       in which symbols were output.  */
10130
0
    while (loc < htab->srelplt2->contents + htab->srelplt2->size)
10131
0
      {
10132
0
        Elf_Internal_Rela rel;
10133
10134
0
        bfd_elf32_swap_reloc_in (output_bfd, loc, &rel);
10135
0
        rel.r_info = ELF32_R_INFO (htab->elf.hgot->indx, R_PPC_ADDR16_HA);
10136
0
        bfd_elf32_swap_reloc_out (output_bfd, &rel, loc);
10137
0
        loc += sizeof (Elf32_External_Rela);
10138
10139
0
        bfd_elf32_swap_reloc_in (output_bfd, loc, &rel);
10140
0
        rel.r_info = ELF32_R_INFO (htab->elf.hgot->indx, R_PPC_ADDR16_LO);
10141
0
        bfd_elf32_swap_reloc_out (output_bfd, &rel, loc);
10142
0
        loc += sizeof (Elf32_External_Rela);
10143
10144
0
        bfd_elf32_swap_reloc_in (output_bfd, loc, &rel);
10145
0
        rel.r_info = ELF32_R_INFO (htab->elf.hplt->indx, R_PPC_ADDR32);
10146
0
        bfd_elf32_swap_reloc_out (output_bfd, &rel, loc);
10147
0
        loc += sizeof (Elf32_External_Rela);
10148
0
      }
10149
0
  }
10150
0
    }
10151
10152
0
  if (htab->glink != NULL
10153
0
      && htab->glink->contents != NULL
10154
0
      && htab->elf.dynamic_sections_created)
10155
0
    {
10156
0
      unsigned char *p;
10157
0
      unsigned char *endp;
10158
0
      bfd_vma res0;
10159
10160
      /*
10161
       * PIC glink code is the following:
10162
       *
10163
       * # ith PLT code stub.
10164
       *   addis 11,30,(plt+(i-1)*4-got)@ha
10165
       *   lwz 11,(plt+(i-1)*4-got)@l(11)
10166
       *   mtctr 11
10167
       *   bctr
10168
       *
10169
       * # A table of branches, one for each plt entry.
10170
       * # The idea is that the plt call stub loads ctr and r11 with these
10171
       * # addresses, so (r11 - res_0) gives the plt index * 4.
10172
       * res_0: b PLTresolve
10173
       * res_1: b PLTresolve
10174
       * .
10175
       * # Some number of entries towards the end can be nops
10176
       * res_n_m3: nop
10177
       * res_n_m2: nop
10178
       * res_n_m1:
10179
       *
10180
       * PLTresolve:
10181
       *    addis 11,11,(1f-res_0)@ha
10182
       *    mflr 0
10183
       *    bcl 20,31,1f
10184
       * 1: addi 11,11,(1b-res_0)@l
10185
       *    mflr 12
10186
       *    mtlr 0
10187
       *    sub 11,11,12    # r11 = index * 4
10188
       *    addis 12,12,(got+4-1b)@ha
10189
       *    lwz 0,(got+4-1b)@l(12)  # got[1] address of dl_runtime_resolve
10190
       *    lwz 12,(got+8-1b)@l(12) # got[2] contains the map address
10191
       *    mtctr 0
10192
       *    add 0,11,11
10193
       *    add 11,0,11     # r11 = index * 12 = reloc offset.
10194
       *    bctr
10195
       *
10196
       * Non-PIC glink code is a little simpler.
10197
       *
10198
       * # ith PLT code stub.
10199
       *   lis 11,(plt+(i-1)*4)@ha
10200
       *   lwz 11,(plt+(i-1)*4)@l(11)
10201
       *   mtctr 11
10202
       *   bctr
10203
       *
10204
       * The branch table is the same, then comes
10205
       *
10206
       * PLTresolve:
10207
       *    lis 12,(got+4)@ha
10208
       *    addis 11,11,(-res_0)@ha
10209
       *    lwz 0,(got+4)@l(12)   # got[1] address of dl_runtime_resolve
10210
       *    addi 11,11,(-res_0)@l # r11 = index * 4
10211
       *    mtctr 0
10212
       *    add 0,11,11
10213
       *    lwz 12,(got+8)@l(12)  # got[2] contains the map address
10214
       *    add 11,0,11     # r11 = index * 12 = reloc offset.
10215
       *    bctr
10216
       */
10217
10218
      /* Build the branch table, one for each plt entry (less one),
10219
   and perhaps some padding.  */
10220
0
      p = htab->glink->contents;
10221
0
      p += htab->glink_pltresolve;
10222
0
      endp = htab->glink->contents;
10223
0
      endp += htab->glink->size - GLINK_PLTRESOLVE;
10224
0
      while (p < endp - (htab->params->ppc476_workaround ? 0 : 8 * 4))
10225
0
  {
10226
0
    bfd_put_32 (output_bfd, B + endp - p, p);
10227
0
    p += 4;
10228
0
  }
10229
0
      while (p < endp)
10230
0
  {
10231
0
    bfd_put_32 (output_bfd, NOP, p);
10232
0
    p += 4;
10233
0
  }
10234
10235
0
      res0 = (htab->glink_pltresolve
10236
0
        + htab->glink->output_section->vma
10237
0
        + htab->glink->output_offset);
10238
10239
0
      if (htab->params->ppc476_workaround)
10240
0
  {
10241
    /* Ensure that a call stub at the end of a page doesn't
10242
       result in prefetch over the end of the page into the
10243
       glink branch table.  */
10244
0
    bfd_vma pagesize = (bfd_vma) 1 << htab->params->pagesize_p2;
10245
0
    bfd_vma page_addr;
10246
0
    bfd_vma glink_start = (htab->glink->output_section->vma
10247
0
         + htab->glink->output_offset);
10248
10249
0
    for (page_addr = res0 & -pagesize;
10250
0
         page_addr > glink_start;
10251
0
         page_addr -= pagesize)
10252
0
      {
10253
        /* We have a plt call stub that may need fixing.  */
10254
0
        bfd_byte *loc;
10255
0
        unsigned int insn;
10256
10257
0
        loc = htab->glink->contents + page_addr - 4 - glink_start;
10258
0
        insn = bfd_get_32 (output_bfd, loc);
10259
0
        if (insn == BCTR)
10260
0
    {
10261
      /* By alignment, we know that there must be at least
10262
         one other call stub before this one.  */
10263
0
      insn = bfd_get_32 (output_bfd, loc - 16);
10264
0
      if (insn == BCTR)
10265
0
        bfd_put_32 (output_bfd, B | (-16 & 0x3fffffc), loc);
10266
0
      else
10267
0
        bfd_put_32 (output_bfd, B | (-20 & 0x3fffffc), loc);
10268
0
    }
10269
0
      }
10270
0
  }
10271
10272
      /* Last comes the PLTresolve stub.  */
10273
0
      endp = p + GLINK_PLTRESOLVE;
10274
0
      if (bfd_link_pic (info))
10275
0
  {
10276
0
    bfd_vma bcl;
10277
10278
0
    bcl = (htab->glink->size - GLINK_PLTRESOLVE + 3*4
10279
0
     + htab->glink->output_section->vma
10280
0
     + htab->glink->output_offset);
10281
10282
0
    bfd_put_32 (output_bfd, ADDIS_11_11 + PPC_HA (bcl - res0), p);
10283
0
    p += 4;
10284
0
    bfd_put_32 (output_bfd, MFLR_0, p);
10285
0
    p += 4;
10286
0
    bfd_put_32 (output_bfd, BCL_20_31, p);
10287
0
    p += 4;
10288
0
    bfd_put_32 (output_bfd, ADDI_11_11 + PPC_LO (bcl - res0), p);
10289
0
    p += 4;
10290
0
    bfd_put_32 (output_bfd, MFLR_12, p);
10291
0
    p += 4;
10292
0
    bfd_put_32 (output_bfd, MTLR_0, p);
10293
0
    p += 4;
10294
0
    bfd_put_32 (output_bfd, SUB_11_11_12, p);
10295
0
    p += 4;
10296
0
    bfd_put_32 (output_bfd, ADDIS_12_12 + PPC_HA (got + 4 - bcl), p);
10297
0
    p += 4;
10298
0
    if (PPC_HA (got + 4 - bcl) == PPC_HA (got + 8 - bcl))
10299
0
      {
10300
0
        bfd_put_32 (output_bfd, LWZ_0_12 + PPC_LO (got + 4 - bcl), p);
10301
0
        p += 4;
10302
0
        bfd_put_32 (output_bfd, LWZ_12_12 + PPC_LO (got + 8 - bcl), p);
10303
0
        p += 4;
10304
0
      }
10305
0
    else
10306
0
      {
10307
0
        bfd_put_32 (output_bfd, LWZU_0_12 + PPC_LO (got + 4 - bcl), p);
10308
0
        p += 4;
10309
0
        bfd_put_32 (output_bfd, LWZ_12_12 + 4, p);
10310
0
        p += 4;
10311
0
      }
10312
0
    bfd_put_32 (output_bfd, MTCTR_0, p);
10313
0
    p += 4;
10314
0
    bfd_put_32 (output_bfd, ADD_0_11_11, p);
10315
0
  }
10316
0
      else
10317
0
  {
10318
0
    bfd_put_32 (output_bfd, LIS_12 + PPC_HA (got + 4), p);
10319
0
    p += 4;
10320
0
    bfd_put_32 (output_bfd, ADDIS_11_11 + PPC_HA (-res0), p);
10321
0
    p += 4;
10322
0
    if (PPC_HA (got + 4) == PPC_HA (got + 8))
10323
0
      bfd_put_32 (output_bfd, LWZ_0_12 + PPC_LO (got + 4), p);
10324
0
    else
10325
0
      bfd_put_32 (output_bfd, LWZU_0_12 + PPC_LO (got + 4), p);
10326
0
    p += 4;
10327
0
    bfd_put_32 (output_bfd, ADDI_11_11 + PPC_LO (-res0), p);
10328
0
    p += 4;
10329
0
    bfd_put_32 (output_bfd, MTCTR_0, p);
10330
0
    p += 4;
10331
0
    bfd_put_32 (output_bfd, ADD_0_11_11, p);
10332
0
    p += 4;
10333
0
    if (PPC_HA (got + 4) == PPC_HA (got + 8))
10334
0
      bfd_put_32 (output_bfd, LWZ_12_12 + PPC_LO (got + 8), p);
10335
0
    else
10336
0
      bfd_put_32 (output_bfd, LWZ_12_12 + 4, p);
10337
0
  }
10338
0
      p += 4;
10339
0
      bfd_put_32 (output_bfd, ADD_11_0_11, p);
10340
0
      p += 4;
10341
0
      bfd_put_32 (output_bfd, BCTR, p);
10342
0
      p += 4;
10343
0
      while (p < endp)
10344
0
  {
10345
0
    bfd_put_32 (output_bfd,
10346
0
          htab->params->ppc476_workaround ? BA : NOP, p);
10347
0
    p += 4;
10348
0
  }
10349
0
      BFD_ASSERT (p == endp);
10350
0
    }
10351
10352
0
  if (htab->glink_eh_frame != NULL
10353
0
      && htab->glink_eh_frame->contents != NULL)
10354
0
    {
10355
0
      unsigned char *p = htab->glink_eh_frame->contents;
10356
0
      bfd_vma val;
10357
10358
0
      p += sizeof (glink_eh_frame_cie);
10359
      /* FDE length.  */
10360
0
      p += 4;
10361
      /* CIE pointer.  */
10362
0
      p += 4;
10363
      /* Offset to .glink.  */
10364
0
      val = (htab->glink->output_section->vma
10365
0
       + htab->glink->output_offset);
10366
0
      val -= (htab->glink_eh_frame->output_section->vma
10367
0
        + htab->glink_eh_frame->output_offset);
10368
0
      val -= p - htab->glink_eh_frame->contents;
10369
0
      bfd_put_32 (htab->elf.dynobj, val, p);
10370
10371
0
      if (htab->glink_eh_frame->sec_info_type == SEC_INFO_TYPE_EH_FRAME
10372
0
    && !_bfd_elf_write_section_eh_frame (output_bfd, info,
10373
0
                 htab->glink_eh_frame,
10374
0
                 htab->glink_eh_frame->contents))
10375
0
  return false;
10376
0
    }
10377
10378
0
  return ret;
10379
0
}
10380

10381
#define TARGET_LITTLE_SYM powerpc_elf32_le_vec
10382
#define TARGET_LITTLE_NAME  "elf32-powerpcle"
10383
#define TARGET_BIG_SYM    powerpc_elf32_vec
10384
#define TARGET_BIG_NAME   "elf32-powerpc"
10385
#define ELF_ARCH    bfd_arch_powerpc
10386
#define ELF_TARGET_ID   PPC32_ELF_DATA
10387
#define ELF_MACHINE_CODE  EM_PPC
10388
#define ELF_MAXPAGESIZE   0x10000
10389
#define ELF_COMMONPAGESIZE  0x1000
10390
#define elf_info_to_howto ppc_elf_info_to_howto
10391
10392
#ifdef  EM_CYGNUS_POWERPC
10393
#define ELF_MACHINE_ALT1  EM_CYGNUS_POWERPC
10394
#endif
10395
10396
#ifdef EM_PPC_OLD
10397
#define ELF_MACHINE_ALT2  EM_PPC_OLD
10398
#endif
10399
10400
#define elf_backend_plt_not_loaded  1
10401
#define elf_backend_want_dynrelro 1
10402
#define elf_backend_can_gc_sections 1
10403
#define elf_backend_can_refcount  1
10404
#define elf_backend_rela_normal   1
10405
#define elf_backend_caches_rawsize  1
10406
10407
#define bfd_elf32_mkobject      ppc_elf_mkobject
10408
#define bfd_elf32_bfd_merge_private_bfd_data  ppc_elf_merge_private_bfd_data
10409
#define bfd_elf32_bfd_relax_section   ppc_elf_relax_section
10410
#define bfd_elf32_bfd_reloc_type_lookup   ppc_elf_reloc_type_lookup
10411
#define bfd_elf32_bfd_reloc_name_lookup   ppc_elf_reloc_name_lookup
10412
#define bfd_elf32_bfd_set_private_flags   ppc_elf_set_private_flags
10413
#define bfd_elf32_bfd_link_hash_table_create  ppc_elf_link_hash_table_create
10414
#define bfd_elf32_get_synthetic_symtab    ppc_elf_get_synthetic_symtab
10415
10416
#define elf_backend_object_p      ppc_elf_object_p
10417
#define elf_backend_gc_mark_hook    ppc_elf_gc_mark_hook
10418
#define elf_backend_section_from_shdr   ppc_elf_section_from_shdr
10419
#define elf_backend_relocate_section    ppc_elf_relocate_section
10420
#define elf_backend_create_dynamic_sections ppc_elf_create_dynamic_sections
10421
#define elf_backend_check_relocs    ppc_elf_check_relocs
10422
#define elf_backend_relocs_compatible   _bfd_elf_relocs_compatible
10423
#define elf_backend_copy_indirect_symbol  ppc_elf_copy_indirect_symbol
10424
#define elf_backend_adjust_dynamic_symbol ppc_elf_adjust_dynamic_symbol
10425
#define elf_backend_add_symbol_hook   ppc_elf_add_symbol_hook
10426
#define elf_backend_late_size_sections    ppc_elf_late_size_sections
10427
#define elf_backend_hash_symbol     ppc_elf_hash_symbol
10428
#define elf_backend_finish_dynamic_symbol ppc_elf_finish_dynamic_symbol
10429
#define elf_backend_finish_dynamic_sections ppc_elf_finish_dynamic_sections
10430
#define elf_backend_fake_sections   ppc_elf_fake_sections
10431
#define elf_backend_additional_program_headers  ppc_elf_additional_program_headers
10432
#define elf_backend_modify_segment_map    ppc_elf_modify_segment_map
10433
#define elf_backend_grok_prstatus   ppc_elf_grok_prstatus
10434
#define elf_backend_grok_psinfo     ppc_elf_grok_psinfo
10435
#define elf_backend_write_core_note   ppc_elf_write_core_note
10436
#define elf_backend_reloc_type_class    ppc_elf_reloc_type_class
10437
#define elf_backend_begin_write_processing  ppc_elf_begin_write_processing
10438
#define elf_backend_final_write_processing  ppc_elf_final_write_processing
10439
#define elf_backend_write_section   ppc_elf_write_section
10440
#define elf_backend_get_sec_type_attr   ppc_elf_get_sec_type_attr
10441
#define elf_backend_plt_sym_val     ppc_elf_plt_sym_val
10442
#define elf_backend_action_discarded    ppc_elf_action_discarded
10443
#define elf_backend_init_index_section    _bfd_elf_init_1_index_section
10444
#define elf_backend_lookup_section_flags_hook ppc_elf_lookup_section_flags
10445
10446
#include "elf32-target.h"
10447
10448
/* FreeBSD Target */
10449
10450
#undef  TARGET_LITTLE_SYM
10451
#undef  TARGET_LITTLE_NAME
10452
10453
#undef  TARGET_BIG_SYM
10454
#define TARGET_BIG_SYM  powerpc_elf32_fbsd_vec
10455
#undef  TARGET_BIG_NAME
10456
#define TARGET_BIG_NAME "elf32-powerpc-freebsd"
10457
10458
#undef  ELF_OSABI
10459
#define ELF_OSABI ELFOSABI_FREEBSD
10460
10461
#undef  elf32_bed
10462
#define elf32_bed elf32_powerpc_fbsd_bed
10463
10464
#include "elf32-target.h"
10465
10466
/* VxWorks Target */
10467
10468
#undef TARGET_LITTLE_SYM
10469
#undef TARGET_LITTLE_NAME
10470
10471
#undef TARGET_BIG_SYM
10472
#define TARGET_BIG_SYM    powerpc_elf32_vxworks_vec
10473
#undef TARGET_BIG_NAME
10474
#define TARGET_BIG_NAME   "elf32-powerpc-vxworks"
10475
10476
#undef  ELF_OSABI
10477
10478
#undef ELF_TARGET_OS
10479
#define ELF_TARGET_OS   is_vxworks
10480
10481
/* VxWorks uses the elf default section flags for .plt.  */
10482
static const struct bfd_elf_special_section *
10483
ppc_elf_vxworks_get_sec_type_attr (bfd *abfd, asection *sec)
10484
2.18k
{
10485
2.18k
  if (sec->name == NULL)
10486
0
    return NULL;
10487
10488
2.18k
  if (strcmp (sec->name, ".plt") == 0)
10489
13
    return _bfd_elf_get_sec_type_attr (abfd, sec);
10490
10491
2.16k
  return ppc_elf_get_sec_type_attr (abfd, sec);
10492
2.18k
}
10493
10494
/* Like ppc_elf_link_hash_table_create, but overrides
10495
   appropriately for VxWorks.  */
10496
static struct bfd_link_hash_table *
10497
ppc_elf_vxworks_link_hash_table_create (bfd *abfd)
10498
0
{
10499
0
  struct bfd_link_hash_table *ret;
10500
10501
0
  ret = ppc_elf_link_hash_table_create (abfd);
10502
0
  if (ret)
10503
0
    {
10504
0
      struct ppc_elf_link_hash_table *htab
10505
0
  = (struct ppc_elf_link_hash_table *)ret;
10506
0
      htab->plt_type = PLT_VXWORKS;
10507
0
      htab->plt_entry_size = VXWORKS_PLT_ENTRY_SIZE;
10508
0
      htab->plt_slot_size = VXWORKS_PLT_ENTRY_SIZE;
10509
0
      htab->plt_initial_entry_size = VXWORKS_PLT_INITIAL_ENTRY_SIZE;
10510
0
    }
10511
0
  return ret;
10512
0
}
10513
10514
/* Tweak magic VxWorks symbols as they are loaded.  */
10515
static bool
10516
ppc_elf_vxworks_add_symbol_hook (bfd *abfd,
10517
         struct bfd_link_info *info,
10518
         Elf_Internal_Sym *sym,
10519
         const char **namep,
10520
         flagword *flagsp,
10521
         asection **secp,
10522
         bfd_vma *valp)
10523
0
{
10524
0
  if (!elf_vxworks_add_symbol_hook (abfd, info, sym, namep, flagsp, secp,
10525
0
            valp))
10526
0
    return false;
10527
10528
0
  return ppc_elf_add_symbol_hook (abfd, info, sym, namep, flagsp, secp, valp);
10529
0
}
10530
10531
static bool
10532
ppc_elf_vxworks_final_write_processing (bfd *abfd)
10533
0
{
10534
0
  ppc_final_write_processing (abfd);
10535
0
  return elf_vxworks_final_write_processing (abfd);
10536
0
}
10537
10538
/* On VxWorks, we emit relocations against _PROCEDURE_LINKAGE_TABLE_, so
10539
   define it.  */
10540
#undef elf_backend_want_plt_sym
10541
#define elf_backend_want_plt_sym    1
10542
#undef elf_backend_want_got_plt
10543
#define elf_backend_want_got_plt    1
10544
#undef elf_backend_got_symbol_offset
10545
#define elf_backend_got_symbol_offset   0
10546
#undef elf_backend_plt_not_loaded
10547
#define elf_backend_plt_not_loaded    0
10548
#undef elf_backend_plt_readonly
10549
#define elf_backend_plt_readonly    1
10550
#undef elf_backend_got_header_size
10551
#define elf_backend_got_header_size   12
10552
#undef elf_backend_dtrel_excludes_plt
10553
#define elf_backend_dtrel_excludes_plt    1
10554
10555
#undef bfd_elf32_get_synthetic_symtab
10556
10557
#undef bfd_elf32_bfd_link_hash_table_create
10558
#define bfd_elf32_bfd_link_hash_table_create \
10559
  ppc_elf_vxworks_link_hash_table_create
10560
#undef elf_backend_add_symbol_hook
10561
#define elf_backend_add_symbol_hook \
10562
  ppc_elf_vxworks_add_symbol_hook
10563
#undef elf_backend_link_output_symbol_hook
10564
#define elf_backend_link_output_symbol_hook \
10565
  elf_vxworks_link_output_symbol_hook
10566
#undef elf_backend_final_write_processing
10567
#define elf_backend_final_write_processing \
10568
  ppc_elf_vxworks_final_write_processing
10569
#undef elf_backend_get_sec_type_attr
10570
#define elf_backend_get_sec_type_attr \
10571
  ppc_elf_vxworks_get_sec_type_attr
10572
#undef elf_backend_emit_relocs
10573
#define elf_backend_emit_relocs \
10574
  elf_vxworks_emit_relocs
10575
10576
#undef elf32_bed
10577
#define elf32_bed       ppc_elf_vxworks_bed
10578
10579
#include "elf32-target.h"