forked from OSchip/llvm-project
93 lines
4.1 KiB
C
93 lines
4.1 KiB
C
// RUN: %clang_cc1 -target-feature +altivec -target-feature +vsx \
|
|
// RUN: -faltivec-src-compat=mixed -triple powerpc-unknown-unknown -S \
|
|
// RUN: -emit-llvm %s -o - | FileCheck %s --check-prefix=MIXED
|
|
// RUN: %clang_cc1 -target-feature +altivec -target-feature +vsx \
|
|
// RUN: -faltivec-src-compat=mixed -triple powerpc64le-unknown-unknown -S \
|
|
// RUN: -emit-llvm %s -o - | FileCheck %s --check-prefix=MIXED
|
|
// RUN: %clang_cc1 -target-feature +altivec -target-feature +vsx \
|
|
// RUN: -faltivec-src-compat=xl -triple powerpc-unknown-unknown -S \
|
|
// RUN: -emit-llvm %s -o - | FileCheck %s --check-prefix=XL
|
|
// RUN: %clang_cc1 -target-feature +altivec -target-feature +vsx \
|
|
// RUN: -faltivec-src-compat=xl -triple powerpc64le-unknown-unknown -S \
|
|
// RUN: -emit-llvm %s -o - | FileCheck %s --check-prefix=XL
|
|
// RUN: %clang -mcpu=pwr8 -faltivec-src-compat=mixed --target=powerpc-unknown-unknown \
|
|
// RUN: -S -emit-llvm %s -o - | FileCheck %s --check-prefix=MIXED
|
|
// RUN: %clang -mcpu=pwr9 -faltivec-src-compat=mixed --target=powerpc-unknown-unknown \
|
|
// RUN: -S -emit-llvm %s -o - | FileCheck %s --check-prefix=MIXED
|
|
// RUN: %clang -mcpu=pwr8 -faltivec-src-compat=xl --target=powerpc-unknown-unknown \
|
|
// RUN: -S -emit-llvm %s -o - | FileCheck %s --check-prefix=XL
|
|
// RUN: %clang -mcpu=pwr9 -faltivec-src-compat=xl --target=powerpc-unknown-unknown \
|
|
// RUN: -S -emit-llvm %s -o - | FileCheck %s --check-prefix=XL
|
|
|
|
// Vector bool type
|
|
vector bool char vbi8_1;
|
|
vector bool char vbi8_2;
|
|
|
|
vector bool short vbi16_1;
|
|
vector bool short vbi16_2;
|
|
|
|
vector bool int vbi32_1;
|
|
vector bool int vbi32_2;
|
|
|
|
vector bool long long vbi64_1;
|
|
vector bool long long vbi64_2;
|
|
|
|
// Vector pixel type
|
|
vector pixel p1;
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
void test_vector_bool_pixel_init() {
|
|
// vector bool char initialization
|
|
vbi8_1 = (vector bool char)('a');
|
|
// MIXED: <i8 97, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0>
|
|
// XL: <i8 97, i8 97, i8 97, i8 97, i8 97, i8 97, i8 97, i8 97, i8 97, i8 97, i8 97, i8 97, i8 97, i8 97, i8 97, i8 97>
|
|
char c = 'c';
|
|
vbi8_2 = (vector bool char)(c);
|
|
// MIXED: [[INS:%.*]] = insertelement <16 x i8>
|
|
// MIXED: store <16 x i8> [[INS:%.*]]
|
|
// XL: [[INS_ELT:%.*]] = insertelement <16 x i8>
|
|
// XL: [[SHUFF:%.*]] = shufflevector <16 x i8> [[INS_ELT]], <16 x i8> poison, <16 x i32> zeroinitializer
|
|
// XL: store <16 x i8> [[SHUFF]]
|
|
|
|
// vector bool short initialization
|
|
vbi16_1 = (vector bool short)(5);
|
|
// MIXED: <i16 5, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0>
|
|
// XL: <i16 5, i16 5, i16 5, i16 5, i16 5, i16 5, i16 5, i16 5>
|
|
short si16 = 55;
|
|
vbi16_2 = (vector bool short)(si16);
|
|
// MIXED: [[INS:%.*]] = insertelement <8 x i16>
|
|
// MIXED: store <8 x i16> [[INS:%.*]]
|
|
// XL: [[INS_ELT:%.*]] = insertelement <8 x i16>
|
|
// XL: [[SHUFF:%.*]] = shufflevector <8 x i16> [[INS_ELT]], <8 x i16> poison, <8 x i32> zeroinitializer
|
|
// XL: store <8 x i16> [[SHUFF]]
|
|
|
|
// vector bool int initialization
|
|
vbi32_1 = (vector bool int)(9);
|
|
// MIXED: <i32 9, i32 0, i32 0, i32 0>
|
|
// XL: <i32 9, i32 9, i32 9, i32 9>
|
|
int si32 = 99;
|
|
vbi32_2 = (vector bool int)(si32);
|
|
// MIXED: [[INS:%.*]] = insertelement <4 x i32>
|
|
// MIXED: store <4 x i32> [[INS:%.*]]
|
|
// XL: [[INS_ELT:%.*]] = insertelement <4 x i32>
|
|
// XL: [[SHUFF:%.*]] = shufflevector <4 x i32> [[INS_ELT]], <4 x i32> poison, <4 x i32> zeroinitializer
|
|
// XL: store <4 x i32> [[SHUFF]]
|
|
|
|
// vector bool long long initialization
|
|
vbi64_1 = (vector bool long long)(13);
|
|
// MIXED: <i64 13, i64 0>
|
|
// XL: <i64 13, i64 13>
|
|
long long si64 = 1313;
|
|
vbi64_2 = (vector bool long long)(si64);
|
|
// MIXED: [[INS:%.*]] = insertelement <2 x i64>
|
|
// MIXED: store <2 x i64> [[INS:%.*]]
|
|
// XL: [[INS_ELT:%.*]] = insertelement <2 x i64>
|
|
// XL: [[SHUFF:%.*]] = shufflevector <2 x i64> [[INS_ELT]], <2 x i64> poison, <2 x i32> zeroinitializer
|
|
// XL: store <2 x i64> [[SHUFF]]
|
|
|
|
// vector pixel initialization
|
|
p1 = (vector pixel)(1);
|
|
// MIXED: <i16 1, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0>
|
|
// XL: <i16 1, i16 1, i16 1, i16 1, i16 1, i16 1, i16 1, i16 1>
|
|
}
|