blob: 224cc75ba0eb0a5b15e2e6d3d1cfa42f613b3848 [file] [log] [blame] [edit]
// -*- C++ -*-
//===----------------------------------------------------------------------===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
#ifndef _LIBCPP_EXPERIMENTAL_SIMD
#define _LIBCPP_EXPERIMENTAL_SIMD
/*
experimental/simd synopsis
namespace std::experimental {
inline namespace parallelism_v2 {
namespace simd_abi {
using scalar = see below;
template<int N> using fixed_size = see below;
template<class T> inline constexpr int max_fixed_size = implementation-defined;
template<class T> using compatible = implementation-defined;
template<class T> using native = implementation-defined;
template<class T, size_t N, class... Abis> struct deduce { using type = see below; };
template<class T, size_t N, class... Abis> using deduce_t =
typename deduce<T, N, Abis...>::type;
} // namespace simd_abi
// class template simd [simd.class]
template <class T, class Abi = simd_abi::compatible<T>> class simd;
template <class T> using native_simd = simd<T, simd_abi::native<T>>;
template <class T, int N> using fixed_size_simd = simd<T, simd_abi::fixed_size<N>>;
// class template simd_mask [simd.mask.class]
template <class T, class Abi = simd_abi::compatible<T>> class simd_mask;
template <class T> using native_simd_mask = simd_mask<T, simd_abi::native<T>>;
template <class T, int N> using fixed_size_simd_mask = simd_mask<T, simd_abi::fixed_size<N>>;
// memory alignment
struct element_aligned_tag {};
struct vector_aligned_tag {};
template <size_t> struct overaligned_tag {};
inline constexpr element_aligned_tag element_aligned{};
inline constexpr vector_aligned_tag vector_aligned{};
template <size_t N> inline constexpr overaligned_tag<N> overaligned{};
// traits [simd.traits]
template<class T> struct is_abi_tag;
template<class T> inline constexpr bool is_abi_tag_v = is_abi_tag<T>::value;
template <class T> struct is_simd;
template <class T> inline constexpr bool is_simd_v = is_simd<T>::value;
template <class T> struct is_simd_mask;
template <class T> inline constexpr bool is_simd_mask_v = is_simd_mask<T>::value;
template<class T> struct is_simd_flag_type;
template<class T> inline constexpr bool is_simd_flag_type_v = is_simd_flag_type<T>::value;
template<class T, class Abi = simd_abi::compatible<T>> struct simd_size;
template<class T, class Abi = simd_abi::compatible<T>>
inline constexpr size_t simd_size_v = simd_size<T,Abi>::value;
template<class T, class U = typename T::value_type> struct memory_alignment;
template<class T, class U = typename T::value_type>
inline constexpr size_t memory_alignment_v = memory_alignment<T,U>::value;
} // namespace parallelism_v2
} // namespace std::experimental
*/
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
# pragma GCC system_header
#endif
#if __cplusplus < 201103L && defined(_LIBCPP_USE_FROZEN_CXX03_HEADERS)
# include <__cxx03/experimental/simd>
#else
# include <__config>
# include <experimental/__simd/aligned_tag.h>
# include <experimental/__simd/declaration.h>
# include <experimental/__simd/reference.h>
# include <experimental/__simd/scalar.h>
# include <experimental/__simd/simd.h>
# include <experimental/__simd/simd_mask.h>
# include <experimental/__simd/traits.h>
# include <experimental/__simd/vec_ext.h>
# if !defined(_LIBCPP_REMOVE_TRANSITIVE_INCLUDES) && _LIBCPP_STD_VER <= 20
# include <cstddef>
# endif
#endif // __cplusplus < 201103L && defined(_LIBCPP_USE_FROZEN_CXX03_HEADERS)
#endif /* _LIBCPP_EXPERIMENTAL_SIMD */