diff options
author | Florian Hahn <flo@fhahn.com> | 2024-11-28 09:13:29 +0000 |
---|---|---|
committer | Florian Hahn <flo@fhahn.com> | 2024-11-28 09:13:29 +0000 |
commit | f8f238d38eaa0a2e27f09fb6d01bcc8e7eab9e93 (patch) | |
tree | a92597586f8e77b7fbc23bdb36683d2249ff81e1 | |
parent | 0604d13790b20f6b385507bb63c62aa87162da9b (diff) | |
download | llvm-f8f238d38eaa0a2e27f09fb6d01bcc8e7eab9e93.zip llvm-f8f238d38eaa0a2e27f09fb6d01bcc8e7eab9e93.tar.gz llvm-f8f238d38eaa0a2e27f09fb6d01bcc8e7eab9e93.tar.bz2 |
[AArch64] Add extra add/cast tests for select-optimize.
Extra tests for https://github.com/llvm/llvm-project/pull/115489
with different operand order. Also fixes the target triple.
-rw-r--r-- | llvm/test/CodeGen/AArch64/selectopt-cast.ll | 112 |
1 files changed, 104 insertions, 8 deletions
diff --git a/llvm/test/CodeGen/AArch64/selectopt-cast.ll b/llvm/test/CodeGen/AArch64/selectopt-cast.ll index b1804a0..c15e6e1d 100644 --- a/llvm/test/CodeGen/AArch64/selectopt-cast.ll +++ b/llvm/test/CodeGen/AArch64/selectopt-cast.ll @@ -1,6 +1,6 @@ ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py -; RUN: opt -select-optimize -mtriple=arm64-apple-macosx-mcpu=apple-m4 -S %s | FileCheck %s -; RUN: opt -passes='require<profile-summary>,function(select-optimize)' -mtriple=arm64-apple-macosx-mcpu=apple-m4 -S %s | FileCheck %s +; RUN: opt -select-optimize -mtriple=arm64-apple-macosx -S %s | FileCheck %s +; RUN: opt -passes='require<profile-summary>,function(select-optimize)' -mtriple=arm64-apple-macosx -S %s | FileCheck %s define void @test_add_zext(ptr %dst, ptr %src, i64 %j.start, i64 %p, i64 %i.start) { ; CHECK-LABEL: @test_add_zext( @@ -49,13 +49,60 @@ exit: ret void } +define void @test_add_zext_first_op(ptr %dst, ptr %src, i64 %j.start, i64 %p, i64 %i.start) { +; CHECK-LABEL: @test_add_zext_first_op( +; CHECK-NEXT: entry: +; CHECK-NEXT: br label [[LOOP:%.*]] +; CHECK: loop: +; CHECK-NEXT: [[IV:%.*]] = phi i64 [ 0, [[ENTRY:%.*]] ], [ [[IV_NEXT:%.*]], [[LOOP]] ] +; CHECK-NEXT: [[J:%.*]] = phi i64 [ [[J_START:%.*]], [[ENTRY]] ], [ [[J_NEXT:%.*]], [[LOOP]] ] +; CHECK-NEXT: [[I:%.*]] = phi i64 [ [[I_START:%.*]], [[ENTRY]] ], [ [[J_NEXT]], [[LOOP]] ] +; CHECK-NEXT: [[GEP_I:%.*]] = getelementptr inbounds ptr, ptr [[SRC:%.*]], i64 [[I]] +; CHECK-NEXT: [[L_I:%.*]] = load ptr, ptr [[GEP_I]], align 8 +; CHECK-NEXT: [[GEP_J:%.*]] = getelementptr inbounds ptr, ptr [[SRC]], i64 [[J]] +; CHECK-NEXT: [[L_J:%.*]] = load ptr, ptr [[GEP_J]], align 8 +; CHECK-NEXT: [[CMP3:%.*]] = icmp ult ptr [[L_I]], [[L_J]] +; CHECK-NEXT: [[DEC:%.*]] = zext i1 [[CMP3]] to i64 +; CHECK-NEXT: [[J_NEXT]] = add nsw i64 [[DEC]], [[J]] +; CHECK-NEXT: [[GEP_DST:%.*]] = getelementptr inbounds ptr, ptr [[DST:%.*]], i64 [[IV]] +; CHECK-NEXT: store i64 [[J_NEXT]], ptr [[GEP_DST]], align 8 +; CHECK-NEXT: [[IV_NEXT]] = add i64 [[IV]], 1 +; CHECK-NEXT: [[EC:%.*]] = icmp eq i64 [[IV]], [[J_START]] +; CHECK-NEXT: br i1 [[EC]], label [[EXIT:%.*]], label [[LOOP]] +; CHECK: exit: +; CHECK-NEXT: ret void +; +entry: + br label %loop + +loop: + %iv = phi i64 [ 0, %entry ], [ %iv.next, %loop ] + %j = phi i64 [ %j.start, %entry ], [ %j.next, %loop ] + %i = phi i64 [ %i.start, %entry ], [ %j.next, %loop ] + %gep.i = getelementptr inbounds ptr, ptr %src, i64 %i + %l.i = load ptr, ptr %gep.i, align 8 + %gep.j = getelementptr inbounds ptr, ptr %src, i64 %j + %l.j = load ptr, ptr %gep.j, align 8 + %cmp3 = icmp ult ptr %l.i, %l.j + %dec = zext i1 %cmp3 to i64 + %j.next = add nsw i64 %dec, %j + %gep.dst = getelementptr inbounds ptr, ptr %dst, i64 %iv + store i64 %j.next, ptr %gep.dst, align 8 + %iv.next = add i64 %iv, 1 + %ec = icmp eq i64 %iv, %j.start + br i1 %ec, label %exit, label %loop + +exit: + ret void +} + define void @test_add_zext_not(ptr %dst, ptr %src, i64 %j.start, i64 %p, i64 %i.start) { ; CHECK-LABEL: @test_add_zext_not( ; CHECK-NEXT: entry: ; CHECK-NEXT: br label [[LOOP:%.*]] ; CHECK: loop: ; CHECK-NEXT: [[IV:%.*]] = phi i64 [ 0, [[ENTRY:%.*]] ], [ [[IV_NEXT:%.*]], [[LOOP]] ] -; CHECK-NEXT: [[J:%.*]] = phi i64 [ [[HIGH:%.*]], [[ENTRY]] ], [ [[J_NEXT:%.*]], [[LOOP]] ] +; CHECK-NEXT: [[J:%.*]] = phi i64 [ [[J_START:%.*]], [[ENTRY]] ], [ [[J_NEXT:%.*]], [[LOOP]] ] ; CHECK-NEXT: [[I:%.*]] = phi i64 [ [[I_START:%.*]], [[ENTRY]] ], [ [[J_NEXT]], [[LOOP]] ] ; CHECK-NEXT: [[GEP_I:%.*]] = getelementptr inbounds ptr, ptr [[SRC:%.*]], i64 [[I]] ; CHECK-NEXT: [[L_I:%.*]] = load ptr, ptr [[GEP_I]], align 8 @@ -68,8 +115,8 @@ define void @test_add_zext_not(ptr %dst, ptr %src, i64 %j.start, i64 %p, i64 %i. ; CHECK-NEXT: [[GEP_DST:%.*]] = getelementptr inbounds ptr, ptr [[DST:%.*]], i64 [[IV]] ; CHECK-NEXT: store i64 [[J_NEXT]], ptr [[GEP_DST]], align 8 ; CHECK-NEXT: [[IV_NEXT]] = add i64 [[IV]], 1 -; CHECK-NEXT: [[EXITCOND_NOT:%.*]] = icmp eq i64 [[IV]], [[HIGH]] -; CHECK-NEXT: br i1 [[EXITCOND_NOT]], label [[EXIT:%.*]], label [[LOOP]] +; CHECK-NEXT: [[EC:%.*]] = icmp eq i64 [[IV]], [[J_START]] +; CHECK-NEXT: br i1 [[EC]], label [[EXIT:%.*]], label [[LOOP]] ; CHECK: exit: ; CHECK-NEXT: ret void ; @@ -97,6 +144,7 @@ loop: exit: ret void } + define void @test_add_sext(ptr %dst, ptr %src, i64 %j.start, i64 %p, i64 %i.start) { ; CHECK-LABEL: @test_add_sext( ; CHECK-NEXT: entry: @@ -350,13 +398,60 @@ exit: ret void } +define void @test_sub_zext_first_op(ptr %dst, ptr %src, i64 %j.start, i64 %p, i64 %i.start) { +; CHECK-LABEL: @test_sub_zext_first_op( +; CHECK-NEXT: entry: +; CHECK-NEXT: br label [[LOOP:%.*]] +; CHECK: loop: +; CHECK-NEXT: [[IV:%.*]] = phi i64 [ 0, [[ENTRY:%.*]] ], [ [[IV_NEXT:%.*]], [[LOOP]] ] +; CHECK-NEXT: [[J:%.*]] = phi i64 [ [[J_START:%.*]], [[ENTRY]] ], [ [[J_NEXT:%.*]], [[LOOP]] ] +; CHECK-NEXT: [[I:%.*]] = phi i64 [ [[I_START:%.*]], [[ENTRY]] ], [ [[J_NEXT]], [[LOOP]] ] +; CHECK-NEXT: [[GEP_I:%.*]] = getelementptr inbounds ptr, ptr [[SRC:%.*]], i64 [[I]] +; CHECK-NEXT: [[L_I:%.*]] = load ptr, ptr [[GEP_I]], align 8 +; CHECK-NEXT: [[GEP_J:%.*]] = getelementptr inbounds ptr, ptr [[SRC]], i64 [[J]] +; CHECK-NEXT: [[L_J:%.*]] = load ptr, ptr [[GEP_J]], align 8 +; CHECK-NEXT: [[CMP3:%.*]] = icmp ult ptr [[L_I]], [[L_J]] +; CHECK-NEXT: [[DEC:%.*]] = zext i1 [[CMP3]] to i64 +; CHECK-NEXT: [[J_NEXT]] = sub nsw i64 [[DEC]], [[J]] +; CHECK-NEXT: [[GEP_DST:%.*]] = getelementptr inbounds ptr, ptr [[DST:%.*]], i64 [[IV]] +; CHECK-NEXT: store i64 [[J_NEXT]], ptr [[GEP_DST]], align 8 +; CHECK-NEXT: [[IV_NEXT]] = add i64 [[IV]], 1 +; CHECK-NEXT: [[EC:%.*]] = icmp eq i64 [[IV]], [[J_START]] +; CHECK-NEXT: br i1 [[EC]], label [[EXIT:%.*]], label [[LOOP]] +; CHECK: exit: +; CHECK-NEXT: ret void +; +entry: + br label %loop + +loop: + %iv = phi i64 [ 0, %entry ], [ %iv.next, %loop ] + %j = phi i64 [ %j.start, %entry ], [ %j.next, %loop ] + %i = phi i64 [ %i.start, %entry ], [ %j.next, %loop ] + %gep.i = getelementptr inbounds ptr, ptr %src, i64 %i + %l.i = load ptr, ptr %gep.i, align 8 + %gep.j = getelementptr inbounds ptr, ptr %src, i64 %j + %l.j = load ptr, ptr %gep.j, align 8 + %cmp3 = icmp ult ptr %l.i, %l.j + %dec = zext i1 %cmp3 to i64 + %j.next = sub nsw i64 %dec, %j + %gep.dst = getelementptr inbounds ptr, ptr %dst, i64 %iv + store i64 %j.next, ptr %gep.dst, align 8 + %iv.next = add i64 %iv, 1 + %ec = icmp eq i64 %iv, %j.start + br i1 %ec, label %exit, label %loop + +exit: + ret void +} + define void @test_sub_zext_not(ptr %dst, ptr %src, i64 %j.start, i64 %p, i64 %i.start) { ; CHECK-LABEL: @test_sub_zext_not( ; CHECK-NEXT: entry: ; CHECK-NEXT: br label [[LOOP:%.*]] ; CHECK: loop: ; CHECK-NEXT: [[IV:%.*]] = phi i64 [ 0, [[ENTRY:%.*]] ], [ [[IV_NEXT:%.*]], [[LOOP]] ] -; CHECK-NEXT: [[J:%.*]] = phi i64 [ [[HIGH:%.*]], [[ENTRY]] ], [ [[J_NEXT:%.*]], [[LOOP]] ] +; CHECK-NEXT: [[J:%.*]] = phi i64 [ [[J_START:%.*]], [[ENTRY]] ], [ [[J_NEXT:%.*]], [[LOOP]] ] ; CHECK-NEXT: [[I:%.*]] = phi i64 [ [[I_START:%.*]], [[ENTRY]] ], [ [[J_NEXT]], [[LOOP]] ] ; CHECK-NEXT: [[GEP_I:%.*]] = getelementptr inbounds ptr, ptr [[SRC:%.*]], i64 [[I]] ; CHECK-NEXT: [[L_I:%.*]] = load ptr, ptr [[GEP_I]], align 8 @@ -369,8 +464,8 @@ define void @test_sub_zext_not(ptr %dst, ptr %src, i64 %j.start, i64 %p, i64 %i. ; CHECK-NEXT: [[GEP_DST:%.*]] = getelementptr inbounds ptr, ptr [[DST:%.*]], i64 [[IV]] ; CHECK-NEXT: store i64 [[J_NEXT]], ptr [[GEP_DST]], align 8 ; CHECK-NEXT: [[IV_NEXT]] = add i64 [[IV]], 1 -; CHECK-NEXT: [[EXITCOND_NOT:%.*]] = icmp eq i64 [[IV]], [[HIGH]] -; CHECK-NEXT: br i1 [[EXITCOND_NOT]], label [[EXIT:%.*]], label [[LOOP]] +; CHECK-NEXT: [[EC:%.*]] = icmp eq i64 [[IV]], [[J_START]] +; CHECK-NEXT: br i1 [[EC]], label [[EXIT:%.*]], label [[LOOP]] ; CHECK: exit: ; CHECK-NEXT: ret void ; @@ -398,6 +493,7 @@ loop: exit: ret void } + define void @test_sub_sext(ptr %dst, ptr %src, i64 %j.start, i64 %p, i64 %i.start) { ; CHECK-LABEL: @test_sub_sext( ; CHECK-NEXT: entry: |