// The Construct // // Copyright (C) The Construct Developers, Authors & Contributors // Copyright (C) 2016-2020 Jason Volk // // Permission to use, copy, modify, and/or distribute this software for any // purpose with or without fee is hereby granted, provided that the above // copyright notice and this permission notice is present in all copies. The // full license for this software is available in the LICENSE file. #pragma once #define HAVE_IRCD_SIMD_SUM_H namespace ircd::simd { template T sum_or(T) noexcept; template T sum_and(T) noexcept; template T sum_xor(T) noexcept; } template [[using gnu: always_inline, gnu_inline, artificial]] extern inline T ircd::simd::sum_and(T a) noexcept { for(size_t i(0); i < lanes(); ++i) if(i != idx) a[idx] &= a[i]; return a; } template [[using gnu: always_inline, gnu_inline, artificial]] extern inline T ircd::simd::sum_or(T a) noexcept { for(size_t i(0); i < lanes(); ++i) if(i != idx) a[idx] |= a[i]; return a; } template [[using gnu: always_inline, gnu_inline, artificial]] extern inline T ircd::simd::sum_xor(T a) noexcept { for(size_t i(0); i < lanes(); ++i) if(i != idx) a[idx] ^= a[i]; return a; }