1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134
|
# Copyright (C) 2015-2023 Free Software Foundation, Inc.
#
# Contributed by Intel Corp. <walfred.tedeschi@intel.com>
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
# Testing handle setup together with boundary violation signals.
#
# Some states are not allowed as reported on the manual, as noprint
# implies nostop, but nostop might print.
#
# Caveat: Setting the handle to nopass, ends up in a endless loop.
if { ![istarget i?86-*-*] && ![istarget x86_64-*-* ] } {
verbose "Skipping x86 MPX tests."
return
}
standard_testfile
if { ![supports_mpx_check_pointer_bounds] } {
return -1
}
if { ![have_mpx] } {
unsupported "processor does not support MPX"
return -1
}
set comp_flags "-mmpx -fcheck-pointer-bounds -I${srcdir}/../nat/"
if { [prepare_for_testing "failed to prepare" ${testfile} ${srcfile} \
[list debug nowarnings additional_flags=${comp_flags}]] } {
return -1
}
if ![runto_main] {
return -1
}
set violation [multi_line "Program received signal SIGSEGV, Segmentation fault" \
"Upper bound violation while accessing address $hex" \
"Bounds: \\\[lower = $hex, upper = $hex\\\]"]
set segv_with_exit "Program received signal SIGSEGV,\
Segmentation fault.*$inferior_exited_re.*"
# Test handler for segmentation fault for:
# print pass stop
#
set parameters "print pass stop"
with_test_prefix "$parameters" {
if ![runto_main] {
return -1
}
gdb_test "handle SIGSEGV $parameters"\
".*SIGSEGV.*Yes.*Yes.*Yes.*Segmentation fault.*"\
"set parameters"
gdb_test "continue" ".*$violation.*" "display"
gdb_test "where" ".*#0 $hex in upper.*"\
"should be in upper"
}
# Test handler for segmentation fault for:
# print pass nostop
#
set parameters "print pass nostop"
with_test_prefix "$parameters" {
if ![runto_main] {
return -1
}
gdb_test "handle SIGSEGV $parameters"\
".*SIGSEGV.*No.*Yes.*Yes.*Segmentation fault.*"\
"set parameters"
gdb_test "continue" ".*$segv_with_exit.*" "display"
gdb_test "where" "No stack." "no inferior"
}
# Test handler for segmentation fault for:
# print nopass stop
#
set parameters "print nopass stop"
with_test_prefix "$parameters" {
if ![runto_main] {
return -1
}
gdb_test "handle SIGSEGV $parameters"\
".*SIGSEGV.*Yes.*Yes.*No.*Segmentation fault.*"\
"set parameters"
gdb_test "continue" ".*$violation.*" "display"
gdb_test "where" ".*#0 $hex in upper.*"\
"should be in upper"
}
# Test handler for segmentation fault for:
# print nopass stop
#
set parameters "noprint pass nostop"
with_test_prefix "$parameters" {
if ![runto_main] {
return -1
}
gdb_test "handle SIGSEGV $parameters"\
".*SIGSEGV.*No.*No.*Yes.*Segmentation fault.*"\
"set parameters"
gdb_test "continue" "Continuing\..*$inferior_exited_re.*"\
"Display"
gdb_test "where" "No stack." "no inferior"
}
|