blob: b508f739e7fd3ceaa48a81242c801b3b72aae8ce [file] [edit]
; RUN: opt -S -passes=amdgpu-late-codegenprepare \
; RUN: -mtriple=amdgcn-amd-amdhsa -mcpu=gfx90a %s | FileCheck %s
; Goal: With a loop-header PHI in illegal vector type and a same-BB
; non-lookthrough user (vector add) in the header, LRO should still coerce
; the PHI to i32 because a profitable sink (store) exists across BB.
define amdgpu_kernel void @phi_samebb_nonlookthrough_store(
ptr addrspace(1) %out, <4 x i8> %v, i1 %exit) {
; CHECK-LABEL: @phi_samebb_nonlookthrough_store(
entry:
br label %loop
loop: ; preds = %entry, %loop
; Loop-carried PHI in illegal vector type.
%acc = phi <4 x i8> [ zeroinitializer, %entry ], [ %acc.next, %loop ]
; Same-BB non-lookthrough use in header.
%acc.next = add <4 x i8> %acc, %v
; Make it a real loop: either iterate or exit to the sink block.
br i1 %exit, label %store, label %loop
store: ; preds = %loop
; The across-BB sink: storing the PHI coerced to i32.
%acc.bc = bitcast <4 x i8> %acc to i32
store i32 %acc.bc, ptr addrspace(1) %out, align 4
ret void
}
; After AMDGPULateCodeGenPrepare we expect:
; - PHI is coerced to i32
; - A header bitcast materializes for the add
; This proves the same-BB non-lookthrough user (add) did not get pruned
; when the def is a PHI.
; CHECK: loop:
; CHECK: %[[ACC_TC:[^ ]+]] = phi i32
; CHECK: %[[ACC_TC_BC:[^ ]+]] = bitcast i32 %[[ACC_TC]] to <4 x i8>
; CHECK: %[[ACC_NEXT:[^ ]+]] = add <4 x i8> %[[ACC_TC_BC]], %v
; CHECK: br i1 %exit, label %store, label %loop
; CHECK: store:
; CHECK: %[[ACC_TC_BC2:[^ ]+]] = bitcast i32 %[[ACC_TC]] to <4 x i8>
; CHECK: %[[ST_I32:[^ ]+]] = bitcast <4 x i8> %[[ACC_TC_BC2]] to i32
; CHECK: store i32 %[[ST_I32]],