diff options
author | Tom de Vries <tdevries@suse.de> | 2022-04-14 12:32:51 +0200 |
---|---|---|
committer | Tom de Vries <tdevries@suse.de> | 2022-04-14 12:32:51 +0200 |
commit | 75b2a443d515f531299ce1ed942810edd5bf5d84 (patch) | |
tree | 0f8a8a23abdd70722dbfbe8169867fca73fd9cdf | |
parent | c641fe0dcb886dc1b8a235ab2b236275ee46510a (diff) | |
download | fsf-binutils-gdb-75b2a443d515f531299ce1ed942810edd5bf5d84.zip fsf-binutils-gdb-75b2a443d515f531299ce1ed942810edd5bf5d84.tar.gz fsf-binutils-gdb-75b2a443d515f531299ce1ed942810edd5bf5d84.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 902fb4a..7c35fbb 100644 --- a/gdb/testsuite/lib/gdb.exp +++ b/gdb/testsuite/lib/gdb.exp @@ -8329,6 +8329,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 } |