aboutsummaryrefslogtreecommitdiff
path: root/lld/docs/ReleaseNotes.rst
blob: 863b2018910067a190e8dc178ce8172bee78195d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
===========================
lld |release| Release Notes
===========================

.. contents::
    :local:

.. only:: PreRelease

  .. warning::
     These are in-progress notes for the upcoming LLVM |release| release.
     Release notes for previous releases can be found on
     `the Download Page <https://releases.llvm.org/download.html>`_.

Introduction
============

This document contains the release notes for the lld linker, release |release|.
Here we describe the status of lld, including major improvements
from the previous release. All lld releases may be downloaded
from the `LLVM releases web site <https://llvm.org/releases/>`_.

Non-comprehensive list of changes in this release
=================================================

ELF Improvements
----------------
* Added ``-z dynamic-undefined-weak`` to make undefined weak symbols dynamic
  when the dynamic symbol table is present.
  (`#143831 <https://github.com/llvm/llvm-project/pull/143831>`_)
* For ``-z undefs`` (default for ``-shared``), relocations referencing undefined
  strong symbols now behave like relocations referencing undefined weak symbols.
* ``--why-live=<glob>`` prints for each symbol matching ``<glob>`` a chain of
  items that kept it live during garbage collection. This is inspired by the
  Mach-O LLD feature of the same name.
* ``--thinlto-distributor=`` and ``--thinlto-remote-compiler=`` options are
  added to support Integrated Distributed ThinLTO.
  (`#142757 <https://github.com/llvm/llvm-project/pull/142757>`_)

* Linker script ``OVERLAY`` descriptions now support virtual memory regions
  (e.g. ``>region``) and ``NOCROSSREFS``.
* When the last ``PT_LOAD`` segment is executable and includes BSS sections,
  its ``p_memsz`` member is now correct.
  (`#139207 <https://github.com/llvm/llvm-project/pull/139207>`_)
* Spurious ``ASSERT`` errors before the layout converges are now fixed.

* For ARM and AArch64, ``--xosegment`` and ``--no-xosegment`` control whether
  to place executable-only and readable-executable sections in the same
  segment. The default option is ``--no-xosegment``.
  (`#132412 <https://github.com/llvm/llvm-project/pull/132412>`_)
* For AArch64, added support for the ``SHF_AARCH64_PURECODE`` section flag,
  which indicates that the section only contains program code and no data.
  An output section will only have this flag set if all input sections also
  have it set. (`#125689 <https://github.com/llvm/llvm-project/pull/125689>`_,
  `#134798 <https://github.com/llvm/llvm-project/pull/134798>`_)
* For AArch64 and ARM, added ``-zexecute-only-report``, which checks for
  missing ``SHF_AARCH64_PURECODE`` and ``SHF_ARM_PURECODE`` section flags
  on executable sections.
  (`#128883 <https://github.com/llvm/llvm-project/pull/128883>`_)
* For AArch64, ``-z nopac-plt`` has been added.
* For AArch64 and X86_64, added ``--branch-to-branch``, which rewrites branches
  that point to another branch instruction to instead branch directly to the
  target of the second instruction. Enabled by default at ``-O2``.
* For AArch64, added support for ``-zgcs-report-dynamic``, enabling checks for
  GNU GCS Attribute Flags in Dynamic Objects when GCS is enabled. Inherits value
  from ``-zgcs-report`` (capped at ``warning`` level) unless user-defined,
  ensuring compatibility with GNU ld linker.
* The default Hexagon architecture version in ELF object files produced by
  lld is changed to v68. This change is only effective when the version is
  not provided in the command line by the user and cannot be inferred from
  inputs.
* For LoongArch, the initial-exec to local-exec TLS optimization has been implemented.
* For LoongArch, several relaxation optimizations are supported, including relaxation for
  ``R_LARCH_PCALA_HI20/LO12`` and ``R_LARCH_GOT_PC_HI20/LO12`` relocations, instruction
  relaxation for ``R_LARCH_CALL36``, TLS local-exec (``LE``)/global dynamic (``GD``)/
  local dynamic (``LD``) model relaxation, and TLSDESC code sequence relaxation.
* For RISCV, an oscillation bug due to call relaxation is now fixed.
  (`#142899 <https://github.com/llvm/llvm-project/pull/142899>`_)
* For x86-64, the ``.ltext`` section is now placed before ``.rodata``.
  
Breaking changes
----------------
* Executable-only and readable-executable sections are now allowed to be placed
  in the same segment by default. Pass ``--xosegment`` to lld in order to get
  the old behavior back.

* When using ``--no-pie`` without a ``SECTIONS`` command, the linker uses the
  target's default image base. If ``-Ttext=`` or ``--section-start`` specifies
  an output section address below this base, there will now be an error.
  ``--image-base`` can be set at a lower address to fix the error.
  (`#140187 <https://github.com/llvm/llvm-project/pull/140187>`_)

COFF Improvements
-----------------

MinGW Improvements
------------------

MachO Improvements
------------------

WebAssembly Improvements
------------------------

Fixes
#####