mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-06 12:09:26 +08:00
0ac85db529
There is a lot of support code for the test suppression mechanism. But as far as I know, it is not useful. The gdb_suppress_tests proc is in fact disabled with this comment that has been there since forever: return; # fnf - disable pending review of results where # testsuite ran better without this I suggest to just remove everything related to test suppression, that removes some unnecessary complexity from the support code and the tests. gdb/testsuite/ChangeLog: * lib/gdb.exp (gdb_test_multiple): Remove things related to test suppression. (default_gdb_exit): Likewise. (default_gdb_spawn): Likewise. (send_gdb): Likewise. (gdb_expect): Likewise. (gdb_expect_list): Likewise. (default_gdb_init): Likewise. (gdb_suppress_entire_file): Remove. (gdb_suppress_tests): Remove. (gdb_stop_suppressing_tests): Remove. (gdb_clear_suppressed): Remove. * lib/mi-support.exp (mi_uncatched_gdb_exit): Remove things related to test suppression. (default_mi_gdb_start): Likewise. (mi_gdb_reinitialize_dir): Likewise. (mi_gdb_test): Likewise. (mi_run_cmd_full): Likewise. (mi_runto_helper): Likewise. (mi_execute_to): Likewise. * lib/prompt.exp (default_prompt_gdb_start): Likewise. * gdb.base/bitfields.exp: Likewise. * gdb.base/bitfields2.exp: Likewise. * gdb.base/break.exp: Likewise. * gdb.base/call-sc.exp: Likewise. * gdb.base/callfuncs.exp: Likewise. * gdb.base/dfp-test.exp: Likewise. * gdb.base/endian.exp: Likewise. * gdb.base/exprs.exp: Likewise. * gdb.base/funcargs.exp: Likewise. * gdb.base/hbreak2.exp: Likewise. * gdb.base/recurse.exp: Likewise. * gdb.base/scope.exp: Likewise. * gdb.base/sepdebug.exp: Likewise. * gdb.base/structs.exp: Likewise. * gdb.base/until.exp: Likewise. * gdb.cp/misc.exp: Likewise. Change-Id: Ie6d3025091691ba72010faa28b85ebd417b738f7
247 lines
7.2 KiB
Plaintext
247 lines
7.2 KiB
Plaintext
# Copyright 1992-2021 Free Software Foundation, Inc.
|
|
|
|
# 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/>.
|
|
|
|
# This file was adapted from bitfields.exp by Paul Hilfinger
|
|
# (Hilfinger@gnat.com)
|
|
|
|
#
|
|
# Tests for bit-fields that do not fit in type (unsigned) int, but do fit
|
|
# in type (unsigned) long long. We perform essentially the same tests as
|
|
# in bitfields.c, which considers only bit-fields that are <= 9 bits long.
|
|
#
|
|
|
|
|
|
standard_testfile .c
|
|
|
|
if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug}] != "" } {
|
|
untested "failed to compile"
|
|
return -1
|
|
}
|
|
|
|
set has_signed_bitfields 1
|
|
|
|
#
|
|
# Continue to expected breakpoint at FUNCTION. Append TAG to make pass/fail
|
|
# messages (to make them unique). Suppress tests on failure.
|
|
#
|
|
proc continue_test { function tag } {
|
|
global decimal
|
|
global srcfile
|
|
|
|
gdb_test "cont" "Break.*$function \\(\\) at .*$srcfile:$decimal.*" "continuing to $function $tag"
|
|
}
|
|
|
|
#
|
|
# Start next test by running to tester and then to FUNCTION. Suppresses
|
|
# tests on failure.
|
|
#
|
|
proc start_test { function } {
|
|
delete_breakpoints
|
|
gdb_test "break tester" ".*" "break tester prior to $function"
|
|
continue_test "tester" "prior to $function"
|
|
gdb_breakpoint $function
|
|
continue_test $function "#0"
|
|
}
|
|
|
|
|
|
#
|
|
# Test bitfield locating and uniqueness.
|
|
# For each member, set that member to 1 and verify that the member (and only
|
|
# that member) is 1, then reset it back to 0.
|
|
#
|
|
|
|
proc bitfield_uniqueness {} {
|
|
global decimal
|
|
global hex
|
|
global gdb_prompt
|
|
global srcfile
|
|
|
|
start_test break1
|
|
|
|
gdb_test "print flags" ".*u1 = 0, u2 = 0, u3 = 0, s1 = 1, s2 = 0, s3 = 0.*" "bitfield uniqueness; flags.s1 = 1"
|
|
continue_test break1 "#1"
|
|
gdb_test "print flags" ".*u1 = 1, u2 = 0, u3 = 0, s1 = 0, s2 = 0, s3 = 0.*" "bitfield uniqueness; flags.u1 = 1"
|
|
continue_test break1 "#2"
|
|
gdb_test "print flags" ".*u1 = 0, u2 = 0, u3 = 0, s1 = 0, s2 = 1, s3 = 0.*" "bitfield uniqueness; flags.s2 = 1"
|
|
continue_test break1 "#3"
|
|
gdb_test "print flags" ".*u1 = 0, u2 = 1, u3 = 0, s1 = 0, s2 = 0, s3 = 0.*" "bitfield uniqueness; flags.u2 = 1"
|
|
continue_test break1 "#4"
|
|
gdb_test "print flags" ".*u1 = 0, u2 = 0, u3 = 0, s1 = 0, s2 = 0, s3 = 1.*" "bitfield uniqueness; flags.s3 = 1"
|
|
continue_test break1 "#5"
|
|
gdb_test "print flags" ".*u1 = 0, u2 = 0, u3 = 1, s1 = 0, s2 = 0, s3 = 0.*" "bitfield uniqueness; flags.u3 = 1"
|
|
}
|
|
|
|
|
|
#
|
|
# Test bitfield containment.
|
|
# Fill alternating fields with all 1's and verify that none of the bits
|
|
# "bleed over" to the other fields.
|
|
#
|
|
|
|
proc bitfield_containment {} {
|
|
global decimal
|
|
global hex
|
|
global gdb_prompt
|
|
global srcfile
|
|
|
|
start_test break2
|
|
|
|
# If program is compiled with Sun CC, signed fields print out as their
|
|
# actual sizes; if compiled with gcc, they print out as 0xffffffff.
|
|
gdb_test "print/x flags" "= {u1 = 0x7fff, u2 = 0x0, u3 = 0xffff, s1 = 0x0, s2 = 0x(1ffffffff|f*), s3 = 0x0}" "bitfield containment; flags.u1, flags.u3, and flags.s3 to all 1s"
|
|
|
|
continue_test break2 "#1"
|
|
|
|
gdb_test "print/x flags" "= {u1 = 0x0, u2 = 0x1ffffffff, u3 = 0x0, s1 = 0x(7fff|f*), s2 = 0x0, s3 = 0xf*}" "bitfield containment; flags.u2, flags.s1, flags.s2 to all 1s"
|
|
}
|
|
|
|
# Test unsigned bitfields for unsignedness and range.
|
|
# Fill the unsigned fields with the maximum positive value and verify that
|
|
# the values are printed correctly.
|
|
|
|
proc bitfield_unsignedness {} {
|
|
global decimal
|
|
global hex
|
|
global gdb_prompt
|
|
global srcfile
|
|
|
|
start_test break3
|
|
|
|
gdb_test "print flags" ".*u1 = 32767, u2 = 8589934591, u3 = 65535, s1 = 0, s2 = 0, s3 = 0.*" "maximum unsigned bitfield values"
|
|
}
|
|
|
|
#
|
|
# Test signed bitfields for signedness and range.
|
|
# Fill the signed fields with the maximum positive value, then the maximally
|
|
# negative value, then -1, and verify in each case that the values are
|
|
# printed correctly.
|
|
#
|
|
|
|
proc bitfield_signedness {} {
|
|
global decimal
|
|
global hex
|
|
global gdb_prompt
|
|
global srcfile
|
|
global has_signed_bitfields
|
|
|
|
start_test break4
|
|
|
|
gdb_test "print flags" "= {.*u1 = 0, u2 = 0, u3 = 0, s1 = 16383, s2 = 4294967295, s3 = 32767.*}" "maximum signed bitfield values"
|
|
|
|
continue_test break4 "#1"
|
|
|
|
# Determine if the target has signed bitfields so we can skip
|
|
# the signed bitfield tests if it doesn't.
|
|
set test "determining signed-ness of bitfields"
|
|
set has_signed_bitfields 0
|
|
gdb_test_multiple "print i" $test {
|
|
-re ".* = -32768.*$gdb_prompt $" {
|
|
set has_signed_bitfields 1
|
|
pass "determining signed-ness of bitfields"
|
|
}
|
|
-re ".* = 32768.*$gdb_prompt $" {
|
|
pass "determining signed-ness of bitfields"
|
|
}
|
|
-re ".*$gdb_prompt $" {
|
|
fail "determining signed-ness of bitfields"
|
|
}
|
|
}
|
|
|
|
set test "most negative signed bitfield values"
|
|
if $has_signed_bitfields then {
|
|
gdb_test "print flags" "u1 = 0, u2 = 0, u3 = 0, s1 = -16384, s2 = -4294967296, s3 = -32768.*" $test
|
|
} else {
|
|
unsupported $test
|
|
}
|
|
|
|
continue_test break4 "#2"
|
|
|
|
set test "signed bitfields containing -1"
|
|
if $has_signed_bitfields then {
|
|
gdb_test "print flags" "u1 = 0, u2 = 0, u3 = 0, s1 = -1, s2 = -1, s3 = -1.*" $test
|
|
} else {
|
|
unsupported $test
|
|
}
|
|
}
|
|
|
|
|
|
# Test setting of long long bit fields from within GDB.
|
|
|
|
proc bitfield_set {} {
|
|
global decimal
|
|
global hex
|
|
global gdb_prompt
|
|
global srcfile
|
|
global has_signed_bitfields
|
|
|
|
start_test break5
|
|
|
|
set big_set_failed 0
|
|
set test "set long long unsigned bitfield"
|
|
gdb_test_multiple "print flags.u2 = 0x100000000" $test {
|
|
-re "warning: Value does not fit.*$gdb_prompt $" {
|
|
fail "$test"
|
|
}
|
|
-re "= 4294967296.*$gdb_prompt $" {
|
|
pass "$test"
|
|
}
|
|
}
|
|
|
|
set test "set long long signed bitfield positive"
|
|
gdb_test_multiple "print flags.s2 = 0x80000000" $test {
|
|
-re "warning: Value does not fit.*$gdb_prompt $" {
|
|
fail "$test"
|
|
}
|
|
-re "= 2147483648.*$gdb_prompt $" {
|
|
pass "$test"
|
|
}
|
|
}
|
|
|
|
gdb_test "print flags" "u1 = 0, u2 = 4294967296, u3 = 0, s1 = 0, s2 = 2147483648, s3 = 0.*" "long long bitfield values after set"
|
|
|
|
set test "set long long signed bitfield negative"
|
|
if $has_signed_bitfields then {
|
|
gdb_test_multiple "print flags.s2 = -1" $test {
|
|
-re "warning: Value does not fit.*$gdb_prompt $" {
|
|
fail "$test"
|
|
}
|
|
-re "= -1.*$gdb_prompt $" {
|
|
pass "$test"
|
|
}
|
|
}
|
|
} else {
|
|
unsupported $test
|
|
}
|
|
|
|
set test "long long bitfield values after set negative"
|
|
if $has_signed_bitfields then {
|
|
gdb_test "print flags" "u1 = 0, u2 = 4294967296, u3 = 0, s1 = 0, s2 = -1, s3 = 0.*" $test
|
|
} else {
|
|
unsupported $test
|
|
}
|
|
}
|
|
|
|
clean_restart ${binfile}
|
|
|
|
gdb_test_no_output "set print sevenbit-strings"
|
|
runto_main
|
|
|
|
bitfield_uniqueness
|
|
bitfield_containment
|
|
bitfield_unsignedness
|
|
bitfield_signedness
|
|
bitfield_set
|
|
|