]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
libstdc++: correct symbol version of typeinfo for bfloat16_t on RISC-V
authorAndreas Schwab <schwab@suse.de>
Tue, 21 Jan 2025 22:50:15 +0000 (23:50 +0100)
committerAndreas Schwab <schwab@suse.de>
Mon, 27 Jan 2025 13:15:53 +0000 (14:15 +0100)
RISC-V only gained support for bfloat16_t after gcc 14.  Passes
libstdc++/check_abi on {x86_64,aarch64,ppc64le,riscv64,s390x}-suse-linux.

PR libstdc++/118563
* testsuite/util/testsuite_abi.cc (check_version): Add
CXXABI_1.3.16.
* config/abi/pre/gnu.ver (CXXABI_1.3.14) [__riscv]: Exclude
typeinfo for bfloat16_t.
(CXXABI_1.3.16) [__riscv]: Add it here.

libstdc++-v3/config/abi/pre/gnu.ver
libstdc++-v3/testsuite/util/testsuite_abi.cc

index f7641974ec4da2ffad9a54feb341d52ad3856372..84ce874fe03663eba1648ab59b10306333339766 100644 (file)
@@ -2852,10 +2852,15 @@ CXXABI_1.3.13 {
 CXXABI_1.3.14 {
 
     # typeinfo for _Float{16,32,64,128,32x,64x,128x} and
-    # __bf16
-    _ZTIDF[0-9]*[_bx];
-    _ZTIPDF[0-9]*[_bx];
-    _ZTIPKDF[0-9]*[_bx];
+    # __bf16/bfloat16_t
+    _ZTIDF[0-9]*[_x];
+    _ZTIPDF[0-9]*[_x];
+    _ZTIPKDF[0-9]*[_x];
+#ifndef __riscv
+    _ZTIDF16b;
+    _ZTIPDF16b;
+    _ZTIPKDF16b;
+#endif
     _ZTIu6__bf16;
     _ZTIPu6__bf16;
     _ZTIPKu6__bf16;
@@ -2869,6 +2874,16 @@ CXXABI_1.3.15 {
 
 } CXXABI_1.3.14;
 
+CXXABI_1.3.16 {
+
+#ifdef __riscv
+    _ZTIDF16b;
+    _ZTIPDF16b;
+    _ZTIPKDF16b;
+#endif
+
+} CXXABI_1.3.15;
+
 # Symbols in the support library (libsupc++) supporting transactional memory.
 CXXABI_TM_1 {
 
index dcf5b1a4e0b10a338865fd96eca71e37fe553b6d..0d6080fb92c0d1541a9d841c675678e6d9159d67 100644 (file)
@@ -237,6 +237,7 @@ check_version(symbol& test, bool added)
       known_versions.push_back("CXXABI_1.3.13");
       known_versions.push_back("CXXABI_1.3.14");
       known_versions.push_back("CXXABI_1.3.15");
+      known_versions.push_back("CXXABI_1.3.16");
       known_versions.push_back("CXXABI_IEEE128_1.3.13");
       known_versions.push_back("CXXABI_TM_1");
       known_versions.push_back("CXXABI_FLOAT128");