25 lines
1.1 KiB
Plaintext
25 lines
1.1 KiB
Plaintext
// RUN: %{ispc} --target=host --nowrap --nostdlib -O2 --emit-llvm-text %s -o - | FileCheck %s --check-prefix=COMMON
|
|
// RUN: %{ispc} --target=avx512skx-x32 --nowrap --nostdlib -O2 --emit-llvm-text %s -o - | FileCheck %s --check-prefix=AVX512_X32
|
|
// RUN: %{ispc} --target=avx512skx-x16 --nowrap --nostdlib -O2 --emit-llvm-text %s -o - | FileCheck %s --check-prefix=COMMON
|
|
// RUN: %{ispc} --target=avx2-i32x4 --nowrap --nostdlib -O2 --emit-llvm-text %s -o - | FileCheck %s --check-prefix=COMMON
|
|
|
|
// COMMON-LABEL: @foo___unT_3C_4_3E_unT_3C_4_3E_(
|
|
// COMMON-NEXT: allocas:
|
|
// COMMON-NEXT: [[CMP:%.*]] = icmp ult <4 x i8> %a, %b
|
|
// COMMON-NEXT: [[CAST:%.*]] = zext <4 x i1> [[CMP]] to <4 x i8>
|
|
// COMMON-NEXT: ret <4 x i8> [[CAST]]
|
|
|
|
// By some reason, avx512-x32 has 8 wide vector for uint8<4>, x64 has 16
|
|
// AVX512_X32-LABEL: @foo___unT_3C_4_3E_unT_3C_4_3E_(
|
|
// AVX512_X32-NEXT: allocas:
|
|
// AVX512_X32-NEXT: [[CMP:%.*]] = icmp ult <8 x i8> %a, %b
|
|
// AVX512_X32-NEXT: [[CAST:%.*]] = zext <8 x i1> [[CMP]] to <8 x i8>
|
|
// AVX512_X32-NEXT: ret <8 x i8> [[CAST]]
|
|
|
|
// REQUIRES: X86_ENABLED
|
|
|
|
uniform uint8<4> foo(uniform uint8<4> a, uniform uint8<4> b)
|
|
{
|
|
return a < b;
|
|
}
|