diff --git a/libs/core/algorithms/include/hpx/parallel/datapar/iterator_helpers.hpp b/libs/core/algorithms/include/hpx/parallel/datapar/iterator_helpers.hpp index 8292b8d0c8a4..2cff8d0e8136 100644 --- a/libs/core/algorithms/include/hpx/parallel/datapar/iterator_helpers.hpp +++ b/libs/core/algorithms/include/hpx/parallel/datapar/iterator_helpers.hpp @@ -1,4 +1,4 @@ -// Copyright (c) 2016 Hartmut Kaiser +// Copyright (c) 2016-2025 Hartmut Kaiser // // SPDX-License-Identifier: BSL-1.0 // Distributed under the Boost Software License, Version 1.0. (See accompanying @@ -30,7 +30,7 @@ namespace hpx::parallel::util::detail { template struct is_data_aligned_impl { - static HPX_FORCEINLINE bool call(Iter const& it) noexcept + static HPX_FORCEINLINE bool call(Iter& it) noexcept { using value_type = typename std::iterator_traits::value_type; using pack_type = traits::vector_pack_type_t; @@ -42,7 +42,7 @@ namespace hpx::parallel::util::detail { }; template - HPX_FORCEINLINE bool is_data_aligned(Iter const& it) noexcept + HPX_FORCEINLINE bool is_data_aligned(Iter& it) noexcept { return is_data_aligned_impl::call(it); } diff --git a/libs/core/execution/include/hpx/execution/traits/detail/eve/vector_pack_load_store.hpp b/libs/core/execution/include/hpx/execution/traits/detail/eve/vector_pack_load_store.hpp index 0aa13869fb05..ff33cd9fe501 100644 --- a/libs/core/execution/include/hpx/execution/traits/detail/eve/vector_pack_load_store.hpp +++ b/libs/core/execution/include/hpx/execution/traits/detail/eve/vector_pack_load_store.hpp @@ -23,14 +23,14 @@ namespace hpx::parallel::traits { struct vector_pack_load { template - HPX_HOST_DEVICE HPX_FORCEINLINE static V aligned(Iter const& iter) + HPX_HOST_DEVICE HPX_FORCEINLINE static V aligned(Iter& iter) { return V( eve::as_aligned(std::addressof(*iter), eve::cardinal_t{})); } template - HPX_HOST_DEVICE HPX_FORCEINLINE static V unaligned(Iter const& iter) + HPX_HOST_DEVICE HPX_FORCEINLINE static V unaligned(Iter& iter) { return *iter; } @@ -42,7 +42,7 @@ namespace hpx::parallel::traits { { template HPX_HOST_DEVICE HPX_FORCEINLINE static void aligned( - V& value, Iter const& iter) + V& value, Iter& iter) { eve::store(value, eve::as_aligned(std::addressof(*iter), eve::cardinal_t{})); @@ -50,7 +50,7 @@ namespace hpx::parallel::traits { template HPX_HOST_DEVICE HPX_FORCEINLINE static void unaligned( - V& value, Iter const& iter) + V& value, Iter& iter) { *iter = value; return; diff --git a/libs/core/execution/include/hpx/execution/traits/detail/simd/vector_pack_load_store.hpp b/libs/core/execution/include/hpx/execution/traits/detail/simd/vector_pack_load_store.hpp index 8a23d078761f..c99347f17471 100644 --- a/libs/core/execution/include/hpx/execution/traits/detail/simd/vector_pack_load_store.hpp +++ b/libs/core/execution/include/hpx/execution/traits/detail/simd/vector_pack_load_store.hpp @@ -1,5 +1,5 @@ // Copyright (c) 2021 Srinivas Yadav -// Copyright (c) 2016-2017 Hartmut Kaiser +// Copyright (c) 2016-2025 Hartmut Kaiser // // SPDX-License-Identifier: BSL-1.0 // Distributed under the Boost Software License, Version 1.0. (See accompanying @@ -25,14 +25,14 @@ namespace hpx::parallel::traits { struct vector_pack_load { template - HPX_HOST_DEVICE HPX_FORCEINLINE static V aligned(Iter const& iter) + HPX_HOST_DEVICE HPX_FORCEINLINE static V aligned(Iter& iter) { return V( std::addressof(*iter), datapar::experimental::vector_aligned); } template - HPX_HOST_DEVICE HPX_FORCEINLINE static V unaligned(Iter const& iter) + HPX_HOST_DEVICE HPX_FORCEINLINE static V unaligned(Iter& iter) { return *iter; } @@ -44,7 +44,7 @@ namespace hpx::parallel::traits { { template HPX_HOST_DEVICE HPX_FORCEINLINE static void aligned( - V& value, Iter const& iter) + V& value, Iter& iter) { value.copy_to( std::addressof(*iter), datapar::experimental::vector_aligned); @@ -52,7 +52,7 @@ namespace hpx::parallel::traits { template HPX_HOST_DEVICE HPX_FORCEINLINE static void unaligned( - V& value, Iter const& iter) + V& value, Iter& iter) { *iter = value; } diff --git a/libs/core/execution/include/hpx/execution/traits/detail/vc/vector_pack_load_store.hpp b/libs/core/execution/include/hpx/execution/traits/detail/vc/vector_pack_load_store.hpp index 4e16ac02e15a..710f2df86ff0 100644 --- a/libs/core/execution/include/hpx/execution/traits/detail/vc/vector_pack_load_store.hpp +++ b/libs/core/execution/include/hpx/execution/traits/detail/vc/vector_pack_load_store.hpp @@ -1,4 +1,4 @@ -// Copyright (c) 2016 Hartmut Kaiser +// Copyright (c) 2016-2025 Hartmut Kaiser // Copyright (c) 2016 Matthias Kretz // // SPDX-License-Identifier: BSL-1.0 @@ -69,13 +69,13 @@ namespace hpx::parallel::traits { using value_type = typename rebind_pack::type; template - static value_type aligned(Iter const& iter) + static value_type aligned(Iter& iter) { return value_type(std::addressof(*iter), Vc::Aligned); } template - static value_type unaligned(Iter const& iter) + static value_type unaligned(Iter& iter) { return value_type(std::addressof(*iter), Vc::Unaligned); } @@ -87,13 +87,13 @@ namespace hpx::parallel::traits { using value_type = typename rebind_pack>::type; template - static value_type aligned(Iter const& iter) + static value_type aligned(Iter& iter) { return *iter; } template - static value_type unaligned(Iter const& iter) + static value_type unaligned(Iter& iter) { return *iter; } @@ -107,13 +107,13 @@ namespace hpx::parallel::traits { typename rebind_pack>::type; template - static value_type aligned(Iter const& iter) + static value_type aligned(Iter& iter) { return *iter; } template - static value_type unaligned(Iter const& iter) + static value_type unaligned(Iter& iter) { return *iter; } @@ -124,13 +124,13 @@ namespace hpx::parallel::traits { struct vector_pack_store { template - static void aligned(V const& value, Iter const& iter) + static void aligned(V& value, Iter& iter) { value.store(std::addressof(*iter), Vc::Aligned); } template - static void unaligned(V const& value, Iter const& iter) + static void unaligned(V& value, Iter& iter) { value.store(std::addressof(*iter), Vc::Unaligned); } @@ -140,13 +140,13 @@ namespace hpx::parallel::traits { struct vector_pack_store> { template - static void aligned(V const& value, Iter const& iter) + static void aligned(V& value, Iter& iter) { *iter = value; } template - static void unaligned(V const& value, Iter const& iter) + static void unaligned(V& value, Iter& iter) { *iter = value; } @@ -157,13 +157,13 @@ namespace hpx::parallel::traits { struct vector_pack_store> { template - static void aligned(Value const& value, Iter const& iter) + static void aligned(Value& value, Iter& iter) { *iter = value; } template - static void unaligned(Value const& value, Iter const& iter) + static void unaligned(Value& value, Iter& iter) { *iter = value; } diff --git a/libs/core/executors/include/hpx/executors/detail/index_queue_spawning.hpp b/libs/core/executors/include/hpx/executors/detail/index_queue_spawning.hpp index 927a1ca7b705..ecf3ad259627 100644 --- a/libs/core/executors/include/hpx/executors/detail/index_queue_spawning.hpp +++ b/libs/core/executors/include/hpx/executors/detail/index_queue_spawning.hpp @@ -1,5 +1,5 @@ // Copyright (c) 2019-2020 ETH Zurich -// Copyright (c) 2007-2023 Hartmut Kaiser +// Copyright (c) 2007-2025 Hartmut Kaiser // Copyright (c) 2019 Agustin Berge // // SPDX-License-Identifier: BSL-1.0 @@ -53,7 +53,7 @@ namespace hpx::parallel::execution::detail { bool const allow_stealing; template - static constexpr void bulk_invoke_helper( + HPX_FORCEINLINE static constexpr void bulk_invoke_helper( hpx::util::index_pack, F&& f, T&& t, Ts&& ts) { HPX_INVOKE(HPX_FORWARD(F, f), HPX_FORWARD(T, t), @@ -63,7 +63,8 @@ namespace hpx::parallel::execution::detail { // Perform the work in one element indexed by index. The index // represents a range of indices (iterators) in the given shape. template - void do_work_chunk(F&& f, Ts&& ts, std::uint32_t const index) const + HPX_FORCEINLINE void do_work_chunk( + F&& f, Ts&& ts, std::uint32_t const index) const { #if HPX_HAVE_ITTNOTIFY != 0 && !defined(HPX_HAVE_APEX) static hpx::util::itt::event notify_event( @@ -104,7 +105,7 @@ namespace hpx::parallel::execution::detail { if (allow_stealing) { // Then steal from the opposite end of the neighboring queues - static constexpr auto opposite_end = + constexpr auto opposite_end = hpx::concurrency::detail::opposite_end_v; for (std::uint32_t offset = 1; offset != state->num_threads; @@ -123,20 +124,6 @@ namespace hpx::parallel::execution::detail { } } - // Execute task function - void do_work() const - { - // schedule chunks from the end, if needed - if (reverse_placement) - { - do_work(); - } - else - { - do_work(); - } - } - // Store an exception and mark that an exception was thrown in the // operation state. This function assumes that there is a current // exception. @@ -150,7 +137,7 @@ namespace hpx::parallel::execution::detail { // Finish the work for one worker thread. If this is not the last worker // thread to finish, it will only decrement the counter. If it is the // last thread it will call set_exception if there is an exception. - // Otherwise it will call set_value on the shared state. + // Otherwise, it will call set_value on the shared state. void finish() const { if (--(state->tasks_remaining.data_) == 0) @@ -186,7 +173,16 @@ namespace hpx::parallel::execution::detail { { try { - do_work(); + // Execute task function + if (reverse_placement) + { + // schedule chunks from the end, if needed + do_work(); + } + else + { + do_work(); + } } catch (std::bad_alloc const&) { diff --git a/libs/core/iterator_support/include/hpx/iterator_support/counting_iterator.hpp b/libs/core/iterator_support/include/hpx/iterator_support/counting_iterator.hpp index 0840b62d031a..4d4401c9118d 100644 --- a/libs/core/iterator_support/include/hpx/iterator_support/counting_iterator.hpp +++ b/libs/core/iterator_support/include/hpx/iterator_support/counting_iterator.hpp @@ -1,4 +1,4 @@ -// Copyright (c) 2020-2023 Hartmut Kaiser +// Copyright (c) 2020-2025 Hartmut Kaiser // // SPDX-License-Identifier: BSL-1.0 // Distributed under the Boost Software License, Version 1.0. (See accompanying @@ -84,7 +84,7 @@ namespace hpx::util { using type = iterator_adaptor, - Incrementable, Incrementable, traversal, Incrementable const&, + Incrementable, Incrementable, traversal, Incrementable&, difference>; }; } // namespace detail @@ -122,6 +122,11 @@ namespace hpx::util { { return this->base_reference(); } + + HPX_HOST_DEVICE constexpr typename base_type::reference dereference() + { + return this->base_reference(); + } }; template base_reference(); } + HPX_HOST_DEVICE constexpr typename base_type::reference + dereference() noexcept + { + return this->base_reference(); + } + template HPX_HOST_DEVICE typename base_type::difference_type distance_to( counting_iterator::reference is used. // // Difference - the difference_type of the resulting iterator. If not diff --git a/libs/core/iterator_support/include/hpx/iterator_support/iterator_facade.hpp b/libs/core/iterator_support/include/hpx/iterator_support/iterator_facade.hpp index 2769e209c3a0..36b922136ef7 100644 --- a/libs/core/iterator_support/include/hpx/iterator_support/iterator_facade.hpp +++ b/libs/core/iterator_support/include/hpx/iterator_support/iterator_facade.hpp @@ -1,5 +1,5 @@ // Copyright (c) 2016 Thomas Heller -// Copyright (c) 2016-2023 Hartmut Kaiser +// Copyright (c) 2016-2025 Hartmut Kaiser // // SPDX-License-Identifier: BSL-1.0 // Distributed under the Boost Software License, Version 1.0. (See accompanying @@ -61,12 +61,23 @@ namespace hpx::util { it.decrement(); } + template + HPX_HOST_DEVICE HPX_FORCEINLINE static constexpr Reference dereference( + Iterator& it) +#if !defined(HPX_MSVC) + // MSVC has issues with this + noexcept(noexcept(std::declval().dereference())) +#endif + { + return it.dereference(); + } + template HPX_HOST_DEVICE HPX_FORCEINLINE static constexpr Reference dereference( Iterator const& it) #if !defined(HPX_MSVC) // MSVC has issues with this - noexcept(noexcept(std::declval().dereference())) + noexcept(noexcept(std::declval().dereference())) #endif { return it.dereference(); @@ -166,9 +177,17 @@ namespace hpx::util { } public: + HPX_HOST_DEVICE constexpr decltype(auto) operator*() noexcept( + noexcept(iterator_core_access::dereference( + std::declval()))) + { + return iterator_core_access::dereference( + this->derived()); + } + HPX_HOST_DEVICE constexpr decltype(auto) operator*() const noexcept(noexcept(iterator_core_access::dereference( - std::declval()))) + std::declval()))) { return iterator_core_access::dereference( this->derived()); diff --git a/libs/core/iterator_support/include/hpx/iterator_support/traits/is_iterator.hpp b/libs/core/iterator_support/include/hpx/iterator_support/traits/is_iterator.hpp index ab579147a272..a84513af56ff 100644 --- a/libs/core/iterator_support/include/hpx/iterator_support/traits/is_iterator.hpp +++ b/libs/core/iterator_support/include/hpx/iterator_support/traits/is_iterator.hpp @@ -1,4 +1,4 @@ -// Copyright (c) 2007-2022 Hartmut Kaiser +// Copyright (c) 2007-2025 Hartmut Kaiser // Copyright (c) 2019 Austin McCartney // // SPDX-License-Identifier: BSL-1.0 @@ -14,7 +14,6 @@ #include #include #include -#include namespace hpx::traits { diff --git a/libs/core/threading_base/include/hpx/threading_base/thread_num_tss.hpp b/libs/core/threading_base/include/hpx/threading_base/thread_num_tss.hpp index f3a3ac9714f7..d54721bf9060 100644 --- a/libs/core/threading_base/include/hpx/threading_base/thread_num_tss.hpp +++ b/libs/core/threading_base/include/hpx/threading_base/thread_num_tss.hpp @@ -1,4 +1,4 @@ -// Copyright (c) 2007-2023 Hartmut Kaiser +// Copyright (c) 2007-2025 Hartmut Kaiser // // SPDX-License-Identifier: BSL-1.0 // Distributed under the Boost Software License, Version 1.0. (See accompanying @@ -19,22 +19,25 @@ namespace hpx::threads::detail { /// Set the global thread id to thread local storage. - HPX_CORE_EXPORT std::size_t set_global_thread_num_tss(std::size_t num); + HPX_CORE_EXPORT std::size_t set_global_thread_num_tss( + std::size_t num) noexcept; /// Get the global thread id from thread local storage. - HPX_CORE_EXPORT std::size_t get_global_thread_num_tss(); + HPX_CORE_EXPORT std::size_t get_global_thread_num_tss() noexcept; /// Set the local thread id to thread local storage. - HPX_CORE_EXPORT std::size_t set_local_thread_num_tss(std::size_t num); + HPX_CORE_EXPORT std::size_t set_local_thread_num_tss( + std::size_t num) noexcept; /// Get the local thread id from thread local storage. - HPX_CORE_EXPORT std::size_t get_local_thread_num_tss(); + HPX_CORE_EXPORT std::size_t get_local_thread_num_tss() noexcept; /// Set the thread pool id to thread local storage. - HPX_CORE_EXPORT std::size_t set_thread_pool_num_tss(std::size_t num); + HPX_CORE_EXPORT std::size_t set_thread_pool_num_tss( + std::size_t num) noexcept; /// Get the thread pool id from thread local storage. - HPX_CORE_EXPORT std::size_t get_thread_pool_num_tss(); + HPX_CORE_EXPORT std::size_t get_thread_pool_num_tss() noexcept; /// Holds the global and local thread numbers, and the pool number /// associated with the thread. @@ -45,13 +48,13 @@ namespace hpx::threads::detail { std::size_t thread_pool_num; }; - HPX_CORE_EXPORT void set_thread_nums_tss(thread_nums const&); - HPX_CORE_EXPORT thread_nums get_thread_nums_tss(); + HPX_CORE_EXPORT void set_thread_nums_tss(thread_nums const&) noexcept; + HPX_CORE_EXPORT thread_nums get_thread_nums_tss() noexcept; /////////////////////////////////////////////////////////////////////////// struct reset_tss_helper { - explicit reset_tss_helper(std::size_t global_thread_num) + explicit reset_tss_helper(std::size_t global_thread_num) noexcept : global_thread_num_(set_global_thread_num_tss(global_thread_num)) { } @@ -92,7 +95,7 @@ namespace hpx { /// /// \note This function needs to be executed on a HPX-thread. It will /// fail otherwise (it will return -1). - HPX_CORE_EXPORT std::size_t get_worker_thread_num(); + HPX_CORE_EXPORT std::size_t get_worker_thread_num() noexcept; /////////////////////////////////////////////////////////////////////////// /// \brief Return the number of the current OS-thread running in the runtime @@ -101,7 +104,8 @@ namespace hpx { /// This function returns the zero based index of the OS-thread which /// executes the current HPX-thread. /// - /// \param ec [in,out] this represents the error status on exit. + /// \param ec [in,out] this represents the error status on exit (obsolete, + /// ignored). /// /// \note The returned value is zero based and its maximum value is /// smaller than the overall number of OS-threads executed (as @@ -111,7 +115,7 @@ namespace hpx { /// /// \note This function needs to be executed on a HPX-thread. It will /// fail otherwise (it will return -1). - HPX_CORE_EXPORT std::size_t get_worker_thread_num(error_code& ec); + HPX_CORE_EXPORT std::size_t get_worker_thread_num(error_code&) noexcept; /////////////////////////////////////////////////////////////////////////// /// \brief Return the number of the current OS-thread running in the current @@ -127,7 +131,7 @@ namespace hpx { /// /// \note This function needs to be executed on a HPX-thread. It will fail /// otherwise (it will return -1). - HPX_CORE_EXPORT std::size_t get_local_worker_thread_num(); + HPX_CORE_EXPORT std::size_t get_local_worker_thread_num() noexcept; /////////////////////////////////////////////////////////////////////////// /// \brief Return the number of the current OS-thread running in the current @@ -136,7 +140,8 @@ namespace hpx { /// This function returns the zero based index of the OS-thread on the /// current thread pool which executes the current HPX-thread. /// - /// \param ec [in,out] this represents the error status on exit. + /// \param ec [in,out] this represents the error status on exit (obsolete, + /// ignored). /// /// \note The returned value is zero based and its maximum value is smaller /// than the number of OS-threads executed on the current thread pool. @@ -145,7 +150,8 @@ namespace hpx { /// /// \note This function needs to be executed on a HPX-thread. It will fail /// otherwise (it will return -1). - HPX_CORE_EXPORT std::size_t get_local_worker_thread_num(error_code& ec); + HPX_CORE_EXPORT std::size_t get_local_worker_thread_num( + error_code&) noexcept; /////////////////////////////////////////////////////////////////////////// /// \brief Return the number of the current thread pool the current @@ -161,7 +167,7 @@ namespace hpx { /// /// \note This function needs to be executed on a HPX-thread. It will fail /// otherwise (it will return -1). - HPX_CORE_EXPORT std::size_t get_thread_pool_num(); + HPX_CORE_EXPORT std::size_t get_thread_pool_num() noexcept; /////////////////////////////////////////////////////////////////////////// /// \brief Return the number of the current thread pool the current @@ -170,7 +176,8 @@ namespace hpx { /// This function returns the zero based index of the thread pool which /// executes the current HPX-thread. /// - /// \param ec [in,out] this represents the error status on exit. + /// \param ec [in,out] this represents the error status on exit (obsolete, + /// ignored). /// /// \note The returned value is zero based and its maximum value is smaller /// than the number of thread pools started by the runtime. It will @@ -179,7 +186,7 @@ namespace hpx { /// /// \note This function needs to be executed on a HPX-thread. It will fail /// otherwise (it will return -1). - HPX_CORE_EXPORT std::size_t get_thread_pool_num(error_code& ec); + HPX_CORE_EXPORT std::size_t get_thread_pool_num(error_code&) noexcept; } // namespace hpx #include diff --git a/libs/core/threading_base/src/thread_num_tss.cpp b/libs/core/threading_base/src/thread_num_tss.cpp index d6687271ab32..23057fe116e8 100644 --- a/libs/core/threading_base/src/thread_num_tss.cpp +++ b/libs/core/threading_base/src/thread_num_tss.cpp @@ -1,4 +1,4 @@ -// Copyright (c) 2007-2024 Hartmut Kaiser +// Copyright (c) 2007-2025 Hartmut Kaiser // // SPDX-License-Identifier: BSL-1.0 // Distributed under the Boost Software License, Version 1.0. (See accompanying @@ -15,88 +15,103 @@ namespace hpx::threads::detail { namespace { - thread_nums& thread_nums_tss() + HPX_FORCEINLINE std::size_t& global_thread_num() noexcept { - thread_local thread_nums thread_nums_tss_ = { - static_cast(-1), static_cast(-1), - static_cast(-1)}; - return thread_nums_tss_; + thread_local std::size_t global_thread_num_ = + static_cast(-1); + return global_thread_num_; + } + + HPX_FORCEINLINE std::size_t& local_thread_num() noexcept + { + thread_local std::size_t local_thread_num_ = + static_cast(-1); + return local_thread_num_; + } + + HPX_FORCEINLINE std::size_t& thread_pool_num() noexcept + { + thread_local std::size_t thread_pool_num_ = + static_cast(-1); + return thread_pool_num_; } } // namespace - std::size_t set_global_thread_num_tss(std::size_t num) + std::size_t set_global_thread_num_tss(std::size_t num) noexcept { - std::swap(thread_nums_tss().global_thread_num, num); + std::swap(global_thread_num(), num); return num; } - std::size_t get_global_thread_num_tss() + HPX_FORCEINLINE std::size_t get_global_thread_num_tss() noexcept { - return thread_nums_tss().global_thread_num; + return global_thread_num(); } - std::size_t set_local_thread_num_tss(std::size_t num) + std::size_t set_local_thread_num_tss(std::size_t num) noexcept { - std::swap(thread_nums_tss().local_thread_num, num); + std::swap(local_thread_num(), num); return num; } - std::size_t get_local_thread_num_tss() + HPX_FORCEINLINE std::size_t get_local_thread_num_tss() noexcept { - return thread_nums_tss().local_thread_num; + return local_thread_num(); } - std::size_t set_thread_pool_num_tss(std::size_t num) + std::size_t set_thread_pool_num_tss(std::size_t num) noexcept { - std::swap(thread_nums_tss().thread_pool_num, num); + std::swap(thread_pool_num(), num); return num; } - std::size_t get_thread_pool_num_tss() + HPX_FORCEINLINE std::size_t get_thread_pool_num_tss() noexcept { - return thread_nums_tss().thread_pool_num; + return thread_pool_num(); } - void set_thread_nums_tss(const thread_nums& t) + void set_thread_nums_tss(thread_nums const& t) noexcept { - thread_nums_tss() = t; + global_thread_num() = t.global_thread_num; + local_thread_num() = t.local_thread_num; + thread_pool_num() = t.thread_pool_num; } - thread_nums get_thread_nums_tss() + thread_nums get_thread_nums_tss() noexcept { - return thread_nums_tss(); + return {global_thread_num(), local_thread_num(), thread_pool_num()}; } } // namespace hpx::threads::detail namespace hpx { - std::size_t get_worker_thread_num(error_code& /* ec */) + std::size_t get_worker_thread_num(error_code& /* ec */) noexcept { - return threads::detail::thread_nums_tss().global_thread_num; + return threads::detail::global_thread_num(); } - std::size_t get_worker_thread_num() + std::size_t get_worker_thread_num() noexcept { - return get_worker_thread_num(throws); + return threads::detail::global_thread_num(); } - std::size_t get_local_worker_thread_num(error_code& /* ec */) + std::size_t get_local_worker_thread_num(error_code& /* ec */) noexcept { - return threads::detail::thread_nums_tss().local_thread_num; + return threads::detail::local_thread_num(); } - std::size_t get_local_worker_thread_num() + std::size_t get_local_worker_thread_num() noexcept { - return get_local_worker_thread_num(throws); + return threads::detail::local_thread_num(); } - std::size_t get_thread_pool_num(error_code& /* ec */) + std::size_t get_thread_pool_num(error_code& /* ec */) noexcept { - return threads::detail::thread_nums_tss().thread_pool_num; + return threads::detail::thread_pool_num(); } - std::size_t get_thread_pool_num() + std::size_t get_thread_pool_num() noexcept { - return get_thread_pool_num(throws); + return threads::detail::thread_pool_num(); } } // namespace hpx