2021-10-14 19:04:33 +08:00
|
|
|
// RUN: %clang_cc1 -triple aarch64-none-linux-gnu -target-feature +sve -mvscale-min=1 -mvscale-max=1 -flax-vector-conversions=none -fallow-half-arguments-and-returns -ffreestanding -fsyntax-only -verify %s
|
|
|
|
// RUN: %clang_cc1 -triple aarch64-none-linux-gnu -target-feature +sve -mvscale-min=2 -mvscale-max=2 -flax-vector-conversions=none -fallow-half-arguments-and-returns -ffreestanding -fsyntax-only -verify %s
|
|
|
|
// RUN: %clang_cc1 -triple aarch64-none-linux-gnu -target-feature +sve -mvscale-min=4 -mvscale-max=4 -flax-vector-conversions=none -fallow-half-arguments-and-returns -ffreestanding -fsyntax-only -verify %s
|
|
|
|
// RUN: %clang_cc1 -triple aarch64-none-linux-gnu -target-feature +sve -mvscale-min=8 -mvscale-max=8 -flax-vector-conversions=none -fallow-half-arguments-and-returns -ffreestanding -fsyntax-only -verify %s
|
|
|
|
// RUN: %clang_cc1 -triple aarch64-none-linux-gnu -target-feature +sve -mvscale-min=16 -mvscale-max=16 -flax-vector-conversions=none -fallow-half-arguments-and-returns -ffreestanding -fsyntax-only -verify %s
|
2020-11-17 20:33:56 +08:00
|
|
|
|
|
|
|
// expected-no-diagnostics
|
|
|
|
|
|
|
|
#include <arm_sve.h>
|
|
|
|
|
|
|
|
#define N __ARM_FEATURE_SVE_BITS
|
|
|
|
#define FIXED_ATTR __attribute__((arm_sve_vector_bits(N)))
|
|
|
|
|
|
|
|
typedef svfloat32_t fixed_float32_t FIXED_ATTR;
|
|
|
|
typedef svfloat64_t fixed_float64_t FIXED_ATTR;
|
|
|
|
typedef svint32_t fixed_int32_t FIXED_ATTR;
|
|
|
|
typedef svint64_t fixed_int64_t FIXED_ATTR;
|
|
|
|
|
|
|
|
// SVE VLSTs can be cast to SVE VLATs, regardless of lane size.
|
|
|
|
// NOTE: the list below is NOT exhaustive for all SVE types.
|
|
|
|
|
|
|
|
#define CAST(from, to) \
|
|
|
|
void from##_to_##to(from a, to b) { \
|
|
|
|
b = (to) a; \
|
|
|
|
}
|
|
|
|
|
|
|
|
#define TESTCASE(ty1, ty2) \
|
|
|
|
CAST(ty1, ty2) \
|
|
|
|
CAST(ty2, ty1)
|
|
|
|
|
|
|
|
TESTCASE(fixed_float32_t, svfloat32_t)
|
|
|
|
TESTCASE(fixed_float32_t, svfloat64_t)
|
|
|
|
TESTCASE(fixed_float32_t, svint32_t)
|
|
|
|
TESTCASE(fixed_float32_t, svint64_t)
|
|
|
|
|
|
|
|
TESTCASE(fixed_float64_t, svfloat32_t)
|
|
|
|
TESTCASE(fixed_float64_t, svfloat64_t)
|
|
|
|
TESTCASE(fixed_float64_t, svint32_t)
|
|
|
|
TESTCASE(fixed_float64_t, svint64_t)
|
|
|
|
|
|
|
|
TESTCASE(fixed_int32_t, svfloat32_t)
|
|
|
|
TESTCASE(fixed_int32_t, svfloat64_t)
|
|
|
|
TESTCASE(fixed_int32_t, svint32_t)
|
|
|
|
TESTCASE(fixed_int32_t, svint64_t)
|
|
|
|
|
|
|
|
TESTCASE(fixed_int64_t, svfloat32_t)
|
|
|
|
TESTCASE(fixed_int64_t, svfloat64_t)
|
|
|
|
TESTCASE(fixed_int64_t, svint32_t)
|
|
|
|
TESTCASE(fixed_int64_t, svint64_t)
|