Properly implement STT_COMMON
[external/binutils.git] / ld / NEWS
1 -*- text -*-
2
3 * Add -z common/-z nocommon options for ELF targets to control whether to
4   convert common symbols to the STT_COMMON type during a relocatable link.
5
6 * Support for -z nodynamic-undefined-weak in the x86 ELF linker, which
7   avoids dynamic relocations against undefined weak symbols in executable.
8
9 Changes in 2.26:
10
11 * Add --fix-stm32l4xx-629360 to the ARM linker to enable a link-time
12   workaround for a bug in the bus matrix / memory controller for some of
13   the STM32 Cortex-M4 based products (STM32L4xx)
14
15 * Add a configure option --enable-compressed-debug-sections={all,ld} to
16   decide whether DWARF debug sections should be compressed by default.
17
18 * Add support for the ARC EM/HS, and ARC600/700 architectures.
19
20 * Experimental support for linker garbage collection (--gc-sections)
21   has been enabled for COFF and PE based targets.
22
23 * New command line option for ELF targets to compress DWARF debug
24   sections, --compress-debug-sections=[none|zlib|zlib-gnu|zlib-gabi].
25
26 * New command line option, --orphan-handling=[place|warn|error|discard], to
27   adjust how orphan sections are handled.  The default is 'place' which gives
28   the current behaviour, 'warn' and 'error' issue a warning or error
29   respectively when orphan sections are found, and 'discard' will discard all
30   orphan sections.
31
32 * Add support for LLVM plugin.
33
34 * Add --print-memory-usage option to report memory blocks usage.
35
36 * Add --require-defined option, it's like --undefined except the new symbol
37   must be defined by the end of the link.
38
39 Changes in 2.25:
40
41 * PE binaries now once again contain real timestamps by default.  To disable
42   the inclusion of a timestamp in a PE binary, use the --no-insert-timestamp
43   command line option.
44
45 * Replace support for openrisc and or32 with support for or1k.
46
47 * Add support for the --build-id command line option to COFF based targets.
48
49 * x86/x86_64 pe-coff now supports the --build-id option.
50
51 * Add support for the Andes NDS32.
52
53 Changes in 2.24:
54
55 * Add LOG2CEIL() builtin function to the linker script language
56
57 * Add support for the Texas Instruments MSP430X processor.
58
59 * Add support for Altera Nios II.
60
61 * Add support for the V850E3V5 architecture.
62
63 * Add support for the Imagination Technologies Meta processor.
64
65 * --enable-new-dtags no longer generates old dtags in addition to new dtags.
66
67 * Remove linker support for MIPS ECOFF targets.
68
69 * Add ALIGN_WITH_INPUT to the linker script language to force the alignment of
70   an output section to use the maximum alignment of all its input sections.
71
72 Changes in 2.23:
73
74 * Enable compressed debug section feature for x86/x86_64 pe-coff.
75
76 * Add support for the 64-bit ARM architecture: AArch64.
77
78 * Added SORT_NONE to the linker script language to disable section sorting.
79
80 * Add a linker-provided symbol when producing ELF output, '__ehdr_start'
81   to point to the ELF file header (and nearby program headers) in the
82   program's memory image.
83
84 * Add support for S12X processor.
85
86 * Add support for the VLE extension to the PowerPC architecture.
87
88 * Add support for the Freescale XGATE architecture.
89
90 * Add option -f FILE on AIX (for response file).
91
92 * Add support for the Renesas RL78 architecture.
93
94 * Add support for the Adapteva EPIPHANY architecture.
95
96 Changes in 2.22:
97
98 * --copy-dt-needed-entries is no longer enabled by default.  Instead
99   --no-copy-dt-needed-entries is the default.
100
101 * INPUT_SECTION_FLAGS has been added to the linker script language
102   to allow selection of input sections by section header section flags.
103
104 * Add support for the Tilera TILEPro and TILE-Gx architectures.
105
106 * Added SORT_BY_INIT_PRIORITY to the linker script language to permit
107   sorting sections by numerical value of the GCC init_priority attribute
108   encoded in the section name.
109
110 Changes in 2.21:
111
112 * Linker script expression evaluation is somewhat more sane.  This may
113   break scripts that depend on quirks of the old expression evaluation.
114
115 * Turn off underscoring for x86_64 PE+-COFF targets.  For old behavior the
116   option --enable-leading-mingw64-underscores can be used on configure of
117   bfd.
118
119 * Add support for the TMS320C6000 (TI C6X) processor family.
120
121 * --add-needed renamed to --copy-dt-needed-entries in order to avoid confusion
122   with --as-needed option.
123
124 * Extend .def file syntax by '== <ID>' for imports and exports. This allows
125   to alias the import/export table name written in PE image.
126
127 * Add --exclude-all-symbols option to PE based linkers.  This prevents all
128   symbols from automatically being exported.
129
130 * Add support for the Renesas RX processor.
131
132 * Add support for alpha-vms target.
133
134 Changes in 2.20:
135
136 * GNU/Linux targets now support the STB_GNU_UNIQUE symbol binding.  This is a
137   GNU extension to the standard set of ELF symbol bindings.  The binding will
138   be passed on to the dynamic linker which will make sure that in the entire
139   process there is just one symbol with the given name and type in use.
140
141 * PE targets now support a GNU extension to allow the alignment of common
142   common symbols to be specified.  This support uses custom options in
143   the .drectve section, which will be disregarded by the native tools.
144
145 * PE targets now add primitive support for ELF version scripts; symbols
146   are not versioned, but the local and global symbol visibility directives
147   are respected when filtering symbols in auto-export mode.
148
149 * New option --no-export-dynamic to undo the effect of the -E and
150   --export-dynamic options.
151
152 * ELF: --warn-alternate-em option to warn if an object has alternate
153   ELF machine code.
154
155 * New script function REGION_ALIAS to add alias names to memory regions.
156
157 * PE targets no longer make use of the long section names PE extension to
158   the COFF format when generating executable images, by default.  The old
159   (slightly non-conformant) behaviour can still be invoked by using the
160   new '--enable-long-section-names' command-line option.  It is also enabled
161   automatically in the presence of un-stripped debug information, as GDB
162   needs to be able to find the debug info sections by their full names.
163
164 * For GNU/Linux systems the linker will now avoid processing any relocations
165   made against symbols of the STT_GNU_IFUNC type and instead emit them into
166   the resulting binary for processing by the loader.
167
168 * --as-needed now links in a dynamic library if it satisfies undefined
169   symbols in regular objects, or in other dynamic libraries.  In the
170   latter case the library is not linked if it is found in a DT_NEEDED
171   entry of one of the libraries already linked.
172
173 * Add a new command line option, -Ttext-segment ADDR, for ELF targets
174   to set the address of the first byte of the text segment.
175
176 * Add support for Sunplus score architecture.
177
178 * Add new option --use-nul-prefixed-import-tables to ld for PE targets to
179   allow fallback to old import table generation with null element prefix.
180
181 * Windows PE systems now support a new --exclude-modules-for-implib option,
182   allowing users to partition object files and archive members between a DLL
183   and its associated import library as they are generated during linking.
184
185 * Add support for Lattice Mico32 (lm32) architecture.
186
187 * Add CR16 ELF --embedded-relocs (used to embedded relocations into binaries
188   for Embedded-PIC code) option.
189
190 * Add to the PE/PE+ targets the support of two different kinds of
191   pseudo-relocations.  They can be selected by the switches
192   --enable-runtime-pseudo-reloc-v1 and --enable-runtime-pseudo-reloc-v2.
193   For the switch --enable-runtime-pseudo-reloc it uses for 32-bit
194   runtime pseudo relocation version one, for 64-bit the version two.
195
196 Changes in 2.19:
197
198 * Linker scripts support a new INSERT command that makes it easier to
199   augment the default script.
200
201 * Linker script input section filespecs may now specify a file within an
202   archive by writing "archive:file".
203
204 * The --sort-common switch now has an optional argument which specifies the
205   direction of sorting.
206
207 * The M68K linker now supports multiple GOT generation schemes controlled via
208   the --got=<type> command line option.
209
210 * The ARM EABI linker will now generate stubs for function calls to symbols
211   that are too far away.  The placement of the stubs is controlled by a new
212   linker command line option: --stub-group-size=N.
213
214 Changes in 2.18:
215
216 * Linker sources now released under version 3 of the GNU General Public
217   License.
218
219 * ELF: New --build-id option to generate a unique per-binary identifier
220   embedded in a note section.
221
222 * Added support for National Semicondutor CompactRISC (ie CR16) target.
223
224 * -l:foo now searches the library path for a filename called foo,
225   without converting it to libfoo.a or libfoo.so.
226
227 * Add a new command line option '--default-script=FILE' or '-dT FILE'
228   which specifies a replacement for the built in, default linker
229   script.
230
231 * ELF: Add -Bsymbolic-functions, --dynamic-list-cpp-new, which puts C++
232   operator new and delete on the dynamic list, and --dynamic-list-data,
233   builtin list for --dynamic-list, which puts global data symbols on the
234   dynamic list.
235
236 * Add support for x86_64 PE+ target.
237
238 * Add support for Score target.
239
240 * ELF: Add --dynamic-list option to specify a list of global symbols
241   whose references shouldn't be bound to the definition within the
242   shared library, or a list of symbols which should be added to the
243   symbol table in the executable.
244
245 * The default output section LMA has changed for allocatable sections from
246   being equal to VMA, to keeping the difference between LMA and VMA the same as
247   the previous output section in the same region.  This is a more useful
248   default when using overlays and other cases where you specify an LMA
249   differing from the VMA for some sections.
250
251 * New switch: --print-gc-sections to list any sections removed by garabge
252   collection.
253
254 * ARM: Added --vfp11-denorm-fix option to work around an erratum in current
255   VFP11 coprocessors.
256
257 Changes in 2.17:
258
259 * Support for the Infineon XC16X has been added by KPIT Cummins Infosystems.
260
261 * Modify the Linux linker search order to better match ld.so search order.
262   Look for DT_NEEDED libraries in paths specified by ld.so.conf before
263   searching the default directories, rather than vice versa.
264   Use $prefix/etc/ld.so.conf if it exists, otherwise /etc/ld.so.conf.
265
266 * PE-COFF: Forward exports from DLL's can now be specified in .def files
267   passed directly to ld.
268
269 * Support for the Z80 processor family has been added.
270
271 * Add support for the "@<file>" syntax to the command line, so that extra
272   switches can be read from <file>.
273
274 Changes in 2.16:
275
276 * Support for the R_ARM_V4BX relocation as defined in the ARM AAELF
277   specification has been added via the --fix-v4bx command-line option.
278
279 * New linker script construct AS_NEEDED(), which sets the --as-needed flag
280   for input files listed inside of it.
281
282 * A new command-line option, --sysroot, can be used to override the
283   default sysroot location.  It only applies to toolchains that were
284   configured using --with-sysroot.
285
286 * New linker script functions: ORIGIN() and LENGTH() which return information
287   about a specified memory region.
288
289 * Port to MAXQ processor contributed by HCL Tech.
290
291 * Added SEGMENT_START to the linker script language to permit the user to
292   override the base address for a segment from the command-line.
293
294 * ELF: --warn-shared-textrel option to warn if adding a DT_TEXTREL to a shared
295   object.
296
297 * Added SORT_BY_NAME and SORT_BY_ALIGNMENT to the linker script
298   language to permit sorting sections by section name or section
299   maximum alignment.
300
301 * Added a new linker command line switch, --sort-section name|alignment,
302   to sort sections by section name or maximum alignment.
303
304 * ELF: --add-needed/--no-add-needed options to control if a DT_NEEDED tag
305   should be added when a shared library comes from DT_NEEDED tags.
306
307 * Support for the crx-elf target added.
308
309 * Support for the sh-symbianelf target added.
310
311 * A new linker command line switch has been added which allows the hash table
312   size to be set to a suitable prime value near to its argument.  This switch
313   is --hash-size=<NUMBER>.  Also if the switch --reduce-memory-overheads is
314   used, and --hash-size has not been used, then the default value will be set
315   to 1021.
316
317 * Linker map files are now generated with an O(N) algorithm for finding symbols
318   that are defined in each section.  This uses about 40% more memory for
319   symbols than the old O(N^2) algorithm.  You can use the new
320   --reduce-memory-overheads option to select the old algorithm; this option
321   might also be used in the future to select similar tradeoffs.
322
323 Changes in 2.15:
324
325 * ELF: --as-needed/--no-as-needed options to control if a DT_NEEDED tag should
326   be added only when a shared library is referenced.
327
328 * PE: --large-address-aware option to indicate executables support virtual
329   addresses greater than 2 gigabytes.
330
331 * DWARF 2 support for i386pe added.
332
333 * The linker script operator DEFINED() will now yield 1 only for a symbol that
334   is defined before the statement where DEFINED is used.
335
336 * The MIPS --embedded-relocs (used to embed relocations into binaries for
337   Embedded-PIC code) is deprecated and will be removed in a future release.
338
339 * cr16c support added by NSC.
340
341 * m32r Linux (ELF) support added by Renesas.
342
343 * Improved linker's handling of unresolved symbols.  The switch
344   --unresolved-symbols=<method> has been added to tell the linker when it
345   should report them and the switch --warn-unresolved-symbols has been added to
346   make reports be issued as warning messages rather than errors.
347
348 Changes in 2.14:
349
350 * Added support for Xtensa architecture.
351
352 * Added --with-sysroot configure switch to specify a target system root, for
353   linking against a target filesystem image.
354
355 * Added --accept-unknown-linker-format to restore old linker behaviour (pre
356   2.14) of silently accepting and linking in any files in an unknown binary
357   file format.
358
359 * Added --no-omagic to undo the effects of the -N option.
360
361 * Support for Texas Instruments TMS320C4x and TMS320C3x series of
362   DSP's contributed by Michael Hayes and Svein E. Seldal.
363
364 * Added --with-lib-path configure switch to specify default value for
365   LIB_PATH.
366
367 * ARM port to QNX operating system added by Graeme Peterson.
368
369 * IP2K support added by Denis Chertykov.
370
371 Changes in 2.13:
372
373 * Support for the Fujitsu FRV architecture added by Red Hat. Models for FR400
374   and FR500 included.
375
376 Changes in version 2.13:
377
378 * DEC VAX ELF support, by Matt Thomas.
379
380 Changes in version 2.12:
381
382 * Support for Don Knuth's MMIX, by Hans-Peter Nilsson.
383
384 * Support for the OpenRISC 32-bit embedded processor by OpenCores.
385
386 * Support for -z nocopyreloc in the x86 ELF linker, which disables
387   production of copy relocs.  Warning: using this option may result in
388   non-sharable applications.
389
390 * Support for -z combreloc in the ELF linker, which puts dynamic
391   relocations against the same symbol together, so that dynamic linker
392   can use an one-entry symbol lookup cache.
393
394 * Support for ELF SHF_MERGE section merging, by Jakub Jelinek.
395
396 Changes in version 2.11:
397
398 * Support for AMD x86-64 architecture, by Jan Hubicka, SuSE Labs.
399
400 * Support added for eliminating duplicate DWARF2 debug information by
401   having the compiler generate the information in sections called
402   .gnu.linkonce.wi.XXXX where XXXX is a checksum for the contents.  The
403   linker then merges these sections together into the normal .debug_info
404   section.
405
406 * The native ELF linker now searches the directories in DT_RUNPATH or
407   DT_RPATH of a shared library for shared libraries needed by it.
408
409 * TI C54x support, by Timothy Wall.
410
411 * Added command line switch --section-start to set the start address of any
412   specified section.
413
414 * Added ability to emit full relocation information in linked executables,
415   enabled by --emit-relocs.  Some post-linkage optimization tools need
416   this information in order to be able to correctly identify and perform
417   symbol relative addressing in the event of changes in section contents
418   (instructions being added or deleted, extending data sections, etc.)
419
420 * Support for i860, by Jason Eckhardt (preliminary, alpha quality).
421
422 * Support for CRIS (Axis Communications ETRAX series).
423
424 * Support for PDP-11 and 2.11BSD a.out format, by Lars Brinkhoff.
425
426 Changes in version 2.10:
427
428 * Added AT> to the linker script language to allow load-time allocation of
429   sections into regions.
430
431 * Added garbage collection of unused sections, enabled by --gc-sections.
432   It does require a bit of backend support; currently implemented are
433   arm-elf, avr-elf, d10v-elf, fr30-elf, i386-elf, m32r-elf, m68k-elf,
434   mcore-elf, mips-elf, mn10300-elf, ppc-elf, sh-elf, sparc-elf, and v850-elf.
435   Others will ignore the option.
436
437 * Added SORT to the linker script language to permit sorting sections by file
438   name or section name.
439
440 * Added EXTERN to the linker script language as an equivalent to the -u
441   command-line option.
442
443 * Added ASSERT to the linker script language.
444
445 * Added EXCLUDE_FILE to the linker script language for further control over
446   wildcard file names.
447
448 * Added -O option to optimize linker output (as of this writing, this only
449   affects ELF shared library generation).
450
451 * The -e option now accepts a number as well as a symbol name.
452
453 * Added --no-undefined option to disallow undefined symbols when creating a
454   shared library.
455
456 * The linker now issues a warning, not an error, for an undefined symbol when
457   using -Bsymbolic; use the new --no-undefined option to get the old
458   behaviour.
459
460 * Added --demangle and --no-demangle options.
461
462 Changes in version 2.9:
463
464 * Added SQUAD to the linker script language.
465
466 * New option --no-warn-mismatch.
467
468 * The MEMORY command now parses the attributes to determine where sections that
469   are not placed in a specific memory region are placed.
470
471 Changes in version 2.8:
472
473 * Linker scripts may now contain shell wildcard characters for file and section
474   names.
475
476 * The linker now supports symbol versions in ELF.
477
478 * The NOCROSSREFS command was added to the linker script language.
479
480 * The LOADADDR expression was added to the linker script language.
481
482 * MAX and MIN functions were added to the linker script language.
483
484 * The OVERLAY construct was added to the linker script language.
485
486 * New option --warn-section-align to warn when the address of an output section
487   changes due to alignment of an input section.
488
489 * New options --filter/-F and --auxiliary/-f.
490
491 Changes in version 2.7:
492
493 * New option --cref to print out a cross reference table.
494
495 * New option --wrap SYMBOL.
496
497 * New option --no-whole-archive, to turn off the effect of --whole-archive.
498
499 * Input sections assigned to the output section /DISCARD/ in the linker script
500   are not included in the output file.
501
502 * The SunOS and ELF linkers now merge stabs debugging information which uses
503   the N_BINCL and N_EINCL stab types.  This reduces the amount of debugging
504   information generated.
505
506 Changes in version 2.6:
507
508 * When an ELF section name is representable as a C identifier (this is not true
509 of most ELF section names), the linker will automatically define symbols
510 __start_SECNAME and __stop_SECNAME, where SECNAME is the section name, at the
511 beginning and the end of the section.  This is used by glibc.
512
513   Addendum: Current versions of the linker (at least for version 2.18 onwards
514 and possibly much earlier as well) place two restrictions on this feature:  The
515 symbols are only implemented for orphaned sections, not for explicitly placed
516 sections and they are PROVIDEd rather than being defined.
517
518 * When an ELF section named .gnu.warning is encountered in an input file, the
519 contents of the section are displayed as an error message, and the section is
520 not copied into the output file.  This is used by glibc.
521
522 * When an ELF section named .gnu.warning.SYMBOL is encountered in an input
523 file, and the symbol SYMBOL is referenced by some object file, the contents of
524 the section are displayed as an error message.  The section is not copied into
525 the output file, unless doing a relocatable or shared link.  This is used by
526 glibc.
527
528 * New options -split-by-reloc and -split-by-file.
529
530 * The linker now supports linking PIC compiled code on SPARC SunOS.  It can
531 also create SPARC SunOS shared libraries, and, like the native SunOS linker,
532 will do so whenever there is an undefined symbol in the link and neither the -e
533 nor the -r option was used.
534
535 * The -rpath option may be used on SunOS to set the list of directories to be
536 searched at run time.  This overrides the default of building the list from the
537 -L options.
538
539 * The COFF linker now combines debugging information for structs, unions, and
540 enums, so that even if the same type is defined in multiple input files it will
541 only be defined once in the output file.  The --traditional-format switch will
542 prevent this optimization.
543
544 Changes in version 2.5:
545
546 * The linker now supports linking against SunOS shared libraries.  It still can
547 not link SunOS PIC (Position Independent Code) files, so it can not be used to
548 generate shared libraries.
549
550 * The linker now supports linking against ELF shared libraries for the i386
551 (UnixWare) and SPARC (Solaris).  It can also link ELF PIC files, and can be
552 used to generate shared libraries.  Shared library generation is not well
553 tested; please report any problems encountered.  The linker is now enabled for
554 Solaris again.
555
556 * Eric Youngdale has contributed Linux support code, including linking against
557 Linux a.out shared libraries.  The linker produces Linux QMAGIC binaries.
558
559 * The ELF backend has been converted to the new linker code.  To use the new
560 ELF linker, each particular target requires a relocation function.  So far,
561 this function has been written for i386 (UnixWare), SPARC (Solaris) MIPS (Irix
562 5), and HPPA ELF targets.
563
564 * The -( (--start-group) and -) (--end-group) options have been added to
565 support searching a group of archives as though they were a single archive.
566 This can also be used in a linker script, as GROUP ( files ).
567
568 * When a file is named on the command line, and the linker does not recognize
569 it as an object file, the linker will now treat the file as a linker script
570 file.  A linker script named in this way augments, but does not replace, the
571 default linker script.
572
573 * The -warn-once option was added.  It causes the linker to only warn once per
574 undefined symbol, rather than once per reference.
575
576 * The COFF backend has been converted to the new linker code.  As with ELF, to
577 use the new linker, each particular target requires a relocation function.  So
578 far, this function has been written for the i386, m68k, a29k and SH targets.
579
580 * The -V flag was made a synonym for -v, for SVR4 compatibility.  The old -V
581 behaviour is available via --verbose.
582
583 Changes in version 2.4:
584
585 * New linker code, by Steve Chamberlain and Ian Taylor.  For a.out and ecoff
586   formats (so far), this should result in considerable savings in time
587   and memory used while linking; slightly poorer performance than
588   before for formats not converted yet.
589
590 * Command-line parsing is no longer done with flex.  This means
591   oddball characters in filenames won't get treated as argument
592   separators.
593
594 * HP-PA ELF support, by Jeff Law.  (No SOM support yet.)
595
596 * Mach i386 support, by David Mackenzie.
597
598 * Irix 4 shared libraries are now supported (Irix 5 uses ELF, and ELF shared
599   libraries are not yet supported).
600
601 * COFF shared libraries (as on SCO) should work as well.
602
603 * The linker is disabled for Solaris.  (Actually, it was in 2.3 also, I just
604   forgot to note it.)  Some of their C library routines don't work when
605   statically linked, and the GNU linker doesn't support dynamic linking yet.
606
607 Changes in version 2.3:
608
609 * Weak symbols are now supported.
610
611 * ELF support has been added.  The linker has been bootstrapped on
612   UnixWare and Solaris.
613
614 * Alpha OSF/1 support has been added (non dynamic linking only).
615
616 Changes in version 2.2:
617
618 * The `bfd' library has been updated to reduce a.out-format string
619   table size.  The effect of this is that files linked from many input
620   files with duplicate symbols (`-g' debugging records, or identical
621   static symbols) should be much smaller.
622
623 Changes in version 2.1:
624
625 * The ld -ySYMBOL flag (to trace references to SYMBOL) is now implemented.
626
627 * There is now support for writing ECOFF files, so ld and the
628   other utilities should work on Risc/Ultrix and Irix.
629
630 \f
631 Copyright (C) 2012-2016 Free Software Foundation, Inc.
632
633 Copying and distribution of this file, with or without modification,
634 are permitted in any medium without royalty provided the copyright
635 notice and this notice are preserved.
636
637 Local variables:
638 fill-column: 79
639 End: