blob: 3060de0338f1d420c86de6b52369a085d501b98a [file] [log] [blame] [edit]
; RUN: clspv-opt --LongVectorLowering --early-cse --instcombine %s -o %t
; RUN: FileCheck %s < %t
target datalayout = "e-p:32:32-i64:64-v16:16-v24:32-v32:32-v48:64-v96:128-v192:256-v256:256-v512:512-v1024:1024"
target triple = "spir-unknown-unknown"
define spir_func <8 x float> @test(i1 %cond, <8 x float> %a, <8 x float> %b) {
entry:
; This is not derived from a regular OpenCL select overload.
%value = select i1 %cond, <8 x float> %a, <8 x float> %b
ret <8 x float> %value
}
; CHECK: define spir_func
; CHECK-SAME: [[FLOAT8:{ float, float, float, float, float, float, float, float }]]
; CHECK-SAME: @test(
; CHECK-SAME: i1 [[COND:%[^ ]+]],
; CHECK-SAME: [[FLOAT8]] [[A:%[^ ]+]],
; CHECK-SAME: [[FLOAT8]] [[B:%[^ ]+]]) {
; There should only be one select, but for compatibility with the SPIR-V
; producer it is scalarised.
; CHECK-DAG: [[A_0:%[^ ]+]] = extractvalue [[FLOAT8]] [[A]], 0
; CHECK-DAG: [[A_1:%[^ ]+]] = extractvalue [[FLOAT8]] [[A]], 1
; CHECK-DAG: [[A_2:%[^ ]+]] = extractvalue [[FLOAT8]] [[A]], 2
; CHECK-DAG: [[A_3:%[^ ]+]] = extractvalue [[FLOAT8]] [[A]], 3
; CHECK-DAG: [[A_4:%[^ ]+]] = extractvalue [[FLOAT8]] [[A]], 4
; CHECK-DAG: [[A_5:%[^ ]+]] = extractvalue [[FLOAT8]] [[A]], 5
; CHECK-DAG: [[A_6:%[^ ]+]] = extractvalue [[FLOAT8]] [[A]], 6
; CHECK-DAG: [[A_7:%[^ ]+]] = extractvalue [[FLOAT8]] [[A]], 7
; CHECK-DAG: [[B_0:%[^ ]+]] = extractvalue [[FLOAT8]] [[B]], 0
; CHECK-DAG: [[B_1:%[^ ]+]] = extractvalue [[FLOAT8]] [[B]], 1
; CHECK-DAG: [[B_2:%[^ ]+]] = extractvalue [[FLOAT8]] [[B]], 2
; CHECK-DAG: [[B_3:%[^ ]+]] = extractvalue [[FLOAT8]] [[B]], 3
; CHECK-DAG: [[B_4:%[^ ]+]] = extractvalue [[FLOAT8]] [[B]], 4
; CHECK-DAG: [[B_5:%[^ ]+]] = extractvalue [[FLOAT8]] [[B]], 5
; CHECK-DAG: [[B_6:%[^ ]+]] = extractvalue [[FLOAT8]] [[B]], 6
; CHECK-DAG: [[B_7:%[^ ]+]] = extractvalue [[FLOAT8]] [[B]], 7
; CHECK-DAG: [[SELECT_0:%[^ ]+]] = select i1 [[COND]], float [[A_0]], float [[B_0]]
; CHECK-DAG: [[SELECT_1:%[^ ]+]] = select i1 [[COND]], float [[A_1]], float [[B_1]]
; CHECK-DAG: [[SELECT_2:%[^ ]+]] = select i1 [[COND]], float [[A_2]], float [[B_2]]
; CHECK-DAG: [[SELECT_3:%[^ ]+]] = select i1 [[COND]], float [[A_3]], float [[B_3]]
; CHECK-DAG: [[SELECT_4:%[^ ]+]] = select i1 [[COND]], float [[A_4]], float [[B_4]]
; CHECK-DAG: [[SELECT_5:%[^ ]+]] = select i1 [[COND]], float [[A_5]], float [[B_5]]
; CHECK-DAG: [[SELECT_6:%[^ ]+]] = select i1 [[COND]], float [[A_6]], float [[B_6]]
; CHECK-DAG: [[SELECT_7:%[^ ]+]] = select i1 [[COND]], float [[A_7]], float [[B_7]]
; CHECK-DAG: [[TMP_0:%[^ ]+]] = insertvalue [[FLOAT8]] undef, float [[SELECT_0]], 0
; CHECK-DAG: [[TMP_1:%[^ ]+]] = insertvalue [[FLOAT8]] [[TMP_0]], float [[SELECT_1]], 1
; CHECK-DAG: [[TMP_2:%[^ ]+]] = insertvalue [[FLOAT8]] [[TMP_1]], float [[SELECT_2]], 2
; CHECK-DAG: [[TMP_3:%[^ ]+]] = insertvalue [[FLOAT8]] [[TMP_2]], float [[SELECT_3]], 3
; CHECK-DAG: [[TMP_4:%[^ ]+]] = insertvalue [[FLOAT8]] [[TMP_3]], float [[SELECT_4]], 4
; CHECK-DAG: [[TMP_5:%[^ ]+]] = insertvalue [[FLOAT8]] [[TMP_4]], float [[SELECT_5]], 5
; CHECK-DAG: [[TMP_6:%[^ ]+]] = insertvalue [[FLOAT8]] [[TMP_5]], float [[SELECT_6]], 6
; CHECK-DAG: [[VALUE:%[^ ]+]] = insertvalue [[FLOAT8]] [[TMP_6]], float [[SELECT_7]], 7
; CHECK-NEXT: ret [[FLOAT8]] [[VALUE]]