diff options
author | Umair Sair <umair_sair@hotmail.com> | 2022-02-24 22:25:51 +0500 |
---|---|---|
committer | Andrew Burgess <aburgess@redhat.com> | 2022-03-07 19:38:53 +0000 |
commit | d43bd54d543742c76fb20a0fe379817ccca4e5f2 (patch) | |
tree | bd9343ee5c85ac675fb3ab8c6f85ab2bf9653e36 /gdb/testsuite | |
parent | cfeab26e4d42fb6f1bde429ab53a885a9d106a69 (diff) | |
download | binutils-gdb-d43bd54d543742c76fb20a0fe379817ccca4e5f2.tar.gz |
gdb/mi: fix regression in mi -add-inferior command
Prior to the multi-target support commit:
commit 5b6d1e4fa4fc6827c7b3f0e99ff120dfa14d65d2
Date: Fri Jan 10 20:06:08 2020 +0000
Multi-target support
When a new inferior was added using the MI -add-inferior command, the
new inferior would be using the same target as all the other
inferiors. This makes sense, GDB only supported a single target stack
at a time.
After the above commit, each inferior has its own target stack.
To maintain backward compatibility, for the CLI add-inferior command,
when a new inferior is added the above commit has the new inferior
inherit a copy of the target stack from the current inferior.
Unfortunately, this same backward compatibility is missing for the MI.
This commit fixes this oversight.
Now, when the -add-inferior MI command is used, the new inferior will
inherit a copy of the target stack from the current inferior.
Diffstat (limited to 'gdb/testsuite')
-rw-r--r-- | gdb/testsuite/gdb.mi/mi-add-inferior.exp | 122 |
1 files changed, 122 insertions, 0 deletions
diff --git a/gdb/testsuite/gdb.mi/mi-add-inferior.exp b/gdb/testsuite/gdb.mi/mi-add-inferior.exp new file mode 100644 index 00000000000..3f0cd7cc06c --- /dev/null +++ b/gdb/testsuite/gdb.mi/mi-add-inferior.exp @@ -0,0 +1,122 @@ +# Copyright 2022 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/>. + +# Test MI '-add-inferior'. + +load_lib mi-support.exp +set MIFLAGS "-i=mi" + +standard_testfile basics.c + +if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" \ + executable {debug}] != "" } { + untested "failed to compile" + return -1 +} + +mi_clean_restart ${binfile} + +# Start execution to establish a connection. +mi_runto_main + +# Use 'info inferiors' to find the details of the current connection. +set header_line "" +set inf_line "" +gdb_test_multiple "info inferiors" "" { + + -re "^info inferiors\r\n" { + exp_continue + } + + -re "^&\[^\r\n\]+\r\n" { + exp_continue + } + + -re "~\"( Num\\s+Description\\s+Connection\[^\r\n\]+)\r\n" { + set header_line $expect_out(1,string) + exp_continue + } + + -re "^~\"(\\*\\s+1\\s+\[^\r\n\]+)\r\n" { + set inf_line $expect_out(1,string) + exp_continue + } + + -re "^\\^done\r\n" { + exp_continue + } + + -re "^$mi_gdb_prompt$" { + gdb_assert { [string length "$header_line"] > 0 } + gdb_assert { [string length "$inf_line"] > 0 } + pass $gdb_test_name + } +} + +# Now extract the string that represents the connection, and convert +# it into a regexp. +set idx [string first "Connection" "${header_line}"] +gdb_assert { $idx > -1 } +set inf_line [string range "${inf_line}" $idx end] +regexp "^(${decimal} \\(\[^)\]+\\))" $inf_line conn_info +set conn_pattern [string_to_regexp "${conn_info}"] + +# Now add a new inferior, this should use the connection of the +# current inferior. +mi_gdb_test "-add-inferior" \ + [multi_line "=thread-group-added,id=\"\[^\"\]+\"" \ + "~\"\\\[New inferior 2\\\]\\\\n\"" \ + "\~\"Added inferior 2 on connection ${conn_pattern}\\\\n\"" \ + "\\^done,inferior=\"\[^\"\]+\"" ] \ + "mi add inferior" + +# Now run 'info inferiors' again to check that the currently selected +# inferior has not changed. +set saw_current_inferior false +set saw_new_inferior false +gdb_test_multiple "info inferiors" \ + "info inferiors, after new inferior was created" { + + -re "^info inferiors\r\n" { + exp_continue + } + + -re "^&\[^\r\n\]+\r\n" { + exp_continue + } + + -re "~\"\\s+Num\\s+Description\\s+Connection\[^\r\n\]+\r\n" { + exp_continue + } + + -re "^~\"\\*\\s+1\\s+\[^\r\n\]+\\s+${conn_pattern}\\s+\[^\r\n\]+\r\n" { + set saw_current_inferior true + exp_continue + } + + -re "^~\"\\s+2\\s+\[^\r\n\]+\\s+${conn_pattern}\\s+\[^\r\n\]+\r\n" { + set saw_new_inferior true + exp_continue + } + + -re "^\\^done\r\n" { + exp_continue + } + + -re "^$mi_gdb_prompt$" { + gdb_assert { $saw_current_inferior && $saw_new_inferior } + pass $gdb_test_name + } + } |