[PATCH] D56574: [MergeFunc] Erase unused duplicate functions if they are discardable
Phabricator via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Fri Jan 11 10:00:32 PST 2019
This revision was automatically updated to reflect the committed changes.
Closed by commit rL350939: [MergeFunc] Erase unused duplicate functions if they are discardable (authored by vedantk, committed by ).
Changed prior to commit:
https://reviews.llvm.org/D56574?vs=181203&id=181303#toc
Repository:
rL LLVM
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D56574/new/
https://reviews.llvm.org/D56574
Files:
llvm/trunk/lib/Transforms/IPO/MergeFunctions.cpp
llvm/trunk/test/Transforms/MergeFunc/linkonce_odr.ll
Index: llvm/trunk/test/Transforms/MergeFunc/linkonce_odr.ll
===================================================================
--- llvm/trunk/test/Transforms/MergeFunc/linkonce_odr.ll
+++ llvm/trunk/test/Transforms/MergeFunc/linkonce_odr.ll
@@ -1,4 +1,4 @@
-; RUN: opt -S -mergefunc < %s | FileCheck %s
+; RUN: opt -S -mergefunc < %s | FileCheck %s -implicit-check-not=funC
; Replacments should be totally ordered on the function name.
; If we don't do this we can end up with one module defining a thunk for @funA
@@ -15,6 +15,13 @@
; CHECK-NEXT: tail call i32 @funA(i32 %0, i32 %1)
; CHECK-NEXT: ret
+define linkonce_odr i32 @funC(i32 %x, i32 %y) {
+ %sum = add i32 %x, %y
+ %sum2 = add i32 %x, %sum
+ %sum3 = add i32 %x, %sum2
+ ret i32 %sum3
+}
+
define linkonce_odr i32 @funB(i32 %x, i32 %y) {
%sum = add i32 %x, %y
%sum2 = add i32 %x, %sum
@@ -28,3 +35,8 @@
%sum3 = add i32 %x, %sum2
ret i32 %sum3
}
+
+; This creates a use of @funB, preventing -mergefunc from deleting it.
+; @funC, however, can safely be deleted as it has no uses, and is discardable
+; if unused.
+ at take_addr_of_funB = global i8* bitcast (i32 (i32, i32)* @funB to i8*)
Index: llvm/trunk/lib/Transforms/IPO/MergeFunctions.cpp
===================================================================
--- llvm/trunk/lib/Transforms/IPO/MergeFunctions.cpp
+++ llvm/trunk/lib/Transforms/IPO/MergeFunctions.cpp
@@ -845,7 +845,7 @@
// If G was internal then we may have replaced all uses of G with F. If so,
// stop here and delete G. There's no need for a thunk. (See note on
// MergeFunctionsPDI above).
- if (G->hasLocalLinkage() && G->use_empty() && !MergeFunctionsPDI) {
+ if (G->isDiscardableIfUnused() && G->use_empty() && !MergeFunctionsPDI) {
G->eraseFromParent();
++NumFunctionsMerged;
return;
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D56574.181303.patch
Type: text/x-patch
Size: 1843 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20190111/601ac78a/attachment.bin>
More information about the llvm-commits
mailing list