[llvm-bugs] [Bug 52384] New: start-stop-gc default change breaks multiple projects with no viable transition option

via llvm-bugs llvm-bugs at lists.llvm.org
Tue Nov 2 20:56:12 PDT 2021


https://bugs.llvm.org/show_bug.cgi?id=52384

            Bug ID: 52384
           Summary: start-stop-gc default change breaks multiple projects
                    with no viable transition option
           Product: lld
           Version: 13.0
          Hardware: PC
                OS: All
            Status: NEW
          Severity: release blocker
          Priority: P
         Component: ELF
          Assignee: unassignedbugs at nondot.org
          Reporter: jrtc27 at jrtc27.com
                CC: llvm-bugs at lists.llvm.org, smithp352 at googlemail.com

4bbcd63eea4950c38e29f9e29b1d11b7d7894469 (D96914) added a new -z start-stop-gc
to allow the existing "__start_foo retains a section called foo" behaviour to
be disabled, coordinated with GNU ld.

6d2d3bd0a61f5fc7fd9f61f48bc30e9ca77cc619 (committed without review 1.5 months
later, within the same release cycle (13)) changed the default of this option,
thereby breaking software that relied on the old semantics.

So far that list of software is:

* FreeBSD
* NetworkManager
* systemd
* LDC

and 13.0.1 final hasn't even been released yet. For some projects (FreeBSD,
NetworkManager and systemd), build systems can be adjusted to add -z
no-start-stop-gc and restore the traditional behaviour. However, some projects,
like LDC, which in this case is behaving like a driver for LD and thus, just
like Clang, cannot easily know what exact linker (GNU vs LLVM, and version) is
being used at run time, and thus cannot know whether the option even exists (so
cannot just unconditionally pass it without getting an error).

I do not believe this is an appropriate way to go about this transition, and so
the default change in 6d2d3bd0a61f5fc7fd9f61f48bc30e9ca77cc619 should be
reverted, both in main and in release/13.x, until such time as a proper
transition plan is put forward, akin to how -f(no-)common was handled (except
this time the errors aren't even bugs in the software, they're "your software
was fine but needs to change because we decided that behaviour is no longer
supported by default") where the option exists for enough years before the
default is flipped such that it can just be assumed to exist and the old
behaviour requested unconditionally for projects that need it.

There is the separate issue of the fact that such a plan still breaks static
libraries that wish to use linker sets, as it's up to the consumer of the
library to decide what semantics it wants, not the library (and I cannot
foresee (a) requiring people to use pkgconf-like mechanisms (b) those adding a
-z option to LDFLAGS being a good idea).

https://reviews.llvm.org/D96914 has a lengthier discussion that lead up to this
bug report, and continues.

-- 
You are receiving this mail because:
You are on the CC list for the bug.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-bugs/attachments/20211103/39437da7/attachment-0001.html>


More information about the llvm-bugs mailing list