[ARM] More MVE compare vector splat combines for ANDs
[llvm-complete.git] / test / CodeGen / PowerPC / fast-isel-icmp-split.ll
blobfdd0fc27678036a5de955aa5e9c3a4768b7ecbc0
1 ; RUN: llc -verify-machineinstrs -O0 -relocation-model=pic < %s | FileCheck %s
2 target datalayout = "E-m:e-i64:64-n32:64"
3 target triple = "powerpc64-bgq-linux"
5 %"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"* }
6 %"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 }>
7 %"class.std::__1::__tree_end_node.127.148" = type { %"class.std::__1::__tree_node_base.126.147"* }
8 %"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] }>
9 %"class.boost::serialization::extended_type_info.129.150" = type { i32 (...)**, i32, i8* }
11 ; Function Attrs: noinline
12 define void @_ZN5boost13serialization18extended_type_info4findEPKc() #0 align 2 personality i8* bitcast (i32 (...)* @__gxx_personality_v0 to i8*) {
13 entry:
14   br i1 undef, label %cond.true, label %cond.false
16 ; CHECK: @_ZN5boost13serialization18extended_type_info4findEPKc
18 cond.true:                                        ; preds = %entry
19   br label %cond.end
21 cond.false:                                       ; preds = %entry
22   unreachable
23                                                   ; No predecessors!
24   br label %cond.end
26 cond.end:                                         ; preds = %0, %cond.true
27   invoke void @_ZNKSt3__16__treeIPKN5boost13serialization18extended_type_infoENS2_6detail11key_compareENS_9allocatorIS5_EEE4findIS5_EENS_21__tree_const_iteratorIS5_PNS_11__tree_nodeIS5_PvEElEERKT_()
28           to label %_ZNKSt3__18multisetIPKN5boost13serialization18extended_type_infoENS2_6detail11key_compareENS_9allocatorIS5_EEE4findERKS5_.exit unwind label %lpad
30 _ZNKSt3__18multisetIPKN5boost13serialization18extended_type_infoENS2_6detail11key_compareENS_9allocatorIS5_EEE4findERKS5_.exit: ; preds = %cond.end
31   br label %invoke.cont
33 invoke.cont:                                      ; preds = %_ZNKSt3__18multisetIPKN5boost13serialization18extended_type_infoENS2_6detail11key_compareENS_9allocatorIS5_EEE4findERKS5_.exit
34   %1 = load %"class.std::__1::__tree_node.130.151"*, %"class.std::__1::__tree_node.130.151"** undef, align 8
35   %cmp.i = icmp eq %"class.std::__1::__tree_node.130.151"* undef, %1
36   br label %invoke.cont.2
38 invoke.cont.2:                                    ; preds = %invoke.cont
39   br i1 %cmp.i, label %if.then, label %if.end
41 if.then:                                          ; preds = %invoke.cont.2
42   br label %cleanup
44 lpad:                                             ; preds = %cond.end
45   %2 = landingpad { i8*, i32 }
46           cleanup
47   br label %eh.resume
49 if.end:                                           ; preds = %invoke.cont.2
50   br label %invoke.cont.4
52 invoke.cont.4:                                    ; preds = %if.end
53   br label %cleanup
55 cleanup:                                          ; preds = %invoke.cont.4, %if.then
56   ret void
58 eh.resume:                                        ; preds = %lpad
59   resume { i8*, i32 } undef
62 declare i32 @__gxx_personality_v0(...)
64 ; Function Attrs: noinline
65 declare void @_ZNKSt3__16__treeIPKN5boost13serialization18extended_type_infoENS2_6detail11key_compareENS_9allocatorIS5_EEE4findIS5_EENS_21__tree_const_iteratorIS5_PNS_11__tree_nodeIS5_PvEElEERKT_() #0 align 2
67 attributes #0 = { noinline "target-cpu"="a2q" }
69 !llvm.module.flags = !{!0}
71 !0 = !{i32 1, !"PIC Level", i32 2}