diff --git a/.upstream-tests/test/cuda/memory_resource/get_property/forward_property.pass.cpp b/.upstream-tests/test/cuda/memory_resource/get_property/forward_property.pass.cpp index fd76c205d8..234f4bc8cd 100644 --- a/.upstream-tests/test/cuda/memory_resource/get_property/forward_property.pass.cpp +++ b/.upstream-tests/test/cuda/memory_resource/get_property/forward_property.pass.cpp @@ -107,7 +107,7 @@ namespace forward_property { return convertible_to_upstream{}; } }; - static_assert(!cuda::has_property); + static_assert(!cuda::has_property, ""); __host__ __device__ constexpr bool test_stateful() { using derived_no_override = derived_plain; diff --git a/.upstream-tests/test/cuda/memory_resource/get_property/has_property.pass.cpp b/.upstream-tests/test/cuda/memory_resource/get_property/has_property.pass.cpp index 6fda218306..c107aeb9d3 100644 --- a/.upstream-tests/test/cuda/memory_resource/get_property/has_property.pass.cpp +++ b/.upstream-tests/test/cuda/memory_resource/get_property/has_property.pass.cpp @@ -20,8 +20,8 @@ struct prop_with_value { }; struct prop {}; -static_assert(cuda::property_with_value); -static_assert(!cuda::property_with_value); +static_assert(cuda::property_with_value, ""); +static_assert(!cuda::property_with_value, ""); struct valid_property { friend void get_property(const valid_property&, prop) {} diff --git a/.upstream-tests/test/cuda/memory_resource/memory_resource.async_resource_ref/async_resource_ref.construction.pass.cpp b/.upstream-tests/test/cuda/memory_resource/memory_resource.async_resource_ref/async_resource_ref.construction.pass.cpp index 672a4fae96..12b8e969de 100644 --- a/.upstream-tests/test/cuda/memory_resource/memory_resource.async_resource_ref/async_resource_ref.construction.pass.cpp +++ b/.upstream-tests/test/cuda/memory_resource/memory_resource.async_resource_ref/async_resource_ref.construction.pass.cpp @@ -50,15 +50,12 @@ struct async_resource { int _val = 0; _LIBCUDACXX_TEMPLATE(class Property) - (requires !cuda::property_with_value && - _CUDA_VSTD::_One_of) // - friend void get_property(const async_resource&, Property) noexcept {} + (requires (!cuda::property_with_value) && _CUDA_VSTD::_One_of) // + friend void get_property(const async_resource&, Property) noexcept {} _LIBCUDACXX_TEMPLATE(class Property) - (requires cuda::property_with_value&& - _CUDA_VSTD::_One_of) // - friend typename Property::value_type - get_property(const async_resource& res, Property) noexcept { + (requires cuda::property_with_value && _CUDA_VSTD::_One_of) // + friend typename Property::value_type get_property(const async_resource& res, Property) noexcept { return res._val; } }; diff --git a/.upstream-tests/test/cuda/memory_resource/memory_resource.async_resource_ref/async_resource_ref.conversion.pass.cpp b/.upstream-tests/test/cuda/memory_resource/memory_resource.async_resource_ref/async_resource_ref.conversion.pass.cpp index 15a04c2b71..e3e8bd8a2a 100644 --- a/.upstream-tests/test/cuda/memory_resource/memory_resource.async_resource_ref/async_resource_ref.conversion.pass.cpp +++ b/.upstream-tests/test/cuda/memory_resource/memory_resource.async_resource_ref/async_resource_ref.conversion.pass.cpp @@ -55,15 +55,12 @@ struct resource { int _val = 0; _LIBCUDACXX_TEMPLATE(class Property) - (requires !cuda::property_with_value && - _CUDA_VSTD::_One_of) // - friend void get_property(const resource&, Property) noexcept {} + (requires (!cuda::property_with_value) && _CUDA_VSTD::_One_of) // + friend void get_property(const resource&, Property) noexcept {} _LIBCUDACXX_TEMPLATE(class Property) - (requires cuda::property_with_value&& - _CUDA_VSTD::_One_of) // - friend typename Property::value_type - get_property(const resource& res, Property) noexcept { + (requires cuda::property_with_value && _CUDA_VSTD::_One_of) // + friend typename Property::value_type get_property(const resource& res, Property) noexcept { return res._val; } }; diff --git a/.upstream-tests/test/cuda/memory_resource/memory_resource.async_resource_ref/async_resource_ref.equality.fail.cpp b/.upstream-tests/test/cuda/memory_resource/memory_resource.async_resource_ref/async_resource_ref.equality.fail.cpp index 1116a13e11..4db52db56b 100644 --- a/.upstream-tests/test/cuda/memory_resource/memory_resource.async_resource_ref/async_resource_ref.equality.fail.cpp +++ b/.upstream-tests/test/cuda/memory_resource/memory_resource.async_resource_ref/async_resource_ref.equality.fail.cpp @@ -8,6 +8,7 @@ //===----------------------------------------------------------------------===// // UNSUPPORTED: c++03, c++11 +// UNSUPPORTED: nvrtc // cuda::mr::async_resource_ref equality diff --git a/.upstream-tests/test/cuda/memory_resource/memory_resource.async_resource_ref/async_resource_ref.equality.pass.cpp b/.upstream-tests/test/cuda/memory_resource/memory_resource.async_resource_ref/async_resource_ref.equality.pass.cpp index a4feced151..0d194714ea 100644 --- a/.upstream-tests/test/cuda/memory_resource/memory_resource.async_resource_ref/async_resource_ref.equality.pass.cpp +++ b/.upstream-tests/test/cuda/memory_resource/memory_resource.async_resource_ref/async_resource_ref.equality.pass.cpp @@ -52,15 +52,12 @@ struct async_resource { int _val = 0; _LIBCUDACXX_TEMPLATE(class Property) - (requires !cuda::property_with_value && - _CUDA_VSTD::_One_of) // - friend void get_property(const async_resource&, Property) noexcept {} + (requires (!cuda::property_with_value) && _CUDA_VSTD::_One_of) // + friend void get_property(const async_resource&, Property) noexcept {} _LIBCUDACXX_TEMPLATE(class Property) - (requires cuda::property_with_value&& - _CUDA_VSTD::_One_of) // - friend typename Property::value_type - get_property(const async_resource& res, Property) noexcept { + (requires cuda::property_with_value && _CUDA_VSTD::_One_of) // + friend typename Property::value_type get_property(const async_resource& res, Property) noexcept { return res._val; } }; diff --git a/.upstream-tests/test/cuda/memory_resource/memory_resource.async_resource_ref/async_resource_ref.inheritance.pass.cpp b/.upstream-tests/test/cuda/memory_resource/memory_resource.async_resource_ref/async_resource_ref.inheritance.pass.cpp index 2f6f3bf883..e24a6ca2bd 100644 --- a/.upstream-tests/test/cuda/memory_resource/memory_resource.async_resource_ref/async_resource_ref.inheritance.pass.cpp +++ b/.upstream-tests/test/cuda/memory_resource/memory_resource.async_resource_ref/async_resource_ref.inheritance.pass.cpp @@ -41,15 +41,12 @@ struct async_resource_base { bool operator!=(const async_resource_base& other) const { return false; } _LIBCUDACXX_TEMPLATE(class Property) - (requires !cuda::property_with_value && - _CUDA_VSTD::_One_of) // - friend void get_property(const async_resource_base&, Property) noexcept {} + (requires (!cuda::property_with_value) && _CUDA_VSTD::_One_of) // + friend void get_property(const async_resource_base&, Property) noexcept {} _LIBCUDACXX_TEMPLATE(class Property) - (requires cuda::property_with_value&& - _CUDA_VSTD::_One_of) // - friend typename Property::value_type - get_property(const async_resource_base& res, Property) noexcept { + (requires cuda::property_with_value && _CUDA_VSTD::_One_of) // + friend typename Property::value_type get_property(const async_resource_base& res, Property) noexcept { return 42; } }; @@ -58,7 +55,6 @@ template struct async_resource_derived_first : public async_resource_base { using super_t = async_resource_base; - using super_t::operator==; async_resource_derived_first(const int val) : _val(val) {} @@ -73,9 +69,12 @@ struct async_resource_derived_first void deallocate_async(void* ptr, std::size_t, std::size_t, cuda::stream_ref) override {} + bool operator==(const async_resource_derived_first& other) const { return true; } + bool operator!=(const async_resource_derived_first& other) const { return false; } + int _val = 0; }; -static_assert(cuda::mr::async_resource >); +static_assert(cuda::mr::async_resource >, ""); struct some_data { int _val; @@ -85,7 +84,6 @@ template struct async_resource_derived_second : public async_resource_base { using super_t = async_resource_base; - using super_t::operator==; async_resource_derived_second(some_data* val) : _val(val) {} @@ -100,6 +98,9 @@ struct async_resource_derived_second void deallocate_async(void* ptr, std::size_t, std::size_t, cuda::stream_ref) override {} + bool operator==(const async_resource_derived_second& other) const { return true; } + bool operator!=(const async_resource_derived_second& other) const { return false; } + some_data* _val = 0; }; diff --git a/.upstream-tests/test/cuda/memory_resource/memory_resource.async_resource_ref/async_resource_ref.properties.pass.cpp b/.upstream-tests/test/cuda/memory_resource/memory_resource.async_resource_ref/async_resource_ref.properties.pass.cpp index 73ba361686..03c3b7ed08 100644 --- a/.upstream-tests/test/cuda/memory_resource/memory_resource.async_resource_ref/async_resource_ref.properties.pass.cpp +++ b/.upstream-tests/test/cuda/memory_resource/memory_resource.async_resource_ref/async_resource_ref.properties.pass.cpp @@ -59,15 +59,12 @@ struct async_resource { int _val = 0; _LIBCUDACXX_TEMPLATE(class Property) - (requires !cuda::property_with_value && - _CUDA_VSTD::_One_of) // - friend void get_property(const async_resource&, Property) noexcept {} + (requires (!cuda::property_with_value) && _CUDA_VSTD::_One_of) // + friend void get_property(const async_resource&, Property) noexcept {} _LIBCUDACXX_TEMPLATE(class Property) - (requires cuda::property_with_value&& - _CUDA_VSTD::_One_of) // - friend typename Property::value_type - get_property(const async_resource& res, Property) noexcept { + (requires cuda::property_with_value && _CUDA_VSTD::_One_of) // + friend typename Property::value_type get_property(const async_resource& res, Property) noexcept { return res._val; } }; @@ -75,39 +72,39 @@ struct async_resource { // Ensure we have the right size static_assert(sizeof(cuda::mr::async_resource_ref, property_with_value >) == - (4 * sizeof(void*))); + (4 * sizeof(void*)), ""); static_assert( sizeof(cuda::mr::async_resource_ref, property_without_value >) == - (3 * sizeof(void*))); + (3 * sizeof(void*)), ""); static_assert(sizeof(cuda::mr::async_resource_ref, property_with_value >) == - (3 * sizeof(void*))); + (3 * sizeof(void*)), ""); static_assert( sizeof(cuda::mr::async_resource_ref, property_without_value >) == - (2 * sizeof(void*))); + (2 * sizeof(void*)), ""); _LIBCUDACXX_TEMPLATE(class Property, class Ref) -(requires !cuda::property_with_value) // + (requires (!cuda::property_with_value)) // int InvokeIfWithValue(const Ref& ref) { return -1; } _LIBCUDACXX_TEMPLATE(class Property, class Ref) -(requires cuda::property_with_value) // + (requires cuda::property_with_value) // typename Property::value_type InvokeIfWithValue(const Ref& ref) { return get_property(ref, Property{}); } _LIBCUDACXX_TEMPLATE(class Property, class Ref) -(requires cuda::property_with_value) // + (requires cuda::property_with_value) // int InvokeIfWithoutValue(const Ref& ref) { return -1; } _LIBCUDACXX_TEMPLATE(class Property, class Ref) -(requires !cuda::property_with_value) // + (requires (!cuda::property_with_value)) // int InvokeIfWithoutValue(const Ref& ref) { get_property(ref, Property{}); return 1; @@ -155,12 +152,12 @@ void test_property_forwarding() { using ref = cuda::mr::async_resource_ref >; static_assert(cuda::mr::async_resource_with, - property_with_value >); + property_with_value >, ""); static_assert(!cuda::mr::async_resource_with, - property_with_value >); + property_with_value >, ""); static_assert( - cuda::mr::async_resource_with >); + cuda::mr::async_resource_with >, ""); } void test_async_resource_ref() { diff --git a/.upstream-tests/test/cuda/memory_resource/memory_resource.resource_ref/resource_ref.construction.pass.cpp b/.upstream-tests/test/cuda/memory_resource/memory_resource.resource_ref/resource_ref.construction.pass.cpp index 1374700a84..e838a3a286 100644 --- a/.upstream-tests/test/cuda/memory_resource/memory_resource.resource_ref/resource_ref.construction.pass.cpp +++ b/.upstream-tests/test/cuda/memory_resource/memory_resource.resource_ref/resource_ref.construction.pass.cpp @@ -40,15 +40,12 @@ struct resource { int _val = 0; _LIBCUDACXX_TEMPLATE(class Property) - (requires !cuda::property_with_value && - _CUDA_VSTD::_One_of) // - friend void get_property(const resource&, Property) noexcept {} + (requires (!cuda::property_with_value) && _CUDA_VSTD::_One_of) // + friend void get_property(const resource&, Property) noexcept {} _LIBCUDACXX_TEMPLATE(class Property) - (requires cuda::property_with_value&& - _CUDA_VSTD::_One_of) // - friend typename Property::value_type - get_property(const resource& res, Property) noexcept { + (requires cuda::property_with_value && _CUDA_VSTD::_One_of) // + friend typename Property::value_type get_property(const resource& res, Property) noexcept { return res._val; } }; diff --git a/.upstream-tests/test/cuda/memory_resource/memory_resource.resource_ref/resource_ref.conversion.pass.cpp b/.upstream-tests/test/cuda/memory_resource/memory_resource.resource_ref/resource_ref.conversion.pass.cpp index d93430935b..15f7331c74 100644 --- a/.upstream-tests/test/cuda/memory_resource/memory_resource.resource_ref/resource_ref.conversion.pass.cpp +++ b/.upstream-tests/test/cuda/memory_resource/memory_resource.resource_ref/resource_ref.conversion.pass.cpp @@ -55,15 +55,12 @@ struct resource { int _val = 0; _LIBCUDACXX_TEMPLATE(class Property) - (requires !cuda::property_with_value && - _CUDA_VSTD::_One_of) // - friend void get_property(const resource&, Property) noexcept {} + (requires (!cuda::property_with_value) && _CUDA_VSTD::_One_of) // + friend void get_property(const resource&, Property) noexcept {} _LIBCUDACXX_TEMPLATE(class Property) - (requires cuda::property_with_value&& - _CUDA_VSTD::_One_of) // - friend typename Property::value_type - get_property(const resource& res, Property) noexcept { + (requires cuda::property_with_value && _CUDA_VSTD::_One_of) // + friend typename Property::value_type get_property(const resource& res, Property) noexcept { return res._val; } }; diff --git a/.upstream-tests/test/cuda/memory_resource/memory_resource.resource_ref/resource_ref.equality.fail.cpp b/.upstream-tests/test/cuda/memory_resource/memory_resource.resource_ref/resource_ref.equality.fail.cpp index 8c43807797..0efff529d3 100644 --- a/.upstream-tests/test/cuda/memory_resource/memory_resource.resource_ref/resource_ref.equality.fail.cpp +++ b/.upstream-tests/test/cuda/memory_resource/memory_resource.resource_ref/resource_ref.equality.fail.cpp @@ -8,6 +8,7 @@ //===----------------------------------------------------------------------===// // UNSUPPORTED: c++03, c++11 +// UNSUPPORTED: nvrtc // cuda::mr::resource_ref equality diff --git a/.upstream-tests/test/cuda/memory_resource/memory_resource.resource_ref/resource_ref.equality.pass.cpp b/.upstream-tests/test/cuda/memory_resource/memory_resource.resource_ref/resource_ref.equality.pass.cpp index d4b8f4b3ea..40ce8ef9ca 100644 --- a/.upstream-tests/test/cuda/memory_resource/memory_resource.resource_ref/resource_ref.equality.pass.cpp +++ b/.upstream-tests/test/cuda/memory_resource/memory_resource.resource_ref/resource_ref.equality.pass.cpp @@ -41,15 +41,12 @@ struct resource { int _val = 0; _LIBCUDACXX_TEMPLATE(class Property) - (requires !cuda::property_with_value && - _CUDA_VSTD::_One_of) // - friend void get_property(const resource&, Property) noexcept {} + (requires (!cuda::property_with_value) && _CUDA_VSTD::_One_of) // + friend void get_property(const resource&, Property) noexcept {} _LIBCUDACXX_TEMPLATE(class Property) - (requires cuda::property_with_value&& - _CUDA_VSTD::_One_of) // - friend typename Property::value_type - get_property(const resource& res, Property) noexcept { + (requires cuda::property_with_value && _CUDA_VSTD::_One_of) // + friend typename Property::value_type get_property(const resource& res, Property) noexcept { return res._val; } }; diff --git a/.upstream-tests/test/cuda/memory_resource/memory_resource.resource_ref/resource_ref.inheritance.pass.cpp b/.upstream-tests/test/cuda/memory_resource/memory_resource.resource_ref/resource_ref.inheritance.pass.cpp index 6add9c7ad9..547b254637 100644 --- a/.upstream-tests/test/cuda/memory_resource/memory_resource.resource_ref/resource_ref.inheritance.pass.cpp +++ b/.upstream-tests/test/cuda/memory_resource/memory_resource.resource_ref/resource_ref.inheritance.pass.cpp @@ -36,15 +36,12 @@ struct resource_base { bool operator!=(const resource_base& other) const { return false; } _LIBCUDACXX_TEMPLATE(class Property) - (requires !cuda::property_with_value && - _CUDA_VSTD::_One_of) // - friend void get_property(const resource_base&, Property) noexcept {} + (requires (!cuda::property_with_value) && _CUDA_VSTD::_One_of) // + friend void get_property(const resource_base&, Property) noexcept {} _LIBCUDACXX_TEMPLATE(class Property) - (requires cuda::property_with_value&& - _CUDA_VSTD::_One_of) // - friend typename Property::value_type - get_property(const resource_base& res, Property) noexcept { + (requires cuda::property_with_value && _CUDA_VSTD::_One_of) // + friend typename Property::value_type get_property(const resource_base& res, Property) noexcept { return 42; } }; @@ -52,7 +49,6 @@ struct resource_base { template struct resource_derived_first : public resource_base { using super_t = resource_base; - using super_t::operator==; resource_derived_first(const int val) : _val(val) {} @@ -60,9 +56,12 @@ struct resource_derived_first : public resource_base { void deallocate(void* ptr, std::size_t, std::size_t) override {} + bool operator==(const resource_derived_first& other) const { return true; } + bool operator!=(const resource_derived_first& other) const { return false; } + int _val = 0; }; -static_assert(cuda::mr::resource >); +static_assert(cuda::mr::resource >, ""); struct some_data { int _val; @@ -71,7 +70,6 @@ struct some_data { template struct resource_derived_second : public resource_base { using super_t = resource_base; - using super_t::operator==; resource_derived_second(some_data* val) : _val(val) {} @@ -79,6 +77,9 @@ struct resource_derived_second : public resource_base { void deallocate(void* ptr, std::size_t, std::size_t) override {} + bool operator==(const resource_derived_second& other) const { return true; } + bool operator!=(const resource_derived_second& other) const { return false; } + some_data* _val = 0; }; diff --git a/.upstream-tests/test/cuda/memory_resource/memory_resource.resource_ref/resource_ref.properties.pass.cpp b/.upstream-tests/test/cuda/memory_resource/memory_resource.resource_ref/resource_ref.properties.pass.cpp index b2641f5b44..a013d1e41e 100644 --- a/.upstream-tests/test/cuda/memory_resource/memory_resource.resource_ref/resource_ref.properties.pass.cpp +++ b/.upstream-tests/test/cuda/memory_resource/memory_resource.resource_ref/resource_ref.properties.pass.cpp @@ -50,15 +50,12 @@ struct resource { int _val = 0; _LIBCUDACXX_TEMPLATE(class Property) - (requires !cuda::property_with_value && - _CUDA_VSTD::_One_of) // - friend void get_property(const resource&, Property) noexcept {} + (requires (!cuda::property_with_value) && _CUDA_VSTD::_One_of) // + friend void get_property(const resource&, Property) noexcept {} _LIBCUDACXX_TEMPLATE(class Property) - (requires cuda::property_with_value&& - _CUDA_VSTD::_One_of) // - friend typename Property::value_type - get_property(const resource& res, Property) noexcept { + (requires cuda::property_with_value && _CUDA_VSTD::_One_of) // + friend typename Property::value_type get_property(const resource& res, Property) noexcept { return res._val; } }; @@ -66,37 +63,37 @@ struct resource { // Ensure we have the right size static_assert(sizeof(cuda::mr::resource_ref, property_with_value >) == - (4 * sizeof(void*))); + (4 * sizeof(void*)), ""); static_assert(sizeof(cuda::mr::resource_ref, property_without_value >) == - (3 * sizeof(void*))); + (3 * sizeof(void*)), ""); static_assert(sizeof(cuda::mr::resource_ref, property_with_value >) == - (3 * sizeof(void*))); + (3 * sizeof(void*)), ""); static_assert(sizeof(cuda::mr::resource_ref, property_without_value >) == - (2 * sizeof(void*))); + (2 * sizeof(void*)), ""); _LIBCUDACXX_TEMPLATE(class Property, class Ref) -(requires !cuda::property_with_value) // + (requires (!cuda::property_with_value)) // int InvokeIfWithValue(const Ref& ref) { return -1; } _LIBCUDACXX_TEMPLATE(class Property, class Ref) -(requires cuda::property_with_value) // + (requires cuda::property_with_value) // typename Property::value_type InvokeIfWithValue(const Ref& ref) { return get_property(ref, Property{}); } _LIBCUDACXX_TEMPLATE(class Property, class Ref) -(requires cuda::property_with_value) // + (requires cuda::property_with_value) // int InvokeIfWithoutValue(const Ref& ref) { return -1; } _LIBCUDACXX_TEMPLATE(class Property, class Ref) -(requires !cuda::property_with_value) // + (requires (!cuda::property_with_value)) // int InvokeIfWithoutValue(const Ref& ref) { get_property(ref, Property{}); return 1; @@ -143,11 +140,11 @@ void test_property_forwarding() { using ref = cuda::mr::resource_ref >; static_assert(cuda::mr::resource_with, - property_with_value >); + property_with_value >, ""); static_assert(!cuda::mr::resource_with, - property_with_value >); + property_with_value >, ""); - static_assert(cuda::mr::resource_with >); + static_assert(cuda::mr::resource_with >, ""); } void test_resource_ref() { diff --git a/.upstream-tests/test/cuda/stream_ref/stream_ref.constructor.pass.cpp b/.upstream-tests/test/cuda/stream_ref/stream_ref.constructor.pass.cpp index 7b77968255..06a945778d 100644 --- a/.upstream-tests/test/cuda/stream_ref/stream_ref.constructor.pass.cpp +++ b/.upstream-tests/test/cuda/stream_ref/stream_ref.constructor.pass.cpp @@ -13,20 +13,28 @@ #include #include -static_assert(cuda::std::is_default_constructible::value); -static_assert(!cuda::std::is_constructible::value); -static_assert(!cuda::std::is_constructible::value); +static_assert(cuda::std::is_default_constructible::value, ""); +static_assert(!cuda::std::is_constructible::value, ""); +static_assert(!cuda::std::is_constructible::value, ""); template using void_t = void; +#if TEST_STD_VER < 14 +template +struct has_value_type : cuda::std::false_type {}; +template +struct has_value_type> : cuda::std::true_type {}; +static_assert(has_value_type::value, ""); +#else template constexpr bool has_value_type = false; template -constexpr bool has_value_type > = true; - +constexpr bool has_value_type_v > = true; static_assert(has_value_type, ""); +#endif + int main(int argc, char** argv) { #ifndef __CUDA_ARCH__ diff --git a/.upstream-tests/test/cuda/stream_ref/stream_ref.ready.fail.cpp b/.upstream-tests/test/cuda/stream_ref/stream_ref.ready.fail.cpp deleted file mode 100644 index a298ac2ce5..0000000000 --- a/.upstream-tests/test/cuda/stream_ref/stream_ref.ready.fail.cpp +++ /dev/null @@ -1,36 +0,0 @@ -//===----------------------------------------------------------------------===// -// -// Part of libcu++, the C++ Standard Library for your entire system, -// under the Apache License v2.0 with LLVM Exceptions. -// See https://llvm.org/LICENSE.txt for license information. -// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception -// SPDX-FileCopyrightText: Copyright (c) 2022 NVIDIA CORPORATION & AFFILIATES. All rights reserved. -// -//===----------------------------------------------------------------------===// - -// UNSUPPORTED: nvrtc - -#define LIBCUDACXX_ENABLE_EXPERIMENTAL_MEMORY_RESOURCE - -#include -#include - -int main(int argc, char** argv) { -#ifndef __CUDA_ARCH__ - cudaStream_t stream = reinterpret_cast(42); - cuda::stream_ref ref{stream}; -#ifndef _LIBCUDACXX_NO_EXCEPTIONS - try { - assert(ref.ready()); - } catch (const cuda::cuda_error& e) { - assert(cudaGetErrorString(e) == ""); - } catch (...) { - assert(false && "Should have thrown"); - } - assert(false); -#else - assert(ref.ready()); -#endif // _LIBCUDACXX_NO_EXCEPTIONS -#endif - return 0; -} diff --git a/.upstream-tests/test/cuda/stream_ref/stream_ref.wait.fail.cpp b/.upstream-tests/test/cuda/stream_ref/stream_ref.wait.fail.cpp deleted file mode 100644 index d3c9654260..0000000000 --- a/.upstream-tests/test/cuda/stream_ref/stream_ref.wait.fail.cpp +++ /dev/null @@ -1,36 +0,0 @@ -//===----------------------------------------------------------------------===// -// -// Part of libcu++, the C++ Standard Library for your entire system, -// under the Apache License v2.0 with LLVM Exceptions. -// See https://llvm.org/LICENSE.txt for license information. -// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception -// SPDX-FileCopyrightText: Copyright (c) 2022 NVIDIA CORPORATION & AFFILIATES. All rights reserved. -// -//===----------------------------------------------------------------------===// - -// UNSUPPORTED: nvrtc - -#define LIBCUDACXX_ENABLE_EXPERIMENTAL_MEMORY_RESOURCE - -#include -#include - -int main(int argc, char** argv) { -#ifndef __CUDA_ARCH__ - cudaStream_t stream = reinterpret_cast(42); - cuda::stream_ref ref{stream}; -#ifndef _LIBCUDACXX_NO_EXCEPTIONS - try { - ref.wait(); - } catch (const cuda::cuda_error& e) { - assert(cudaGetErrorString(e) == "Failed to synchronize stream."); - } catch (...) { - assert(false && "Should have thrown"); - } - assert(false); -#else - ref.wait(); -#endif // _LIBCUDACXX_NO_EXCEPTIONS -#endif - return 0; -} diff --git a/include/cuda/memory_resource b/include/cuda/memory_resource index 181770d0d3..a74cee1e1d 100644 --- a/include/cuda/memory_resource +++ b/include/cuda/memory_resource @@ -437,7 +437,7 @@ using _Filtered_vtable = typename _Filtered<_Properties...>::_Filtered_vtable::_ template struct _Alloc_base { - static_assert(cuda::std::is_base_of_v<_Alloc_vtable, _Vtable>); + static_assert(cuda::std::is_base_of_v<_Alloc_vtable, _Vtable>, ""); _Alloc_base(void* __object_, const _Vtable* __static_vtabl_) noexcept : __object(__object_) @@ -462,7 +462,7 @@ protected: template struct _Async_alloc_base : public _Alloc_base<_Vtable> { - static_assert(cuda::std::is_base_of_v<_Async_alloc_vtable, _Vtable>); + static_assert(cuda::std::is_base_of_v<_Async_alloc_vtable, _Vtable>, ""); _Async_alloc_base(void* __object_, const _Vtable* __static_vtabl_) noexcept : _Alloc_base<_Vtable>(__object_, __static_vtabl_) @@ -588,11 +588,11 @@ public: } _LIBCUDACXX_TEMPLATE(class _Property) - (requires !property_with_value<_Property> && _CUDA_VSTD::_One_of<_Property, _Properties...>) // + (requires (!property_with_value<_Property>) _LIBCUDACXX_AND _CUDA_VSTD::_One_of<_Property, _Properties...>) // friend void get_property(const basic_resource_ref &, _Property) noexcept {} _LIBCUDACXX_TEMPLATE(class _Property) - (requires property_with_value<_Property> &&_CUDA_VSTD::_One_of<_Property, _Properties...>) // + (requires property_with_value<_Property> _LIBCUDACXX_AND _CUDA_VSTD::_One_of<_Property, _Properties...>) // friend __property_value_t<_Property> get_property( const basic_resource_ref &__res, _Property) noexcept { return __res._Property_vtable<_Property>::__property_fn(__res.__object);