[PATCH] D15798: Fix for Bug 24852 (crash with -debug -instcombine)
Than McIntosh via llvm-commits
llvm-commits at lists.llvm.org
Thu Jan 7 09:11:49 PST 2016
thanm updated this revision to Diff 44221.
thanm added a comment.
Reduced unit test based on guidance from joker.eph.
http://reviews.llvm.org/D15798
Files:
lib/IR/AsmWriter.cpp
unittests/IR/AsmWriterTest.cpp
unittests/IR/CMakeLists.txt
Index: unittests/IR/CMakeLists.txt
===================================================================
--- unittests/IR/CMakeLists.txt
+++ unittests/IR/CMakeLists.txt
@@ -6,6 +6,7 @@
)
set(IRSources
+ AsmWriterTest.cpp
AttributesTest.cpp
ConstantRangeTest.cpp
ConstantsTest.cpp
Index: unittests/IR/AsmWriterTest.cpp
===================================================================
--- /dev/null
+++ unittests/IR/AsmWriterTest.cpp
@@ -0,0 +1,35 @@
+//===- llvm/unittest/IR/AsmWriter.cpp - AsmWriter tests -------------------===//
+//
+// The LLVM Compiler Infrastructure
+//
+// This file is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+#include "llvm/IR/IRBuilder.h"
+#include "llvm/IR/Function.h"
+#include "llvm/IR/LLVMContext.h"
+#include "llvm/IR/MDBuilder.h"
+#include "llvm/IR/Module.h"
+#include "gtest/gtest.h"
+
+using namespace llvm;
+
+namespace {
+
+TEST(AsmWriterTest, DebugPrintDetachedInstruction) {
+
+ // PR24852: Ensure that an instruction can be printed even when it
+ // has no parent.
+ LLVMContext Ctx;
+ auto Ty = Type::getInt32Ty(Ctx);
+ auto Undef = UndefValue::get(Ty);
+ std::unique_ptr<BinaryOperator> Add(BinaryOperator::CreateAdd(Undef, Undef));
+ Add->setDebugLoc(DebugLoc());
+ std::string S;
+ raw_string_ostream OS(S);
+ Add->print(OS);
+ EXPECT_EQ(OS.str(), " <badref> = add i32 undef, undef");
+}
+
+}
Index: lib/IR/AsmWriter.cpp
===================================================================
--- lib/IR/AsmWriter.cpp
+++ lib/IR/AsmWriter.cpp
@@ -3148,7 +3148,7 @@
if (MDs.empty())
return;
- if (MDNames.empty())
+ if (TheModule && MDNames.empty())
TheModule->getMDKindNames(MDNames);
for (const auto &I : MDs) {
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D15798.44221.patch
Type: text/x-patch
Size: 1868 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20160107/e4e4341b/attachment.bin>
More information about the llvm-commits
mailing list