diff options
author | Pedro Alves <pedro@palves.net> | 2022-04-07 18:01:12 +0100 |
---|---|---|
committer | Pedro Alves <pedro@palves.net> | 2022-04-08 16:19:15 +0100 |
commit | 01772c548b91499272dcb0f6864ba990e2abf873 (patch) | |
tree | ea4bf0aad239a0dbb8e2a2876ae9e59cae501a00 /gdb/testsuite/lib | |
parent | 7d41169b6d4dbc3950516d0cdf0d8ca462b52bbb (diff) | |
download | gdb-01772c548b91499272dcb0f6864ba990e2abf873.zip gdb-01772c548b91499272dcb0f6864ba990e2abf873.tar.gz gdb-01772c548b91499272dcb0f6864ba990e2abf873.tar.bz2 |
Fix undefined behavior in the Fortran, Go and Pascal number parsers
This commit ports these two fixes to the C parser:
commit ebf13736b42af47c9907b5157c8e80c78dbe00e1
CommitDate: Thu Sep 4 21:46:28 2014 +0100
parse_number("0") reads uninitialized memory
commit 20562150d8a894bc91657c843ee88c508188e32e
CommitDate: Wed Oct 3 15:19:06 2018 -0600
Avoid undefined behavior in parse_number
... to the Fortran, Go, and Fortran number parsers, fixing the same
problems there.
Also add a new testcase that exercises printing 0xffffffffffffffff
(max 64-bit) in all languages, which crashes a GDB built with UBsan
without the fix.
I moved get_set_option_choices out of all-architectures.exp.tcl to
common code to be able to extract all the supported languages. I did
a tweak to it to generalize it a bit -- you now have to pass down the
"set" part of the command as well. This is so that the proc can be
used with "maintenance set" commands as well in future.
Change-Id: I8e8f2fdc1e8407f63d923c26fd55d98148b9e16a
Diffstat (limited to 'gdb/testsuite/lib')
-rw-r--r-- | gdb/testsuite/lib/gdb.exp | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/gdb/testsuite/lib/gdb.exp b/gdb/testsuite/lib/gdb.exp index 0ef7e12..2eb7117 100644 --- a/gdb/testsuite/lib/gdb.exp +++ b/gdb/testsuite/lib/gdb.exp @@ -8486,5 +8486,25 @@ gdb_caching_proc has_hw_wp_support { return $has_hw_wp_support } +# Return a list of all the accepted values of the set command SET_CMD. + +proc get_set_option_choices {set_cmd} { + global gdb_prompt + + set values {} + + set test "complete $set_cmd" + gdb_test_multiple "complete $set_cmd " "$test" { + -re "$set_cmd (\[^\r\n\]+)\r\n" { + lappend values $expect_out(1,string) + exp_continue + } + -re "$gdb_prompt " { + pass $test + } + } + return $values +} + # Always load compatibility stuff. load_lib future.exp |