summaryrefslogtreecommitdiff
path: root/tools/llvm-c-test
diff options
context:
space:
mode:
authorAmaury Sechet <deadalnix@gmail.com>2016-02-18 20:38:32 +0000
committerAmaury Sechet <deadalnix@gmail.com>2016-02-18 20:38:32 +0000
commit10ae0ad5058f87605399288b1a78932d4a072378 (patch)
tree4fa3c0ec404c5ea0563f33cf0da2431b23154245 /tools/llvm-c-test
parent1dddbb710649c5338f68e64e20be6abe359b3c89 (diff)
Add support for invoke/landingpad/resume in C API test
Summary: As per title. There was a lot of part missing in the C API, so I had to extend the invoke and landingpad API. Reviewers: echristo, joker.eph, Wallbraker Subscribers: llvm-commits Differential Revision: http://reviews.llvm.org/D17359 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@261254 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'tools/llvm-c-test')
-rw-r--r--tools/llvm-c-test/echo.cpp36
1 files changed, 35 insertions, 1 deletions
diff --git a/tools/llvm-c-test/echo.cpp b/tools/llvm-c-test/echo.cpp
index 229530155fc..35c73e22fbc 100644
--- a/tools/llvm-c-test/echo.cpp
+++ b/tools/llvm-c-test/echo.cpp
@@ -388,8 +388,19 @@ struct FunCloner {
}
case LLVMSwitch:
case LLVMIndirectBr:
- case LLVMInvoke:
break;
+ case LLVMInvoke: {
+ SmallVector<LLVMValueRef, 8> Args;
+ int ArgCount = LLVMGetNumArgOperands(Src);
+ for (int i = 0; i < ArgCount; i++)
+ Args.push_back(CloneValue(LLVMGetOperand(Src, i)));
+ LLVMValueRef Fn = CloneValue(LLVMGetCalledValue(Src));
+ LLVMBasicBlockRef Then = DeclareBB(LLVMGetNormalDest(Src));
+ LLVMBasicBlockRef Unwind = DeclareBB(LLVMGetUnwindDest(Src));
+ Dst = LLVMBuildInvoke(Builder, Fn, Args.data(), ArgCount,
+ Then, Unwind, Name);
+ break;
+ }
case LLVMUnreachable:
Dst = LLVMBuildUnreachable(Builder);
break;
@@ -536,6 +547,20 @@ struct FunCloner {
Args.push_back(CloneValue(LLVMGetOperand(Src, i)));
LLVMValueRef Fn = CloneValue(LLVMGetCalledValue(Src));
Dst = LLVMBuildCall(Builder, Fn, Args.data(), ArgCount, Name);
+ LLVMSetTailCall(Dst, LLVMIsTailCall(Src));
+ break;
+ }
+ case LLVMResume: {
+ Dst = LLVMBuildResume(Builder, CloneValue(LLVMGetOperand(Src, 0)));
+ break;
+ }
+ case LLVMLandingPad: {
+ // The landing pad API is a bit screwed up for historical reasons.
+ Dst = LLVMBuildLandingPad(Builder, CloneType(Src), nullptr, 0, Name);
+ unsigned NumClauses = LLVMGetNumClauses(Src);
+ for (unsigned i = 0; i < NumClauses; ++i)
+ LLVMAddClause(Dst, CloneValue(LLVMGetClause(Src, i)));
+ LLVMSetCleanup(Dst, LLVMIsCleanup(Src));
break;
}
case LLVMExtractValue: {
@@ -788,6 +813,15 @@ FunClone:
LLVMValueRef Fun = LLVMGetNamedFunction(M, Name);
if (!Fun)
report_fatal_error("Function must have been declared already");
+
+ if (LLVMHasPersonalityFn(Cur)) {
+ const char *FName = LLVMGetValueName(LLVMGetPersonalityFn(Cur));
+ LLVMValueRef P = LLVMGetNamedFunction(M, FName);
+ if (!P)
+ report_fatal_error("Could not find personality function");
+ LLVMSetPersonalityFn(Fun, P);
+ }
+
FunCloner FC(Cur, Fun);
FC.CloneBBs(Cur);