https://gcc.gnu.org/g:1c87964c1efc84c89d49fd94804549ff94392f9e

commit 1c87964c1efc84c89d49fd94804549ff94392f9e
Author: Jonathan Wakely <jwak...@redhat.com>
Date:   Thu Feb 20 14:08:11 2025 +0000

    Fix 'libstdc++-v3/src/c++20/tzdb.cc' build for '__GTHREADS && 
!__GTHREADS_CXX0X' configurations
    
            libstdc++-v3/
            * src/c++20/tzdb.cc [__GTHREADS && !__GTHREADS_CXX0X]: Use
            '__gnu_cxx::__mutex'.
    
    Co-authored-by: Thomas Schwinge <tschwi...@baylibre.com>
    (cherry picked from commit 780932620d859fa9e0190edd0c408d0bedf9179e)

Diff:
---
 libstdc++-v3/ChangeLog.omp     |  7 +++++++
 libstdc++-v3/src/c++20/tzdb.cc | 12 +++++++++++-
 2 files changed, 18 insertions(+), 1 deletion(-)

diff --git a/libstdc++-v3/ChangeLog.omp b/libstdc++-v3/ChangeLog.omp
index a3487cda9291..7ede4aed9664 100644
--- a/libstdc++-v3/ChangeLog.omp
+++ b/libstdc++-v3/ChangeLog.omp
@@ -1,5 +1,12 @@
 2025-03-19  Thomas Schwinge  <tschwi...@baylibre.com>
 
+       Backported from trunk:
+       2025-03-06  Jonathan Wakely  <jwak...@redhat.com>
+                   Thomas Schwinge  <tschwi...@baylibre.com>
+
+       * src/c++20/tzdb.cc [__GTHREADS && !__GTHREADS_CXX0X]: Use
+       '__gnu_cxx::__mutex'.
+
        Backported from trunk:
        2025-03-06  Thomas Schwinge  <tschwi...@baylibre.com>
 
diff --git a/libstdc++-v3/src/c++20/tzdb.cc b/libstdc++-v3/src/c++20/tzdb.cc
index 7e8cce7ce8cf..f6a36f422e1d 100644
--- a/libstdc++-v3/src/c++20/tzdb.cc
+++ b/libstdc++-v3/src/c++20/tzdb.cc
@@ -35,6 +35,9 @@
 #include <atomic>     // atomic<T*>, atomic<int>
 #include <memory>     // atomic<shared_ptr<T>>
 #include <mutex>      // mutex
+#if defined __GTHREADS && ! defined _GLIBCXX_HAS_GTHREADS
+# include <ext/concurrence.h> // __gnu_cxx::__mutex
+#endif
 #include <filesystem> // filesystem::read_symlink
 
 #ifndef _AIX
@@ -97,11 +100,18 @@ namespace std::chrono
 {
   namespace
   {
-#if ! USE_ATOMIC_SHARED_PTR
 #ifndef __GTHREADS
     // Dummy no-op mutex type for single-threaded targets.
     struct mutex { void lock() { } void unlock() { } };
+#elif ! defined _GLIBCXX_HAS_GTHREADS
+    // Use __gnu_cxx::__mutex if std::mutex isn't available.
+    using mutex = __gnu_cxx::__mutex;
+# if ! USE_ATOMIC_SHARED_PTR && defined __GTHREAD_MUTEX_INIT
+#  error "TODO: __gnu_cxx::__mutex can't be initialized with 'constinit'"
+# endif
 #endif
+
+#if ! USE_ATOMIC_SHARED_PTR
     inline mutex& list_mutex()
     {
 #ifdef __GTHREAD_MUTEX_INIT

Reply via email to