From e54b82c9f3499b35e7e789d41d2042a5d5a80810 Mon Sep 17 00:00:00 2001 From: Mark Harris <783069+harrism@users.noreply.github.com> Date: Tue, 23 Jul 2024 05:03:04 +1000 Subject: [PATCH] Use resource_ref for upstream in stream_checking_resource_adaptor (#16187) As we move toward replacing all `device_memory_resource` pointers with `resource_ref`s, there are some places that changes can be made ahead of RMM to simplify required changes as RMM is refactored. In this PR I eliminate the unnecessary `Upstream` template parameter from `cudf_test::stream_checking_resource_adaptor`, and use a `device_async_resource` for the upstream resource. A similar change will be made to all RMM resource adaptors, but this one can be done without deprecations since it is just a test utility. Authors: - Mark Harris (https://github.com/harrism) - Vyas Ramasubramani (https://github.com/vyasr) Approvers: - Vyas Ramasubramani (https://github.com/vyasr) URL: https://github.com/rapidsai/cudf/pull/16187 --- .../stream_checking_resource_adaptor.hpp | 33 +++++++++---------- cpp/include/cudf_test/testing_main.hpp | 10 +++--- 2 files changed, 19 insertions(+), 24 deletions(-) diff --git a/cpp/include/cudf_test/stream_checking_resource_adaptor.hpp b/cpp/include/cudf_test/stream_checking_resource_adaptor.hpp index 5a077e86a0f..4f3c723d195 100644 --- a/cpp/include/cudf_test/stream_checking_resource_adaptor.hpp +++ b/cpp/include/cudf_test/stream_checking_resource_adaptor.hpp @@ -24,13 +24,11 @@ #include +namespace cudf::test { + /** * @brief Resource that verifies that the default stream is not used in any allocation. - * - * @tparam Upstream Type of the upstream resource used for - * allocation/deallocation. */ -template class stream_checking_resource_adaptor final : public rmm::mr::device_memory_resource { public: /** @@ -40,14 +38,13 @@ class stream_checking_resource_adaptor final : public rmm::mr::device_memory_res * * @param upstream The resource used for allocating/deallocating device memory */ - stream_checking_resource_adaptor(Upstream* upstream, + stream_checking_resource_adaptor(rmm::device_async_resource_ref upstream, bool error_on_invalid_stream, bool check_default_stream) : upstream_{upstream}, error_on_invalid_stream_{error_on_invalid_stream}, check_default_stream_{check_default_stream} { - CUDF_EXPECTS(nullptr != upstream, "Unexpected null upstream resource pointer."); } stream_checking_resource_adaptor() = delete; @@ -86,7 +83,7 @@ class stream_checking_resource_adaptor final : public rmm::mr::device_memory_res void* do_allocate(std::size_t bytes, rmm::cuda_stream_view stream) override { verify_stream(stream); - return upstream_->allocate(bytes, stream); + return upstream_.allocate_async(bytes, rmm::CUDA_ALLOCATION_ALIGNMENT, stream); } /** @@ -101,7 +98,7 @@ class stream_checking_resource_adaptor final : public rmm::mr::device_memory_res void do_deallocate(void* ptr, std::size_t bytes, rmm::cuda_stream_view stream) override { verify_stream(stream); - upstream_->deallocate(ptr, bytes, stream); + upstream_.deallocate_async(ptr, bytes, rmm::CUDA_ALLOCATION_ALIGNMENT, stream); } /** @@ -113,8 +110,8 @@ class stream_checking_resource_adaptor final : public rmm::mr::device_memory_res [[nodiscard]] bool do_is_equal(device_memory_resource const& other) const noexcept override { if (this == &other) { return true; } - auto cast = dynamic_cast const*>(&other); - if (cast == nullptr) { return upstream_->is_equal(other); } + auto cast = dynamic_cast(&other); + if (cast == nullptr) { return false; } return get_upstream_resource() == cast->get_upstream_resource(); } @@ -150,7 +147,8 @@ class stream_checking_resource_adaptor final : public rmm::mr::device_memory_res } } - Upstream* upstream_; // the upstream resource used for satisfying allocation requests + rmm::device_async_resource_ref + upstream_; // the upstream resource used for satisfying allocation requests bool error_on_invalid_stream_; // If true, throw an exception when the wrong stream is detected. // If false, simply print to stdout. bool check_default_stream_; // If true, throw an exception when the default stream is observed. @@ -162,13 +160,12 @@ class stream_checking_resource_adaptor final : public rmm::mr::device_memory_res * @brief Convenience factory to return a `stream_checking_resource_adaptor` around the * upstream resource `upstream`. * - * @tparam Upstream Type of the upstream `device_memory_resource`. - * @param upstream Pointer to the upstream resource + * @param upstream Reference to the upstream resource */ -template -stream_checking_resource_adaptor make_stream_checking_resource_adaptor( - Upstream* upstream, bool error_on_invalid_stream, bool check_default_stream) +inline stream_checking_resource_adaptor make_stream_checking_resource_adaptor( + rmm::device_async_resource_ref upstream, bool error_on_invalid_stream, bool check_default_stream) { - return stream_checking_resource_adaptor{ - upstream, error_on_invalid_stream, check_default_stream}; + return stream_checking_resource_adaptor{upstream, error_on_invalid_stream, check_default_stream}; } + +} // namespace cudf::test diff --git a/cpp/include/cudf_test/testing_main.hpp b/cpp/include/cudf_test/testing_main.hpp index 66b831b917f..3ad4b127f80 100644 --- a/cpp/include/cudf_test/testing_main.hpp +++ b/cpp/include/cudf_test/testing_main.hpp @@ -32,8 +32,7 @@ #include #include -namespace cudf { -namespace test { +namespace cudf::test { /// MR factory functions inline auto make_cuda() { return std::make_shared(); } @@ -91,8 +90,7 @@ inline std::shared_ptr create_memory_resource( CUDF_FAIL("Invalid RMM allocation mode: " + allocation_mode); } -} // namespace test -} // namespace cudf +} // namespace cudf::test /** * @brief Parses the cuDF test command line options. @@ -182,8 +180,8 @@ inline auto make_stream_mode_adaptor(cxxopts::ParseResult const& cmd_opts) auto const stream_error_mode = cmd_opts["stream_error_mode"].as(); auto const error_on_invalid_stream = (stream_error_mode == "error"); auto const check_default_stream = (stream_mode == "new_cudf_default"); - auto adaptor = - make_stream_checking_resource_adaptor(resource, error_on_invalid_stream, check_default_stream); + auto adaptor = cudf::test::make_stream_checking_resource_adaptor( + resource, error_on_invalid_stream, check_default_stream); if ((stream_mode == "new_cudf_default") || (stream_mode == "new_testing_default")) { rmm::mr::set_current_device_resource(&adaptor); }