The difference is that now we don't error on out-of-comdat access to
internal global values. We copy them instead. This seems to match the
expectation of COFF linkers (see pr25686).
Original message:
Start deciding earlier what to link.
A traditional linker is roughly split in symbol resolution and
"copying
stuff".
The two tasks are badly mixed in lib/Linker.
This starts splitting them apart.
With this patch there are no direct call to linkGlobalValueBody or
linkGlobalValueProto. Everything is linked via WapValue.
This also includes a few fixes:
* A GV goes undefined if the comdat is dropped (comdat11.ll).
* We error if an internal GV goes undefined (comdat13.ll).
* We don't link an unused comdat.
The first two match the behavior of an ELF linker. The second one is
equivalent to running globaldce on the input.
llvm-svn: 254418
23 lines
474 B
LLVM
23 lines
474 B
LLVM
; RUN: llvm-link %s -S -o - | FileCheck %s
|
|
|
|
$c = comdat any
|
|
@a = alias void (), void ()* @f
|
|
define internal void @f() comdat($c) {
|
|
ret void
|
|
}
|
|
|
|
; CHECK-DAG: $c = comdat any
|
|
; CHECK-DAG: @a = alias void (), void ()* @f
|
|
; CHECK-DAG: define internal void @f() comdat($c)
|
|
|
|
$f2 = comdat largest
|
|
define internal void @f2() comdat($f2) {
|
|
ret void
|
|
}
|
|
define void @f3() comdat($f2) {
|
|
ret void
|
|
}
|
|
|
|
; CHECK-DAG: $f2 = comdat largest
|
|
; CHECK-DAG: define internal void @f2() comdat {
|