Restore "Move metadata linking after lazy global materialization/linking."
authorTeresa Johnson <tejohnson@google.com>
Fri, 6 Nov 2015 17:50:53 +0000 (17:50 +0000)
committerTeresa Johnson <tejohnson@google.com>
Fri, 6 Nov 2015 17:50:53 +0000 (17:50 +0000)
commit99ee897f5441f6bc2d70ef24f92cd9c37269cd41
treef7f6bd67cdcea594b898b950260bd54f582e4253
parent46c7bcb5d1c405996dbc82cb38cdbc1207626f0a
Restore "Move metadata linking after lazy global materialization/linking."

Summary:
This reverts commit r251965.

Restore "Move metadata linking after lazy global materialization/linking."

This restores commit r251926, with fixes for the LTO bootstrapping bot
failure.

The bot failure was caused by references from debug metadata to
otherwise unreferenced globals. Previously, this caused the lazy linking
to link in their defs, which is unnecessary. With this patch, because
lazy linking is complete when we encounter the metadata reference, the
materializer created a declaration. For definitions such as aliases and
comdats, it is illegal to have a declaration. Furthermore, metadata
linking should not change code generation. Therefore, when linking of
global value bodies is complete, the materializer will simply return
nullptr as the new reference for the linked metadata.

This change required fixing a different test to ensure there was a
real reference to a linkonce global that was only being reference from
metadata.

Note that the new changes to the only-needed-named-metadata.ll test
illustrate an issue with llvm-link -only-needed handling of comdat
groups, whereby it may result in an incomplete comdat group. I note this
in the test comments, but the issue is orthogonal to this patch (it can
be reproduced without any metadata at head).

Reviewers: dexonsmith, rafael, tra

Subscribers: tobiasvk, joker.eph, llvm-commits

Differential Revision: http://reviews.llvm.org/D14447

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@252320 91177308-0d34-0410-b5e6-96231b3b80d8
lib/Linker/LinkModules.cpp
test/Linker/Inputs/only-needed-named-metadata.ll
test/Linker/distinct.ll
test/Linker/only-needed-named-metadata.ll