Tweak the std::hash<> specialization for aarch64_features.
authorJohn Baldwin <jhb@FreeBSD.org>
Mon, 23 May 2022 18:02:55 +0000 (11:02 -0700)
committerJohn Baldwin <jhb@FreeBSD.org>
Mon, 23 May 2022 18:02:55 +0000 (11:02 -0700)
Move the specialization into an explicit std namespace to workaround a
bug in older compilers.  GCC 6.4.1 at least fails to compile the previous
version with the following error:

gdb/arch/aarch64.h:48:13: error: specialization of 'template<class _Tp> struct std::hash' in different namespace [-fpermissive]

  struct std::hash<aarch64_features>

gdb/arch/aarch64.h

index 72ec4193eba4c04f6b26001295548521fdc7ed96..8e3fd36726a8b30c52cf4405f4e86ff3dfb3f463 100644 (file)
@@ -44,20 +44,23 @@ inline bool operator==(const aarch64_features &lhs, const aarch64_features &rhs)
     && lhs.tls == rhs.tls;
 }
 
-template<>
-struct std::hash<aarch64_features>
+namespace std
 {
-  std::size_t operator()(const aarch64_features &features) const noexcept
+  template<>
+  struct hash<aarch64_features>
   {
-    std::size_t h;
-
-    h = features.vq;
-    h = h << 1 | features.pauth;
-    h = h << 1 | features.mte;
-    h = h << 1 | features.tls;
-    return h;
-  }
-};
+    std::size_t operator()(const aarch64_features &features) const noexcept
+    {
+      std::size_t h;
+
+      h = features.vq;
+      h = h << 1 | features.pauth;
+      h = h << 1 | features.mte;
+      h = h << 1 | features.tls;
+      return h;
+    }
+  };
+}
 
 /* Create the aarch64 target description.  */