mirror of
https://github.com/RPCS3/llvm.git
synced 2024-12-14 15:39:06 +00:00
cc714e2142
The personality routine currently lives in the LandingPadInst. This isn't desirable because: - All LandingPadInsts in the same function must have the same personality routine. This means that each LandingPadInst beyond the first has an operand which produces no additional information. - There is ongoing work to introduce EH IR constructs other than LandingPadInst. Moving the personality routine off of any one particular Instruction and onto the parent function seems a lot better than have N different places a personality function can sneak onto an exceptional function. Differential Revision: http://reviews.llvm.org/D10429 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@239940 91177308-0d34-0410-b5e6-96231b3b80d8
73 lines
3.5 KiB
LLVM
73 lines
3.5 KiB
LLVM
; RUN: llc -O0 -relocation-model=pic < %s | FileCheck %s
|
|
target datalayout = "E-m:e-i64:64-n32:64"
|
|
target triple = "powerpc64-bgq-linux"
|
|
|
|
%"class.std::__1::__tree_node.130.151" = type { %"class.std::__1::__tree_node_base.base.128.149", %"class.boost::serialization::extended_type_info.129.150"* }
|
|
%"class.std::__1::__tree_node_base.base.128.149" = type <{ %"class.std::__1::__tree_end_node.127.148", %"class.std::__1::__tree_node_base.126.147"*, %"class.std::__1::__tree_node_base.126.147"*, i8 }>
|
|
%"class.std::__1::__tree_end_node.127.148" = type { %"class.std::__1::__tree_node_base.126.147"* }
|
|
%"class.std::__1::__tree_node_base.126.147" = type <{ %"class.std::__1::__tree_end_node.127.148", %"class.std::__1::__tree_node_base.126.147"*, %"class.std::__1::__tree_node_base.126.147"*, i8, [7 x i8] }>
|
|
%"class.boost::serialization::extended_type_info.129.150" = type { i32 (...)**, i32, i8* }
|
|
|
|
; Function Attrs: noinline
|
|
define void @_ZN5boost13serialization18extended_type_info4findEPKc() #0 align 2 personality i8* bitcast (i32 (...)* @__gxx_personality_v0 to i8*) {
|
|
entry:
|
|
br i1 undef, label %cond.true, label %cond.false
|
|
|
|
; CHECK: @_ZN5boost13serialization18extended_type_info4findEPKc
|
|
|
|
cond.true: ; preds = %entry
|
|
br label %cond.end
|
|
|
|
cond.false: ; preds = %entry
|
|
unreachable
|
|
; No predecessors!
|
|
br label %cond.end
|
|
|
|
cond.end: ; preds = %0, %cond.true
|
|
invoke void @_ZNKSt3__16__treeIPKN5boost13serialization18extended_type_infoENS2_6detail11key_compareENS_9allocatorIS5_EEE4findIS5_EENS_21__tree_const_iteratorIS5_PNS_11__tree_nodeIS5_PvEElEERKT_()
|
|
to label %_ZNKSt3__18multisetIPKN5boost13serialization18extended_type_infoENS2_6detail11key_compareENS_9allocatorIS5_EEE4findERKS5_.exit unwind label %lpad
|
|
|
|
_ZNKSt3__18multisetIPKN5boost13serialization18extended_type_infoENS2_6detail11key_compareENS_9allocatorIS5_EEE4findERKS5_.exit: ; preds = %cond.end
|
|
br label %invoke.cont
|
|
|
|
invoke.cont: ; preds = %_ZNKSt3__18multisetIPKN5boost13serialization18extended_type_infoENS2_6detail11key_compareENS_9allocatorIS5_EEE4findERKS5_.exit
|
|
%1 = load %"class.std::__1::__tree_node.130.151"*, %"class.std::__1::__tree_node.130.151"** undef, align 8
|
|
%cmp.i = icmp eq %"class.std::__1::__tree_node.130.151"* undef, %1
|
|
br label %invoke.cont.2
|
|
|
|
invoke.cont.2: ; preds = %invoke.cont
|
|
br i1 %cmp.i, label %if.then, label %if.end
|
|
|
|
if.then: ; preds = %invoke.cont.2
|
|
br label %cleanup
|
|
|
|
lpad: ; preds = %cond.end
|
|
%2 = landingpad { i8*, i32 }
|
|
cleanup
|
|
br label %eh.resume
|
|
|
|
if.end: ; preds = %invoke.cont.2
|
|
br label %invoke.cont.4
|
|
|
|
invoke.cont.4: ; preds = %if.end
|
|
br label %cleanup
|
|
|
|
cleanup: ; preds = %invoke.cont.4, %if.then
|
|
ret void
|
|
|
|
eh.resume: ; preds = %lpad
|
|
resume { i8*, i32 } undef
|
|
}
|
|
|
|
declare i32 @__gxx_personality_v0(...)
|
|
|
|
; Function Attrs: noinline
|
|
declare void @_ZNKSt3__16__treeIPKN5boost13serialization18extended_type_infoENS2_6detail11key_compareENS_9allocatorIS5_EEE4findIS5_EENS_21__tree_const_iteratorIS5_PNS_11__tree_nodeIS5_PvEElEERKT_() #0 align 2
|
|
|
|
attributes #0 = { noinline "target-cpu"="a2q" }
|
|
|
|
!llvm.module.flags = !{!0}
|
|
|
|
!0 = !{i32 1, !"PIC Level", i32 2}
|
|
|