125 lines
3 KiB
LLVM
125 lines
3 KiB
LLVM
|
; 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"}
|