|
| 1 | +// RUN: %clang_cc1 -triple x86_64-unknown-linux-gnu -Wno-unused-value -fclangir -emit-cir %s -o %t.cir |
| 2 | +// RUN: FileCheck --input-file=%t.cir %s -check-prefix=CIR |
| 3 | +// RUN: %clang_cc1 -triple x86_64-unknown-linux-gnu -Wno-unused-value -fclangir -emit-llvm %s -o %t-cir.ll |
| 4 | +// RUN: FileCheck --input-file=%t-cir.ll %s -check-prefix=LLVM |
| 5 | +// RUN: %clang_cc1 -triple x86_64-unknown-linux-gnu -Wno-unused-value -emit-llvm %s -o %t.ll |
| 6 | +// RUN: FileCheck --input-file=%t.ll %s -check-prefix=OGCG |
| 7 | + |
| 8 | +typedef int vi4 __attribute__((ext_vector_type(4))); |
| 9 | +typedef int vi3 __attribute__((ext_vector_type(3))); |
| 10 | +typedef int vi2 __attribute__((ext_vector_type(2))); |
| 11 | +typedef double vd2 __attribute__((ext_vector_type(2))); |
| 12 | + |
| 13 | +vi4 vec_a; |
| 14 | +// CIR: cir.global external @[[VEC_A:.*]] = #cir.zero : !cir.vector<4 x !s32i> |
| 15 | + |
| 16 | +// LLVM: @[[VEC_A:.*]] = dso_local global <4 x i32> zeroinitializer |
| 17 | + |
| 18 | +// OGCG: @[[VEC_A:.*]] = global <4 x i32> zeroinitializer |
| 19 | + |
| 20 | +vi3 vec_b; |
| 21 | +// CIR: cir.global external @[[VEC_B:.*]] = #cir.zero : !cir.vector<3 x !s32i> |
| 22 | + |
| 23 | +// LLVM: @[[VEC_B:.*]] = dso_local global <3 x i32> zeroinitializer |
| 24 | + |
| 25 | +// OGCG: @[[VEC_B:.*]] = global <3 x i32> zeroinitializer |
| 26 | + |
| 27 | +vi2 vec_c; |
| 28 | +// CIR: cir.global external @[[VEC_C:.*]] = #cir.zero : !cir.vector<2 x !s32i> |
| 29 | + |
| 30 | +// LLVM: @[[VEC_C:.*]] = dso_local global <2 x i32> zeroinitializer |
| 31 | + |
| 32 | +// OGCG: @[[VEC_C:.*]] = global <2 x i32> zeroinitializer |
| 33 | + |
| 34 | +vd2 d; |
| 35 | + |
| 36 | +// CIR: cir.global external @[[VEC_D:.*]] = #cir.zero : !cir.vector<2 x !cir.double> |
| 37 | + |
| 38 | +// LLVM: @[[VEC_D:.*]] = dso_local global <2 x double> zeroinitialize |
| 39 | + |
| 40 | +// OGCG: @[[VEC_D:.*]] = global <2 x double> zeroinitializer |
| 41 | + |
| 42 | +void foo() { |
| 43 | + vi4 a; |
| 44 | + vi3 b; |
| 45 | + vi2 c; |
| 46 | + vd2 d; |
| 47 | +} |
| 48 | + |
| 49 | +// CIR: %[[VEC_A:.*]] = cir.alloca !cir.vector<4 x !s32i>, !cir.ptr<!cir.vector<4 x !s32i>>, ["a"] |
| 50 | +// CIR: %[[VEC_B:.*]] = cir.alloca !cir.vector<3 x !s32i>, !cir.ptr<!cir.vector<3 x !s32i>>, ["b"] |
| 51 | +// CIR: %[[VEC_C:.*]] = cir.alloca !cir.vector<2 x !s32i>, !cir.ptr<!cir.vector<2 x !s32i>>, ["c"] |
| 52 | +// CIR: %[[VEC_D:.*]] = cir.alloca !cir.vector<2 x !cir.double>, !cir.ptr<!cir.vector<2 x !cir.double>>, ["d"] |
| 53 | + |
| 54 | +// LLVM: %[[VEC_A:.*]] = alloca <4 x i32>, i64 1, align 16 |
| 55 | +// LLVM: %[[VEC_B:.*]] = alloca <3 x i32>, i64 1, align 16 |
| 56 | +// LLVM: %[[VEC_C:.*]] = alloca <2 x i32>, i64 1, align 8 |
| 57 | +// LLVM: %[[VEC_D:.*]] = alloca <2 x double>, i64 1, align 16 |
| 58 | + |
| 59 | +// OGCG: %[[VEC_A:.*]] = alloca <4 x i32>, align 16 |
| 60 | +// OGCG: %[[VEC_B:.*]] = alloca <3 x i32>, align 16 |
| 61 | +// OGCG: %[[VEC_C:.*]] = alloca <2 x i32>, align 8 |
| 62 | +// OGCG: %[[VEC_D:.*]] = alloca <2 x double>, align 16 |
| 63 | + |
| 64 | +void foo2(vi4 p) {} |
| 65 | + |
| 66 | +// CIR: %[[VEC_A:.*]] = cir.alloca !cir.vector<4 x !s32i>, !cir.ptr<!cir.vector<4 x !s32i>>, ["p", init] |
| 67 | +// CIR: cir.store %{{.*}}, %[[VEC_A]] : !cir.vector<4 x !s32i>, !cir.ptr<!cir.vector<4 x !s32i>> |
| 68 | + |
| 69 | +// LLVM: %[[VEC_A:.*]] = alloca <4 x i32>, i64 1, align 16 |
| 70 | +// LLVM: store <4 x i32> %{{.*}}, ptr %[[VEC_A]], align 16 |
| 71 | + |
| 72 | +// OGCG: %[[VEC_A:.*]] = alloca <4 x i32>, align 16 |
| 73 | +// OGCG: store <4 x i32> %{{.*}}, ptr %[[VEC_A]], align 16 |
0 commit comments