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.
This commit is contained in:
parent
cfeab26e4d
commit
d43bd54d54
6
gdb/NEWS
6
gdb/NEWS
@ -152,6 +152,12 @@ info win
|
||||
of the floating-point type, and the "f" is the marker for floating
|
||||
point.
|
||||
|
||||
* MI changes
|
||||
|
||||
** The '-add-inferior' with no option flags now inherits the
|
||||
connection of the current inferior, this restores the behaviour of
|
||||
GDB as it was prior to GDB 10.
|
||||
|
||||
* New targets
|
||||
|
||||
GNU/Linux/LoongArch loongarch*-*-linux*
|
||||
|
@ -759,11 +759,9 @@ add_inferior_with_spaces (void)
|
||||
return inf;
|
||||
}
|
||||
|
||||
/* Switch to inferior NEW_INF, a new inferior, and unless
|
||||
NO_CONNECTION is true, push the process_stratum_target of ORG_INF
|
||||
to NEW_INF. */
|
||||
/* See inferior.h. */
|
||||
|
||||
static void
|
||||
void
|
||||
switch_to_inferior_and_push_target (inferior *new_inf,
|
||||
bool no_connection, inferior *org_inf)
|
||||
{
|
||||
|
@ -740,4 +740,11 @@ extern struct inferior *add_inferior_with_spaces (void);
|
||||
/* Print the current selected inferior. */
|
||||
extern void print_selected_inferior (struct ui_out *uiout);
|
||||
|
||||
/* Switch to inferior NEW_INF, a new inferior, and unless
|
||||
NO_CONNECTION is true, push the process_stratum_target of ORG_INF
|
||||
to NEW_INF. */
|
||||
|
||||
extern void switch_to_inferior_and_push_target
|
||||
(inferior *new_inf, bool no_connection, inferior *org_inf);
|
||||
|
||||
#endif /* !defined (INFERIOR_H) */
|
||||
|
@ -1708,8 +1708,12 @@ mi_cmd_add_inferior (const char *command, char **argv, int argc)
|
||||
if (argc != 0)
|
||||
error (_("-add-inferior should be passed no arguments"));
|
||||
|
||||
scoped_restore_current_pspace_and_thread restore_pspace_thread;
|
||||
|
||||
inf = add_inferior_with_spaces ();
|
||||
|
||||
switch_to_inferior_and_push_target (inf, false, current_inferior ());
|
||||
|
||||
current_uiout->field_fmt ("inferior", "i%d", inf->num);
|
||||
}
|
||||
|
||||
|
122
gdb/testsuite/gdb.mi/mi-add-inferior.exp
Normal file
122
gdb/testsuite/gdb.mi/mi-add-inferior.exp
Normal file
@ -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
|
||||
}
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user