mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-28 14:46:10 +00:00

This is the `ext_vector_type` alternative to D81083. This patch extends Clang to allow 'bool' as a valid vector element type (attribute ext_vector_type) in C/C++. This is intended as the canonical type for SIMD masks and facilitates clean vector intrinsic declarations. Vectors of i1 are supported on IR level and below down to many SIMD ISAs, such as AVX512, ARM SVE (fixed vector length) and the VE target (NEC SX-Aurora TSUBASA). The RFC on cfe-dev: https://lists.llvm.org/pipermail/cfe-dev/2020-May/065434.html Reviewed By: erichkeane Differential Revision: https://reviews.llvm.org/D88905
12 lines
457 B
C
12 lines
457 B
C
// RUN: %clang_cc1 -triple x86_64-linux-pc -emit-llvm -debug-info-kind=limited %s -o - | FileCheck %s
|
|
typedef _Bool bool512 __attribute__((ext_vector_type(512)));
|
|
|
|
bool512 b;
|
|
|
|
// Test that we get bit-sized bool elements on x86
|
|
// CHECK: !DICompositeType(tag: DW_TAG_array_type,
|
|
// CHECK-SAME: baseType: ![[BOOL:[0-9]+]]
|
|
// CHECK-SAME: size: 512
|
|
// CHECK-SAME: DIFlagVector
|
|
// CHECK: ![[BOOL]] = !DIBasicType(name: "char"
|