llvm-project/llvm/test/Linker/comdat-nodeduplicate.ll
Fangrui Song 01152626ab [Linker] Handle comdat nodeduplicate
For a variable in a comdat nodeduplicate, its initializer may be significant.
E.g. its content may be implicitly referenced by another comdat member (or
required to parallel to another comdat member by the runtime when explicit
section is used). We can clone it into an unnamed private linkage variable to
preserve its content.

This partially fixes PR51394 (Sony's proprietary linker using LTO): no error
will be reported. This is partial because we do not guarantee the global
variable order if the runtime has parallel section requirement.

---

There is a similar issue for regular LTO, but unrelated to PR51394:

with lib/LTO (using either ld.lld or LLVMgold.so), linking two modules
with a weak function of the same name, can leave one weak profc and two
private profd, due to lib/LTO's current deficiency that it mixes the two
concepts together: comdat selection and symbol resolution. If the issue
is considered important, we should suppress private profd for the weak+
regular LTO case.

Reviewed By: phosek

Differential Revision: https://reviews.llvm.org/D108879
2021-08-31 22:32:20 -07:00

45 lines
1.5 KiB
LLVM

; RUN: rm -rf %t && split-file %s %t
; RUN: not llvm-link -S %t/1.ll %t/1-aux.ll 2>&1 | FileCheck %s
; CHECK: Linking globals named 'foo': symbol multiply defined!
; RUN: llvm-link -S %t/2.ll %t/2-aux.ll | FileCheck %s --check-prefix=CHECK2
; RUN: llvm-link -S %t/2-aux.ll %t/2.ll | FileCheck %s --check-prefix=CHECK2
; CHECK2-DAG: @[[#]] = private global i64 0, section "data", comdat($foo)
; CHECK2-DAG: @[[#]] = private global i64 0, section "cnts", comdat($foo)
; CHECK2-DAG: @foo = hidden global i64 2, section "data", comdat, align 8
; CHECK2-DAG: @bar = dso_local global i64 3, section "cnts", comdat($foo), align 16
; CHECK2-DAG: @qux = weak_odr global i64 4, comdat($foo)
; CHECK2-DAG: @fred = linkonce global i64 5, comdat($foo)
; RUN: llvm-link -S %t/non-var.ll %t/non-var.ll 2>&1 | FileCheck %s --check-prefix=NONVAR
; NONVAR: linking 'foo': non-variables in comdat nodeduplicate are not handled
;--- 1.ll
$foo = comdat nodeduplicate
@foo = global i64 43, comdat($foo)
;--- 1-aux.ll
$foo = comdat nodeduplicate
@foo = global i64 43, comdat($foo)
;--- 2.ll
$foo = comdat nodeduplicate
@foo = global i64 2, section "data", comdat($foo), align 8
@bar = weak global i64 0, section "cnts", comdat($foo)
@qux = weak_odr global i64 4, comdat($foo)
;--- 2-aux.ll
$foo = comdat nodeduplicate
@foo = weak hidden global i64 0, section "data", comdat($foo)
@bar = dso_local global i64 3, section "cnts", comdat($foo), align 16
@fred = linkonce global i64 5, comdat($foo)
;--- non-var.ll
$foo = comdat nodeduplicate
define weak void @foo() comdat {
ret void
}