1e78f53d1SNikolas Klauser // -*- C++ -*- 2e78f53d1SNikolas Klauser //===----------------------------------------------------------------------===// 3e78f53d1SNikolas Klauser // 4e78f53d1SNikolas Klauser // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 5e78f53d1SNikolas Klauser // See https://llvm.org/LICENSE.txt for license information. 6e78f53d1SNikolas Klauser // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 7e78f53d1SNikolas Klauser // 8e78f53d1SNikolas Klauser //===----------------------------------------------------------------------===// 9e78f53d1SNikolas Klauser 10*ce777190SNikolas Klauser #ifndef _LIBCPP___CXX03_EXPERIMENTAL___SIMD_SCALAR_H 11*ce777190SNikolas Klauser #define _LIBCPP___CXX03_EXPERIMENTAL___SIMD_SCALAR_H 12e78f53d1SNikolas Klauser 1373fbae83SNikolas Klauser #include <__cxx03/__assert> 1473fbae83SNikolas Klauser #include <__cxx03/cstddef> 1573fbae83SNikolas Klauser #include <__cxx03/experimental/__config> 1673fbae83SNikolas Klauser #include <__cxx03/experimental/__simd/declaration.h> 1773fbae83SNikolas Klauser #include <__cxx03/experimental/__simd/traits.h> 18e78f53d1SNikolas Klauser 19e78f53d1SNikolas Klauser #if _LIBCPP_STD_VER >= 17 && defined(_LIBCPP_ENABLE_EXPERIMENTAL) 20e78f53d1SNikolas Klauser 21e78f53d1SNikolas Klauser _LIBCPP_BEGIN_NAMESPACE_EXPERIMENTAL 22e78f53d1SNikolas Klauser inline namespace parallelism_v2 { 23e78f53d1SNikolas Klauser namespace simd_abi { 24e78f53d1SNikolas Klauser struct __scalar { 25e78f53d1SNikolas Klauser static constexpr size_t __simd_size = 1; 26e78f53d1SNikolas Klauser }; 27e78f53d1SNikolas Klauser } // namespace simd_abi 28e78f53d1SNikolas Klauser 29e78f53d1SNikolas Klauser template <> 30e78f53d1SNikolas Klauser inline constexpr bool is_abi_tag_v<simd_abi::__scalar> = true; 31e78f53d1SNikolas Klauser 32e78f53d1SNikolas Klauser template <class _Tp> 33e78f53d1SNikolas Klauser struct __simd_storage<_Tp, simd_abi::__scalar> { 34e78f53d1SNikolas Klauser _Tp __data; 35e78f53d1SNikolas Klauser 36e78f53d1SNikolas Klauser _LIBCPP_HIDE_FROM_ABI _Tp __get([[maybe_unused]] size_t __idx) const noexcept { 37e78f53d1SNikolas Klauser _LIBCPP_ASSERT_UNCATEGORIZED(__idx == 0, "Index is out of bounds"); 38e78f53d1SNikolas Klauser return __data; 39e78f53d1SNikolas Klauser } 40e78f53d1SNikolas Klauser _LIBCPP_HIDE_FROM_ABI void __set([[maybe_unused]] size_t __idx, _Tp __v) noexcept { 41e78f53d1SNikolas Klauser _LIBCPP_ASSERT_UNCATEGORIZED(__idx == 0, "Index is out of bounds"); 42e78f53d1SNikolas Klauser __data = __v; 43e78f53d1SNikolas Klauser } 44e78f53d1SNikolas Klauser }; 45e78f53d1SNikolas Klauser 46e78f53d1SNikolas Klauser template <class _Tp> 47e78f53d1SNikolas Klauser struct __mask_storage<_Tp, simd_abi::__scalar> : __simd_storage<bool, simd_abi::__scalar> {}; 48e78f53d1SNikolas Klauser 49e78f53d1SNikolas Klauser template <class _Tp> 50e78f53d1SNikolas Klauser struct __simd_operations<_Tp, simd_abi::__scalar> { 51e78f53d1SNikolas Klauser using _SimdStorage = __simd_storage<_Tp, simd_abi::__scalar>; 52e78f53d1SNikolas Klauser using _MaskStorage = __mask_storage<_Tp, simd_abi::__scalar>; 53e78f53d1SNikolas Klauser 54e78f53d1SNikolas Klauser static _LIBCPP_HIDE_FROM_ABI _SimdStorage __broadcast(_Tp __v) noexcept { return {__v}; } 55e78f53d1SNikolas Klauser 56e78f53d1SNikolas Klauser template <class _Generator> 57e78f53d1SNikolas Klauser static _LIBCPP_HIDE_FROM_ABI _SimdStorage __generate(_Generator&& __g) noexcept { 58e78f53d1SNikolas Klauser return {__g(std::integral_constant<size_t, 0>())}; 59e78f53d1SNikolas Klauser } 60e78f53d1SNikolas Klauser 61e78f53d1SNikolas Klauser template <class _Up> 62e78f53d1SNikolas Klauser static _LIBCPP_HIDE_FROM_ABI void __load(_SimdStorage& __s, const _Up* __mem) noexcept { 63e78f53d1SNikolas Klauser __s.__data = static_cast<_Tp>(__mem[0]); 64e78f53d1SNikolas Klauser } 65e78f53d1SNikolas Klauser 66e78f53d1SNikolas Klauser template <class _Up> 67e78f53d1SNikolas Klauser static _LIBCPP_HIDE_FROM_ABI void __store(_SimdStorage __s, _Up* __mem) noexcept { 68e78f53d1SNikolas Klauser *__mem = static_cast<_Up>(__s.__data); 69e78f53d1SNikolas Klauser } 70e78f53d1SNikolas Klauser }; 71e78f53d1SNikolas Klauser 72e78f53d1SNikolas Klauser template <class _Tp> 73e78f53d1SNikolas Klauser struct __mask_operations<_Tp, simd_abi::__scalar> { 74e78f53d1SNikolas Klauser using _MaskStorage = __mask_storage<_Tp, simd_abi::__scalar>; 75e78f53d1SNikolas Klauser 76e78f53d1SNikolas Klauser static _LIBCPP_HIDE_FROM_ABI _MaskStorage __broadcast(bool __v) noexcept { return {__v}; } 77e78f53d1SNikolas Klauser 78e78f53d1SNikolas Klauser static _LIBCPP_HIDE_FROM_ABI void __load(_MaskStorage& __s, const bool* __mem) noexcept { __s.__data = __mem[0]; } 79e78f53d1SNikolas Klauser 80e78f53d1SNikolas Klauser static _LIBCPP_HIDE_FROM_ABI void __store(_MaskStorage __s, bool* __mem) noexcept { __mem[0] = __s.__data; } 81e78f53d1SNikolas Klauser }; 82e78f53d1SNikolas Klauser 83e78f53d1SNikolas Klauser } // namespace parallelism_v2 84e78f53d1SNikolas Klauser _LIBCPP_END_NAMESPACE_EXPERIMENTAL 85e78f53d1SNikolas Klauser 86e78f53d1SNikolas Klauser #endif // _LIBCPP_STD_VER >= 17 && defined(_LIBCPP_ENABLE_EXPERIMENTAL) 87*ce777190SNikolas Klauser #endif // _LIBCPP___CXX03_EXPERIMENTAL___SIMD_SCALAR_H 88