[llvm] [CodeGen] Avoid sinking vector comparisons during CodeGenPrepare (PR #113158)
David Green via llvm-commits
llvm-commits at lists.llvm.org
Tue Nov 5 01:08:36 PST 2024
================
@@ -0,0 +1,136 @@
+; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
+; RUN: llc -mtriple=thumbv8.1m.main -mattr=+mve.fp,+fp-armv8d16sp,+fp16,+fullfp16 < %s | FileCheck %s
+
+define arm_aapcs_vfpcc void @vector_loop_with_icmp(ptr nocapture noundef writeonly %dest) {
+; CHECK-LABEL: vector_loop_with_icmp:
+; CHECK: @ %bb.0: @ %entry
+; CHECK-NEXT: push.w {r4, r5, r6, r7, r8, r9, lr}
+; CHECK-NEXT: adr r1, .LCPI0_0
+; CHECK-NEXT: adr r2, .LCPI0_1
+; CHECK-NEXT: vldrw.u32 q0, [r1]
+; CHECK-NEXT: vldrw.u32 q1, [r2]
+; CHECK-NEXT: movs r1, #0
+; CHECK-NEXT: mov.w r12, #1
+; CHECK-NEXT: mov.w lr, #0
+; CHECK-NEXT: .LBB0_1: @ %vector.body
+; CHECK-NEXT: @ =>This Inner Loop Header: Depth=1
+; CHECK-NEXT: vmov r2, r3, d0
+; CHECK-NEXT: vmov r4, r5, d3
+; CHECK-NEXT: vmov r6, r7, d1
+; CHECK-NEXT: subs r2, #15
+; CHECK-NEXT: sbcs r2, r3, #0
+; CHECK-NEXT: cset r2, lo
+; CHECK-NEXT: cmp r2, #0
+; CHECK-NEXT: vmov r2, r3, d1
+; CHECK-NEXT: it ne
+; CHECK-NEXT: strne.w r12, [r0, r1, lsl #2]
+; CHECK-NEXT: subs r2, #15
+; CHECK-NEXT: sbcs r2, r3, #0
+; CHECK-NEXT: cset r2, lo
+; CHECK-NEXT: cmp r2, #0
+; CHECK-NEXT: itt ne
+; CHECK-NEXT: orrne r2, r1, #1
+; CHECK-NEXT: strne.w r12, [r0, r2, lsl #2]
+; CHECK-NEXT: vmov r2, r3, d2
+; CHECK-NEXT: subs r2, #15
+; CHECK-NEXT: sbcs r2, r3, #0
+; CHECK-NEXT: cset r2, lo
+; CHECK-NEXT: cmp r2, #0
+; CHECK-NEXT: itt ne
+; CHECK-NEXT: orrne r2, r1, #2
+; CHECK-NEXT: strne.w r12, [r0, r2, lsl #2]
+; CHECK-NEXT: vmov r2, r3, d3
+; CHECK-NEXT: subs r2, #15
+; CHECK-NEXT: sbcs r2, r3, #0
+; CHECK-NEXT: cset r2, lo
+; CHECK-NEXT: cmp r2, #0
+; CHECK-NEXT: itt ne
+; CHECK-NEXT: orrne r2, r1, #3
+; CHECK-NEXT: strne.w r12, [r0, r2, lsl #2]
+; CHECK-NEXT: vmov r2, r3, d2
+; CHECK-NEXT: adds r1, #4
+; CHECK-NEXT: adc lr, lr, #0
+; CHECK-NEXT: adds.w r9, r2, #4
+; CHECK-NEXT: adc r8, r3, #0
+; CHECK-NEXT: vmov r3, r2, d0
+; CHECK-NEXT: adds r4, #4
+; CHECK-NEXT: adc r5, r5, #0
+; CHECK-NEXT: adds r6, #4
+; CHECK-NEXT: adc r7, r7, #0
+; CHECK-NEXT: vmov q1[2], q1[0], r9, r4
+; CHECK-NEXT: vmov q1[3], q1[1], r8, r5
+; CHECK-NEXT: adds r3, #4
+; CHECK-NEXT: vmov q0[2], q0[0], r3, r6
+; CHECK-NEXT: adc r2, r2, #0
+; CHECK-NEXT: vmov q0[3], q0[1], r2, r7
+; CHECK-NEXT: eor r2, r1, #16
+; CHECK-NEXT: orrs.w r2, r2, lr
+; CHECK-NEXT: bne .LBB0_1
+; CHECK-NEXT: @ %bb.2: @ %for.cond.cleanup
+; CHECK-NEXT: pop.w {r4, r5, r6, r7, r8, r9, pc}
+; CHECK-NEXT: .p2align 4
+; CHECK-NEXT: @ %bb.3:
+; CHECK-NEXT: .LCPI0_0:
+; CHECK-NEXT: .long 0 @ 0x0
+; CHECK-NEXT: .long 0 @ 0x0
+; CHECK-NEXT: .long 1 @ 0x1
+; CHECK-NEXT: .long 0 @ 0x0
+; CHECK-NEXT: .LCPI0_1:
+; CHECK-NEXT: .long 2 @ 0x2
+; CHECK-NEXT: .long 0 @ 0x0
+; CHECK-NEXT: .long 3 @ 0x3
+; CHECK-NEXT: .long 0 @ 0x0
+entry:
+ br label %vector.body
+
+vector.body:
+ %index = phi i64 [ 0, %entry ], [ %index.next, %pred.store.continue18 ]
+ %vec.ind = phi <4 x i64> [ <i64 0, i64 1, i64 2, i64 3>, %entry ], [ %vec.ind.next, %pred.store.continue18 ]
+ %0 = icmp ult <4 x i64> %vec.ind, <i64 15, i64 15, i64 15, i64 15>
----------------
davemgreen wrote:
Can you make this 4 x i32, so that it is a legal type under MVE.
https://github.com/llvm/llvm-project/pull/113158
More information about the llvm-commits
mailing list