; RUN: llc -march=hexagon < %s | FileCheck %s target triple = "hexagon" @g0 = external global i32 @g1 = external global i32, align 4 @g2 = external hidden unnamed_addr constant [49 x i8], align 8 @g3 = external hidden unnamed_addr constant [76 x i8], align 8 @g4 = external unnamed_addr constant { ptr, ptr } @g5 = external hidden unnamed_addr constant [36 x i8], align 8 declare void @f0() declare i32 @f1() declare i32 @f2(i32) declare void @f3() ; Function Attrs: nounwind declare ptr @f4(ptr) #0 ; Function Attrs: nounwind declare ptr @f5(ptr) #0 ; CHECK: f6: ; CHECK-DAG: call f4 ; CHECK-DAG: r0 = ##f3 ; CHECK-DAG: call f5 ; CHECK-DAG: r0 = ##f0 ; CHECK-DAG: call f8 ; CHECK-DAG: r0 = ##g2 ; CHECK-DAG: call f9 ; CHECK-DAG: call f8 ; CHECK-DAG: r0 = ##g3 ; CHECK-DAG: call f10 ; CHECK-DAG: r0 = #4 ; CHECK-DAG: r{{[0-9]+}} = ##g1 define i32 @f6() personality ptr @f11 { b0: tail call void @f7() %v0 = tail call ptr @f4(ptr @f3) #0 %v1 = tail call ptr @f5(ptr @f0) #0 tail call void (ptr, ...) @f8(ptr @g2) tail call void @f9() tail call void (ptr, ...) @f8(ptr @g3) %v2 = tail call ptr @f10(i32 4) #0 %v3 = load i32, ptr @g1, align 4, !tbaa !0 %v4 = add nsw i32 %v3, 1 store i32 %v4, ptr @g1, align 4, !tbaa !0 invoke void @f12(ptr %v2, ptr @g4, ptr null) #1 to label %b7 unwind label %b1 b1: ; preds = %b0 %v5 = landingpad { ptr, i32 } catch ptr null %v6 = extractvalue { ptr, i32 } %v5, 0 %v7 = tail call ptr @f13(ptr %v6) #0 store i32 0, ptr @g1, align 4, !tbaa !0 invoke void @f14() #1 to label %b7 unwind label %b2 b2: ; preds = %b1 %v8 = landingpad { ptr, i32 } catch ptr null invoke void @f15() to label %b3 unwind label %b6 b3: ; preds = %b2 %v9 = extractvalue { ptr, i32 } %v8, 0 %v10 = tail call ptr @f13(ptr %v9) #0 tail call void @f15() %v11 = load i32, ptr @g1, align 4, !tbaa !0 %v12 = icmp eq i32 %v11, 0 br i1 %v12, label %b5, label %b4 b4: ; preds = %b3 tail call void (ptr, ...) @f8(ptr @g5) store i32 1, ptr @g0, align 4, !tbaa !0 br label %b5 b5: ; preds = %b4, %b3 %v13 = tail call i32 @f1() %v14 = tail call i32 @f2(i32 1) ret i32 %v14 b6: ; preds = %b2 %v15 = landingpad { ptr, i32 } catch ptr null tail call void @f16() #2 unreachable b7: ; preds = %b1, %b0 unreachable } declare void @f7() declare void @f8(ptr, ...) declare void @f9() declare ptr @f10(i32) declare i32 @f11(...) declare void @f12(ptr, ptr, ptr) declare ptr @f13(ptr) declare void @f14() declare void @f15() declare void @f16() attributes #0 = { nounwind } attributes #1 = { noreturn } attributes #2 = { noreturn nounwind } !0 = !{!1, !1, i64 0} !1 = !{!"int", !2} !2 = !{!"omnipotent char", !3} !3 = !{!"Simple C/C++ TBAA"}