]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
PowerPC: Skip base type RTTI tests before inferior start
authorAbhay Kandpal <abhay@linux.ibm.com>
Wed, 26 Nov 2025 06:33:25 +0000 (01:33 -0500)
committerAbhay Kandpal <abhay@linux.ibm.com>
Wed, 26 Nov 2025 06:40:28 +0000 (01:40 -0500)
On PowerPC targets, RTTI typeinfo objects for simple base types such as
`int`, `char*`, and `const char*` may not be emitted until the inferior
has been started.  As a result, the `gdb.cp/typeid.exp` test fails when
checking typeid results before program execution begins.

This patch extends the existing Clang-specific logic that skips base type
RTTI checks before the inferior starts, to also apply on PowerPC.  This
ensures consistent test behavior across compilers and targets.

gdb/testsuite/
    * gdb.cp/typeid.exp (do_typeid_tests): Skip base type RTTI tests
    before inferior start on PowerPC.

Approved-By: Tom de Vries <tdevries@suse.de>
gdb/testsuite/gdb.cp/typeid.exp

index bd97b26c6e49988d15d94c2b6ad0daa3ea7acbf1..e12b032f32b823be0335c7fc3981853a5f1666b4 100644 (file)
@@ -28,11 +28,22 @@ proc do_typeid_tests {started} {
     set type_re "(std::type_info|gdb_gnu_v3_type_info)"
 
     set var {ca b}
-    if {$started || ![test_compiler_info clang-*-* c++]} {
-       # Clang doesn't place type information for the base types in
-       # the executable, and relies on this being linked in from the
-       # standard library.  As a result, type information for these
-       # variables is only available once the inferior is started.
+    set have_base_types 1
+    if {!$started} {
+       if {[test_compiler_info clang-*-* c++]} {
+          # Note that we test pointer equality rather than object
+          # Clang doesn't place type information for the base types in
+          # the executable, and relies on this being linked in from the
+          # standard library.  As a result, type information for these
+          # variables is only available once the inferior is started.
+          set have_base_types 0
+       } elseif {[istarget "powerpc*-*-*"]} {
+          # On PowerPC, RTTI typeinfo for base types (i, cp, ccp) may not be
+          # emitted until the inferior is started.
+          set have_base_types 0
+       }
+    }
+    if { $have_base_types } {
        lappend var i cp ccp
     }