61 lines
2.4 KiB
C++
61 lines
2.4 KiB
C++
// RUN: %clang_cc1 -triple x86_64-unknown-linux-gnu -Wno-unused-value -fclangir -emit-cir %s -o %t.cir
|
|
// RUN: FileCheck --input-file=%t.cir %s -check-prefix=CIR
|
|
// RUN: %clang_cc1 -triple x86_64-unknown-linux-gnu -Wno-unused-value -fclangir -emit-llvm %s -o %t-cir.ll
|
|
// RUN: FileCheck --input-file=%t-cir.ll %s -check-prefix=LLVM
|
|
// RUN: %clang_cc1 -triple x86_64-unknown-linux-gnu -Wno-unused-value -emit-llvm %s -o %t.ll
|
|
// RUN: FileCheck --input-file=%t.ll %s -check-prefix=OGCG
|
|
|
|
typedef int vi4 __attribute__((vector_size(16)));
|
|
typedef double vd2 __attribute__((vector_size(16)));
|
|
typedef long long vll2 __attribute__((vector_size(16)));
|
|
|
|
vi4 vec_a;
|
|
// CIR: cir.global external @[[VEC_A:.*]] = #cir.zero : !cir.vector<4 x !s32i>
|
|
|
|
// LLVM: @[[VEC_A:.*]] = dso_local global <4 x i32> zeroinitializer
|
|
|
|
// OGCG: @[[VEC_A:.*]] = global <4 x i32> zeroinitializer
|
|
|
|
vd2 b;
|
|
// CIR: cir.global external @[[VEC_B:.*]] = #cir.zero : !cir.vector<2 x !cir.double>
|
|
|
|
// LLVM: @[[VEC_B:.*]] = dso_local global <2 x double> zeroinitialize
|
|
|
|
// OGCG: @[[VEC_B:.*]] = global <2 x double> zeroinitializer
|
|
|
|
vll2 c;
|
|
// CIR: cir.global external @[[VEC_C:.*]] = #cir.zero : !cir.vector<2 x !s64i>
|
|
|
|
// LLVM: @[[VEC_C:.*]] = dso_local global <2 x i64> zeroinitialize
|
|
|
|
// OGCG: @[[VEC_C:.*]] = global <2 x i64> zeroinitializer
|
|
|
|
void vec_int_test() {
|
|
vi4 a;
|
|
vd2 b;
|
|
vll2 c;
|
|
}
|
|
|
|
// CIR: %[[VEC_A:.*]] = cir.alloca !cir.vector<4 x !s32i>, !cir.ptr<!cir.vector<4 x !s32i>>, ["a"]
|
|
// CIR: %[[VEC_B:.*]] = cir.alloca !cir.vector<2 x !cir.double>, !cir.ptr<!cir.vector<2 x !cir.double>>, ["b"]
|
|
// CIR: %[[VEC_C:.*]] = cir.alloca !cir.vector<2 x !s64i>, !cir.ptr<!cir.vector<2 x !s64i>>, ["c"]
|
|
|
|
// LLVM: %[[VEC_A:.*]] = alloca <4 x i32>, i64 1, align 16
|
|
// LLVM: %[[VEC_B:.*]] = alloca <2 x double>, i64 1, align 16
|
|
// LLVM: %[[VEC_C:.*]] = alloca <2 x i64>, i64 1, align 16
|
|
|
|
// OGCG: %[[VEC_A:.*]] = alloca <4 x i32>, align 16
|
|
// OGCG: %[[VEC_B:.*]] = alloca <2 x double>, align 16
|
|
// OGCG: %[[VEC_C:.*]] = alloca <2 x i64>, align 16
|
|
|
|
void foo2(vi4 p) {}
|
|
|
|
// CIR: %[[VEC_A:.*]] = cir.alloca !cir.vector<4 x !s32i>, !cir.ptr<!cir.vector<4 x !s32i>>, ["p", init]
|
|
// CIR: cir.store %{{.*}}, %[[VEC_A]] : !cir.vector<4 x !s32i>, !cir.ptr<!cir.vector<4 x !s32i>>
|
|
|
|
// LLVM: %[[VEC_A:.*]] = alloca <4 x i32>, i64 1, align 16
|
|
// LLVM: store <4 x i32> %{{.*}}, ptr %[[VEC_A]], align 16
|
|
|
|
// OGCG: %[[VEC_A:.*]] = alloca <4 x i32>, align 16
|
|
// OGCG: store <4 x i32> %{{.*}}, ptr %[[VEC_A]], align 16
|