|
1 |
| -; NOTE: Assertions have been autogenerated by utils/update_test_checks.py |
| 1 | +; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --function-signature |
2 | 2 | ; RUN: opt < %s -passes=tailcallelim -verify-dom-info -S | FileCheck %s
|
3 | 3 |
|
4 | 4 | ; the test was generated from the following C++ source:
|
|
24 | 24 |
|
25 | 25 | ; Function Attrs: noinline nounwind uwtable
|
26 | 26 | define dso_local void @_Z7dostuff1AS_i(ptr nocapture byval(%struct.A) align 8 %a, ptr nocapture readonly byval(%struct.A) align 8 %b, i32 %i) local_unnamed_addr #0 {
|
27 |
| -; CHECK-LABEL: @_Z7dostuff1AS_i( |
| 27 | +; CHECK-LABEL: define {{[^@]+}}@_Z7dostuff1AS_i |
| 28 | +; CHECK-SAME: (ptr nocapture byval([[STRUCT_A:%.*]]) align 8 [[A:%.*]], ptr nocapture readonly byval([[STRUCT_A]]) align 8 [[B:%.*]], i32 [[I:%.*]]) local_unnamed_addr #[[ATTR0:[0-9]+]] { |
28 | 29 | ; CHECK-NEXT: entry:
|
29 |
| -; CHECK-NEXT: [[AGG_TMP52:%.*]] = alloca [[STRUCT_A:%.*]], align 8 |
| 30 | +; CHECK-NEXT: [[AGG_TMP52:%.*]] = alloca [[STRUCT_A]], align 8 |
30 | 31 | ; CHECK-NEXT: [[AGG_TMP1:%.*]] = alloca [[STRUCT_A]], align 8
|
31 | 32 | ; CHECK-NEXT: [[AGG_TMP:%.*]] = alloca [[STRUCT_A]], align 8
|
32 | 33 | ; CHECK-NEXT: [[AGG_TMP5:%.*]] = alloca [[STRUCT_A]], align 8
|
33 | 34 | ; CHECK-NEXT: br label [[TAILRECURSE:%.*]]
|
34 | 35 | ; CHECK: tailrecurse:
|
35 |
| -; CHECK-NEXT: [[I_TR:%.*]] = phi i32 [ [[I:%.*]], [[ENTRY:%.*]] ], [ [[ADD:%.*]], [[IF_END:%.*]] ] |
| 36 | +; CHECK-NEXT: [[I_TR:%.*]] = phi i32 [ [[I]], [[ENTRY:%.*]] ], [ [[ADD:%.*]], [[IF_END:%.*]] ] |
36 | 37 | ; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[I_TR]], 10
|
37 | 38 | ; CHECK-NEXT: br i1 [[CMP]], label [[RETURN:%.*]], label [[IF_END]]
|
38 | 39 | ; CHECK: if.end:
|
39 |
| -; CHECK-NEXT: [[ARRAYIDX:%.*]] = getelementptr inbounds [[STRUCT_A]], ptr [[A:%.*]], i64 0, i32 0, i64 5 |
| 40 | +; CHECK-NEXT: [[ARRAYIDX:%.*]] = getelementptr inbounds [[STRUCT_A]], ptr [[A]], i64 0, i32 0, i64 5 |
40 | 41 | ; CHECK-NEXT: [[TMP0:%.*]] = load i64, ptr [[ARRAYIDX]], align 8
|
41 | 42 | ; CHECK-NEXT: [[INC:%.*]] = add nsw i64 [[TMP0]], 1
|
42 | 43 | ; CHECK-NEXT: store i64 [[INC]], ptr [[ARRAYIDX]], align 8
|
43 |
| -; CHECK-NEXT: [[ARRAYIDX4:%.*]] = getelementptr inbounds [[STRUCT_A]], ptr [[B:%.*]], i64 0, i32 0, i64 5 |
| 44 | +; CHECK-NEXT: [[ARRAYIDX4:%.*]] = getelementptr inbounds [[STRUCT_A]], ptr [[B]], i64 0, i32 0, i64 5 |
44 | 45 | ; CHECK-NEXT: [[TMP1:%.*]] = load i64, ptr [[ARRAYIDX4]], align 8
|
45 | 46 | ; CHECK-NEXT: [[CALL:%.*]] = tail call i32 (ptr, ...) @printf(ptr nonnull dereferenceable(1) @.str, i64 [[INC]], i64 [[TMP1]])
|
46 | 47 | ; CHECK-NEXT: call void @llvm.lifetime.start.p0(i64 80, ptr nonnull [[AGG_TMP]])
|
@@ -101,13 +102,13 @@ declare void @llvm.lifetime.end.p0(i64 immarg, ptr nocapture) #2
|
101 | 102 |
|
102 | 103 | ; Function Attrs: noinline norecurse nounwind optnone uwtable
|
103 | 104 | define dso_local i32 @main() local_unnamed_addr #3 {
|
104 |
| -; CHECK-LABEL: @main( |
| 105 | +; CHECK-LABEL: define {{[^@]+}}@main() local_unnamed_addr { |
105 | 106 | ; CHECK-NEXT: entry:
|
106 | 107 | ; CHECK-NEXT: [[AGG_TMP:%.*]] = alloca [[STRUCT_A:%.*]], align 8
|
107 | 108 | ; CHECK-NEXT: [[AGG_TMP1:%.*]] = alloca [[STRUCT_A]], align 8
|
108 | 109 | ; CHECK-NEXT: call void @llvm.memcpy.p0.p0.i64(ptr align 8 [[AGG_TMP]], ptr align 8 @global, i64 80, i1 false)
|
109 | 110 | ; CHECK-NEXT: call void @llvm.memcpy.p0.p0.i64(ptr align 8 [[AGG_TMP1]], ptr align 8 @global, i64 80, i1 false)
|
110 |
| -; CHECK-NEXT: tail call void @_Z7dostuff1AS_i(ptr byval(%struct.A) align 8 [[AGG_TMP]], ptr byval(%struct.A) align 8 [[AGG_TMP1]], i32 0) |
| 111 | +; CHECK-NEXT: tail call void @_Z7dostuff1AS_i(ptr byval([[STRUCT_A]]) align 8 [[AGG_TMP]], ptr byval([[STRUCT_A]]) align 8 [[AGG_TMP1]], i32 0) |
111 | 112 | ; CHECK-NEXT: ret i32 0
|
112 | 113 | ;
|
113 | 114 | entry:
|
|
0 commit comments