From 2e362e8f5626889825881bed208bb6ce16a0209b Mon Sep 17 00:00:00 2001 From: ptaylor Date: Sat, 19 Sep 2020 18:01:53 -0700 Subject: [PATCH 01/13] update to official libcu++ on github --- cpp/include/cudf/fixed_point/fixed_point.hpp | 44 ++++++++--------- cpp/include/cudf/utilities/traits.hpp | 8 ++-- cpp/include/cudf/wrappers/durations.hpp | 15 +++--- cpp/include/cudf/wrappers/timestamps.hpp | 17 +++---- cpp/src/binaryop/jit/code/kernel.cpp | 2 +- cpp/src/binaryop/jit/code/operation.cpp | 10 ++-- cpp/src/binaryop/jit/code/traits.cpp | 26 +++++----- cpp/src/datetime/datetime_ops.cu | 14 +++--- cpp/src/io/csv/datetime.cuh | 4 +- cpp/src/io/csv/durations.cu | 20 ++++---- cpp/src/strings/convert/convert_datetime.cu | 6 +-- cpp/src/strings/convert/convert_durations.cu | 48 +++++++++---------- cpp/src/transform/jit/code/kernel.cpp | 2 +- cpp/src/unary/cast_ops.cu | 8 ++-- cpp/tests/datetime/datetime_ops_test.cpp | 26 +++++----- cpp/tests/io/csv_test.cpp | 14 +++--- .../integration/unary-transform-test.cpp | 4 +- cpp/tests/utilities/timestamp_utilities.cuh | 14 +++--- cpp/tests/wrappers/timestamps_test.cu | 4 +- thirdparty/CMakeLists.txt | 4 +- 20 files changed, 141 insertions(+), 149 deletions(-) diff --git a/cpp/include/cudf/fixed_point/fixed_point.hpp b/cpp/include/cudf/fixed_point/fixed_point.hpp index 2ae6c277056..eb19defef7f 100644 --- a/cpp/include/cudf/fixed_point/fixed_point.hpp +++ b/cpp/include/cudf/fixed_point/fixed_point.hpp @@ -16,12 +16,10 @@ #pragma once -#define _LIBCUDACXX_USE_CXX17_TYPE_TRAITS - -// Note: The versions are used in order for Jitify to work with our fixed_point type. +// Note: The versions are used in order for Jitify to work with our fixed_point type. // Jitify is needed for several algorithms (binaryop, rolling, etc) -#include -#include // add simt namespace +#include +#include // add cuda namespace #include #include @@ -60,13 +58,13 @@ enum class Radix : int32_t { BASE_2 = 2, BASE_10 = 10 }; template constexpr inline auto is_supported_representation_type() { - return simt::std::is_same::value || simt::std::is_same::value; + return cuda::std::is_same::value || cuda::std::is_same::value; } template constexpr inline auto is_supported_construction_value_type() { - return simt::std::is_integral::value || simt::std::is_floating_point::value; + return cuda::std::is_integral::value || cuda::std::is_floating_point::value; } // Helper functions for `fixed_point` type @@ -87,7 +85,7 @@ namespace detail { template ::value && + typename cuda::std::enable_if_t<(cuda::std::is_same::value && is_supported_representation_type())>* = nullptr> CUDA_HOST_DEVICE_CALLABLE Rep ipow(T exponent) { @@ -209,7 +207,7 @@ CUDA_HOST_DEVICE_CALLABLE constexpr T shift(T const& val, scale_type const& scal template ::value>* = nullptr> + typename cuda::std::enable_if_t::value>* = nullptr> CUDA_HOST_DEVICE_CALLABLE auto shift_with_precise_round(T const& value, scale_type const& scale) -> Rep { @@ -237,7 +235,7 @@ CUDA_HOST_DEVICE_CALLABLE auto shift_with_precise_round(T const& value, scale_ty template ::value>* = nullptr> + typename cuda::std::enable_if_t::value>* = nullptr> CUDA_HOST_DEVICE_CALLABLE auto shift_with_precise_round(T const& value, scale_type const& scale) -> Rep { @@ -265,7 +263,7 @@ CUDA_HOST_DEVICE_CALLABLE auto shift_with_precise_round(T const& value, scale_ty * @tparam Rep The representation type (either `int32_t` or `int64_t`) */ template ()>* = nullptr> + typename cuda::std::enable_if_t()>* = nullptr> struct scaled_integer { Rep value; scale_type scale; @@ -295,7 +293,7 @@ class fixed_point { * @param scale The exponent that is applied to Rad to perform shifting */ template () && + typename cuda::std::enable_if_t() && is_supported_representation_type()>* = nullptr> CUDA_HOST_DEVICE_CALLABLE explicit fixed_point(T const& value, scale_type const& scale) : _value{detail::shift_with_precise_round(value, scale)}, _scale{scale} @@ -316,7 +314,7 @@ class fixed_point { * value and scale of zero */ template ()>* = nullptr> + typename cuda::std::enable_if_t()>* = nullptr> CUDA_HOST_DEVICE_CALLABLE fixed_point(T const& value) : _value{static_cast(value)}, _scale{scale_type{0}} { @@ -336,7 +334,7 @@ class fixed_point { * @return The `fixed_point` number in base 10 (aka human readable format) */ template ()>* = nullptr> + typename cuda::std::enable_if_t()>* = nullptr> CUDA_HOST_DEVICE_CALLABLE explicit constexpr operator U() const { return detail::shift(static_cast(_value), detail::negate(_scale)); @@ -592,9 +590,9 @@ class fixed_point { template std::string print_rep() { - if (simt::std::is_same::value) + if (cuda::std::is_same::value) return "int32_t"; - else if (simt::std::is_same::value) + else if (cuda::std::is_same::value) return "int64_t"; else return "unknown type"; @@ -611,8 +609,8 @@ std::string print_rep() template CUDA_HOST_DEVICE_CALLABLE auto addition_overflow(T lhs, T rhs) { - return rhs > 0 ? lhs > simt::std::numeric_limits::max() - rhs - : lhs < simt::std::numeric_limits::min() - rhs; + return rhs > 0 ? lhs > cuda::std::numeric_limits::max() - rhs + : lhs < cuda::std::numeric_limits::min() - rhs; } /** @brief Function for identifying integer overflow when subtracting @@ -626,8 +624,8 @@ CUDA_HOST_DEVICE_CALLABLE auto addition_overflow(T lhs, T rhs) template CUDA_HOST_DEVICE_CALLABLE auto subtraction_overflow(T lhs, T rhs) { - return rhs > 0 ? lhs < simt::std::numeric_limits::min() + rhs - : lhs > simt::std::numeric_limits::max() + rhs; + return rhs > 0 ? lhs < cuda::std::numeric_limits::min() + rhs + : lhs > cuda::std::numeric_limits::max() + rhs; } /** @brief Function for identifying integer overflow when dividing @@ -641,7 +639,7 @@ CUDA_HOST_DEVICE_CALLABLE auto subtraction_overflow(T lhs, T rhs) template CUDA_HOST_DEVICE_CALLABLE auto division_overflow(T lhs, T rhs) { - return lhs == simt::std::numeric_limits::min() && rhs == -1; + return lhs == cuda::std::numeric_limits::min() && rhs == -1; } /** @brief Function for identifying integer overflow when multiplying @@ -655,8 +653,8 @@ CUDA_HOST_DEVICE_CALLABLE auto division_overflow(T lhs, T rhs) template CUDA_HOST_DEVICE_CALLABLE auto multiplication_overflow(T lhs, T rhs) { - auto const min = simt::std::numeric_limits::min(); - auto const max = simt::std::numeric_limits::max(); + auto const min = cuda::std::numeric_limits::min(); + auto const max = cuda::std::numeric_limits::max(); if (rhs > 0) return lhs > max / rhs || lhs < min / rhs; else if (rhs < -1) diff --git a/cpp/include/cudf/utilities/traits.hpp b/cpp/include/cudf/utilities/traits.hpp index a0d5bb61591..6d832c54e66 100644 --- a/cpp/include/cudf/utilities/traits.hpp +++ b/cpp/include/cudf/utilities/traits.hpp @@ -23,8 +23,8 @@ #include #include -#include -#include "cudf/structs/struct_view.hpp" +#include +#include namespace cudf { @@ -65,14 +65,14 @@ struct is_equality_comparable_impl>> : st }; template -using is_timestamp_t = simt::std::disjunction, +using is_timestamp_t = cuda::std::disjunction, std::is_same, std::is_same, std::is_same, std::is_same>; template -using is_duration_t = simt::std::disjunction, +using is_duration_t = cuda::std::disjunction, std::is_same, std::is_same, std::is_same, diff --git a/cpp/include/cudf/wrappers/durations.hpp b/cpp/include/cudf/wrappers/durations.hpp index fa533f9d474..2b971a78306 100644 --- a/cpp/include/cudf/wrappers/durations.hpp +++ b/cpp/include/cudf/wrappers/durations.hpp @@ -18,10 +18,7 @@ #include -#define _LIBCUDACXX_USE_CXX20_CHRONO -#define _LIBCUDACXX_USE_CXX17_TYPE_TRAITS - -#include +#include /** * @file durations.hpp @@ -36,23 +33,23 @@ namespace cudf { /** * @brief Type alias representing an int32_t duration of days. **/ -using duration_D = simt::std::chrono::duration; +using duration_D = cuda::std::chrono::duration; /** * @brief Type alias representing an int64_t duration of seconds. **/ -using duration_s = simt::std::chrono::duration; +using duration_s = cuda::std::chrono::duration; /** * @brief Type alias representing an int64_t duration of milliseconds. **/ -using duration_ms = simt::std::chrono::duration; +using duration_ms = cuda::std::chrono::duration; /** * @brief Type alias representing an int64_t duration of microseconds. **/ -using duration_us = simt::std::chrono::duration; +using duration_us = cuda::std::chrono::duration; /** * @brief Type alias representing an int64_t duration of nanoseconds. **/ -using duration_ns = simt::std::chrono::duration; +using duration_ns = cuda::std::chrono::duration; static_assert(sizeof(duration_D) == sizeof(typename duration_D::rep), ""); static_assert(sizeof(duration_s) == sizeof(typename duration_s::rep), ""); diff --git a/cpp/include/cudf/wrappers/timestamps.hpp b/cpp/include/cudf/wrappers/timestamps.hpp index b86c2218963..ab6122d31f2 100644 --- a/cpp/include/cudf/wrappers/timestamps.hpp +++ b/cpp/include/cudf/wrappers/timestamps.hpp @@ -18,10 +18,7 @@ #include -#define _LIBCUDACXX_USE_CXX20_CHRONO -#define _LIBCUDACXX_USE_CXX17_TYPE_TRAITS - -#include +#include /** * @file timestamps.hpp @@ -32,7 +29,7 @@ namespace cudf { namespace detail { // TODO: Use chrono::utc_clock when available in libcu++? template -using time_point = simt::std::chrono::sys_time; +using time_point = cuda::std::chrono::sys_time; template struct timestamp : time_point { @@ -60,27 +57,27 @@ struct timestamp : time_point { * epoch. **/ using timestamp_D = - detail::timestamp>>; + detail::timestamp>>; /** * @brief Type alias representing an int64_t duration of seconds since the * unix epoch. **/ -using timestamp_s = detail::timestamp>>; +using timestamp_s = detail::timestamp>>; /** * @brief Type alias representing an int64_t duration of milliseconds since * the unix epoch. **/ -using timestamp_ms = detail::timestamp>; +using timestamp_ms = detail::timestamp>; /** * @brief Type alias representing an int64_t duration of microseconds since * the unix epoch. **/ -using timestamp_us = detail::timestamp>; +using timestamp_us = detail::timestamp>; /** * @brief Type alias representing an int64_t duration of nanoseconds since * the unix epoch. **/ -using timestamp_ns = detail::timestamp>; +using timestamp_ns = detail::timestamp>; static_assert(sizeof(timestamp_D) == sizeof(typename timestamp_D::rep), ""); static_assert(sizeof(timestamp_s) == sizeof(typename timestamp_s::rep), ""); diff --git a/cpp/src/binaryop/jit/code/kernel.cpp b/cpp/src/binaryop/jit/code/kernel.cpp index ba7ab305de4..d41729172b4 100644 --- a/cpp/src/binaryop/jit/code/kernel.cpp +++ b/cpp/src/binaryop/jit/code/kernel.cpp @@ -27,7 +27,7 @@ namespace code { const char* kernel = R"***( #include - #include + #include #include #include #include diff --git a/cpp/src/binaryop/jit/code/operation.cpp b/cpp/src/binaryop/jit/code/operation.cpp index 5d930afc1c6..b8e42747296 100644 --- a/cpp/src/binaryop/jit/code/operation.cpp +++ b/cpp/src/binaryop/jit/code/operation.cpp @@ -28,7 +28,7 @@ const char* operation = #include #include #include "traits.h" - using namespace simt::std; + using namespace cuda::std; struct Add { // Allow sum between chronos only when both input and output types @@ -514,9 +514,9 @@ const char* operation = template ::type>)>* = nullptr> + enable_if_t<(is_integral_v::type>)>* = nullptr> static TypeOut operate(TypeLhs x, TypeRhs y) { - using common_t = typename simt::std::common_type::type; + using common_t = typename cuda::std::common_type::type; common_t xconv{x}; common_t yconv{y}; auto rem = xconv % yconv; @@ -527,9 +527,9 @@ const char* operation = template ::type>)>* = nullptr> + enable_if_t::type>)>* = nullptr> static TypeOut operate(TypeLhs x, TypeRhs y) { - using common_t = typename simt::std::common_type::type; + using common_t = typename cuda::std::common_type::type; common_t xconv{x}; common_t yconv{y}; auto rem = std::fmod(xconv, yconv); diff --git a/cpp/src/binaryop/jit/code/traits.cpp b/cpp/src/binaryop/jit/code/traits.cpp index da826c43ec3..9ff7ddda652 100644 --- a/cpp/src/binaryop/jit/code/traits.cpp +++ b/cpp/src/binaryop/jit/code/traits.cpp @@ -25,16 +25,16 @@ const char* traits = R"***( #pragma once #include - #include + #include // ------------------------------------------------------------------------- // Simplifying std::is_integral template - constexpr bool is_integral_v = simt::std::is_integral::value; + constexpr bool is_integral_v = cuda::std::is_integral::value; // Simplifying std::is_floating_point template - constexpr bool is_floating_point_v = simt::std::is_floating_point::value; + constexpr bool is_floating_point_v = cuda::std::is_floating_point::value; // ------------------------------------------------------------------------- // type_traits cannot tell the difference between float and double @@ -43,19 +43,19 @@ const char* traits = template constexpr bool is_timestamp_v = - simt::std::is_same::value || - simt::std::is_same::value || - simt::std::is_same::value || - simt::std::is_same::value || - simt::std::is_same::value; + cuda::std::is_same::value || + cuda::std::is_same::value || + cuda::std::is_same::value || + cuda::std::is_same::value || + cuda::std::is_same::value; template constexpr bool is_duration_v = - simt::std::is_same::value || - simt::std::is_same::value || - simt::std::is_same::value || - simt::std::is_same::value || - simt::std::is_same::value; + cuda::std::is_same::value || + cuda::std::is_same::value || + cuda::std::is_same::value || + cuda::std::is_same::value || + cuda::std::is_same::value; template constexpr bool is_chrono_v = is_timestamp_v || is_duration_v; diff --git a/cpp/src/datetime/datetime_ops.cu b/cpp/src/datetime/datetime_ops.cu index 919d1d4eacc..0dcfc76214c 100644 --- a/cpp/src/datetime/datetime_ops.cu +++ b/cpp/src/datetime/datetime_ops.cu @@ -46,7 +46,7 @@ struct extract_component_operator { template CUDA_DEVICE_CALLABLE int16_t operator()(Timestamp const ts) const { - using namespace simt::std::chrono; + using namespace cuda::std::chrono; auto days_since_epoch = floor(ts); @@ -81,7 +81,7 @@ static __device__ int16_t const days_until_month[2][13] = { {0, 31, 60, 91, 121, 152, 182, 213, 244, 274, 305, 335, 366} // For leap years }; -CUDA_DEVICE_CALLABLE uint8_t days_in_month(simt::std::chrono::month mon, bool is_leap_year) +CUDA_DEVICE_CALLABLE uint8_t days_in_month(cuda::std::chrono::month mon, bool is_leap_year) { return days_until_month[is_leap_year][unsigned{mon}] - days_until_month[is_leap_year][unsigned{mon} - 1]; @@ -93,7 +93,7 @@ struct extract_last_day_of_month { template CUDA_DEVICE_CALLABLE timestamp_D operator()(Timestamp const ts) const { - using namespace simt::std::chrono; + using namespace cuda::std::chrono; // IDEAL: does not work with CUDA10.0 due to nvcc compiler bug // cannot invoke ym_last_day.day() // const year_month_day orig_ymd(floor(ts)); @@ -114,7 +114,7 @@ struct extract_day_num_of_year { template CUDA_DEVICE_CALLABLE int16_t operator()(Timestamp const ts) const { - using namespace simt::std::chrono; + using namespace cuda::std::chrono; // Only has the days - time component is chopped off, which is what we want auto const days_since_epoch = floor(ts); @@ -189,9 +189,9 @@ struct add_calendrical_months_functor { // std chrono implementation is copied here due to nvcc bug 2909685 // https://howardhinnant.github.io/date_algorithms.html#days_from_civil static CUDA_DEVICE_CALLABLE timestamp_D - compute_sys_days(simt::std::chrono::year_month_day const& ymd) + compute_sys_days(cuda::std::chrono::year_month_day const& ymd) { - const int yr = static_cast(ymd.year()) - (ymd.month() <= simt::std::chrono::month{2}); + const int yr = static_cast(ymd.year()) - (ymd.month() <= cuda::std::chrono::month{2}); const unsigned mth = static_cast(ymd.month()); const unsigned dy = static_cast(ymd.day()); @@ -219,7 +219,7 @@ struct add_calendrical_months_functor { months_column.begin(), output.begin(), [] __device__(auto time_val, auto months_val) { - using namespace simt::std::chrono; + using namespace cuda::std::chrono; using duration_m = duration; // Get the days component from the input diff --git a/cpp/src/io/csv/datetime.cuh b/cpp/src/io/csv/datetime.cuh index 1f3b817cc23..d1b914eb8c6 100644 --- a/cpp/src/io/csv/datetime.cuh +++ b/cpp/src/io/csv/datetime.cuh @@ -465,8 +465,8 @@ __inline__ __device__ int64_t parseTimeDeltaFormat(const char *data, long start, nanosecond *= powers_of_ten[9 - num_digits]; } - return simt::std::chrono::duration_cast( + return cuda::std::chrono::duration_cast( cudf::duration_s{((days * 24L + hour) * 60L + minute) * 60L + second}) .count() + - simt::std::chrono::duration_cast(cudf::duration_ns{nanosecond}).count(); + cuda::std::chrono::duration_cast(cudf::duration_ns{nanosecond}).count(); } diff --git a/cpp/src/io/csv/durations.cu b/cpp/src/io/csv/durations.cu index 839a013c784..0e862d39552 100644 --- a/cpp/src/io/csv/durations.cu +++ b/cpp/src/io/csv/durations.cu @@ -43,25 +43,25 @@ template __device__ void dissect_duration(T duration, duration_component* timeparts) { timeparts->is_negative = (duration < T{0}); - timeparts->day = simt::std::chrono::floor(duration).count(); + timeparts->day = cuda::std::chrono::floor(duration).count(); - if (simt::std::is_same::value) return; + if (cuda::std::is_same::value) return; // adjust for pandas format if (timeparts->is_negative) { duration = - simt::std::chrono::duration_cast(duration % duration_D(1) + simt::std::chrono::hours(24)); + cuda::std::chrono::duration_cast(duration % duration_D(1) + cuda::std::chrono::hours(24)); } - duration_s seconds = simt::std::chrono::duration_cast(duration); + duration_s seconds = cuda::std::chrono::duration_cast(duration); timeparts->hour = - (simt::std::chrono::duration_cast(seconds) % duration_D(1)).count(); - timeparts->minute = (simt::std::chrono::duration_cast(seconds) % - simt::std::chrono::hours(1)) + (cuda::std::chrono::duration_cast(seconds) % duration_D(1)).count(); + timeparts->minute = (cuda::std::chrono::duration_cast(seconds) % + cuda::std::chrono::hours(1)) .count(); - timeparts->second = (seconds % simt::std::chrono::minutes(1)).count(); - if (not simt::std::is_same::value) { + timeparts->second = (seconds % cuda::std::chrono::minutes(1)).count(); + if (not cuda::std::is_same::value) { timeparts->nanosecond = - (simt::std::chrono::duration_cast(duration) % duration_s(1)).count(); + (cuda::std::chrono::duration_cast(duration) % duration_s(1)).count(); } } diff --git a/cpp/src/strings/convert/convert_datetime.cu b/cpp/src/strings/convert/convert_datetime.cu index b98ba33e48e..d87b453af97 100644 --- a/cpp/src/strings/convert/convert_datetime.cu +++ b/cpp/src/strings/convert/convert_datetime.cu @@ -437,7 +437,7 @@ struct datetime_formatter { __device__ cudf::timestamp_D::duration convert_to_days(int64_t timestamp, timestamp_units units) { - using namespace simt::std::chrono; + using namespace cuda::std::chrono; using minutes = duration; using hours = duration; switch (units) { @@ -452,7 +452,7 @@ struct datetime_formatter { } // divide timestamp integer into time components (year, month, day, etc) - // TODO call the simt::std::chrono methods here instead when they are ready + // TODO call the cuda::std::chrono methods here instead when they are ready __device__ void dissect_timestamp(int64_t timestamp, int32_t* timeparts) { if (units == timestamp_units::years) { @@ -493,7 +493,7 @@ struct datetime_formatter { // first, convert to days so we can handle months, years, day of the year. auto const days = convert_to_days(timestamp, units); - auto const ymd = simt::std::chrono::year_month_day(simt::std::chrono::sys_days(days)); + auto const ymd = cuda::std::chrono::year_month_day(cuda::std::chrono::sys_days(days)); auto const year = static_cast(ymd.year()); auto const month = static_cast(ymd.month()); auto const day = static_cast(ymd.day()); diff --git a/cpp/src/strings/convert/convert_durations.cu b/cpp/src/strings/convert/convert_durations.cu index ba444c4ebe0..ced87d331e4 100644 --- a/cpp/src/strings/convert/convert_durations.cu +++ b/cpp/src/strings/convert/convert_durations.cu @@ -158,18 +158,18 @@ template __device__ void dissect_duration(T duration, duration_component* timeparts) { timeparts->is_negative = (duration < T{0}); - timeparts->day = simt::std::chrono::duration_cast(duration).count(); + timeparts->day = cuda::std::chrono::duration_cast(duration).count(); - if (simt::std::is_same::value) return; + if (cuda::std::is_same::value) return; - duration_s seconds = simt::std::chrono::duration_cast(duration); + duration_s seconds = cuda::std::chrono::duration_cast(duration); timeparts->hour = - (simt::std::chrono::duration_cast(seconds) % duration_D(1)).count(); - timeparts->minute = (simt::std::chrono::duration_cast(seconds) % - simt::std::chrono::hours(1)) + (cuda::std::chrono::duration_cast(seconds) % duration_D(1)).count(); + timeparts->minute = (cuda::std::chrono::duration_cast(seconds) % + cuda::std::chrono::hours(1)) .count(); - timeparts->second = (seconds % simt::std::chrono::minutes(1)).count(); - if (not simt::std::is_same::value) { + timeparts->second = (seconds % cuda::std::chrono::minutes(1)).count(); + if (not cuda::std::is_same::value) { timeparts->subsecond = (duration % duration_s(1)).count(); } } @@ -187,9 +187,9 @@ struct duration_to_string_size_fn { case 'D': return count_digits(timeparts->day) - (timeparts->day < 0); break; case 'S': return 2 + (timeparts->subsecond == 0 ? 0 : [] { - if (simt::std::is_same::value) return 3 + 1; // +1 is for dot - if (simt::std::is_same::value) return 6 + 1; // +1 is for dot - if (simt::std::is_same::value) return 9 + 1; // +1 is for dot + if (cuda::std::is_same::value) return 3 + 1; // +1 is for dot + if (cuda::std::is_same::value) return 6 + 1; // +1 is for dot + if (cuda::std::is_same::value) return 9 + 1; // +1 is for dot return 0; }()); break; @@ -633,21 +633,21 @@ struct parse_duration { auto hour = timeparts->hour; auto minute = timeparts->minute; auto second = timeparts->second; - auto duration = duration_D(days) + simt::std::chrono::hours(hour) + - simt::std::chrono::minutes(minute) + duration_s(second); - if (simt::std::is_same::value) - return simt::std::chrono::duration_cast(duration).count(); - else if (simt::std::is_same::value) - return simt::std::chrono::duration_cast(duration).count(); + auto duration = duration_D(days) + cuda::std::chrono::hours(hour) + + cuda::std::chrono::minutes(minute) + duration_s(second); + if (cuda::std::is_same::value) + return cuda::std::chrono::duration_cast(duration).count(); + else if (cuda::std::is_same::value) + return cuda::std::chrono::duration_cast(duration).count(); duration_ns subsecond(timeparts->subsecond); // ns - if (simt::std::is_same::value) { - return simt::std::chrono::duration_cast(duration + subsecond).count(); - } else if (simt::std::is_same::value) { - return simt::std::chrono::duration_cast(duration + subsecond).count(); - } else if (simt::std::is_same::value) - return simt::std::chrono::duration_cast(duration + subsecond).count(); - return simt::std::chrono::duration_cast(duration + subsecond).count(); + if (cuda::std::is_same::value) { + return cuda::std::chrono::duration_cast(duration + subsecond).count(); + } else if (cuda::std::is_same::value) { + return cuda::std::chrono::duration_cast(duration + subsecond).count(); + } else if (cuda::std::is_same::value) + return cuda::std::chrono::duration_cast(duration + subsecond).count(); + return cuda::std::chrono::duration_cast(duration + subsecond).count(); } __device__ T operator()(size_type idx) diff --git a/cpp/src/transform/jit/code/kernel.cpp b/cpp/src/transform/jit/code/kernel.cpp index 38d4e951373..aa91dce407b 100644 --- a/cpp/src/transform/jit/code/kernel.cpp +++ b/cpp/src/transform/jit/code/kernel.cpp @@ -20,8 +20,8 @@ namespace jit { namespace code { const char* kernel_header = R"***( + #include #include - #include #include )***"; diff --git a/cpp/src/unary/cast_ops.cu b/cpp/src/unary/cast_ops.cu index 338bb481606..293bf1d523f 100644 --- a/cpp/src/unary/cast_ops.cu +++ b/cpp/src/unary/cast_ops.cu @@ -45,7 +45,7 @@ struct unary_cast { // Convert source tick counts into target tick counts without blindly truncating them // by dividing the respective duration time periods (which may not work for time before // UNIX epoch) - return TargetT{simt::std::chrono::floor(element.time_since_epoch())}; + return TargetT{cuda::std::chrono::floor(element.time_since_epoch())}; } template ())>* = nullptr> CUDA_DEVICE_CALLABLE TargetT operator()(SourceT const element) { - return TargetT{simt::std::chrono::floor(element)}; + return TargetT{cuda::std::chrono::floor(element)}; } template ())>* = nullptr> CUDA_DEVICE_CALLABLE TargetT operator()(SourceT const element) { - return TargetT{simt::std::chrono::floor(element.time_since_epoch())}; + return TargetT{cuda::std::chrono::floor(element.time_since_epoch())}; } template ())>* = nullptr> CUDA_DEVICE_CALLABLE TargetT operator()(SourceT const element) { - return TargetT{simt::std::chrono::floor(element)}; + return TargetT{cuda::std::chrono::floor(element)}; } }; diff --git a/cpp/tests/datetime/datetime_ops_test.cpp b/cpp/tests/datetime/datetime_ops_test.cpp index 8f3ab84c4f3..2053c8b159e 100644 --- a/cpp/tests/datetime/datetime_ops_test.cpp +++ b/cpp/tests/datetime/datetime_ops_test.cpp @@ -41,7 +41,7 @@ TYPED_TEST(NonTimestampTest, TestThrowsOnNonTimestamp) using T = TypeParam; using namespace cudf::test; using namespace cudf::datetime; - using namespace simt::std::chrono; + using namespace cuda::std::chrono; cudf::data_type dtype{cudf::type_to_id()}; cudf::column col{dtype, 0, rmm::device_buffer{0}}; @@ -68,7 +68,7 @@ TEST_F(BasicDatetimeOpsTest, TestExtractingDatetimeComponents) { using namespace cudf::test; using namespace cudf::datetime; - using namespace simt::std::chrono; + using namespace cuda::std::chrono; auto timestamps_D = cudf::test::fixed_width_column_wrapper{ @@ -155,7 +155,7 @@ TYPED_TEST(TypedDatetimeOpsTest, TestEmptyColumns) using T = TypeParam; using namespace cudf::test; using namespace cudf::datetime; - using namespace simt::std::chrono; + using namespace cuda::std::chrono; auto int16s_dtype = cudf::data_type{cudf::type_to_id()}; auto timestamps_dtype = cudf::data_type{cudf::type_to_id()}; @@ -177,7 +177,7 @@ TYPED_TEST(TypedDatetimeOpsTest, TestExtractingGeneratedDatetimeComponents) using T = TypeParam; using namespace cudf::test; using namespace cudf::datetime; - using namespace simt::std::chrono; + using namespace cuda::std::chrono; auto start = milliseconds(-2500000000000); // Sat, 11 Oct 1890 19:33:20 GMT auto stop_ = milliseconds(2500000000000); // Mon, 22 Mar 2049 04:26:40 GMT @@ -214,7 +214,7 @@ TYPED_TEST(TypedDatetimeOpsTest, TestExtractingGeneratedNullableDatetimeComponen using T = TypeParam; using namespace cudf::test; using namespace cudf::datetime; - using namespace simt::std::chrono; + using namespace cuda::std::chrono; auto start = milliseconds(-2500000000000); // Sat, 11 Oct 1890 19:33:20 GMT auto stop_ = milliseconds(2500000000000); // Mon, 22 Mar 2049 04:26:40 GMT @@ -269,7 +269,7 @@ TEST_F(BasicDatetimeOpsTest, TestLastDayOfMonthWithSeconds) { using namespace cudf::test; using namespace cudf::datetime; - using namespace simt::std::chrono; + using namespace cuda::std::chrono; // Time in seconds since epoch // Dates converted using epochconverter.com @@ -309,7 +309,7 @@ TEST_F(BasicDatetimeOpsTest, TestLastDayOfMonthWithDate) { using namespace cudf::test; using namespace cudf::datetime; - using namespace simt::std::chrono; + using namespace cuda::std::chrono; // Time in days since epoch // Dates converted using epochconverter.com @@ -349,7 +349,7 @@ TEST_F(BasicDatetimeOpsTest, TestDayOfYearWithDate) { using namespace cudf::test; using namespace cudf::datetime; - using namespace simt::std::chrono; + using namespace cuda::std::chrono; // Day number in the year // Dates converted using epochconverter.com @@ -391,7 +391,7 @@ TEST_F(BasicDatetimeOpsTest, TestDayOfYearWithEmptyColumn) { using namespace cudf::test; using namespace cudf::datetime; - using namespace simt::std::chrono; + using namespace cuda::std::chrono; // Create an empty column auto timestamps_d = fixed_width_column_wrapper{}; @@ -403,7 +403,7 @@ TEST_F(BasicDatetimeOpsTest, TestAddMonthsWithInvalidColType) { using namespace cudf::test; using namespace cudf::datetime; - using namespace simt::std::chrono; + using namespace cuda::std::chrono; // Time in seconds since epoch // Dates converted using epochconverter.com @@ -422,7 +422,7 @@ TEST_F(BasicDatetimeOpsTest, TestAddMonthsWithIncorrectColSizes) { using namespace cudf::test; using namespace cudf::datetime; - using namespace simt::std::chrono; + using namespace cuda::std::chrono; // Time in seconds since epoch // Dates converted using epochconverter.com @@ -441,7 +441,7 @@ TEST_F(BasicDatetimeOpsTest, TestAddMonthsWithSeconds) { using namespace cudf::test; using namespace cudf::datetime; - using namespace simt::std::chrono; + using namespace cuda::std::chrono; // Time in seconds since epoch // Dates converted using epochconverter.com @@ -487,7 +487,7 @@ TEST_F(BasicDatetimeOpsTest, TestAddMonthsWithSecondsAndNullValues) { using namespace cudf::test; using namespace cudf::datetime; - using namespace simt::std::chrono; + using namespace cuda::std::chrono; // Time in seconds since epoch // Dates converted using epochconverter.com diff --git a/cpp/tests/io/csv_test.cpp b/cpp/tests/io/csv_test.cpp index 5c0f8d5fcbd..53092ac5f07 100644 --- a/cpp/tests/io/csv_test.cpp +++ b/cpp/tests/io/csv_test.cpp @@ -131,7 +131,7 @@ void check_timestamp_column(cudf::column_view const& col_lhs, long tol_ms = 1000l) { using T = cudf::timestamp_ms; - using namespace simt::std::chrono; + using namespace cuda::std::chrono; auto h_lhs = cudf::test::to_host(col_lhs).first; auto h_rhs = cudf::test::to_host(col_rhs).first; @@ -148,7 +148,7 @@ void check_timestamp_column(cudf::column_view const& col_lhs, auto found = thrust::find_if( thrust::host, begin_count, end_count, [ptr_lhs, ptr_rhs, tol_ms](auto row_index) { - auto delta_ms = simt::std::chrono::duration_cast( + auto delta_ms = cuda::std::chrono::duration_cast( ptr_lhs[row_index] - ptr_rhs[row_index]); return delta_ms.count() >= tol_ms; }); @@ -395,7 +395,7 @@ TEST_F(CsvReaderTest, Dates) EXPECT_EQ(1, view.num_columns()); ASSERT_EQ(cudf::type_id::TIMESTAMP_MILLISECONDS, view.column(0).type().id()); - using namespace simt::std::chrono_literals; + using namespace cuda::std::chrono_literals; expect_column_data_equal(std::vector{cudf::timestamp_ms{983750400000ms}, cudf::timestamp_ms{1288483200000ms}, cudf::timestamp_ms{782611200000ms}, @@ -432,7 +432,7 @@ TEST_F(CsvReaderTest, DatesCastToTimestampSeconds) EXPECT_EQ(1, view.num_columns()); ASSERT_EQ(cudf::type_id::TIMESTAMP_SECONDS, view.column(0).type().id()); - using namespace simt::std::chrono_literals; + using namespace cuda::std::chrono_literals; expect_column_data_equal(std::vector{cudf::timestamp_s{983750400s}, cudf::timestamp_s{1288483200s}, cudf::timestamp_s{782611200s}, @@ -469,7 +469,7 @@ TEST_F(CsvReaderTest, DatesCastToTimestampMilliSeconds) EXPECT_EQ(1, view.num_columns()); ASSERT_EQ(cudf::type_id::TIMESTAMP_MILLISECONDS, view.column(0).type().id()); - using namespace simt::std::chrono_literals; + using namespace cuda::std::chrono_literals; expect_column_data_equal(std::vector{cudf::timestamp_ms{983750400000ms}, cudf::timestamp_ms{1288483200000ms}, cudf::timestamp_ms{782611200000ms}, @@ -506,7 +506,7 @@ TEST_F(CsvReaderTest, DatesCastToTimestampMicroSeconds) EXPECT_EQ(1, view.num_columns()); ASSERT_EQ(cudf::type_id::TIMESTAMP_MICROSECONDS, view.column(0).type().id()); - using namespace simt::std::chrono_literals; + using namespace cuda::std::chrono_literals; expect_column_data_equal(std::vector{cudf::timestamp_us{983750400000000us}, cudf::timestamp_us{1288483200000000us}, cudf::timestamp_us{782611200000000us}, @@ -543,7 +543,7 @@ TEST_F(CsvReaderTest, DatesCastToTimestampNanoSeconds) EXPECT_EQ(1, view.num_columns()); ASSERT_EQ(cudf::type_id::TIMESTAMP_NANOSECONDS, view.column(0).type().id()); - using namespace simt::std::chrono_literals; + using namespace cuda::std::chrono_literals; expect_column_data_equal( std::vector{cudf::timestamp_ns{983750400000000000ns}, cudf::timestamp_ns{1288483200000000000ns}, diff --git a/cpp/tests/transform/integration/unary-transform-test.cpp b/cpp/tests/transform/integration/unary-transform-test.cpp index 65b20ebde0f..e15b8e4b5ae 100644 --- a/cpp/tests/transform/integration/unary-transform-test.cpp +++ b/cpp/tests/transform/integration/unary-transform-test.cpp @@ -205,7 +205,7 @@ TEST_F(UnaryOperationIntegrationTest, Transform_Datetime) R"***( __device__ inline void f(cudf::timestamp_us* output, cudf::timestamp_us input) { - using dur = simt::std::chrono::duration>; + using dur = cuda::std::chrono::duration>; *output = static_cast(input + dur{1}); } @@ -213,7 +213,7 @@ __device__ inline void f(cudf::timestamp_us* output, cudf::timestamp_us input) using dtype = timestamp_us; auto op = [](dtype a) { - using dur = simt::std::chrono::duration>; + using dur = cuda::std::chrono::duration>; return static_cast(a + dur{1}); }; auto random_eng = UniformRandomGenerator(0, 100000000); diff --git a/cpp/tests/utilities/timestamp_utilities.cuh b/cpp/tests/utilities/timestamp_utilities.cuh index 47f11014b77..4f9a8f497ec 100644 --- a/cpp/tests/utilities/timestamp_utilities.cuh +++ b/cpp/tests/utilities/timestamp_utilities.cuh @@ -28,7 +28,7 @@ namespace cudf { namespace test { using time_point_ms = - simt::std::chrono::time_point; + cuda::std::chrono::time_point; /** * @brief Creates a `thrust::device_vector` with ascending timestamps in the @@ -38,11 +38,11 @@ using time_point_ms = * and `stop`. * * @tparam Rep The arithmetic type representing the number of ticks - * @tparam Period A simt::std::ratio representing the tick period (i.e. the + * @tparam Period A cuda::std::ratio representing the tick period (i.e. the *number of seconds per tick) * @param count The number of timestamps to create - * @param start The first timestamp as a simt::std::chrono::time_point - * @param stop The last timestamp as a simt::std::chrono::time_point + * @param start The first timestamp as a cuda::std::chrono::time_point + * @param stop The last timestamp as a cuda::std::chrono::time_point **/ template inline cudf::test::fixed_width_column_wrapper generate_timestamps(int32_t count, @@ -51,7 +51,7 @@ inline cudf::test::fixed_width_column_wrapper generate_timestamps(in { using Rep = typename T::rep; using Period = typename T::period; - using ToDuration = simt::std::chrono::duration; + using ToDuration = cuda::std::chrono::duration; auto lhs = start.time_since_epoch().count(); auto rhs = stop.time_since_epoch().count(); @@ -61,8 +61,8 @@ inline cudf::test::fixed_width_column_wrapper generate_timestamps(in auto max = std::max(lhs, rhs); auto range = max - min; auto iter = cudf::test::make_counting_transform_iterator(0, [=](auto i) { - return simt::std::chrono::floor( - simt::std::chrono::milliseconds(min + (range / count) * i)) + return cuda::std::chrono::floor( + cuda::std::chrono::milliseconds(min + (range / count) * i)) .count(); }); diff --git a/cpp/tests/wrappers/timestamps_test.cu b/cpp/tests/wrappers/timestamps_test.cu index 593176acf57..bfbc586a92f 100644 --- a/cpp/tests/wrappers/timestamps_test.cu +++ b/cpp/tests/wrappers/timestamps_test.cu @@ -72,7 +72,7 @@ TYPED_TEST(ChronoColumnTest, ChronoDurationsMatchPrimitiveRepresentation) using T = TypeParam; using Rep = typename T::rep; using namespace cudf::test; - using namespace simt::std::chrono; + using namespace cuda::std::chrono; auto start = milliseconds(-2500000000000); // Sat, 11 Oct 1890 19:33:20 GMT auto stop_ = milliseconds(2500000000000); // Mon, 22 Mar 2049 04:26:40 GMT @@ -129,7 +129,7 @@ TYPED_TEST(ChronoColumnTest, ChronosCanBeComparedInDeviceCode) { using T = TypeParam; using namespace cudf::test; - using namespace simt::std::chrono; + using namespace cuda::std::chrono; auto start_lhs = milliseconds(-2500000000000); // Sat, 11 Oct 1890 19:33:20 GMT auto start_rhs = milliseconds(-2400000000000); // Tue, 12 Dec 1893 05:20:00 GMT diff --git a/thirdparty/CMakeLists.txt b/thirdparty/CMakeLists.txt index f8f3457e84f..6270f3a818c 100644 --- a/thirdparty/CMakeLists.txt +++ b/thirdparty/CMakeLists.txt @@ -45,8 +45,8 @@ message("Fetching libcudacxx") FetchContent_Declare( libcudacxx - GIT_REPOSITORY https://github.com/rapidsai/thirdparty-freestanding.git - GIT_TAG cudf + GIT_REPOSITORY https://github.com/trxcllnt/libcudacxx.git + GIT_TAG cudf-backports GIT_SHALLOW true ) From efb6edb9585dd6bd6f736ba9b434a50619600720 Mon Sep 17 00:00:00 2001 From: ptaylor Date: Sat, 19 Sep 2020 18:11:16 -0700 Subject: [PATCH 02/13] changelog --- CHANGELOG.md | 1 + 1 file changed, 1 insertion(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 2b2e90df54b..c77a93b5441 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -65,6 +65,7 @@ - PR #6218 increase visiblity/consistency for cuio reader writer private member variable names. - PR #6265 Update JNI to use ORC options builder - PR #6273 Update JNI to use ORC options builder +- PR #6275 Update to official libcu++ on Github ## Bug Fixes From 71d178428db4ab10fd14a2774dc1cf5cd04cd2a9 Mon Sep 17 00:00:00 2001 From: ptaylor Date: Sat, 19 Sep 2020 19:50:04 -0700 Subject: [PATCH 03/13] update simt references in benchmarks --- cpp/benchmarks/common/generate_benchmark_input.cpp | 8 ++++---- cpp/benchmarks/common/generate_benchmark_input.hpp | 4 ++-- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/cpp/benchmarks/common/generate_benchmark_input.cpp b/cpp/benchmarks/common/generate_benchmark_input.cpp index 4e4436b80c6..09d942f5fcd 100644 --- a/cpp/benchmarks/common/generate_benchmark_input.cpp +++ b/cpp/benchmarks/common/generate_benchmark_input.cpp @@ -120,11 +120,11 @@ struct random_value_fn()>> { random_value_fn(distribution_params params) { - using simt::std::chrono::duration_cast; + using cuda::std::chrono::duration_cast; std::pair const range_s = { - duration_cast(typename T::duration{params.lower_bound}), - duration_cast(typename T::duration{params.upper_bound})}; + duration_cast(typename T::duration{params.lower_bound}), + duration_cast(typename T::duration{params.upper_bound})}; if (range_s.first != range_s.second) { seconds_gen = make_distribution(params.id, range_s.first.count(), range_s.second.count()); @@ -148,7 +148,7 @@ struct random_value_fn()>> { auto const timestamp_ns = cudf::duration_s{seconds_gen(engine)} + cudf::duration_ns{nanoseconds_gen(engine)}; // Return value in the type's precision - return T(simt::std::chrono::duration_cast(timestamp_ns)); + return T(cuda::std::chrono::duration_cast(timestamp_ns)); } }; diff --git a/cpp/benchmarks/common/generate_benchmark_input.hpp b/cpp/benchmarks/common/generate_benchmark_input.hpp index d7197cc944f..635245aa159 100644 --- a/cpp/benchmarks/common/generate_benchmark_input.hpp +++ b/cpp/benchmarks/common/generate_benchmark_input.hpp @@ -93,7 +93,7 @@ distribution_id default_distribution_id() template ()>* = nullptr> std::pair default_range() { - using simt::std::chrono::duration_cast; + using cuda::std::chrono::duration_cast; auto const year = duration_cast(cudf::duration_D{365l}); return {50 * year.count(), 0}; } @@ -106,7 +106,7 @@ std::pair default_range() template ()>* = nullptr> std::pair default_range() { - using simt::std::chrono::duration_cast; + using cuda::std::chrono::duration_cast; auto const year = duration_cast(cudf::duration_D{365l}); return {0, 2 * year.count()}; } From f17b02c32cb992ba7e94dc60b765d299516cbf8b Mon Sep 17 00:00:00 2001 From: ptaylor Date: Tue, 22 Sep 2020 18:43:36 -0700 Subject: [PATCH 04/13] get jitify working with libcu++ --- cpp/CMakeLists.txt | 194 ++++++++++-------- cpp/include/cudf/fixed_point/fixed_point.hpp | 3 +- cpp/include/cudf/utilities/traits.hpp | 2 +- .../cudf/utilities/type_dispatcher.hpp | 4 +- cpp/src/binaryop/binaryop.cpp | 28 +-- cpp/src/binaryop/jit/code/kernel.cpp | 4 +- cpp/src/binaryop/jit/code/operation.cpp | 8 +- cpp/src/binaryop/jit/code/traits.cpp | 20 +- cpp/src/jit/common_headers.hpp | 99 +++++---- cpp/src/jit/type.h | 4 + cpp/src/rolling/rolling.cu | 20 +- cpp/src/transform/jit/code/kernel.cpp | 9 +- cpp/src/transform/transform.cpp | 12 +- cpp/tests/binaryop/binop-generic-ptx-test.cpp | 3 +- cpp/tests/binaryop/binop-integration-test.cpp | 12 +- cpp/tests/binaryop/binop-null-test.cpp | 3 +- .../binaryop/binop-verify-input-test.cpp | 1 + cpp/tests/unary/unary_ops_test.cpp | 4 +- cpp/tests/wrappers/timestamps_test.cu | 8 +- thirdparty/CMakeLists.txt | 2 +- 20 files changed, 245 insertions(+), 195 deletions(-) diff --git a/cpp/CMakeLists.txt b/cpp/CMakeLists.txt index 5f5dfd3a4bc..3fea4fdcae6 100644 --- a/cpp/CMakeLists.txt +++ b/cpp/CMakeLists.txt @@ -628,124 +628,142 @@ set_target_properties(cudf PROPERTIES BUILD_RPATH "\$ORIGIN") add_executable(stringify "${JITIFY_INCLUDE_DIR}/stringify.cpp") execute_process(WORKING_DIRECTORY ${CMAKE_BINARY_DIR} COMMAND ${CMAKE_COMMAND} -E make_directory - ${CMAKE_BINARY_DIR}/include/jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/details - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/simt - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/libcxx/include) + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include + ) add_custom_command(WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/include COMMENT "Stringify headers for use in JIT compiled code" DEPENDS stringify OUTPUT ${CMAKE_BINARY_DIR}/include/jit/types.h.jit ${CMAKE_BINARY_DIR}/include/jit/types.hpp.jit - ${CMAKE_BINARY_DIR}/include/bit.hpp.jit + ${CMAKE_BINARY_DIR}/include/jit/bit.hpp.jit ${CMAKE_BINARY_DIR}/include/jit/timestamps.hpp.jit ${CMAKE_BINARY_DIR}/include/jit/fixed_point.hpp.jit ${CMAKE_BINARY_DIR}/include/jit/durations.hpp.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/details/__config.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/simt/limits.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/simt/cfloat.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/simt/chrono.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/simt/ctime.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/simt/ratio.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/simt/type_traits.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/simt/version.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/simt/cmath.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/simt/cassert.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/libcxx/include/__config.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/libcxx/include/__undef_macros.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/libcxx/include/cfloat.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/libcxx/include/chrono.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/libcxx/include/ctime.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/libcxx/include/limits.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/libcxx/include/ratio.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/libcxx/include/type_traits.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/libcxx/include/cmath.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/libcxx/include/cassert.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/chrono.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/climits.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/cstddef.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/cstdint.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/ctime.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/limits.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/ratio.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/type_traits.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/version.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/__config.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/__pragma_pop.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/__pragma_push.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/__config.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/__pragma_pop.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/__pragma_push.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/__undef_macros.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/chrono.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/climits.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/cstddef.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/cstdint.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/ctime.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/limits.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/ratio.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/type_traits.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/version.jit MAIN_DEPENDENCY ${CMAKE_CURRENT_SOURCE_DIR}/include/cudf/types.h ${CMAKE_CURRENT_SOURCE_DIR}/include/cudf/types.hpp ${CMAKE_CURRENT_SOURCE_DIR}/include/cudf/utilities/bit.hpp ${CMAKE_CURRENT_SOURCE_DIR}/include/cudf/wrappers/timestamps.hpp ${CMAKE_CURRENT_SOURCE_DIR}/include/cudf/fixed_point/fixed_point.hpp ${CMAKE_CURRENT_SOURCE_DIR}/include/cudf/wrappers/durations.hpp - ${LIBCUDACXX_INCLUDE_DIR}/details/__config - ${LIBCUDACXX_INCLUDE_DIR}/simt/limits - ${LIBCUDACXX_INCLUDE_DIR}/simt/cfloat - ${LIBCUDACXX_INCLUDE_DIR}/simt/chrono - ${LIBCUDACXX_INCLUDE_DIR}/simt/ctime - ${LIBCUDACXX_INCLUDE_DIR}/simt/ratio - ${LIBCUDACXX_INCLUDE_DIR}/simt/type_traits - ${LIBCUDACXX_INCLUDE_DIR}/simt/version - ${LIBCUDACXX_INCLUDE_DIR}/simt/cmath - ${LIBCUDACXX_INCLUDE_DIR}/simt/cassert - ${LIBCXX_INCLUDE_DIR}/__config - ${LIBCXX_INCLUDE_DIR}/__undef_macros - ${LIBCXX_INCLUDE_DIR}/cfloat - ${LIBCXX_INCLUDE_DIR}/chrono - ${LIBCXX_INCLUDE_DIR}/ctime - ${LIBCXX_INCLUDE_DIR}/limits - ${LIBCXX_INCLUDE_DIR}/ratio - ${LIBCXX_INCLUDE_DIR}/type_traits - ${LIBCXX_INCLUDE_DIR}/cmath - ${LIBCXX_INCLUDE_DIR}/cassert + ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/chrono + ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/climits + ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/cstddef + ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/cstdint + ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/ctime + ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/limits + ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/ratio + ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/type_traits + ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/version + ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/detail/__config + ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/detail/__pragma_pop + ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/detail/__pragma_push + ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/detail/libcxx/include/__config + ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/detail/libcxx/include/__pragma_pop + ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/detail/libcxx/include/__pragma_push + ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/detail/libcxx/include/__undef_macros + ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/detail/libcxx/include/chrono + ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/detail/libcxx/include/climits + ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/detail/libcxx/include/cstddef + ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/detail/libcxx/include/cstdint + ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/detail/libcxx/include/ctime + ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/detail/libcxx/include/limits + ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/detail/libcxx/include/ratio + ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/detail/libcxx/include/type_traits + ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/detail/libcxx/include/version # stringified headers are placed underneath the bin include jit directory and end in ".jit" COMMAND ${CMAKE_BINARY_DIR}/stringify cudf/types.h > ${CMAKE_BINARY_DIR}/include/jit/types.h.jit COMMAND ${CMAKE_BINARY_DIR}/stringify cudf/types.hpp > ${CMAKE_BINARY_DIR}/include/jit/types.hpp.jit - COMMAND ${CMAKE_BINARY_DIR}/stringify cudf/utilities/bit.hpp > ${CMAKE_BINARY_DIR}/include/bit.hpp.jit - COMMAND ${CMAKE_BINARY_DIR}/stringify ../src/rolling/rolling_jit_detail.hpp > ${CMAKE_BINARY_DIR}/include/rolling_jit_detail.hpp.jit + COMMAND ${CMAKE_BINARY_DIR}/stringify cudf/utilities/bit.hpp > ${CMAKE_BINARY_DIR}/include/jit/bit.hpp.jit + COMMAND ${CMAKE_BINARY_DIR}/stringify ../src/rolling/rolling_jit_detail.hpp > ${CMAKE_BINARY_DIR}/include/jit/rolling_jit_detail.hpp.jit COMMAND ${CMAKE_BINARY_DIR}/stringify cudf/wrappers/timestamps.hpp > ${CMAKE_BINARY_DIR}/include/jit/timestamps.hpp.jit COMMAND ${CMAKE_BINARY_DIR}/stringify cudf/fixed_point/fixed_point.hpp > ${CMAKE_BINARY_DIR}/include/jit/fixed_point.hpp.jit COMMAND ${CMAKE_BINARY_DIR}/stringify cudf/wrappers/durations.hpp > ${CMAKE_BINARY_DIR}/include/jit/durations.hpp.jit - COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/details/__config libcudacxx_details_config > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/details/__config.jit - COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/simt/limits libcudacxx_simt_limits > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/simt/limits.jit - COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/simt/cfloat libcudacxx_simt_cfloat > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/simt/cfloat.jit - COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/simt/chrono libcudacxx_simt_chrono > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/simt/chrono.jit - COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/simt/ctime libcudacxx_simt_ctime > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/simt/ctime.jit - COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/simt/ratio libcudacxx_simt_ratio > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/simt/ratio.jit - COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/simt/type_traits libcudacxx_simt_type_traits > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/simt/type_traits.jit - COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/simt/cmath libcudacxx_simt_cmath > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/simt/cmath.jit - COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/simt/cassert libcudacxx_simt_cassert > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/simt/cassert.jit - COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/version libcudacxx_simt_version > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/simt/version.jit - COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCXX_INCLUDE_DIR}/__config libcxx_config > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/libcxx/include/__config.jit - COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCXX_INCLUDE_DIR}/__undef_macros libcxx_undef_macros > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/libcxx/include/__undef_macros.jit - COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCXX_INCLUDE_DIR}/cfloat libcxx_cfloat > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/libcxx/include/cfloat.jit - COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCXX_INCLUDE_DIR}/chrono libcxx_chrono > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/libcxx/include/chrono.jit - COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCXX_INCLUDE_DIR}/ctime libcxx_ctime > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/libcxx/include/ctime.jit - COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCXX_INCLUDE_DIR}/limits libcxx_limits > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/libcxx/include/limits.jit - COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCXX_INCLUDE_DIR}/ratio libcxx_ratio > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/libcxx/include/ratio.jit - COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCXX_INCLUDE_DIR}/type_traits libcxx_type_traits > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/libcxx/include/type_traits.jit - COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCXX_INCLUDE_DIR}/cmath libcxx_cmath > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/libcxx/include/cmath.jit - COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCXX_INCLUDE_DIR}/cassert libcxx_cassert > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/libcxx/include/cassert.jit + COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/chrono cuda_std_chrono > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/chrono.jit + COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/climits cuda_std_climits > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/climits.jit + COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/cstddef cuda_std_cstddef > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/cstddef.jit + COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/cstdint cuda_std_cstdint > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/cstdint.jit + COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/ctime cuda_std_ctime > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/ctime.jit + COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/limits cuda_std_limits > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/limits.jit + COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/ratio cuda_std_ratio > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/ratio.jit + COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/type_traits cuda_std_type_traits > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/type_traits.jit + COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/version cuda_std_version > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/version.jit + COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/detail/__config cuda_std_detail___config > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/__config.jit + COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/detail/__pragma_pop cuda_std_detail___pragma_pop > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/__pragma_pop.jit + COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/detail/__pragma_push cuda_std_detail___pragma_push > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/__pragma_push.jit + COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/detail/libcxx/include/__config cuda_std_detail_libcxx_include___config > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/__config.jit + COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/detail/libcxx/include/__pragma_pop cuda_std_detail_libcxx_include___pragma_pop > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/__pragma_pop.jit + COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/detail/libcxx/include/__pragma_push cuda_std_detail_libcxx_include___pragma_push > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/__pragma_push.jit + COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/detail/libcxx/include/__undef_macros cuda_std_detail_libcxx_include___undef_macros > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/__undef_macros.jit + COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/detail/libcxx/include/chrono cuda_std_detail_libcxx_include_chrono > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/chrono.jit + COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/detail/libcxx/include/climits cuda_std_detail_libcxx_include_climits > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/climits.jit + COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/detail/libcxx/include/cstddef cuda_std_detail_libcxx_include_cstddef > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/cstddef.jit + COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/detail/libcxx/include/cstdint cuda_std_detail_libcxx_include_cstdint > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/cstdint.jit + COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/detail/libcxx/include/ctime cuda_std_detail_libcxx_include_ctime > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/ctime.jit + COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/detail/libcxx/include/limits cuda_std_detail_libcxx_include_limits > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/limits.jit + COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/detail/libcxx/include/ratio cuda_std_detail_libcxx_include_ratio > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/ratio.jit + COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/detail/libcxx/include/type_traits cuda_std_detail_libcxx_include_type_traits > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/type_traits.jit + COMMAND ${CMAKE_BINARY_DIR}/stringify ${LIBCUDACXX_INCLUDE_DIR}/cuda/std/detail/libcxx/include/version cuda_std_detail_libcxx_include_version > ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/version.jit ) add_custom_target(stringify_run DEPENDS ${CMAKE_BINARY_DIR}/include/jit/types.h.jit ${CMAKE_BINARY_DIR}/include/jit/types.hpp.jit - ${CMAKE_BINARY_DIR}/include/bit.hpp.jit + ${CMAKE_BINARY_DIR}/include/jit/bit.hpp.jit ${CMAKE_BINARY_DIR}/include/jit/timestamps.hpp.jit ${CMAKE_BINARY_DIR}/include/jit/fixed_point.hpp.jit ${CMAKE_BINARY_DIR}/include/jit/durations.hpp.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/details/__config.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/simt/limits.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/simt/cfloat.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/simt/chrono.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/simt/ctime.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/simt/ratio.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/simt/type_traits.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/simt/cmath.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/simt/cassert.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/simt/version.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/libcxx/include/__config.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/libcxx/include/__undef_macros.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/libcxx/include/cfloat.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/libcxx/include/chrono.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/libcxx/include/ctime.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/libcxx/include/limits.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/libcxx/include/ratio.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/libcxx/include/type_traits.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/libcxx/include/cmath.jit - ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/libcxx/include/cassert.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/chrono.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/climits.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/cstddef.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/cstdint.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/ctime.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/limits.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/ratio.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/type_traits.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/version.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/__config.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/__pragma_pop.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/__pragma_push.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/__config.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/__pragma_pop.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/__pragma_push.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/__undef_macros.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/chrono.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/climits.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/cstddef.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/cstdint.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/ctime.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/limits.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/ratio.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/type_traits.jit + ${CMAKE_BINARY_DIR}/include/jit/libcudacxx/cuda/std/detail/libcxx/include/version.jit ) add_dependencies(cudf stringify_run) diff --git a/cpp/include/cudf/fixed_point/fixed_point.hpp b/cpp/include/cudf/fixed_point/fixed_point.hpp index eb19defef7f..b62048ccd31 100644 --- a/cpp/include/cudf/fixed_point/fixed_point.hpp +++ b/cpp/include/cudf/fixed_point/fixed_point.hpp @@ -16,6 +16,8 @@ #pragma once +#include + // Note: The versions are used in order for Jitify to work with our fixed_point type. // Jitify is needed for several algorithms (binaryop, rolling, etc) #include @@ -24,7 +26,6 @@ #include #include #include - #include //! `fixed_point` and supporting types diff --git a/cpp/include/cudf/utilities/traits.hpp b/cpp/include/cudf/utilities/traits.hpp index 6d832c54e66..1f570379d90 100644 --- a/cpp/include/cudf/utilities/traits.hpp +++ b/cpp/include/cudf/utilities/traits.hpp @@ -18,13 +18,13 @@ #include #include +#include #include #include #include #include #include -#include namespace cudf { diff --git a/cpp/include/cudf/utilities/type_dispatcher.hpp b/cpp/include/cudf/utilities/type_dispatcher.hpp index fbf540c3d12..d6ae10869ff 100644 --- a/cpp/include/cudf/utilities/type_dispatcher.hpp +++ b/cpp/include/cudf/utilities/type_dispatcher.hpp @@ -17,14 +17,14 @@ #pragma once #include +#include #include #include #include #include #include -#include -#include +#include /** * @file type_dispatcher.hpp diff --git a/cpp/src/binaryop/binaryop.cpp b/cpp/src/binaryop/binaryop.cpp index 0cdd2db67cb..de86da30d2b 100644 --- a/cpp/src/binaryop/binaryop.cpp +++ b/cpp/src/binaryop/binaryop.cpp @@ -17,6 +17,13 @@ * limitations under the License. */ +#include "binaryop/jit/code/code.h" +#include "binaryop/jit/util.hpp" +#include "compiled/binary_ops.hpp" +#include "jit/launcher.h" +#include "jit/parser.h" +#include "jit/type.h" + #include #include #include @@ -25,23 +32,16 @@ #include #include #include +// #include // replace eventually -#include -#include -#include -#include -#include -#include // replace eventually - -#include "compiled/binary_ops.hpp" - -#include -#include -#include +#include #include +#include +#include +#include +#include + #include -#include -#include namespace cudf { diff --git a/cpp/src/binaryop/jit/code/kernel.cpp b/cpp/src/binaryop/jit/code/kernel.cpp index d41729172b4..cfa1f1f82d2 100644 --- a/cpp/src/binaryop/jit/code/kernel.cpp +++ b/cpp/src/binaryop/jit/code/kernel.cpp @@ -26,13 +26,13 @@ namespace code { // clang-format off const char* kernel = R"***( + #include "operation.h" + #include - #include #include #include #include #include - #include "operation.h" template __global__ diff --git a/cpp/src/binaryop/jit/code/operation.cpp b/cpp/src/binaryop/jit/code/operation.cpp index b8e42747296..938ab0614d4 100644 --- a/cpp/src/binaryop/jit/code/operation.cpp +++ b/cpp/src/binaryop/jit/code/operation.cpp @@ -25,9 +25,13 @@ namespace code { const char* operation = R"***( #pragma once - #include - #include + #include "traits.h" + + #include + + #include + using namespace cuda::std; struct Add { diff --git a/cpp/src/binaryop/jit/code/traits.cpp b/cpp/src/binaryop/jit/code/traits.cpp index 9ff7ddda652..53b980b1a02 100644 --- a/cpp/src/binaryop/jit/code/traits.cpp +++ b/cpp/src/binaryop/jit/code/traits.cpp @@ -23,18 +23,18 @@ namespace jit { namespace code { const char* traits = R"***( -#pragma once - #include - #include + #pragma once - // ------------------------------------------------------------------------- - // Simplifying std::is_integral - template - constexpr bool is_integral_v = cuda::std::is_integral::value; + // Include Jitify's cstddef header first + #include - // Simplifying std::is_floating_point - template - constexpr bool is_floating_point_v = cuda::std::is_floating_point::value; + #include + #include + #include + #include + + #include + #include // ------------------------------------------------------------------------- // type_traits cannot tell the difference between float and double diff --git a/cpp/src/jit/common_headers.hpp b/cpp/src/jit/common_headers.hpp index 876ecce5194..204a8dea4a1 100644 --- a/cpp/src/jit/common_headers.hpp +++ b/cpp/src/jit/common_headers.hpp @@ -17,28 +17,37 @@ * limitations under the License. */ +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include #include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include #include +#include +#include namespace cudf { namespace jit { @@ -52,12 +61,6 @@ const std::vector compiler_flags "-w", // force libcudacxx to not include system headers "-D__CUDACC_RTC__", - // __CHAR_BIT__ is from GCC, but libcxx uses it - "-D__CHAR_BIT__=" + std::to_string(__CHAR_BIT__), - // enable temporary workarounds to compile libcudacxx with nvrtc - "-D_LIBCUDACXX_HAS_NO_CTIME", "-D_LIBCUDACXX_HAS_NO_WCHAR", "-D_LIBCUDACXX_HAS_NO_CFLOAT", - "-D_LIBCUDACXX_HAS_NO_STDINT", "-D_LIBCUDACXX_HAS_NO_CSTDDEF", "-D_LIBCUDACXX_HAS_NO_CLIMITS", - "-D_LIBCPP_DISABLE_VISIBILITY_ANNOTATIONS", #if defined(__powerpc64__) "-D__powerpc64__" #elif defined(__x86_64__) @@ -66,24 +69,32 @@ const std::vector compiler_flags }; const std::unordered_map stringified_headers{ - {"details/../../libcxx/include/__config", libcxx_config}, - {"../libcxx/include/__undef_macros", libcxx_undef_macros}, - {"simt/../../libcxx/include/cfloat", libcxx_cfloat}, - {"simt/../../libcxx/include/chrono", libcxx_chrono}, - {"simt/../../libcxx/include/ctime", libcxx_ctime}, - {"simt/../../libcxx/include/limits", libcxx_limits}, - {"simt/../../libcxx/include/ratio", libcxx_ratio}, - {"simt/../../libcxx/include/cmath", libcxx_cmath}, - {"simt/../../libcxx/include/cassert", libcxx_cassert}, - {"simt/../../libcxx/include/type_traits", libcxx_type_traits}, - {"simt/../details/__config", libcudacxx_details_config}, - {"simt/cfloat", libcudacxx_simt_cfloat}, - {"simt/chrono", libcudacxx_simt_chrono}, - {"simt/ctime", libcudacxx_simt_ctime}, - {"simt/limits", libcudacxx_simt_limits}, - {"simt/ratio", libcudacxx_simt_ratio}, - {"simt/type_traits", libcudacxx_simt_type_traits}, - {"simt/version", libcudacxx_simt_version}, + {"cuda/std/chrono", cuda_std_chrono}, + {"cuda/std/climits", cuda_std_climits}, + {"cuda/std/cstddef", cuda_std_cstddef}, + {"cuda/std/cstdint", cuda_std_cstdint}, + {"cuda/std/ctime", cuda_std_ctime}, + {"cuda/std/limits", cuda_std_limits}, + {"cuda/std/ratio", cuda_std_ratio}, + {"cuda/std/type_traits", cuda_std_type_traits}, + {"cuda/std/type_traits", cuda_std_type_traits}, + {"cuda/std/version", cuda_std_version}, + {"cuda/std/detail/__config", cuda_std_detail___config}, + {"cuda/std/detail/__pragma_pop", cuda_std_detail___pragma_pop}, + {"cuda/std/detail/__pragma_push", cuda_std_detail___pragma_push}, + {"cuda/std/detail/libcxx/include/__config", cuda_std_detail_libcxx_include___config}, + {"cuda/std/detail/libcxx/include/__pragma_pop", cuda_std_detail_libcxx_include___pragma_pop}, + {"cuda/std/detail/libcxx/include/__pragma_push", cuda_std_detail_libcxx_include___pragma_push}, + {"cuda/std/detail/libcxx/include/__undef_macros", cuda_std_detail_libcxx_include___undef_macros}, + {"cuda/std/detail/libcxx/include/chrono", cuda_std_detail_libcxx_include_chrono}, + {"cuda/std/detail/libcxx/include/climits", cuda_std_detail_libcxx_include_climits}, + {"cuda/std/detail/libcxx/include/cstddef", cuda_std_detail_libcxx_include_cstddef}, + {"cuda/std/detail/libcxx/include/cstdint", cuda_std_detail_libcxx_include_cstdint}, + {"cuda/std/detail/libcxx/include/ctime", cuda_std_detail_libcxx_include_ctime}, + {"cuda/std/detail/libcxx/include/limits", cuda_std_detail_libcxx_include_limits}, + {"cuda/std/detail/libcxx/include/ratio", cuda_std_detail_libcxx_include_ratio}, + {"cuda/std/detail/libcxx/include/type_traits", cuda_std_detail_libcxx_include_type_traits}, + {"cuda/std/detail/libcxx/include/version", cuda_std_detail_libcxx_include_version}, }; inline std::istream* send_stringified_header(std::iostream& stream, char const* header) diff --git a/cpp/src/jit/type.h b/cpp/src/jit/type.h index 12ae0beabf3..8d6402065e0 100644 --- a/cpp/src/jit/type.h +++ b/cpp/src/jit/type.h @@ -16,6 +16,10 @@ #pragma once +#include + +#include + namespace cudf { namespace jit { /** diff --git a/cpp/src/rolling/rolling.cu b/cpp/src/rolling/rolling.cu index b739ae57b13..b586cdbb45e 100644 --- a/cpp/src/rolling/rolling.cu +++ b/cpp/src/rolling/rolling.cu @@ -28,23 +28,23 @@ #include #include #include -#include -#include -#include -#include -#include -#include - -#include -#include -#include +#include +#include +#include #include #include #include +#include "jit/launcher.h" +#include "jit/parser.h" +#include "jit/type.h" +#include "rolling/jit/code/code.h" +#include "rolling/rolling_detail.hpp" +#include "rolling/rolling_jit_detail.hpp" + namespace cudf { namespace detail { namespace { // anonymous diff --git a/cpp/src/transform/jit/code/kernel.cpp b/cpp/src/transform/jit/code/kernel.cpp index aa91dce407b..58fdb945de3 100644 --- a/cpp/src/transform/jit/code/kernel.cpp +++ b/cpp/src/transform/jit/code/kernel.cpp @@ -20,9 +20,16 @@ namespace jit { namespace code { const char* kernel_header = R"***( + #pragma once + + // Include Jitify's cstddef header first + #include + + #include + #include #include - #include + #include #include )***"; diff --git a/cpp/src/transform/transform.cpp b/cpp/src/transform/transform.cpp index 643222e9a20..b38b32b7c0b 100644 --- a/cpp/src/transform/transform.cpp +++ b/cpp/src/transform/transform.cpp @@ -22,14 +22,14 @@ #include #include -#include -#include -#include #include "jit/code/code.h" +#include "jit/common_headers.hpp" +#include "jit/launcher.h" +#include "jit/parser.h" +#include "jit/type.h" -#include -#include -#include +#include +#include namespace cudf { namespace transformation { diff --git a/cpp/tests/binaryop/binop-generic-ptx-test.cpp b/cpp/tests/binaryop/binop-generic-ptx-test.cpp index 7ef10f1df67..6e35bdac41c 100644 --- a/cpp/tests/binaryop/binop-generic-ptx-test.cpp +++ b/cpp/tests/binaryop/binop-generic-ptx-test.cpp @@ -17,8 +17,9 @@ * limitations under the License. */ -#include #include + +#include #include namespace cudf { diff --git a/cpp/tests/binaryop/binop-integration-test.cpp b/cpp/tests/binaryop/binop-integration-test.cpp index 28bad252578..088e9d291b2 100644 --- a/cpp/tests/binaryop/binop-integration-test.cpp +++ b/cpp/tests/binaryop/binop-integration-test.cpp @@ -17,16 +17,16 @@ * limitations under the License. */ +#include +#include +#include +#include + #include #include +#include #include -#include -#include -#include "cudf/types.hpp" -#include "cudf/utilities/type_dispatcher.hpp" -#include "tests/utilities/column_utilities.hpp" - namespace cudf { namespace test { namespace binop { diff --git a/cpp/tests/binaryop/binop-null-test.cpp b/cpp/tests/binaryop/binop-null-test.cpp index 7f2af67fb2b..3277e991b94 100644 --- a/cpp/tests/binaryop/binop-null-test.cpp +++ b/cpp/tests/binaryop/binop-null-test.cpp @@ -17,8 +17,9 @@ * limitations under the License. */ -#include #include + +#include #include namespace cudf { diff --git a/cpp/tests/binaryop/binop-verify-input-test.cpp b/cpp/tests/binaryop/binop-verify-input-test.cpp index 0827b8f3148..167fbc22bde 100644 --- a/cpp/tests/binaryop/binop-verify-input-test.cpp +++ b/cpp/tests/binaryop/binop-verify-input-test.cpp @@ -18,6 +18,7 @@ */ #include + #include namespace cudf { diff --git a/cpp/tests/unary/unary_ops_test.cpp b/cpp/tests/unary/unary_ops_test.cpp index b782b92e296..b18ccf3f35b 100644 --- a/cpp/tests/unary/unary_ops_test.cpp +++ b/cpp/tests/unary/unary_ops_test.cpp @@ -21,11 +21,13 @@ #include #include #include -#include + #include #include #include #include + +#include #include template diff --git a/cpp/tests/wrappers/timestamps_test.cu b/cpp/tests/wrappers/timestamps_test.cu index bfbc586a92f..d91b67e55a6 100644 --- a/cpp/tests/wrappers/timestamps_test.cu +++ b/cpp/tests/wrappers/timestamps_test.cu @@ -17,16 +17,16 @@ #include #include #include +#include +#include #include #include #include +#include +#include #include #include -#include "cudf/column/column_view.hpp" -#include "cudf/types.hpp" -#include "tests/utilities/column_utilities.hpp" -#include "tests/utilities/column_wrapper.hpp" template struct ChronoColumnTest : public cudf::test::BaseFixture { diff --git a/thirdparty/CMakeLists.txt b/thirdparty/CMakeLists.txt index 6270f3a818c..0b3166cc765 100644 --- a/thirdparty/CMakeLists.txt +++ b/thirdparty/CMakeLists.txt @@ -27,7 +27,7 @@ message("Fetching Jitify") FetchContent_Declare( jitify GIT_REPOSITORY https://github.com/rapidsai/jitify.git - GIT_TAG cudf_0.15 + GIT_TAG cudf_0.16 GIT_SHALLOW true ) From 8056f17b6bcb8551b592730e974b7ced389fc56e Mon Sep 17 00:00:00 2001 From: ptaylor Date: Tue, 22 Sep 2020 19:46:10 -0700 Subject: [PATCH 05/13] fix span_tests.cu includes --- cpp/tests/utilities_tests/span_tests.cu | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/cpp/tests/utilities_tests/span_tests.cu b/cpp/tests/utilities_tests/span_tests.cu index 7710f859316..2c14d26c01d 100644 --- a/cpp/tests/utilities_tests/span_tests.cu +++ b/cpp/tests/utilities_tests/span_tests.cu @@ -16,9 +16,9 @@ #include -#include -#include -#include +#include +#include +#include #include #include From befb135b7f367dde2bb885404972352b53e3c090 Mon Sep 17 00:00:00 2001 From: ptaylor Date: Tue, 22 Sep 2020 19:46:58 -0700 Subject: [PATCH 06/13] fix span_tests.cu includes --- cpp/tests/utilities_tests/span_tests.cu | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/cpp/tests/utilities_tests/span_tests.cu b/cpp/tests/utilities_tests/span_tests.cu index 2c14d26c01d..60215d31734 100644 --- a/cpp/tests/utilities_tests/span_tests.cu +++ b/cpp/tests/utilities_tests/span_tests.cu @@ -16,9 +16,9 @@ #include -#include -#include -#include +#include +#include +#include #include #include From c7bbbec069874dd2e768bba16b8d1ec650081153 Mon Sep 17 00:00:00 2001 From: ptaylor Date: Fri, 9 Oct 2020 13:32:08 -0700 Subject: [PATCH 07/13] update new simt -> cuda references --- cpp/include/cudf/ast/detail/operators.hpp | 10 +++++----- cpp/include/cudf/ast/detail/transform.cuh | 4 ++-- 2 files changed, 7 insertions(+), 7 deletions(-) diff --git a/cpp/include/cudf/ast/detail/operators.hpp b/cpp/include/cudf/ast/detail/operators.hpp index e2dda57bab8..b95f14ff878 100644 --- a/cpp/include/cudf/ast/detail/operators.hpp +++ b/cpp/include/cudf/ast/detail/operators.hpp @@ -16,11 +16,11 @@ #pragma once #include +#include #include #include #include #include -#include #include #include #include @@ -33,10 +33,10 @@ namespace detail { // Traits for valid operator / type combinations template -constexpr bool is_valid_binary_op = simt::std::is_invocable::value; +constexpr bool is_valid_binary_op = cuda::std::is_invocable::value; template -constexpr bool is_valid_unary_op = simt::std::is_invocable::value; +constexpr bool is_valid_unary_op = cuda::std::is_invocable::value; /** * @brief Operator dispatcher @@ -983,7 +983,7 @@ struct return_type_functor { std::enable_if_t>* = nullptr> CUDA_HOST_DEVICE_CALLABLE void operator()(cudf::data_type& result) { - using Out = simt::std::invoke_result_t; + using Out = cuda::std::invoke_result_t; result = cudf::data_type(cudf::type_to_id()); } @@ -1012,7 +1012,7 @@ struct return_type_functor { std::enable_if_t>* = nullptr> CUDA_HOST_DEVICE_CALLABLE void operator()(cudf::data_type& result) { - using Out = simt::std::invoke_result_t; + using Out = cuda::std::invoke_result_t; result = cudf::data_type(cudf::type_to_id()); } diff --git a/cpp/include/cudf/ast/detail/transform.cuh b/cpp/include/cudf/ast/detail/transform.cuh index 3366acefe35..e21386fec07 100644 --- a/cpp/include/cudf/ast/detail/transform.cuh +++ b/cpp/include/cudf/ast/detail/transform.cuh @@ -74,7 +74,7 @@ struct unary_row_output : public row_output { detail::device_data_reference output) const { using OperatorFunctor = detail::operator_functor; - using Out = simt::std::invoke_result_t; + using Out = cuda::std::invoke_result_t; resolve_output(output, row_index, OperatorFunctor{}(input)); } @@ -102,7 +102,7 @@ struct binary_row_output : public row_output { detail::device_data_reference output) const { using OperatorFunctor = detail::operator_functor; - using Out = simt::std::invoke_result_t; + using Out = cuda::std::invoke_result_t; resolve_output(output, row_index, OperatorFunctor{}(lhs, rhs)); } From d48539115b9e17b5ef8b35f6003d569ae0afbec3 Mon Sep 17 00:00:00 2001 From: ptaylor Date: Fri, 20 Nov 2020 17:23:00 -0600 Subject: [PATCH 08/13] remove unnecessary include --- cpp/src/binaryop/binaryop.cpp | 1 - 1 file changed, 1 deletion(-) diff --git a/cpp/src/binaryop/binaryop.cpp b/cpp/src/binaryop/binaryop.cpp index 6cbdc9870c6..ae52ec2b9c1 100644 --- a/cpp/src/binaryop/binaryop.cpp +++ b/cpp/src/binaryop/binaryop.cpp @@ -33,7 +33,6 @@ #include #include -// #include // replace eventually #include #include #include From 0c0babf5a005f967656405604e86bd695305f222 Mon Sep 17 00:00:00 2001 From: ptaylor Date: Mon, 23 Nov 2020 11:41:29 -0600 Subject: [PATCH 09/13] update simt -> cuda --- cpp/src/io/parquet/page_enc.cu | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/cpp/src/io/parquet/page_enc.cu b/cpp/src/io/parquet/page_enc.cu index 3d87901f269..e71b9f83eff 100644 --- a/cpp/src/io/parquet/page_enc.cu +++ b/cpp/src/io/parquet/page_enc.cu @@ -13,15 +13,15 @@ * See the License for the specific language governing permissions and * limitations under the License. */ -#include #include #include -#include #include #include #include +#include +#include namespace cudf { namespace io { @@ -917,8 +917,8 @@ static __device__ void PlainBoolEncode(page_enc_state_s *s, constexpr auto julian_calendar_epoch_diff() { - using namespace simt::std::chrono; - using namespace simt::std::chrono_literals; + using namespace cuda::std::chrono; + using namespace cuda::std::chrono_literals; return sys_days{January / 1 / 1970} - (sys_days{November / 24 / -4713} + 12h); } @@ -930,10 +930,10 @@ constexpr auto julian_calendar_epoch_diff() * @return std::pair where nanoseconds is the number of nanoseconds * elapsed in the day and days is the number of days from Julian epoch. */ -static __device__ std::pair -convert_nanoseconds(simt::std::chrono::sys_time const ns) +static __device__ std::pair +convert_nanoseconds(cuda::std::chrono::sys_time const ns) { - using namespace simt::std::chrono; + using namespace cuda::std::chrono; auto const nanosecond_ticks = ns.time_since_epoch(); auto const gregorian_days = floor(nanosecond_ticks); auto const julian_days = gregorian_days + ceil(julian_calendar_epoch_diff()); @@ -1190,7 +1190,7 @@ __global__ void __launch_bounds__(128, 8) gpuEncodePages(EncPage *pages, } auto const ret = convert_nanoseconds([&]() { - using namespace simt::std::chrono; + using namespace cuda::std::chrono; switch (s->col.converted_type) { case TIMESTAMP_MILLIS: { From 61296b99d050de2fbc3c415bbfd9dead88c0b449 Mon Sep 17 00:00:00 2001 From: ptaylor Date: Fri, 4 Dec 2020 14:47:53 -0600 Subject: [PATCH 10/13] Update libcu++ git tag to 1.4.0 --- thirdparty/CMakeLists.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/thirdparty/CMakeLists.txt b/thirdparty/CMakeLists.txt index f15f831c552..5202764c844 100644 --- a/thirdparty/CMakeLists.txt +++ b/thirdparty/CMakeLists.txt @@ -52,7 +52,7 @@ message(STATUS "Fetching libcudacxx from ${SRC_LIBCUDACXX}") FetchContent_Declare( libcudacxx GIT_REPOSITORY ${SRC_LIBCUDACXX} - GIT_TAG main + GIT_TAG 1.4.0 GIT_SHALLOW true ) From 85f29e467b35e1109eb1a43cfc8daf9e879cae32 Mon Sep 17 00:00:00 2001 From: ptaylor Date: Mon, 7 Dec 2020 19:17:10 -0600 Subject: [PATCH 11/13] move changelog entry --- CHANGELOG.md | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 97fcd5f3ef8..153675e50b7 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -6,6 +6,8 @@ ## Improvements +- PR #6275 Update to official libcu++ on Github + ## Bug Fixes - PR #6912 Fix rmm_mode=managed parameter for gtests @@ -343,7 +345,6 @@ - PR #6407 Add RMM_LOGGING_LEVEL flag to Java docker build - PR #6425 Factor out csv parse_options creation to pure function - PR #6438 Fetch nvcomp v1.1.0 for JNI build -- PR #6275 Update to official libcu++ on Github - PR #6459 Add `map` method to series - PR #6379 Add list hashing functionality to MD5 - PR #6498 Add helper method to ColumnBuilder with some nits From beaa827079ea841b879ded7945b4f4a2009458a3 Mon Sep 17 00:00:00 2001 From: Paul Taylor Date: Mon, 7 Dec 2020 23:12:36 -0600 Subject: [PATCH 12/13] Fix quoted includes Co-authored-by: Mark Harris --- cpp/src/binaryop/binaryop.cpp | 13 +++++++------ cpp/src/rolling/rolling.cu | 13 +++++++------ cpp/src/transform/transform.cpp | 9 +++++---- 3 files changed, 19 insertions(+), 16 deletions(-) diff --git a/cpp/src/binaryop/binaryop.cpp b/cpp/src/binaryop/binaryop.cpp index ae52ec2b9c1..18e277ca228 100644 --- a/cpp/src/binaryop/binaryop.cpp +++ b/cpp/src/binaryop/binaryop.cpp @@ -17,12 +17,13 @@ * limitations under the License. */ -#include "binaryop/compiled/binary_ops.hpp" -#include "binaryop/jit/code/code.h" -#include "binaryop/jit/util.hpp" -#include "jit/launcher.h" -#include "jit/parser.h" -#include "jit/type.h" +#include "compiled/binary_ops.hpp" +#include "jit/code/code.h" +#include "jit/util.hpp" + +#include +#include +#include #include #include diff --git a/cpp/src/rolling/rolling.cu b/cpp/src/rolling/rolling.cu index b278a41994c..714a644925f 100644 --- a/cpp/src/rolling/rolling.cu +++ b/cpp/src/rolling/rolling.cu @@ -14,12 +14,13 @@ * limitations under the License. */ -#include "jit/launcher.h" -#include "jit/parser.h" -#include "jit/type.h" -#include "rolling/jit/code/code.h" -#include "rolling/rolling_detail.hpp" -#include "rolling/rolling_jit_detail.hpp" +#include +#include +#include + +#include "jit/code/code.h" +#include "rolling_detail.hpp" +#include "rolling_jit_detail.hpp" #include #include diff --git a/cpp/src/transform/transform.cpp b/cpp/src/transform/transform.cpp index 6c1570d3ce2..01e5c883eb3 100644 --- a/cpp/src/transform/transform.cpp +++ b/cpp/src/transform/transform.cpp @@ -15,10 +15,11 @@ */ #include "jit/code/code.h" -#include "jit/common_headers.hpp" -#include "jit/launcher.h" -#include "jit/parser.h" -#include "jit/type.h" + +#include +#include +#include +#include #include #include From 9d4e254ec48de62367257262d50822699b88d30e Mon Sep 17 00:00:00 2001 From: ptaylor Date: Mon, 7 Dec 2020 23:16:21 -0600 Subject: [PATCH 13/13] fix lint --- cpp/src/transform/transform.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/cpp/src/transform/transform.cpp b/cpp/src/transform/transform.cpp index 01e5c883eb3..6da0f78687b 100644 --- a/cpp/src/transform/transform.cpp +++ b/cpp/src/transform/transform.cpp @@ -16,10 +16,10 @@ #include "jit/code/code.h" -#include #include #include #include +#include #include #include