1 //===----------------------------------------------------------------------===//
3 // The LLVM Compiler Infrastructure
5 // This file is dual licensed under the MIT and the University of Illinois Open
6 // Source Licenses. See LICENSE.TXT for details.
8 //===----------------------------------------------------------------------===//
10 // UNSUPPORTED: c++98, c++03, c++11, c++14
12 // <experimental/simd>
16 #include <experimental/simd>
19 namespace ex = std::experimental::parallelism_v2;
21 constexpr inline int reg_width() {
29 #ifndef _LIBCPP_HAS_NO_VECTOR_EXTENSION
32 sizeof(ex::simd<char, ex::__simd_abi<ex::_StorageKind::_VecExt, 1>>) == 1,
35 sizeof(ex::simd<char, ex::__simd_abi<ex::_StorageKind::_VecExt, 2>>) == 2,
38 sizeof(ex::simd<char, ex::__simd_abi<ex::_StorageKind::_VecExt, 3>>) == 4,
41 sizeof(ex::simd<char, ex::__simd_abi<ex::_StorageKind::_VecExt, 12>>) == 16,
44 sizeof(ex::simd<int32_t, ex::__simd_abi<ex::_StorageKind::_VecExt, 3>>) ==
48 sizeof(ex::simd<int32_t, ex::__simd_abi<ex::_StorageKind::_VecExt, 5>>) ==
52 std::is_same<ex::simd_abi::native<int8_t>,
53 ex::__simd_abi<ex::_StorageKind::_VecExt, reg_width()>>::value,
57 std::is_same<ex::simd_abi::native<int8_t>,
58 ex::__simd_abi<ex::_StorageKind::_Array, reg_width()>>::value,
63 static_assert(std::is_same<ex::simd_abi::compatible<int8_t>,
64 ex::__simd_abi<ex::_StorageKind::_Array, 16>>::value,