diff options
| author | Johannes Doerfert <johannes@jdoerfert.de> | 2019-10-10 02:10:51 -0500 |
|---|---|---|
| committer | Johannes Doerfert <johannes@jdoerfert.de> | 2019-12-14 00:29:38 -0600 |
| commit | c0cfdd32d036c29ac3f77a1817d11e92eb143eb1 (patch) | |
| tree | 75fdfb9c1e6d2a261b65898e73ca346b0fa0310c /llvm/test/Transforms/ArgumentPromotion/attrs.ll | |
| parent | d14a5693c07f0fb1b82c75ed72f77a495751dcf7 (diff) | |
| download | bcm5719-llvm-c0cfdd32d036c29ac3f77a1817d11e92eb143eb1.tar.gz bcm5719-llvm-c0cfdd32d036c29ac3f77a1817d11e92eb143eb1.zip | |
[ArgPromo][Tests] Run update_test_checks on all ArgumentPromotion tests
Summary:
In preparation of D65531 as well as the reuse of these tests for the
Attributor, we modernize them and use the update_test_checks to simplify
updates.
This was done with the update_test_checks after D68819 and D68850.
Reviewers: hfinkel, vsk, dblaikie, davidxl, tejohnson, tstellar, echristo, chandlerc, efriedma, lebedev.ri
Subscribers: bollu, arphaman, llvm-commits
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D68766
Diffstat (limited to 'llvm/test/Transforms/ArgumentPromotion/attrs.ll')
| -rw-r--r-- | llvm/test/Transforms/ArgumentPromotion/attrs.ll | 52 |
1 files changed, 31 insertions, 21 deletions
diff --git a/llvm/test/Transforms/ArgumentPromotion/attrs.ll b/llvm/test/Transforms/ArgumentPromotion/attrs.ll index 29cef50fe80..7d801ebf60f 100644 --- a/llvm/test/Transforms/ArgumentPromotion/attrs.ll +++ b/llvm/test/Transforms/ArgumentPromotion/attrs.ll @@ -1,3 +1,4 @@ +; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --function-signature --scrub-attributes ; RUN: opt < %s -argpromotion -S | FileCheck %s ; RUN: opt < %s -passes=argpromotion -S | FileCheck %s @@ -5,48 +6,57 @@ ; Don't drop 'byval' on %X here. define internal void @f(%struct.ss* byval %b, i32* byval %X, i32 %i) nounwind { -; CHECK-LABEL: define internal void @f( -; CHECK: i32 %[[B0:.*]], i64 %[[B1:.*]], i32* byval %X, i32 %i) +; CHECK-LABEL: define {{[^@]+}}@f +; CHECK-SAME: (i32 [[B_0:%.*]], i64 [[B_1:%.*]], i32* byval [[X:%.*]], i32 [[I:%.*]]) +; CHECK-NEXT: entry: +; CHECK-NEXT: [[B:%.*]] = alloca [[STRUCT_SS:%.*]] +; CHECK-NEXT: [[DOT0:%.*]] = getelementptr [[STRUCT_SS]], %struct.ss* [[B]], i32 0, i32 0 +; CHECK-NEXT: store i32 [[B_0]], i32* [[DOT0]] +; CHECK-NEXT: [[DOT1:%.*]] = getelementptr [[STRUCT_SS]], %struct.ss* [[B]], i32 0, i32 1 +; CHECK-NEXT: store i64 [[B_1]], i64* [[DOT1]] +; CHECK-NEXT: [[TMP:%.*]] = getelementptr [[STRUCT_SS]], %struct.ss* [[B]], i32 0, i32 0 +; CHECK-NEXT: [[TMP1:%.*]] = load i32, i32* [[TMP]], align 4 +; CHECK-NEXT: [[TMP2:%.*]] = add i32 [[TMP1]], 1 +; CHECK-NEXT: store i32 [[TMP2]], i32* [[TMP]], align 4 +; CHECK-NEXT: store i32 0, i32* [[X]] +; CHECK-NEXT: ret void +; entry: -; CHECK: %[[B:.*]] = alloca %struct.ss -; CHECK: %[[B_GEP0:.*]] = getelementptr %struct.ss, %struct.ss* %[[B]], i32 0, i32 0 -; CHECK: store i32 %[[B0]], i32* %[[B_GEP0]] -; CHECK: %[[B_GEP1:.*]] = getelementptr %struct.ss, %struct.ss* %[[B]], i32 0, i32 1 -; CHECK: store i64 %[[B1]], i64* %[[B_GEP1]] %tmp = getelementptr %struct.ss, %struct.ss* %b, i32 0, i32 0 -; CHECK: %[[TMP:.*]] = getelementptr %struct.ss, %struct.ss* %[[B]], i32 0, i32 0 %tmp1 = load i32, i32* %tmp, align 4 -; CHECK: %[[TMP1:.*]] = load i32, i32* %[[TMP]] %tmp2 = add i32 %tmp1, 1 -; CHECK: %[[TMP2:.*]] = add i32 %[[TMP1]], 1 store i32 %tmp2, i32* %tmp, align 4 -; CHECK: store i32 %[[TMP2]], i32* %[[TMP]] store i32 0, i32* %X -; CHECK: store i32 0, i32* %X ret void } ; Also make sure we don't drop the call zeroext attribute. define i32 @test(i32* %X) { -; CHECK-LABEL: define i32 @test( +; CHECK-LABEL: define {{[^@]+}}@test +; CHECK-SAME: (i32* [[X:%.*]]) +; CHECK-NEXT: entry: +; CHECK-NEXT: [[S:%.*]] = alloca [[STRUCT_SS:%.*]] +; CHECK-NEXT: [[TMP1:%.*]] = getelementptr [[STRUCT_SS]], %struct.ss* [[S]], i32 0, i32 0 +; CHECK-NEXT: store i32 1, i32* [[TMP1]], align 8 +; CHECK-NEXT: [[TMP4:%.*]] = getelementptr [[STRUCT_SS]], %struct.ss* [[S]], i32 0, i32 1 +; CHECK-NEXT: store i64 2, i64* [[TMP4]], align 4 +; CHECK-NEXT: [[S_0:%.*]] = getelementptr [[STRUCT_SS]], %struct.ss* [[S]], i32 0, i32 0 +; CHECK-NEXT: [[S_0_VAL:%.*]] = load i32, i32* [[S_0]] +; CHECK-NEXT: [[S_1:%.*]] = getelementptr [[STRUCT_SS]], %struct.ss* [[S]], i32 0, i32 1 +; CHECK-NEXT: [[S_1_VAL:%.*]] = load i64, i64* [[S_1]] +; CHECK-NEXT: call void @f(i32 [[S_0_VAL]], i64 [[S_1_VAL]], i32* byval [[X]], i32 zeroext 0) +; CHECK-NEXT: ret i32 0 +; entry: %S = alloca %struct.ss -; CHECK: %[[S:.*]] = alloca %struct.ss %tmp1 = getelementptr %struct.ss, %struct.ss* %S, i32 0, i32 0 store i32 1, i32* %tmp1, align 8 -; CHECK: store i32 1 %tmp4 = getelementptr %struct.ss, %struct.ss* %S, i32 0, i32 1 store i64 2, i64* %tmp4, align 4 -; CHECK: store i64 2 call void @f( %struct.ss* byval %S, i32* byval %X, i32 zeroext 0) -; CHECK: %[[S_GEP0:.*]] = getelementptr %struct.ss, %struct.ss* %[[S]], i32 0, i32 0 -; CHECK: %[[S0:.*]] = load i32, i32* %[[S_GEP0]] -; CHECK: %[[S_GEP1:.*]] = getelementptr %struct.ss, %struct.ss* %[[S]], i32 0, i32 1 -; CHECK: %[[S1:.*]] = load i64, i64* %[[S_GEP1]] -; CHECK: call void @f(i32 %[[S0]], i64 %[[S1]], i32* byval %X, i32 zeroext 0) ret i32 0 } |

