Blame SOURCES/0016-Conditionalize-test-for-hashtable-bucket-sizes-on-__.patch

0b9bbe
From db8f53df0be1daeda3159c1413549ff40696c710 Mon Sep 17 00:00:00 2001
0b9bbe
From: David Malcolm <dmalcolm@redhat.com>
0b9bbe
Date: Thu, 2 Sep 2021 17:02:33 -0400
0b9bbe
Subject: [PATCH 16/17] Conditionalize test for hashtable bucket sizes on
0b9bbe
 __LIBSTDCXX_SO_VERSION >= 11
0b9bbe
0b9bbe
These tests were added upstream 2020-01-20 as part of:
0b9bbe
  libstdc++: Do not over-size hashtable buckets on range insertion
0b9bbe
    https://gcc.gnu.org/git/?p=gcc.git;a=commitdiff;h=6dcf042368012e2d7ce1626ee5d378bf3ad0ccfc
0b9bbe
0b9bbe
but fail when run in DTS against a system libstdc++.so from an older GCC.
0b9bbe
0b9bbe
In particular, _M_insert_unique_node from the header is using the older
0b9bbe
implementation of
0b9bbe
  std::__detail::_Prime_rehash_policy::_M_need_rehash
0b9bbe
from the dynamic library.
0b9bbe
0b9bbe
   23: 0000000000000000      0 FUNC    GLOBAL DEFAULT    UNDEF std::__detail::_Prime_rehash_policy::_M_need_rehash(unsigned long, unsigned long, unsigned long) const@GLIBCXX_3.4.18 (5)
0b9bbe
  412: 0000000000000000      0 FUNC    GLOBAL DEFAULT    UNDEF std::__detail::_Prime_rehash_policy::_M_need_rehash(unsigned long, unsigned long, unsigned long) const@@GLIBCXX_3.4.18
0b9bbe
---
0b9bbe
 .../23_containers/unordered_set/cons/bucket_hint.cc    | 10 ++++++++++
0b9bbe
 .../23_containers/unordered_set/modifiers/insert.cc    |  9 +++++++++
0b9bbe
 2 files changed, 19 insertions(+)
0b9bbe
0b9bbe
diff --git a/libstdc++-v3/testsuite/23_containers/unordered_set/cons/bucket_hint.cc b/libstdc++-v3/testsuite/23_containers/unordered_set/cons/bucket_hint.cc
0b9bbe
index a3b014a3a..af231e54e 100644
0b9bbe
--- a/libstdc++-v3/testsuite/23_containers/unordered_set/cons/bucket_hint.cc
0b9bbe
+++ b/libstdc++-v3/testsuite/23_containers/unordered_set/cons/bucket_hint.cc
0b9bbe
@@ -29,7 +29,11 @@ void test01()
0b9bbe
   a.reserve(2);
0b9bbe
 
0b9bbe
   std::unordered_set<int> b({ 0, 1, 0, 1, 0, 1, 0, 1 }, a.bucket_count());
0b9bbe
+
0b9bbe
+  // Fixed upstream in GCC 11
0b9bbe
+#if __LIBSTDCXX_SO_VERSION >= 11
0b9bbe
   VERIFY( b.bucket_count() == a.bucket_count() );
0b9bbe
+#endif
0b9bbe
 }
0b9bbe
 
0b9bbe
 void test02()
0b9bbe
@@ -40,7 +44,10 @@ void test02()
0b9bbe
   std::vector<int> v { 0, 1, 0, 1, 0, 1, 0, 1, 0, 1 };
0b9bbe
 
0b9bbe
   std::unordered_set<int> b(v.begin(), v.end(), a.bucket_count());
0b9bbe
+  // Fixed upstream in GCC 11
0b9bbe
+#if __LIBSTDCXX_SO_VERSION >= 11
0b9bbe
   VERIFY( b.bucket_count() == a.bucket_count() );
0b9bbe
+#endif
0b9bbe
 }
0b9bbe
 
0b9bbe
 void test03()
0b9bbe
@@ -51,7 +58,10 @@ void test03()
0b9bbe
   std::forward_list<int> fl { 0, 1, 0, 1, 0, 1, 0, 1, 0, 1 };
0b9bbe
 
0b9bbe
   std::unordered_set<int> b(fl.begin(), fl.end(), a.bucket_count());
0b9bbe
+  // Fixed upstream in GCC 11
0b9bbe
+#if __LIBSTDCXX_SO_VERSION >= 11
0b9bbe
   VERIFY( b.bucket_count() == a.bucket_count() );
0b9bbe
+#endif
0b9bbe
 }
0b9bbe
 
0b9bbe
 int main()
0b9bbe
diff --git a/libstdc++-v3/testsuite/23_containers/unordered_set/modifiers/insert.cc b/libstdc++-v3/testsuite/23_containers/unordered_set/modifiers/insert.cc
0b9bbe
index 015c2f872..aae8298ae 100644
0b9bbe
--- a/libstdc++-v3/testsuite/23_containers/unordered_set/modifiers/insert.cc
0b9bbe
+++ b/libstdc++-v3/testsuite/23_containers/unordered_set/modifiers/insert.cc
0b9bbe
@@ -30,7 +30,10 @@ void test01()
0b9bbe
 
0b9bbe
   auto bkt_count = a.bucket_count();
0b9bbe
   a.insert({ 0, 1, 0, 1, 0, 1, 0, 1 });
0b9bbe
+  // Fixed upstream in GCC 11
0b9bbe
+#if __LIBSTDCXX_SO_VERSION >= 11
0b9bbe
   VERIFY( a.bucket_count() == bkt_count );
0b9bbe
+#endif
0b9bbe
 }
0b9bbe
 
0b9bbe
 void test02()
0b9bbe
@@ -42,7 +45,10 @@ void test02()
0b9bbe
 
0b9bbe
   auto bkt_count = a.bucket_count();
0b9bbe
   a.insert(v.begin(), v.end());
0b9bbe
+  // Fixed upstream in GCC 11
0b9bbe
+#if __LIBSTDCXX_SO_VERSION >= 11
0b9bbe
   VERIFY( a.bucket_count() == bkt_count );
0b9bbe
+#endif
0b9bbe
 }
0b9bbe
 
0b9bbe
 void test03()
0b9bbe
@@ -54,7 +60,10 @@ void test03()
0b9bbe
 
0b9bbe
   auto bkt_count = a.bucket_count();
0b9bbe
   a.insert(fl.begin(), fl.end());
0b9bbe
+  // Fixed upstream in GCC 11
0b9bbe
+#if __LIBSTDCXX_SO_VERSION >= 11
0b9bbe
   VERIFY( a.bucket_count() == bkt_count );
0b9bbe
+#endif
0b9bbe
 }
0b9bbe
 
0b9bbe
 int main()
0b9bbe
-- 
0b9bbe
2.31.1
0b9bbe