summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorAdrian Prantl <aprantl@apple.com>2015-07-06 16:36:02 +0000
committerAdrian Prantl <aprantl@apple.com>2015-07-06 16:36:02 +0000
commit4276d4a8d08b7640eb57cabf6988a5cf65b228b6 (patch)
treeadf57de33acf99c026e27666afc5710ea107deee /llvm/lib
parentfbdab437f01fea995c6778b62444ea57bfe25a66 (diff)
downloadbcm5719-llvm-4276d4a8d08b7640eb57cabf6988a5cf65b228b6.tar.gz
bcm5719-llvm-4276d4a8d08b7640eb57cabf6988a5cf65b228b6.zip
DIBuilder: Don't rauw null pointers with empty arrays in finalize().
This makes the IR a little easier to read. llvm-svn: 241470
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/IR/DIBuilder.cpp18
1 files changed, 12 insertions, 6 deletions
diff --git a/llvm/lib/IR/DIBuilder.cpp b/llvm/lib/IR/DIBuilder.cpp
index 1aa7685b629..453ea00a003 100644
--- a/llvm/lib/IR/DIBuilder.cpp
+++ b/llvm/lib/IR/DIBuilder.cpp
@@ -90,10 +90,14 @@ void DIBuilder::finalize() {
for (unsigned I = 0, E = AllRetainTypes.size(); I < E; I++)
if (RetainSet.insert(AllRetainTypes[I]).second)
RetainValues.push_back(AllRetainTypes[I]);
- CUNode->replaceRetainedTypes(MDTuple::get(VMContext, RetainValues));
+
+ if (!RetainValues.empty())
+ CUNode->replaceRetainedTypes(MDTuple::get(VMContext, RetainValues));
DISubprogramArray SPs = MDTuple::get(VMContext, AllSubprograms);
- CUNode->replaceSubprograms(SPs.get());
+ if (!AllSubprograms.empty())
+ CUNode->replaceSubprograms(SPs.get());
+
for (auto *SP : SPs) {
if (MDTuple *Temp = SP->getVariables().get()) {
const auto &PV = PreservedVariables.lookup(SP);
@@ -103,11 +107,13 @@ void DIBuilder::finalize() {
}
}
- CUNode->replaceGlobalVariables(MDTuple::get(VMContext, AllGVs));
+ if (!AllGVs.empty())
+ CUNode->replaceGlobalVariables(MDTuple::get(VMContext, AllGVs));
- CUNode->replaceImportedEntities(MDTuple::get(
- VMContext, SmallVector<Metadata *, 16>(AllImportedModules.begin(),
- AllImportedModules.end())));
+ if (!AllImportedModules.empty())
+ CUNode->replaceImportedEntities(MDTuple::get(
+ VMContext, SmallVector<Metadata *, 16>(AllImportedModules.begin(),
+ AllImportedModules.end())));
// Now that all temp nodes have been replaced or deleted, resolve remaining
// cycles.
OpenPOWER on IntegriCloud