[PATCH] D60231: Include invoke'd functions for recursive extract
David Callahan via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Thu Apr 4 14:25:07 PDT 2019
david2050 updated this revision to Diff 193784.
david2050 added a comment.
use CallBase
Repository:
rL LLVM
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D60231/new/
https://reviews.llvm.org/D60231
Files:
test/tools/llvm-extract/recursive.ll
tools/llvm-extract/llvm-extract.cpp
Index: tools/llvm-extract/llvm-extract.cpp
===================================================================
--- tools/llvm-extract/llvm-extract.cpp
+++ tools/llvm-extract/llvm-extract.cpp
@@ -270,10 +270,11 @@
ExitOnErr(F->materialize());
for (auto &BB : *F) {
for (auto &I : BB) {
- auto *CI = dyn_cast<CallInst>(&I);
- if (!CI)
+ Function *CF = nullptr;
+ CallBase *CB = dyn_cast<CallBase>(&I);
+ if (!CB)
continue;
- Function *CF = CI->getCalledFunction();
+ CF = CB->getCalledFunction();
if (!CF)
continue;
if (CF->isDeclaration() || GVs.count(CF))
Index: test/tools/llvm-extract/recursive.ll
===================================================================
--- test/tools/llvm-extract/recursive.ll
+++ test/tools/llvm-extract/recursive.ll
@@ -1,6 +1,7 @@
; RUN: llvm-extract -func=a --recursive %s -S | FileCheck --check-prefix=CHECK-AB %s
; RUN: llvm-extract -func=a --recursive --delete %s -S | FileCheck --check-prefix=CHECK-CD %s
; RUN: llvm-extract -func=d --recursive %s -S | FileCheck --check-prefix=CHECK-CD %s
+; RUN: llvm-extract -func=e --recursive %s -S | FileCheck --check-prefix=CHECK-CD %s
; CHECK-AB: define void @a
; CHECK-AB: define void @b
@@ -30,3 +31,10 @@
call void @c()
ret void
}
+
+define void @e() {
+ invoke void @c()
+ to label %L unwind label %L
+L:
+ ret void
+}
\ No newline at end of file
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D60231.193784.patch
Type: text/x-patch
Size: 1483 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20190404/1fea7e5b/attachment-0001.bin>
More information about the llvm-commits
mailing list