Add the operand encoding types for the new Armv8.2-a back-ported instructions. These...
[deliverable/binutils-gdb.git] / gold / ChangeLog
CommitLineData
dc8d2d90
L
12017-11-08 H.J. Lu <hongjiu.lu@intel.com>
2
3 PR gold/22291
4 * layout.cc (Layout::define_section_symbols): Use STV_PROTECTED
5 for __start and __stop symbols.
6 * symtab.cc (Symbol_table::define_special_symbol): Add an
7 argument, visibility. Ignore definition and reference from
8 a dynamic object, depending on visibility.
9 (Symbol_table::do_define_in_output_data): Pass visibility to
10 define_special_symbol.
11 (Symbol_table::do_define_in_output_segment): Likewise.
12 (Symbol_table::do_define_as_constant): Likewise.
13 (Symbol_table::add_undefined_symbol_from_command_line): Pass
14 STV_DEFAULT to define_special_symbol.
15 * symtab.h (Symbol_table::define_special_symbol): Add an
16 argument, visibility.
17
333d0055
JC
182017-11-08 James Clarke <jrtc27@jrtc27.com>
19
20 PR gold/22266
21 * object.cc (Sized_relobj_file::compute_final_local_value_internal):
22 Drop relocatable parameter and stop adjusting output value based on
23 it.
24 (Sized_relobj_file::compute_final_local_value): Stop passing
25 relocatable to compute_final_local_value_internal.
26 (Sized_relobj_file::do_finalize_local_symbols): Ditto.
27 * object.h (Sized_relobj_file::compute_final_local_value_internal):
28 Drop relocatable parameter.
29
08228b11
EC
302017-11-08 Kyle Butt <iteratee@google.com>
31
32 * object.cc (do_find_special_sections): Fix a thinko with memmem return
33 values and check for != NULL rather than == 0.
34
6003e27e
AM
352017-11-07 Alan Modra <amodra@gmail.com>
36
37 * system.h (textdomain, bindtextdomain): Use safer "do nothing".
38 (ngettext, dngettext, dcngettext): Define when !ENABLE_NLS.
39
e601d38b
AM
402017-10-25 Alan Modra <amodra@gmail.com>
41
42 * symtab.cc (Symbol_table::add_from_relobj): Match "__gnu_lto_slim"
43 optionally prefixed with "_".
44
d6361359 452017-10-20 Sriraman Tallam <tmsriram@google.com>
3b4190cc
ST
46
47 * options.h (-z,text_unlikely_segment): New option.
48 * layout.cc (Layout::layout): Create new output section
49 for .text.unlikely sections with the new option.
50 (Layout::segment_precedes): Check for the new option
51 when segment flags match.
52 * testsuite/text_unlikely_segment.cc: New test source.
53 * testsuite/text_unlikely_segment.sh: New test script.
54 * testsuite/Makefile.am (text_unlikely_segment): New test.
55 * testsuite/Makefile.in: Regenerate.
56
36862fc0
UK
572017-10-19 Umesh Kalappa <ukalappa@cisco.com>
58
59 * arm.cc (Stub::do_fixed_endian_write):Far call stubs support for arm
60 in the be8 mode.
61 * testsuite/Makefile.am: New test cases.
62 * testsuite/Makefile.in: Regenerate.
63 * testsuite/arm_farcall_arm_arm_be8.sh: New script for arm to arm far
64 call stubs.
65 * testsuite/arm_farcall_thumb_thumb_be8.sh: New script for thumb to
66 thumb far call stubs.
67
412294da
AM
682017-10-18 Kyle Butt <iteratee@google.com>
69 Alan Modra <amodra@gmail.com>
70
71 * powerpc.cc (Target_powerpc::Scan::local): Correct dst_off
72 calculation for TOC16 relocs.
73 (Target_powerpc::Scan::global): Likewise.
74
00956d3a
CC
752017-09-26 Cary Coutant <ccoutant@gmail.com>
76
77 PR gold/22213
78 * sparc.cc (Target_sparc): Fix incorrect register mask.
79
0cf44ec8
JW
802017-09-22 Jim Wilson <jim.wilson@linaro.org>
81
82 * aarch64.cc (Target_aarch64::aarch64_info): Set
83 is_default_stack_executable to false.
84
7790bd6c
AM
852017-09-22 Alan Modra <amodra@gmail.com>
86
87 * resolve.cc (clone): Fix got_offset_list test.
88
ec769010
AM
892017-09-22 Alan Modra <amodra@gmail.com>
90
91 * powerpc.cc (Target_powerpc<64,*>::powerpc_info): Set
92 is_default_stack_executable false.
93
ca464aac
TJ
942017-09-20 Teresa Johnson <tejohnson@google.com>
95
96 * plugin.cc (is_visible_from_outside): Check for export dynamic symbol
97 option and list.
98 * testsuite/Makefile.am (plugin_test_12): New test.
99 * testsuite/Makefile.in: Regenerate.
100 * testsuite/export_dynamic_plugin.cc: New test source.
101 * testsuite/plugin_test_12.sh: New test script.
102
64b5d6d7
AM
1032017-09-20 Alan Modra <amodra@gmail.com>
104
105 * powerpc.cc (Target_powerpc::Branch_info::make_stub): Put
106 stubs for ppc32 non-branch relocs in first stub table.
107 (Target_powerpc::Relocate::relocate): Resolve similarly.
108
ab502e63
AM
1092017-09-19 Alan Modra <amodra@gmail.com>
110
111 * options.h (stub-group-multi): Default to true. Add
112 --no-stub-group-multi.
113
9a23f96e
AM
1142017-08-30 Alan Modra <amodra@gmail.com>
115
116 * powerpc.cc (Target_powerpc::Relocate::relocate): Nop addis on
117 TPREL16_HA, and convert insn on TPREL16_LO and TPREL16_LO_DS
118 relocs to use r2/r13 when addis would add zero.
119
34e0882b
AM
1202017-08-29 Alan Modra <amodra@gmail.com>
121
122 * options.h (tls_get_addr_optimize): New option.
123 * symtab.h (Symbol::clear_in_reg, clone): New functions.
124 (Sized_symbol::clone): New function.
125 (Symbol_table::clone): New function.
126 * resolve.cc (Symbol::clone, Sized_symbol::clone): New functions.
127 * powerpc.cc (Target_powerpc::has_tls_get_addr_opt_,
128 tls_get_addr_, tls_get_addr_opt_): New vars.
129 (Target_powerpc::tls_get_addr_opt, tls_get_addr,
130 is_tls_get_addr_opt, replace_tls_get_addr,
131 set_has_tls_get_addr_opt, stk_linker): New functions.
132 (Target_powerpc::Track_tls::maybe_skip_tls_get_addr_call): Add
133 target param. Update callers. Compare symbols rather than names.
134 (Target_powerpc::do_define_standard_symbols): Init tls_get_addr_
135 and tls_get_addr_opt_.
136 (Target_powerpc::Branch_info::mark_pltcall): Translate tls_get_addr
137 sym to tls_get_addr_opt.
138 (Target_powerpc::Branch_info::make_stub): Likewise.
139 (Stub_table::define_stub_syms): Likewise.
140 (Target_powerpc::Scan::global): Likewise.
141 (Target_powerpc::Relocate::relocate): Likewise.
142 (add_3_12_2, add_3_12_13, bctrl, beqlr, cmpdi_11_0, cmpwi_11_0,
143 ld_11_1, ld_11_3, ld_12_3, lwz_11_3, lwz_12_3, mr_0_3, mr_3_0,
144 mtlr_11, std_11_1): New constants.
145 (Stub_table::eh_frame_added_): Delete.
146 (Stub_table::tls_get_addr_opt_bctrl_, plt_fde_len_, plt_fde_): New vars.
147 (Stub_table::init_plt_fde): New functions.
148 (Stub_table::add_eh_frame, replace_eh_frame): Move definition out
149 of line. Init and use plt_fde_.
150 (Stub_table::plt_call_size): Return size for tls_get_addr stub.
151 Extract alignment code to..
152 (Stub_table::plt_call_align): ..this new function. Adjust all callers.
153 (Stub_table::add_plt_call_entry): Set has_tls_get_addr_opt and
154 tls_get_addr_opt_bctrl, and align after that.
155 (Stub_table::do_write): Write out tls_get_addr stub.
156 (Target_powerpc::do_finalize_sections): Emit DT_PPC_OPT
157 PPC_OPT_TLS/PPC64_OPT_TLS bit.
158 (Target_powerpc::Relocate::relocate): Don't check for or modify
159 nop following bl for tls_get_addr stub.
160
34ca2bd7
AM
1612017-08-29 Alan Modra <amodra@gmail.com>
162
163 * symtab.h (Symbol): Split u_ into u1_ and u2_. Adjust accessors
164 to suit. Move plt_offset_ before got_offsets_.
165 * symtab.cc (Symbol::init_fields): Adjust for union change.
166 (Symbol::init_base_output_data): Likewise.
167 (Symbol::init_base_output_segment): Likewise.
168 (Symbol::allocate_base_common): Likewise.
169 (Symbol::output_section): Likewise.
170 (Symbol::set_output_section): Likewise.
171 (Symbol::set_output_segment): Likewise.
172 * resolve.cc (Symbol::override_base): Likewise.
173 (Symbol::override_base_with_special): Likewise.
174
cefdd1cd
IK
1752017-08-28 Igor Kudrin <ikudrin@accesssoftek.com>
176
177 * aarch64.cc (Target_aarch64::Relocate::relocate_tls):
178 Make got_tlsdesc_offset signed and fix its calculation.
179 * testsuite/Makefile.am (aarch64_tlsdesc): New test.
180 * testsuite/Makefile.in: Regenerate.
181 * testsuite/aarch64_tlsdesc.s: New test source file.
182 * testsuite/aarch64_tlsdesc.sh: New test script.
183 * testsuite/aarch64_tlsdesc.t: New test linker script.
184
565ed01a
AM
1852017-08-28 Alan Modra <amodra@gmail.com>
186
187 PR 21847
188 * powerpc.cc (Target_powerpc::is_elfv2_localentry0): Test
189 non_zero_localentry.
190 (Target_powerpc::resolve): New function.
191 (powerpc_info): Set has_resolve for 64-bit.
192 * target.h (Sized_target::resolve): Return bool.
193 * resolve.cc (Symbol_table::resolve): Continue with normal
194 processing when target resolve returns false.
195 * symtab.h (Symbol::non_zero_localentry, set_non_zero_localentry):
196 New accessors.
197 (Symbol::non_zero_localentry_): New flag bit.
198 * symtab.cc (Symbol::init_fields): Init non_zero_localentry_.
199
2760f24c
RG
2002017-08-08 Romain Geissler <romain.geissler@gmail.com>
201 Alan Modra <amodra@gmail.com>
202
203 * configure.ac: Add --enable-default-hash-style option.
204 * options.h (hash_style): Use DEFAULT_HASH_STYLE as default value.
205 * configure: Regenerate.
206 * config.in: Regenerate.
207
223b97ba
JC
2082017-08-03 James Clarke <jrtc27@jrtc27.com>
209
210 * options.h (General_options): Set a non-NULL second help string
211 argument for relax to allow --no-relax.
212
be897fb7
AM
2132017-08-01 Alan Modra <amodra@gmail.com>
214
215 * ehframe.cc (Fde::operator==): New.
216 (Cie::remove_fde, Eh_frame::remove_ehframe_for_plt): New.
217 * ehframe.h (Fde::operator==): Declare.
218 (Cie::remove_fde, Eh_frame::remove_ehframe_for_plt): Likewise.
219 * layout.cc (Layout::remove_eh_frame_for_plt): New.
220 * layout.h (Layout::remove_eh_frame_for_plt): Declare.
221 * powerpc.cc (Target_powerpc::do_relax): Remove old eh_frame FDEs.
222 (Stub_table::add_eh_frame): Delete eh_frame_added_ condition.
223 Don't add eh_frame for empty stub section.
224 (Stub_table::remove_eh_frame): New.
225
aacb3b6d
AM
2262017-07-31 Alan Modra <amodra@gmail.com>
227
228 * options.h (no_tls_optimize): New powerpc option.
229 * powerpc.cc (Target_powerpc::abiversion, set_abiversion): Formatting.
230 (Target_powerpc::stk_toc): Formatting, fix comment.
231 (Target_powerpc::Track_tls::tls_get_addr_state): Rename from
232 tls_get_addr.
233 (Target_powerpc::optimize_tls_gd, optimize_tls_ld, optimize_tls_ie):
234 Return TLSOPT_NONE when !tls_optimize.
235 (Target_powerpc::add_global_pair_with_rel): Check
236 for existing reloc before reserving.
237 (Target_powerpc::add_local_tls_pair): Likewise.
238
d44c746a
AM
2392017-07-31 Alan Modra <amodra@gmail.com>
240
565ed01a 241 PR 21847
d44c746a
AM
242 * powerpc.cc (Target_powerpc::scan_relocs): Warn on --plt-localentry
243 without ld.so checks.
244
8b5f1ed8
AM
2452017-07-29 Alan Modra <amodra@gmail.com>
246
247 PR 21847
248 * powerpc.cc (Target_powerpc::scan_relocs): Default to
249 --no-plt-localentry.
250
49ba15a2
L
2512017-07-28 H.J. Lu <hongjiu.lu@intel.com>
252
253 PR gold/21857
254 * compressed_output.cc (Output_compressed_section::set_final_data_size):
255 Call put_ch_reserved to clear the reserved field for 64-bit ELF.
256
104f0515
L
2572017-07-26 H.J. Lu <hongjiu.lu@intel.com>
258
259 * mips.cc (Mips_relocate_functions): Add "llu" suffix to
260 0x800080008000.
261
15a3a14f
AM
2622017-07-23 Alan Modra <amodra@gmail.com>
263
264 * powerpc.cc (glink_eh_frame_fde_64v2): Correct advance to
265 restore of LR.
266 (glink_eh_frame_fde_64v1): Advance to restore of LR at latest
267 possible insn.
268
de194d85
YC
2692017-07-18 Nick Clifton <nickc@redhat.com>
270
271 PR 21775
272 * aarch64.cc: Fix spelling typos.
273 * arm.cc: Likewise.
274 * layout.cc: Likewise.
275 * powerpc.cc: Likewise.
276 * x86_64.cc: Likewise.
277
429d795d
AM
2782017-07-12 Alan Modra <amodra@gmail.com>
279
280 * po/es.po: Update from translationproject.org/latest/gold/.
281 * po/fi.po: Likewise.
282 * po/fr.po: Likewise.
283 * po/id.po: Likewise.
284 * po/it.po: Likewise.
285 * po/vi.po: Likewise.
286 * po/zh_CN.po: Likewise.
287 * po/ja.po: New file from translationproject.org.
288 * po/sv.po: Likewise.
289 * po/uk.po: Likewise.
290
b7d7d459
CC
2912017-07-06 Han Shen <shenhan@google.com>
292
293 PR gold/21491
294 * aarch64.cc (Erratum_stub::invalidate_erratum_stub): New method.
295 (Erratum_stub::is_invalidated_erratum_stub): New method.
296 (Stub_table::relocate_reloc_stub): Renamed from "relocate_stub".
297 (Stub_table::relocate_reloc_stubs): Renamed from "relocate_stubs".
298 (Stub_table::relocate_erratum_stub): New method.
299 (AArch64_relobj::fix_errata_and_relocate_erratum_stubs): Renamed from
300 "fix_errata".
301 (Target_aarch64::relocate_reloc_stub): Renamed from "relocate_stub".
302
7ee7ff70
AM
3032017-06-23 Alan Modra <amodra@gmail.com>
304
305 * options.h (General_options): Add plt_localentry.
306 * powerpc.cc (Target_powerpc::st_other): New function.
307 (Target_powerpc::plt_localentry0_, plt_localentry0_init_,
308 has_localentry0_): New vars.
309 (Target_powerpc::plt_localentry0, set_has_localentry0,
310 is_elfv2_localentry0): New functions.
311 (Target_powerpc::Branch_info::mark_pltcall): Don't set tocsave or
312 return true for localentry:0 calls.
313 (Stub_table::Plt_stub_ent::localentry0_): New var.
314 (Stub_table::add_plt_call_entry): Set localentry0_ and has_localentry0_.
315 Don't set r2save_ for localentry:0 calls.
316 (Output_data_glink::do_write): Save r2 in __glink_PLTresolve for elfv2.
317 (Target_powerpc::scan_relocs): Default plt_localentry0_.
318 (Target_powerpc::do_finalize_sections): Set DT_PPC64_OPT.
319 (Target_powerpc::Relocate::relocate): Don't require nop following
320 calls for localentry:0 plt calls, and don't change nop.
321
7e57d19e
AM
3222017-06-23 Alan Modra <amodra@gmail.com>
323
324 * powerpc.cc (Target_powerpc::tocsave_loc_): New var.
325 (Target_powerpc::mark_pltcall, add_tocsave, tocsave_loc): New functions.
326 (Target_powerpc::Branch_info::tocsave_): New var.
327 (Target_powerpc::Branch_info::mark_pltcall): New function.
328 (Target_powerpc::Branch_info::make_stub): Pass tocsave_ to
329 add_plt_call_entry.
330 (Stub_table::Plt_stub_ent): Make public. Add r2save_.
331 (Stub_table::add_plt_call_entry): Add bool tocsave_ param. Set
332 r2save_.
333 (Stub_table::find_plt_call_entry): Return Plt_stub_ent*. Adjust
334 use throughout.
335 (Stub_table::do_write): Conditionally output r2 save in plt stubs.
336 (Target_powerpc::Scan::local): Handle R_PPC64_TOCSAVE.
337 (Target_powerpc::Scan::global): Likewise.
338 (Target_powerpc::Relocate::relocate): Skip r2 save in plt call stub
339 with tocsave reloc. Replace header tocsave nop with r2 save.
340 * symtab.h (struct Symbol_location_hash): Make public.
341
bdab445c
AM
3422017-06-21 Alan Modra <amodra@gmail.com>
343
344 * powerpc.cc (Plt_stub_key): Rename from Plt_stub_ent. Remove indx_.
345 (Plt_stub_key_hash): Rename from Plt_stub_ent_hash.
346 (struct Plt_stub_ent): New.
347 (Plt_stub_entries): Map from Plt_stub_key to Plt_stub_ent. Adjust
348 use throughout file.
349
69431bab
EC
3502017-06-20 Eric Christopher <echristo@gmail.com>
351
352 * aarch64.cc (scan_reloc_for_stub): Use plt_address_for_global to
353 calculate the symbol value.
354 (scan_reloc_section_for_stubs): Allow stubs to be created for
355 section symbols.
356 (maybe_apply_stub): Handle creating stubs for weak symbols to
357 match the code in scan_reloc_for_stub.
358
94de2a2c
JC
3592017-06-20 James Clarke <jrtc27@jrtc27.com>
360
361 * powerpc.cc (Stub_table::define_stub_syms): Always include object's
362 uniq_ value.
363
c092b67b
EC
3642017-06-15 Eric Christopher <echristo@gmail.com>
365
366 * aarch64.cc: Fix a few typos and grammar-os.
367
37de058a
JW
3682017-06-15 Jiong Wang <jiong.wang@arm.com>
369
370 * aarch64.cc (Insn_utilities::is_mrs_tpidr_el0): New method.
371 (AArch64_relobj<size, big_endian>::try_fix_erratum_843419_optimized):
372 Return ture for some TLS relaxed sequences.
373
81b6fe3b
EC
3742017-06-07 Eric Christopher <echristo@gmail.com>
375
376 * aarch64.cc (maybe_apply_stub): Add debug logging for looking
377 up stubs to undefined symbols and early return rather than
378 fail to look them up.
379 (scan_reloc_for_stub): Add debug logging for no stub creation
380 for undefined symbols.
381
590b87ff
AM
3822017-05-23 Alan Modra <amodra@gmail.com>
383
384 PR 21503
385 * options.h: Add --emit-stub-syms option.
386 * powerpc.cc (object_id): New.
387 (Powerpc_relobj): Add uniq_ and accessor. Sort variables for
388 better packing.
389 (Powerpc_dynobj): Sort variables for better packing.
390 (Target_powerpc::define_local): New function.
391 (Target_powerpc::group_sections): Pass stub table size to
392 Stub_table constructor.
393 (Target_powerpc::do_relax): Define stub and glink symbols.
394 (Stub_table): Add uniq_ variable, and id param to constructor.
395 (Stub_table::Plt_stub_ent): Add indx_ variable.
396 (Stub_table::Branch_stub_entries): Move typedef earlier.
397 (Stub_table::branch_stub_size): Replace "to" parameter with a
398 Branch_stub_entries iterator.
399 (Stub_table::add_long_branch_entry): Adjust to suit.
400 (Stub_table::add_plt_call_entry): Set indx_.
401 (Stub_table::define_stub_syms): New function.
402
0c38a3d1
EC
4032017-05-15 Eric Christopher <echristo@gmail.com>
404
405 * layout.cc (Layout::segment_precedes): Add a case for testing
406 pointer equality when determining which segment precedes
407 another.
408
67f46fed
JC
4092017-05-13 James Clarke <jrtc27@jrtc27.com>
410
411 PR gold/21444
412 * gold.cc (Target_sparc::Relocate::relocate_tls): Local
413 variables are final for position-independent executables. This
414 has to be consistent with Target_sparc::Scan::local otherwise
415 they will disagree as to whether local-exec is used.
416
6bf56e74
IK
4172017-05-12 Igor Kudrin <ikudrin@accesssoftek.com>
418
419 PR gold/21430
420 * aarch64.cc
421 (AArch64_relobj::convert_input_section_to_relaxed_section):
422 Set the section offset to -1ULL.
423 (Target_aarch64::relocate_section): Adjust the view in case
424 of a relaxed input section.
425 * testsuite/Makefile.am (pr21430): New test.
426 * testsuite/Makefile.in: Regenerate
427 * testsuite/pr21430.s: New test source file.
428 * testsuite/pr21430.sh: New test script.
429
a61d92b7
AM
4302017-04-27 Alan Modra <amodra@gmail.com>
431
432 * testsuite/plugin_section_order.c (onload): Add missing break.
433
aab2c177
VR
4342017-03-15 Vladimir Radosavljevic <Vladimir.Radosavljevic@imgtec.com>
435
436 * mips.cc (Mips_got_entry::hash()): Shift addend to reduce
437 possibility of collisions.
438 (Mips_got_entry::equals): Fix case for GOT_TLS_LDM
439 entries.
440
4d78db49
VR
4412017-03-15 Vladimir Radosavljevic <Vladimir.Radosavljevic@imgtec.com>
442
443 * mips.cc (Mips_relobj::merge_processor_specific_data_): New data
444 member.
445 (Mips_relobj::merge_processor_specific_data): New method.
446 (Mips_relobj::do_read_symbols): Set merge_processor_specific_data_
447 to false, only if the input file is a binary or if object has no
448 contents except the section name string table and an empty symbol
449 table with the undefined symbol.
450 (Target_mips::do_finalize_sections): Refactor. Skip empty object files
451 for merging processor-specific data.
452
152c92b2
VR
4532017-03-15 Vladimir Radosavljevic <Vladimir.Radosavljevic@imgtec.com>
454
455 * mips.cc (Target_mips::Relocate::calculated_value_): New data
456 member.
457 (Target_mips::Relocate::calculate_only_): Likewise.
458 (Target_mips::Relocate::relocate): Handle multiple consecutive
459 relocations with the same offset.
460
1728969e
VR
4612017-03-15 Vladimir Radosavljevic <Vladimir.Radosavljevic@imgtec.com>
462
1e1247c8
VR
463 * mips.cc (Target_mips::Relocate::relocate): Remove redundant
464 checks for relocatable link.
465 (Mips_relocate_functions::reljalr): Likewise.
1728969e 466
c3847462
VR
4672017-03-15 Vladimir Radosavljevic <Vladimir.Radosavljevic@imgtec.com>
468
1e1247c8
VR
469 * mips.cc (class Mips_output_section_options): New class.
470 (Target_mips::do_make_output_section): New method.
c3847462 471
453018bf
VR
4722017-03-15 Vladimir Radosavljevic <Vladimir.Radosavljevic@imgtec.com>
473
1e1247c8
VR
474 * mips.cc (Mips_relocate_functions::rel26): Don't print relocation
475 overflow error message.
476 (Target_mips::relocate_special_relocatable): Improve relocation
477 overflow error message.
478 (Target_mips::Relocate::relocate): Likewise.
479
4802017-03-15 Vladimir Radosavljevic <Vladimir.Radosavljevic@imgtec.com>
481
482 * mips.cc (symbol_refs_local): Return false if a symbol
483 is from a dynamic object.
484 (Target_mips::got_section): Make _GLOBAL_OFFSET_TABLE_ STV_HIDDEN.
485 (Target_mips::set_gp): Refactor. Make _gp STT_NOTYPE and
486 STB_LOCAL.
487 (Target_mips::do_finalize_sections): Set _gp after all the checks
488 for creating .got are done.
489 (Target_mips::Scan::global): Remove unused code.
453018bf 490
6528b6eb
AM
4912017-02-22 Alan Modra <amodra@gmail.com>
492
493 * powerpc.cc (Target_powerpc::make_iplt_section): Check that
494 output_section exists before attempting add_output_section_data.
495 (Target_powerpc::make_brlt_section): Likewise.
496
f9029569
VR
4972017-02-15 Vladimir Radosavljevic <Vladimir.Radosavljevic@imgtec.com>
498
499 * mips.cc (Target_mips::Scan::get_reference_flags): Remove
500 gold_unreachable from default case.
501
e242ece1
VR
5022017-02-15 Vladimir Radosavljevic <Vladimir.Radosavljevic@imgtec.com>
503
504 PR gold/21111
f9029569
VR
505 * mips.cc (Mips_relocate_functions::relhigher): New method.
506 (Mips_relocate_functions::relhighest): Likewise.
507 (mips_get_size_for_reloc): Add support for relocs: R_MIPS_HIGHER and
508 R_MIPS_HIGHEST.
509 (Target_mips::Scan::local): Add support for relocs: R_MIPS_HIGHER,
510 R_MIPS_HIGHEST, R_MICROMIPS_HIGHER and R_MICROMIPS_HIGHEST.
511 (Target_mips::Scan::global): Likewise.
512 (Target_mips::Scan::get_reference_flags): Likewise.
513 (Target_mips::Relocate::relocate): Call static methods for resolving
514 HIGHER and HIGHEST relocations.
e242ece1 515
4aebb631
RC
5162017-02-03 Rahul Chaudhry <rahulchaudhry@google.com>
517
518 * x86_64.cc (Target_x86_64::do_can_check_for_function_pointers):
519 Return true even when building pie binaries.
520 (Target_x86_64::possible_function_pointer_reloc): Check opcode
521 for R_X86_64_PC32 relocations.
522 (Target_x86_64::local_reloc_may_be_function_pointer): Pass
523 extra arguments to local_reloc_may_be_function_pointer.
524 (Target_x86_64::global_reloc_may_be_function_pointer): Likewise.
525 * gc.h (gc_process_relocs): Add check for STT_FUNC.
526 * testsuite/Makefile.am (icf_safe_pie_test): New test case.
527 * testsuite/Makefile.in: Regenerate.
528 * testsuite/icf_safe_pie_test.sh: New shell script.
529
e666304e
AM
5302017-02-03 Alan Modra <amodra@gmail.com>
531
532 * powerpc.cc (Powerpc_relobj::make_toc_relative): Don't crash
533 when no .toc section exists.
534
ed35cc4a
CC
5352017-01-31 Cary Coutant <ccoutant@gmail.com>
536
537 PR gold/21090
538 * x86_64.cc (Target_x86_64::can_convert_mov_to_lea): Add check
539 for predefined symbol.
540 (Target_x86_64::Relocate::relocate): Fix formatting.
541
741bcbe9
RC
5422017-01-23 Rahul Chaudhry <rahulchaudhry@google.com>
543
544 * testsuite/icf_safe_so_test.sh: Use "set -e".
545 * testsuite/icf_safe_test.sh: Likewise.
546 * testsuite/icf_test.sh: Likewise.
547
04bc2a28
VR
5482017-01-23 Vladimir Radosavljevic <Vladimir.Radosavljevic@imgtec.com>
549
550 * mips.cc (Mips_output_data_plt::rel_plt): Remove const from return
551 type.
552 (Target_mips::make_plt_entry): Make the sh_info field of .rel.plt
553 point to .plt.
554
c1f59f8f
VR
5552017-01-23 Vladimir Radosavljevic <Vladimir.Radosavljevic@imgtec.com>
556
557 PR gold/21054
558 * mips.cc (Mips_got_info::record_global_got_symbol): Don't add symbol
559 to the dynamic symbol table if it is forced to local visibility.
560 (Target_mips::do_finalize_sections): Don't add __RLD_MAP symbol to the
561 dynamic symbol table if it is forced to local visibility.
562
a24df305
NC
5632017-01-20 Nick Clifton <nickc@redhat.com>
564
565 * aarch64.cc (Stub_template_repertoire): Change ST_E_835769_INSNS
566 from a pointer to an array.
567
857e829e
L
5682017-01-13 H.J. Lu <hongjiu.lu@intel.com>
569
570 PR gold/21040
571 * powerpc.cc (Powerpc_relobj<size, big_endian>::make_toc_relative):
572 Cast 0x80008000 to uint64_t.
573
aca5eec6
CC
5742017-01-12 Cary Coutant <ccoutant@gmail.com>
575
576 * object.cc (Sized_relobj_file): Fix byte counts for calls to memmem.
577
6624f3a1
CC
5782017-01-11 Cary Coutant <ccoutant@gmail.com>
579
580 PR gold/21040
581 * x86_64.cc (Output_data_plt_x86_64_bnd::do_fill_first_plt_entry):
582 Remove unnecessary 'typename' keyword.
583 (Output_data_plt_x86_64_bnd::do_fill_plt_entry): Likewise.
584 (Output_data_plt_x86_64_bnd::fill_aplt_entry): Likewise.
585 (Output_data_plt_x86_64_bnd::do_fill_tlsdesc_entry): Likewise.
586 (Output_data_plt_x86_64_bnd::do_write): Likewise.
587
976e204b
CC
5882017-01-11 Cary Coutant <ccoutant@gmail.com>
589
590 PR gold/21040
591 * x86_64.cc (Output_data_plt_x86_64_bnd::do_fill_first_plt_entry):
592 Remove unnecessary 'typename' keyword.
593 (Output_data_plt_x86_64_bnd::do_fill_plt_entry): Likewise.
594 (Output_data_plt_x86_64_bnd::do_fill_tlsdesc_entry): Likewise.
595 (Output_data_plt_x86_64_bnd::fill_aplt_entry): Likewise.
596 * testsuite/copy_test_relro_1.cc (p, b, c, q): Add separate extern
597 declarations.
598
1fa5f68b
CC
5992017-01-11 Cary Coutant <ccoutant@gmail.com>
600
601 PR gold/21039
602 * testsuite/script_test_13.sh: Adjust patterns to work for i386.
603 * testsuite/script_test_15a.sh: Likewise.
604 * testsuite/script_test_15b.sh: Likewise.
605 * testsuite/script_test_15c.sh: Likewise.
606
5edad15d
AM
6072017-01-11 Alan Modra <amodra@gmail.com>
608
609 * powerpc.cc (class Powerpc_copy_relocs): New.
610 (Powerpc_copy_relocs::emit): New function.
611 (Powerpc_relobj::relatoc_, toc_, no_toc_opt_): New variables.
612 (Powerpc_relobj::toc_shndx, set_no_toc_opt, no_toc_opt): New inlines.
613 (Powerpc_relobj::do_relocate_sections): New function.
614 (Powerpc_relobj::make_toc_relative): Likewise.
615 (Powerpc_relobj::do_find_special_sections): Stash away .rela.toc
616 and .toc too.
617 (ok_lo_toc_insn): Move earlier, and handle more insns.
618 (Target_powerpc::Scan::local): If optimizing toc accesses, set
619 no_toc_opt for entries we can't edit. Check insn validity.
620 Emit "toc optimization is not supported" warning, downgraded
621 from error.
622 (Target_powerpc::Scan::global): Likewise.
623 (Target_powerpc::Relocate::relocate): Edit TOC indirect code
624 to TOC relative. Don't emit "toc optimization is not supported"
625 error here.
626
98461510
CC
6272017-01-10 Cary Coutant <ccoutant@gmail.com>
628
629 * aarch64.cc (AArch64_relobj::do_relocate_sections): Call
630 Sized_relobj_file::relocate_section_range().
631 * arm.cc (Arm_relobj::do_relocate_sections): Likewise.
632 * object.h (Sized_relobj_file::relocate_section_range): New method.
633 * reloc.cc (Sized_relobj_file::do_relocate_sections): Move
634 implementation...
635 (Sized_relobj_file::relocate_section_range): ...to new method.
636
f7fd19e2
AM
6372017-01-10 Alan Modra <amodra@gmail.com>
638
639 * testsuite/ver_test_8.sh: Accept .TOC. in lieu of
640 _GLOBAL_OFFSET_TABLE_. Allow zero count.
641 * testsuite/copy_test_relro_1.cc (c, q): New vars.
642 * testsuite/copy_test_relro.cc: Rewrite to test read-only
643 status of variables directly. Reference new vars in
644 read-only data.
645
f159cdb6
AM
6462017-01-10 Alan Modra <amodra@gmail.com>
647
648 * options.h: Add --secure-plt option.
649 * powerpc.cc (Target_powerpc::Scan::local): Detect and error
650 on -fPIC -mbss-plt code.
651 (Target_powerpc::Scan::global): Likewise.
652
3254d32c
AM
6532017-01-09 Alan Modra <amodra@gmail.com>
654
655 * powerpc.cc (Target_powerpc::make_plt_section): Point sh_info of
656 ".rela.plt" at ".plt".
657
0e123f69
AM
6582017-01-07 Alan Modra <amodra@gmail.com>
659
660 * powerpc.cc: Use shorter equivalent elfcpp typedef for
661 Reltype and reloc_size throughout.
662 (Target_powerpc::symval_for_branch): Exclude dynamic symbols.
663 (Target_powerpc::Scan::local): Use local var r_sym.
664 (Target_powerpc::Scan::global: Likewise.
665 (Target_powerpc::Relocate::relocate): Delete shadowing r_sym.
666
2571583a
AM
6672017-01-02 Alan Modra <amodra@gmail.com>
668
669 Update year range in copyright notice of all files.
670
5c1ad6b5 671For older changes see ChangeLog-2016
3499769a 672\f
5c1ad6b5 673Copyright (C) 2017 Free Software Foundation, Inc.
3499769a
AM
674
675Copying and distribution of this file, with or without modification,
676are permitted in any medium without royalty provided the copyright
677notice and this notice are preserved.
678
679Local Variables:
680mode: change-log
681left-margin: 8
682fill-column: 74
683version-control: never
684End:
This page took 0.151314 seconds and 4 git commands to generate.