Guard compile tests from running when unsupported + harden feature support check

Message ID 55DE989C.7030402@codesourcery.com
State New, archived
Headers

Commit Message

Luis Machado Aug. 27, 2015, 4:57 a.m. UTC
  On 08/19/2015 10:45 AM, Pedro Alves wrote:
> On 08/19/2015 02:34 PM, Luis Machado wrote:
>
> This binary has no debug info (by test design), so we should just
> make the test do "set language c" (with a comment).
>

Here's what i pushed for this one.

I see no further gdb.compile failures.
  

Patch

commit 8ce74153537add5e364865518a72194ab58b3dbc
Author: Luis Machado <lgustavo@codesourcery.com>
Date:   Thu Aug 27 01:49:05 2015 -0300

    Force language to C in gdb.compile/compile-ifunc.exp
    
    Due to the lack of debug information in the binary, GDB is unable to figure
    out what language is being used.  This may be a problem when doing remote
    debugging and the binary stops at the entry point containing asm code.
    
    In this case GDB will switch to asm as current language and will not switch
    back to C when it reaches main, which in turn causes the compile feature check
    to malfunction.
    
    This is solved by forcing the language to C after reaching main.
    
    gdb/testsuite/ChangeLog:
    
    2015-08-26  Luis Machado  <lgustavo@codesourcery.com>
    
    	* gdb.compile/compile-ifunc.exp (with_test_prefix): Force language
    	to C.

diff --git a/gdb/testsuite/ChangeLog b/gdb/testsuite/ChangeLog
index 5bba9d7..7b271e2 100644
--- a/gdb/testsuite/ChangeLog
+++ b/gdb/testsuite/ChangeLog
@@ -1,3 +1,8 @@ 
+2015-08-26  Luis Machado  <lgustavo@codesourcery.com>
+
+	* gdb.compile/compile-ifunc.exp (with_test_prefix): Force language
+	to C.
+
 2015-08-26  Patrick Palka  <patrick@parcs.ath.cx>
 
 	* gdb.base/run-after-attach.exp: New test file.
diff --git a/gdb/testsuite/gdb.compile/compile-ifunc.exp b/gdb/testsuite/gdb.compile/compile-ifunc.exp
index 026c62f..3a96552 100644
--- a/gdb/testsuite/gdb.compile/compile-ifunc.exp
+++ b/gdb/testsuite/gdb.compile/compile-ifunc.exp
@@ -25,6 +25,12 @@  with_test_prefix "nodebug" {
 	return -1
     }
 
+    # This binary has no debug information, so force the language to C in case
+    # GDB happened to see real asm code when it stopped at the entry point
+    # when talking to a remote target, like gdbserver.  This guarantees the
+    # feature check below will work.
+    gdb_test_no_output "set language c" ""
+
     if {[skip_compile_feature_tests]} {
 	untested "compile command not supported (could not find libcc1 shared library?)"
 	return -1