diff options
author | Tom de Vries <tdevries@suse.de> | 2022-04-14 13:17:24 +0200 |
---|---|---|
committer | Tom de Vries <tdevries@suse.de> | 2022-04-14 13:17:24 +0200 |
commit | d4c9e8f5834939909859ad748c31b7a3d239aeab (patch) | |
tree | eb274c4b8791a948aced18de0e753e831d892b90 | |
parent | 4f538bcbb7b367c17e9c288fc506d650e1c8d7c8 (diff) | |
download | gdb-d4c9e8f5834939909859ad748c31b7a3d239aeab.zip gdb-d4c9e8f5834939909859ad748c31b7a3d239aeab.tar.gz gdb-d4c9e8f5834939909859ad748c31b7a3d239aeab.tar.bz2 |
[gdb/testsuite] Detect 'No MPX support'
On openSUSE Leap 15.3, mpx support has been disabled for m32, so I run into:
...
(gdb) run ^M
Starting program: outputs/gdb.arch/i386-mpx/i386-mpx ^M
[Thread debugging using libthread_db enabled]^M
Using host libthread_db library "/lib64/libthread_db.so.1".^M
No MPX support^M
...
and eventually into all sort of fails in this and other mpx test-cases.
Fix this by detecting the "No MPX support" message in have_mpx.
Tested on x86_64-linux with target boards unix and unix/-m32.
-rw-r--r-- | gdb/testsuite/lib/gdb.exp | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/gdb/testsuite/lib/gdb.exp b/gdb/testsuite/lib/gdb.exp index 08726f7..6f6acfe 100644 --- a/gdb/testsuite/lib/gdb.exp +++ b/gdb/testsuite/lib/gdb.exp @@ -8302,6 +8302,29 @@ gdb_caching_proc have_mpx { remote_file build delete $obj + if { $status == 0 } { + verbose "$me: returning $status" 2 + return $status + } + + # Compile program with -mmpx -fcheck-pointer-bounds, try to trigger + # 'No MPX support', in other words, see if kernel supports mpx. + set src { int main (void) { return 0; } } + set comp_flags {} + append comp_flags " additional_flags=-mmpx" + append comp_flags " additional_flags=-fcheck-pointer-bounds" + if {![gdb_simple_compile $me-2 $src executable $comp_flags]} { + return 0 + } + + set result [remote_exec target $obj] + set status [lindex $result 0] + set output [lindex $result 1] + set status [expr ($status == 0) \ + && ![string equal $output "No MPX support\r\n"]] + + remote_file build delete $obj + verbose "$me: returning $status" 2 return $status } |