]> granicus.if.org Git - llvm/commitdiff
ThinLTOBitcodeWriter: Strip debug info from merged module.
authorPeter Collingbourne <peter@pcc.me.uk>
Wed, 8 Feb 2017 20:44:00 +0000 (20:44 +0000)
committerPeter Collingbourne <peter@pcc.me.uk>
Wed, 8 Feb 2017 20:44:00 +0000 (20:44 +0000)
This module will contain nothing but vtable definitions and (soon)
available_externally function definitions, so there is no point in keeping
debug info in the module.

Differential Revision: https://reviews.llvm.org/D28913

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@294511 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Transforms/IPO/ThinLTOBitcodeWriter.cpp
test/Transforms/ThinLTOBitcodeWriter/split.ll

index 6ec69e32198012f10103b77964dac4184dbf139c..74fada5b45845f3e16ae582025a12f9ade90acd4 100644 (file)
@@ -19,6 +19,7 @@
 #include "llvm/Analysis/TypeMetadataUtils.h"
 #include "llvm/Bitcode/BitcodeWriter.h"
 #include "llvm/IR/Constants.h"
+#include "llvm/IR/DebugInfo.h"
 #include "llvm/IR/Intrinsics.h"
 #include "llvm/IR/Module.h"
 #include "llvm/IR/PassManager.h"
@@ -261,6 +262,7 @@ void splitAndWriteThinLTOBitcode(raw_ostream &OS, Module &M) {
 
   ValueToValueMapTy VMap;
   std::unique_ptr<Module> MergedM(CloneModule(&M, VMap, IsInMergedM));
+  StripDebugInfo(*MergedM);
 
   filterModule(&M, [&](const GlobalValue *GV) { return !IsInMergedM(GV); });
 
index b86d7017c8bbe83988ad11d55371efc136fa9065..98799a2c01fbd5842c7829784cbca76e5e8068ab 100644 (file)
@@ -26,3 +26,10 @@ define i8* @f() {
 
 ; M1: !0 = !{i32 0, !"typeid"}
 !0 = !{i32 0, !"typeid"}
+
+; M0: !llvm.dbg.cu
+; M1-NOT: !llvm.dbg.cu
+!llvm.dbg.cu = !{}
+
+!1 = !{i32 2, !"Debug Info Version", i32 3}
+!llvm.module.flags = !{!1}