summaryrefslogtreecommitdiffstats
path: root/clang/lib/CodeGen/CGException.cpp
diff options
context:
space:
mode:
authorReid Kleckner <reid@kleckner.net>2015-07-01 22:33:45 +0000
committerReid Kleckner <reid@kleckner.net>2015-07-01 22:33:45 +0000
commit698310b004f83e9b4300c1d1bbd53ead0bc7f77d (patch)
tree998505f6034bd551b619c7d9dc0f9b5f10be4638 /clang/lib/CodeGen/CGException.cpp
parent489759672814aab8af90985efef1d4812266e9a5 (diff)
downloadbcm5719-llvm-698310b004f83e9b4300c1d1bbd53ead0bc7f77d.tar.gz
bcm5719-llvm-698310b004f83e9b4300c1d1bbd53ead0bc7f77d.zip
[SEH] Update EmitCapturedLocals to match r241187
It was still using frameaddress(1) to get the parent FP, even though it had the value it wanted as a parameter. llvm-svn: 241199
Diffstat (limited to 'clang/lib/CodeGen/CGException.cpp')
-rw-r--r--clang/lib/CodeGen/CGException.cpp25
1 files changed, 11 insertions, 14 deletions
diff --git a/clang/lib/CodeGen/CGException.cpp b/clang/lib/CodeGen/CGException.cpp
index c1e7eae405f..d6913156794 100644
--- a/clang/lib/CodeGen/CGException.cpp
+++ b/clang/lib/CodeGen/CGException.cpp
@@ -1447,15 +1447,11 @@ void CodeGenFunction::EmitCapturedLocals(CodeGenFunction &ParentCGF,
llvm::Value *EntryEBP = nullptr;
llvm::Value *ParentFP;
- if (CGM.getTarget().getTriple().getArch() != llvm::Triple::x86) {
- // On x64, the parent FP is passed as the second argument.
- auto AI = CurFn->arg_begin();
- ++AI;
- ParentFP = AI;
- } else {
- // The end of the EH registration is passed in as the EBP physical register.
- // We can recover that with llvm.frameaddress(1), and adjust that to
- // recover the parent's true frame pointer.
+ if (IsFilter && CGM.getTarget().getTriple().getArch() == llvm::Triple::x86) {
+ // 32-bit SEH filters need to be careful about FP recovery. The end of the
+ // EH registration is passed in as the EBP physical register. We can
+ // recover that with llvm.frameaddress(1), and adjust that to recover the
+ // parent's true frame pointer.
CGBuilderTy Builder(AllocaInsertPt);
EntryEBP = Builder.CreateCall(
CGM.getIntrinsic(llvm::Intrinsic::frameaddress), {Builder.getInt32(1)});
@@ -1464,11 +1460,12 @@ void CodeGenFunction::EmitCapturedLocals(CodeGenFunction &ParentCGF,
llvm::Constant *ParentI8Fn =
llvm::ConstantExpr::getBitCast(ParentCGF.CurFn, Int8PtrTy);
ParentFP = Builder.CreateCall(RecoverFPIntrin, {ParentI8Fn, EntryEBP});
-
- // Inlining will break llvm.frameaddress(1), so disable it.
- // FIXME: We could teach the inliner about the special meaning of
- // frameaddress, framerecover, and frameescape to remove this limitation.
- CurFn->addFnAttr(llvm::Attribute::NoInline);
+ } else {
+ // Otherwise, for x64 and 32-bit finally functions, the parent FP is the
+ // second parameter.
+ auto AI = CurFn->arg_begin();
+ ++AI;
+ ParentFP = AI;
}
// Create llvm.framerecover calls for all captures.
OpenPOWER on IntegriCloud