Skip to content

Commit

Permalink
Proclaim pair and tuple trivially relocatable
Browse files Browse the repository at this point in the history
  • Loading branch information
bernhardmgruber committed Jul 19, 2024
1 parent fc457b4 commit 4d12f8c
Show file tree
Hide file tree
Showing 4 changed files with 92 additions and 0 deletions.
57 changes: 57 additions & 0 deletions thrust/testing/type_traits.cu
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,14 @@
#include <thrust/iterator/iterator_traits.h>
#include <thrust/iterator/transform_iterator.h>
#include <thrust/iterator/zip_iterator.h>
#include <thrust/pair.h>
#include <thrust/tuple.h>
#include <thrust/type_traits/is_contiguous_iterator.h>

#include <cuda/std/complex>
#include <cuda/std/tuple>
#include <cuda/std/utility>

#include <unittest/unittest.h>

void TestIsContiguousIterator()
Expand Down Expand Up @@ -146,3 +152,54 @@ void TestIsCommutative()
}
}
DECLARE_UNITTEST(TestIsCommutative);

using trivial_reloc_types = unittest::type_list<
int,
#if THRUST_DEVICE_SYSTEM == THRUST_DEVICE_SYSTEM_CUDA
int1,
int2,
int3,
int4,
#endif // THRUST_DEVICE_SYSTEM == THRUST_DEVICE_SYSTEM_CUDA
thrust::complex<int>,
::cuda::std::complex<int>,
thrust::pair<int, int>,
::cuda::std::pair<int, int>,
thrust::tuple<int, int>,
::cuda::std::tuple<int, int>>;

template <typename T, bool Expected>
constexpr void check_trivially_relocatable()
{
static_assert(::cuda::std::is_trivially_copyable<T>::value == Expected, "");
static_assert(thrust::is_trivially_relocatable<T>::value == Expected, "");
}

void TestTriviallyRelocatable()
{
static_assert(thrust::is_trivially_relocatable<int>::value, "");
#if THRUST_DEVICE_SYSTEM == THRUST_DEVICE_SYSTEM_CUDA
static_assert(thrust::is_trivially_relocatable<__half>::value, "");
static_assert(thrust::is_trivially_relocatable<int1>::value, "");
static_assert(thrust::is_trivially_relocatable<int2>::value, "");
static_assert(thrust::is_trivially_relocatable<int3>::value, "");
static_assert(thrust::is_trivially_relocatable<int4>::value, "");
static_assert(thrust::is_trivially_relocatable<__int128>::value, "");
#endif // THRUST_DEVICE_SYSTEM == THRUST_DEVICE_SYSTEM_CUDA
static_assert(thrust::is_trivially_relocatable<thrust::complex<float>>::value, "");
static_assert(thrust::is_trivially_relocatable<::cuda::std::complex<float>>::value, "");
static_assert(thrust::is_trivially_relocatable<thrust::pair<int, int>>::value, "");
static_assert(thrust::is_trivially_relocatable<::cuda::std::pair<int, int>>::value, "");
static_assert(thrust::is_trivially_relocatable<thrust::tuple<int, float, char>>::value, "");
static_assert(thrust::is_trivially_relocatable<::cuda::std::tuple<int, float, char>>::value, "");
static_assert(thrust::is_trivially_relocatable<
::cuda::std::tuple<thrust::pair<int, thrust::tuple<int, ::cuda::std::tuple<>>>,
thrust::tuple<::cuda::std::pair<int, thrust::tuple<>>, int>>>::value,
"");

static_assert(!thrust::is_trivially_relocatable<thrust::pair<int, std::string>>::value, "");
static_assert(!thrust::is_trivially_relocatable<::cuda::std::pair<int, std::string>>::value, "");
static_assert(!thrust::is_trivially_relocatable<thrust::tuple<int, float, std::string>>::value, "");
static_assert(!thrust::is_trivially_relocatable<::cuda::std::tuple<int, float, std::string>>::value, "");
};
DECLARE_UNITTEST(TestTriviallyRelocatable);
7 changes: 7 additions & 0 deletions thrust/thrust/pair.h
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,8 @@
# pragma system_header
#endif // no system header

#include <thrust/type_traits/is_trivially_relocatable.h>

#include <cuda/std/utility>

THRUST_NAMESPACE_BEGIN
Expand Down Expand Up @@ -117,6 +119,11 @@ make_pair(T1&& t1, T2&& t2)

using _CUDA_VSTD::get;

template <typename T, typename U>
struct proclaim_trivially_relocatable<pair<T, U>>
: ::cuda::std::conjunction<is_trivially_relocatable<T>, is_trivially_relocatable<U>>
{};

/*! \endcond
*/

Expand Down
6 changes: 6 additions & 0 deletions thrust/thrust/tuple.h
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,8 @@
# pragma system_header
#endif // no system header

#include <thrust/type_traits/is_trivially_relocatable.h>

#include <cuda/std/tuple>
#include <cuda/std/type_traits>
#include <cuda/std/utility>
Expand Down Expand Up @@ -232,6 +234,10 @@ inline _CCCL_HOST_DEVICE tuple<Ts&...> tie(Ts&... ts) noexcept

using _CUDA_VSTD::get;

template <typename... Ts>
struct proclaim_trivially_relocatable<tuple<Ts...>> : ::cuda::std::conjunction<is_trivially_relocatable<Ts>...>
{};

/*! \endcond
*/

Expand Down
22 changes: 22 additions & 0 deletions thrust/thrust/type_traits/is_trivially_relocatable.h
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,8 @@
#include <thrust/detail/type_traits.h>
#include <thrust/type_traits/is_contiguous_iterator.h>

#include <cuda/std/__type_traits/conjunction.h>

#include <type_traits>

THRUST_NAMESPACE_BEGIN
Expand Down Expand Up @@ -283,8 +285,28 @@ THRUST_PROCLAIM_TRIVIALLY_RELOCATABLE(double1)
THRUST_PROCLAIM_TRIVIALLY_RELOCATABLE(double2)
THRUST_PROCLAIM_TRIVIALLY_RELOCATABLE(double3)
THRUST_PROCLAIM_TRIVIALLY_RELOCATABLE(double4)

#endif

// forward declare libcu++ pair and tuple, so we don't need to include them, but we can proclaim them trivially
// relocatable
_LIBCUDACXX_BEGIN_NAMESPACE_STD
template <class _T1, class _T2>
struct _LIBCUDACXX_TEMPLATE_VIS pair;
template <class... _Tp>
class _LIBCUDACXX_TEMPLATE_VIS tuple;
_LIBCUDACXX_END_NAMESPACE_STD

template <typename T, typename U>
struct THRUST_NS_QUALIFIER::proclaim_trivially_relocatable<::cuda::std::pair<T, U>>
: ::cuda::std::conjunction<THRUST_NS_QUALIFIER::is_trivially_relocatable<T>, is_trivially_relocatable<U>>
{};

template <typename... Ts>
struct THRUST_NS_QUALIFIER::proclaim_trivially_relocatable<::cuda::std::tuple<Ts...>>
: ::cuda::std::conjunction<THRUST_NS_QUALIFIER::is_trivially_relocatable<Ts>...>
{};

/*! \endcond
*/

Expand Down

0 comments on commit 4d12f8c

Please sign in to comment.