| 1 | // RUN: %clang_cc1 -triple x86_64-unknown-unknown %s -emit-llvm -o - | FileCheck %s |
| 2 | |
| 3 | typedef int __attribute__((mode(byte))) __attribute__((vector_size(4))) vec_t1; |
| 4 | typedef int __attribute__((mode(QI))) __attribute__((vector_size(8))) vec_t2; |
| 5 | typedef int __attribute__((mode(SI))) __attribute__((vector_size(16))) vec_t3; |
| 6 | typedef int __attribute__((mode(DI))) __attribute__((vector_size(64)))vec_t4; |
| 7 | typedef float __attribute__((mode(SF))) __attribute__((vector_size(128))) vec_t5; |
| 8 | typedef float __attribute__((mode(DF))) __attribute__((vector_size(256))) vec_t6; |
| 9 | |
| 10 | void check() { |
| 11 | // CHECK: alloca <4 x i8> |
| 12 | vec_t1 v1; |
| 13 | // CHECK: alloca <8 x i8> |
| 14 | vec_t2 v2; |
| 15 | // CHECK: alloca <4 x i32> |
| 16 | vec_t3 v3; |
| 17 | // CHECK: alloca <8 x i64> |
| 18 | vec_t4 v4; |
| 19 | // CHECK: alloca <32 x float> |
| 20 | vec_t5 v5; |
| 21 | // CHECK: alloca <32 x double> |
| 22 | vec_t6 v6; |
| 23 | } |
| 24 | |
| 25 | // CHECK: ret i32 4 |
| 26 | int check_size1() { return sizeof(vec_t1); } |
| 27 | |
| 28 | // CHECK: ret i32 8 |
| 29 | int check_size2() { return sizeof(vec_t2); } |
| 30 | |
| 31 | // CHECK: ret i32 16 |
| 32 | int check_size3() { return sizeof(vec_t3); } |
| 33 | |
| 34 | // CHECK: ret i32 64 |
| 35 | int check_size4() { return sizeof(vec_t4); } |
| 36 | |
| 37 | // CHECK: ret i32 128 |
| 38 | int check_size5() { return sizeof(vec_t5); } |
| 39 | |
| 40 | // CHECK: ret i32 256 |
| 41 | int check_size6() { return sizeof(vec_t6); } |
| 42 | |