On 03/04/2021 13:25, Iain Sandoe wrote:
Jonathan Wakely via Gcc <gcc@gcc.gnu.org> wrote:
On Sat, 3 Apr 2021 at 00:53, Richard Copley via Gcc <gcc@gcc.gnu.org>
wrote:
On 01/04/2021 13:35, Richard Biener wrote:
The first release candidate for GCC 10.3 is available from
https://gcc.gnu.org/pub/gcc/snapshots/10.3.0-RC-20210401/
ftp://gcc.gnu.org/pub/gcc/snapshots/10.3.0-RC-20210401/
and shortly its mirrors. It has been generated from git commit
892024d4af83b258801ff7484bf28f0cf1a1a999.
I have so far bootstrapped and tested the release candidate on
x86_64-linux. Please test it and report any issues to bugzilla.
If all goes well, I'd like to release 10.3 on Thursday, April 8th.
On Windows, linking two C++ translation units that both #include
<coroutine> results in errors about multiple definition of the weak
function __dummy_resume_destroy. This can be avoided by cherry-picking
commit 94fd05f1f76faca9dc9033b55d44c960155d38e9 [PR 95917].
That problem is already present in GCC 10.2, right?
Right, yes.
I didn't backport that because it's an ABI change, so not appropriate
to change between minor releases (even for an experimental feature
like coroutines). PR 95917 was about suboptimal codegen; nobody
reported that there's a multiple definition error on Windows.
Yeah. This just happens to be the time I first came across the problem.
I know I should have started with a bug report on bugzilla, but I
thought I'd chance my arm.
That agrees with my recollection - the entity was marked as ‘weak’ so that
there should only be one instance in a linked exe. However, that did lead
to a complaint that object files then contained the weak entity any time
the
coroutine header was included.
Is there something more needed to support weak definitions for Windows?
Maybe! I don't know though -- the description of weak definitions in the
documentation doesn't seem to imply that multiple weak definitions are
allowed. Forgive me if I misunderstood.
I don’t think we should fix this for 10.3, but please report it to
bugzilla
and we can look into a fix for 10.4 (maybe with something specific to
Windows).
+1
Yes, I don't see any big urgency! I will construct a bugzilla report.
Maybe the downstreams will decide to do something in the meantime (e.g.,
my PR at MINGW-packeges [1]).
[1] https://github.com/msys2/MINGW-packages/pull/8263