From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from nikam.ms.mff.cuni.cz (nikam.ms.mff.cuni.cz [195.113.20.16]) by sourceware.org (Postfix) with ESMTPS id 3ACA53858D20 for ; Wed, 17 Apr 2024 14:34:09 +0000 (GMT) DMARC-Filter: OpenDMARC Filter v1.4.2 sourceware.org 3ACA53858D20 Authentication-Results: sourceware.org; dmarc=fail (p=none dis=none) header.from=ucw.cz Authentication-Results: sourceware.org; spf=pass smtp.mailfrom=kam.mff.cuni.cz ARC-Filter: OpenARC Filter v1.0.0 sourceware.org 3ACA53858D20 Authentication-Results: server2.sourceware.org; arc=none smtp.remote-ip=195.113.20.16 ARC-Seal: i=1; a=rsa-sha256; d=sourceware.org; s=key; t=1713364452; cv=none; b=GU9X+s5uNHw5UU1MYaGQs+FtLSZAGzOnFqfjuC58dlUkqqU1Ru3aSosrzAy6wgboqbjn3P+i/8jG6rn4xOc/KkagNHBTRX0kbvi3nk4E2PFzMwIP31yOANj4Epc2Ba0A0uJPm0QRkPCgaTI8V57DArsQk4zkB5Ly5zZy35T6pX0= ARC-Message-Signature: i=1; a=rsa-sha256; d=sourceware.org; s=key; t=1713364452; c=relaxed/simple; bh=uX+k6eEnbMwIZwqez6Wc0afCyZCFjVpiqm8vznmZ9AA=; h=DKIM-Signature:Date:From:To:Subject:Message-ID:MIME-Version; b=t7/4k1DV2s5IRWKVK11FdQfgz3AtKYnooRx5gJlxk6qtFHG67vMkakcWCccKVHlRHgCm/iKLBo7DepopHqf3812sDrHMTWC8oDXm4gAowFU9soznku9MsPPDahpp5IGKKzMrF1xg7QX/nYjwt+dnQRUFdJ1uBlcBV5KiOEBHCsE= ARC-Authentication-Results: i=1; server2.sourceware.org Received: by nikam.ms.mff.cuni.cz (Postfix, from userid 16202) id 0548A284E6E; Wed, 17 Apr 2024 16:34:07 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ucw.cz; s=gen1; t=1713364448; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: in-reply-to:in-reply-to:references:references; bh=JHERMxE+lcqpiGnz3vlgXzQxLcPCCEvGr/XmYCV7nEk=; b=ApCz5kNBKhLoqELi1Fq4SkD++dK68uvlQbWwg/NO/OCfjdmMiJkh8ChD8xlkVzwbndi2ZM UOynsd1xoZhgw/p3qBT/dD2ww8zvVzE5xqA7BTdHDuMOTeRs7jRN6UhbXfsIekS/cvpLYI P4PQWiiv/ZSf6iDlcIAGbDXIxjKkFQM= Date: Wed, 17 Apr 2024 16:34:07 +0200 From: Jan Hubicka To: Jakub Jelinek Cc: Jason Merrill , Richard Biener , Patrick Palka , gcc-patches@gcc.gnu.org Subject: Re: [PATCH] c++: Retry the aliasing of base/complete cdtor optimization at import_export_decl time [PR113208] Message-ID: References: MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: X-Spam-Status: No, score=-4.6 required=5.0 tests=BAYES_00,DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,JMQ_SPF_NEUTRAL,RCVD_IN_MSPIKE_H3,RCVD_IN_MSPIKE_WL,SPF_HELO_NONE,SPF_PASS,TXREP autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on server2.sourceware.org List-Id: > > Ah, you're right. > If I compile (the one line modified) pr113208_0.C with > -O -fno-early-inlining -fdisable-ipa-inline -std=c++20 > it does have just _ZN6vectorI12QualityValueEC2ERKS1_ in _ZN6vectorI12QualityValueEC2ERKS1_ > comdat and no _ZN6vectorI12QualityValueEC1ERKS1_ > and pr113208_1.C with -O -fno-early-inlining -fdisable-ipa-inline -std=c++20 -fno-omit-frame-pointer > and link that together with the above mentioned third *.C file, I see > 000000000040112a <_ZN6vectorI12QualityValueEC2ERKS1_>: > 40112a: 53 push %rbx > 40112b: 48 89 fb mov %rdi,%rbx > 40112e: 48 89 f7 mov %rsi,%rdi > 401131: e8 9c 00 00 00 call 4011d2 <_ZNK12_Vector_baseI12QualityValueE1gEv> > 401136: 89 c2 mov %eax,%edx > 401138: be 01 00 00 00 mov $0x1,%esi > 40113d: 48 89 df mov %rbx,%rdi > 401140: e8 7b 00 00 00 call 4011c0 <_ZN12_Vector_baseI12QualityValueEC1Eii> > 401145: 5b pop %rbx > 401146: c3 ret > i.e. the C2 prevailing from pr113208_0.s where it is the only symbol, and > 0000000000401196 <_ZN6vectorI12QualityValueEC1ERKS1_>: > 401196: 55 push %rbp > 401197: 48 89 e5 mov %rsp,%rbp > 40119a: 53 push %rbx > 40119b: 48 83 ec 08 sub $0x8,%rsp > 40119f: 48 89 fb mov %rdi,%rbx > 4011a2: 48 89 f7 mov %rsi,%rdi > 4011a5: e8 28 00 00 00 call 4011d2 <_ZNK12_Vector_baseI12QualityValueE1gEv> > 4011aa: 89 c2 mov %eax,%edx > 4011ac: be 01 00 00 00 mov $0x1,%esi > 4011b1: 48 89 df mov %rbx,%rdi > 4011b4: e8 07 00 00 00 call 4011c0 <_ZN12_Vector_baseI12QualityValueEC1Eii> > 4011b9: 48 8b 5d f8 mov -0x8(%rbp),%rbx > 4011bd: c9 leave > 4011be: c3 ret > which is the C1 alias originally aliased to C2 in C5 comdat. > So, that would match linker behavior where it sees C1 -> C2 alias prevails, > but a different version of C2 prevails, so let's either make C1 a non-alias > or alias to a non-exported symbol or something like that. Yep, I think the linker simply handles the C2 symbol as weak symbol and after it decides to keep both comdat section (C2 and C5) the C5's weak symbol is prevailed by C2. I wrote patch doing the same with LTO - we need to handle alias references specially and do not update them according to the resolution info and then look for prevailed symbols which have aliases and turn them to static symbols. I think for most scenarios this is OK, but I am not sure about incremental linking (both LTO and non-LTO). What seems wrong is that we produce C5 comdat that is not exporting what it should and thus breaking the invariant that in valid code all comdats of same name are semantically equivalent. Perhaps it makes no difference since this scenario is pretty special and we know that the functions are semantically equivalent and their addresses are never compared for equality (at least I failed to produce some useful testcase). Honza