[PATCH] D33571: PMB: Run the whole-program-devirt pass during LTO at --lto-O0.

Peter Collingbourne via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Fri May 26 11:27:31 PDT 2017


This revision was automatically updated to reflect the committed changes.
Closed by commit rL304019: PMB: Run the whole-program-devirt pass during LTO at --lto-O0. (authored by pcc).

Changed prior to commit:
  https://reviews.llvm.org/D33571?vs=100343&id=100439#toc

Repository:
  rL LLVM

https://reviews.llvm.org/D33571

Files:
  llvm/trunk/lib/Transforms/IPO/PassManagerBuilder.cpp
  llvm/trunk/test/LTO/Resolution/X86/type-checked-load.ll


Index: llvm/trunk/lib/Transforms/IPO/PassManagerBuilder.cpp
===================================================================
--- llvm/trunk/lib/Transforms/IPO/PassManagerBuilder.cpp
+++ llvm/trunk/lib/Transforms/IPO/PassManagerBuilder.cpp
@@ -913,6 +913,12 @@
 
   if (OptLevel != 0)
     addLTOOptimizationPasses(PM);
+  else {
+    // The whole-program-devirt pass needs to run at -O0 because only it knows
+    // about the llvm.type.checked.load intrinsic: it needs to both lower the
+    // intrinsic itself and handle it in the summary.
+    PM.add(createWholeProgramDevirtPass(ExportSummary, nullptr));
+  }
 
   // Create a function that performs CFI checks for cross-DSO calls with targets
   // in the current module.
Index: llvm/trunk/test/LTO/Resolution/X86/type-checked-load.ll
===================================================================
--- llvm/trunk/test/LTO/Resolution/X86/type-checked-load.ll
+++ llvm/trunk/test/LTO/Resolution/X86/type-checked-load.ll
@@ -0,0 +1,16 @@
+; RUN: llvm-as -o %t %s
+; RUN: llvm-lto2 run %t -O0 -r %t,foo,px -o %t2
+
+; This just tests that we don't crash when compiling this test case.
+; It means that the wholeprogramdevirt pass must have run and lowered
+; the llvm.type.checked.load call.
+
+target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
+target triple = "x86_64-unknown-linux-gnu"
+
+define {i8*, i1} @foo(i8* %ptr) {
+  %pair = call {i8*, i1} @llvm.type.checked.load(i8* %ptr, i32 16, metadata !"foo")
+  ret {i8*, i1} %pair
+}
+
+declare {i8*, i1} @llvm.type.checked.load(i8* %ptr, i32 %offset, metadata %type)


-------------- next part --------------
A non-text attachment was scrubbed...
Name: D33571.100439.patch
Type: text/x-patch
Size: 1591 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20170526/3342f6e4/attachment.bin>


More information about the llvm-commits mailing list