summaryrefslogtreecommitdiffstats
path: root/llvm
diff options
context:
space:
mode:
authorJoseph Tremoulet <jotrem@microsoft.com>2015-10-17 00:08:08 +0000
committerJoseph Tremoulet <jotrem@microsoft.com>2015-10-17 00:08:08 +0000
commit55b51e9dccd1328995b410772f24be3973a122a2 (patch)
treee7e8cc40a79ed9cfa8288e8a848cb991bf4a1f48 /llvm
parentce10cec56a83c415409bbeb0bce5d5dd9ac5cf64 (diff)
downloadbcm5719-llvm-55b51e9dccd1328995b410772f24be3973a122a2.tar.gz
bcm5719-llvm-55b51e9dccd1328995b410772f24be3973a122a2.zip
[WinEH] Fix eh.exceptionpointer intrinsic lowering
Summary: Some shared code for handling eh.exceptionpointer and eh.exceptioncode needs to not share the part that truncates to 32 bits, which is intended just for exception codes. Reviewers: rnk Subscribers: llvm-commits Differential Revision: http://reviews.llvm.org/D13747 llvm-svn: 250588
Diffstat (limited to 'llvm')
-rw-r--r--llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp3
-rw-r--r--llvm/test/CodeGen/WinEH/wineh-exceptionpointer.ll28
2 files changed, 30 insertions, 1 deletions
diff --git a/llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp b/llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp
index 3f061f3150d..cd4ef362d47 100644
--- a/llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp
+++ b/llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp
@@ -5258,7 +5258,8 @@ SelectionDAGBuilder::visitIntrinsicCall(const CallInst &I, unsigned Intrinsic) {
unsigned VReg = FuncInfo.getCatchPadExceptionPointerVReg(CPI, PtrRC);
SDValue N =
DAG.getCopyFromReg(DAG.getEntryNode(), getCurSDLoc(), VReg, PtrVT);
- N = DAG.getZExtOrTrunc(N, getCurSDLoc(), MVT::i32);
+ if (Intrinsic == Intrinsic::eh_exceptioncode)
+ N = DAG.getZExtOrTrunc(N, getCurSDLoc(), MVT::i32);
setValue(&I, N);
return nullptr;
}
diff --git a/llvm/test/CodeGen/WinEH/wineh-exceptionpointer.ll b/llvm/test/CodeGen/WinEH/wineh-exceptionpointer.ll
new file mode 100644
index 00000000000..05139ef1bd9
--- /dev/null
+++ b/llvm/test/CodeGen/WinEH/wineh-exceptionpointer.ll
@@ -0,0 +1,28 @@
+; RUN: llc -mtriple=x86_64-pc-windows-coreclr < %s | FileCheck %s
+
+declare void @ProcessCLRException()
+declare i8 addrspace(1)* @llvm.eh.exceptionpointer.p1i8(token)
+declare void @f()
+declare void @g(i32 addrspace(1)*)
+
+; CHECK-LABEL: test1: # @test1
+define void @test1() personality i8* bitcast (void ()* @ProcessCLRException to i8*) {
+entry:
+ invoke void @f()
+ to label %exit unwind label %catch.pad
+catch.pad:
+; CHECK: {{^[^: ]+}}: # %catch.pad
+ %catch = catchpad [i32 5]
+ to label %catch.body unwind label %catch.end
+catch.body:
+ %exn = call i8 addrspace(1)* @llvm.eh.exceptionpointer.p1i8(token %catch)
+ %cast_exn = bitcast i8 addrspace(1)* %exn to i32 addrspace(1)*
+ ; CHECK: movq %rax, %rcx
+ ; CHECK-NEXT: callq g
+ call void @g(i32 addrspace(1)* %cast_exn)
+ catchret %catch to label %exit
+catch.end:
+ catchendpad unwind to caller
+exit:
+ ret void
+}
OpenPOWER on IntegriCloud