Mirror of the gdb-patches mailing list
 help / color / mirror / Atom feed
From: Pedro Alves <palves@redhat.com>
To: Philippe Waroquiers <philippe.waroquiers@skynet.be>,
	gdb-patches@sourceware.org
Subject: Re: [PATCH 00/23] Multi-target support
Date: Sun, 08 Sep 2019 20:06:00 -0000	[thread overview]
Message-ID: <6bed10d6-482f-917d-54f5-34c079ee9547@redhat.com> (raw)
In-Reply-To: <2802fb1954a3756ec7e507141652b8d92127424a.camel@skynet.be>

On 9/7/19 12:19 PM, Philippe Waroquiers wrote:
> Patch is a nice target :).
> This can be useful e.g. with the valgrind gdbserver, that only
> supports to debug a single process (i.e. the valgrind process that
> runs its embedded gdbserver).

Ahah, yeah, this was one of potential use cases for the multi-target work
that I talked about in last year's cauldron (in the multicore bof).

https://gcc.gnu.org/wiki/cauldron2018?action=AttachFile&do=get&target=palves-TheMulticoreGDBBoF%282018%29.pdf

> 
> First, a minor suggestion about the terminology (as introduced in patch 17, and used
> in command names): the rational is that 'target' being already overloaded,
> the wording 'target connection' is used  (leading to e.g. the command
> 'info connections').
> I am wondering if the word "connection" is not also too overloaded,
> and too much interpreted as meaning 'a real connection', which might lead to
> some user confusion.
> Maybe other wording could be used instead (such as 'target channel' 
> and 'info channels') ?  Or maybe another synonym of channel or similar ?

Hmm, I'm not seeing how those would be an improvement over connection,
to be honest.

I'm already used to saying / hearing "open a connection to some target",
so I thought it was natural.  E.g., we have this command already:

 (gdb) help set auto-connect-native-target 
 Set whether GDB may automatically connect to the native target.
 When on, and GDB is not connected to a target yet, GDB
 attempts "run" and other commands with the native target.

Granted, I was the one who invented/added that command and
wrote that text.

But see the much older "target" command:

(gdb) help target 
Connect to a target machine or process.
^^^^^^^
The first argument is the type or protocol of the target machine.
Remaining arguments are interpreted by the target protocol.  For more
information on the arguments for a particular protocol, type
`help target ' followed by the protocol name.


Also, we have the "disconnect" command, with "disconnect" obviously
being the opposite of "connect", meaning close a connection:

 (gdb) target native 
 Done.  Use the "run" command to start a process.
 (gdb) maintenance print target-stack 
 The current target stack is:
   - native (Native process)
   - None (None)
 (gdb) disconnect 
 (gdb) maintenance print target-stack 
 The current target stack is:
   - None (None)

I'm thinking that it would be natural to use that
command to stop debugging a core dump too, for example,
I think this should be made to work:

 (gdb) core core.10872 
 ...
 Program terminated with signal SIGSEGV, Segmentation fault.
 #0  0x00007f176838d3e7 in ?? ()
 [Current thread is 1 (LWP 10872)]
 (gdb) maint print target-stack 
 The current target stack is:
   - core (Local core dump file)
   - None (None)
 (gdb) disconnect 
 You can't do that when your target is `core'
 (gdb) 

> 
> Otherwise, I did a minimal test to see how GDB could connect to 2 different
> valgrind gdbservers (a 64 bits and a 32 bits), but I could not make it work.
> The 2 valgrind I have launched are (in the top of a valgrind build):
> 
> ./path to/bin/valgrind --vgdb-error=0 ./memcheck/tests/trivialleak 
> ./path to/bin/valgrind --vgdb-error=0 ./memcheck/tests/x86-linux/scalar_exit_group
> 
> (gdb) tar rem|lvgdb
> Remote debugging using |lvgdb
> ...
> (gdb) add-inferior -no-connection
> [New inferior 2]
> Added inferior 2
> (gdb) tar rem |lvgdb --pid=16727
> Remote debugging using |lvgdb --pid=16727
> ...
> (gdb) info connection
>   Num  Name                      Description       
>   1    remote lvgdb              Remote serial target in gdb-specific protocol 
> * 2    remote lvgdb --pid=16727  Remote serial target in gdb-specific protocol 
> (gdb) b main
> Breakpoint 1 at 0x109168: main. (2 locations)
> ????? this has put a break at 2 locations in 2 different inferiors, reporting
> only one address.  Wondering if that is the expected
> behaviour.  In any case, that behaviour does not look to be a big deal.

Yeah, this behavior shouldn't have changed with this patchset.  You should
see the exact same if you were debugging the two inferiors under the
same target.  Does it differ for you?  You have two locations, because
we create one location per inferior.  I don't recall offhand why we only
show one address -- maybe the address is the same for all locations?

> (gdb) infer 1
> [Switching to inferior 1 [Remote target]
> (/home/philippe/valgrind/git/trunk_untouched/memcheck/tests/trivialleak)]
> [Switching to thread 1.1 (Thread 10050)]
> #0  0x0000000004001090 in _start () from /lib64/ld-linux-x86-64.so.2
> (gdb) c
> Continuing.
> Connection 2 (remote lvgdb --pid=16727) does not support multi-target resumption.
> (gdb)
> 
> So, the continue command is refused both in inferior 1 and inferior 2.

Does valgrind's gdbserver support non-stop mode?  I thought it didn't,
but if it does, then you need to do "maint set target-non-stop on"
before connecting.  This is one of the limitations that I described
in patch #17.

Was this with "set schedule-multiple" set to "on", or "off", BTW?

> 
> Then when stopping this gdb (which automatically continues the valgrind executables
> till valgrind reports the next error), launching a new gdb, and only connecting to the 32
> bits valgrind gdbserver, here is what I see.
> 
> (gdb) tar rem|lvgdb --pid=16727
> Remote debugging using |lvgdb
> ...
> 0x04001092 in _dl_sysinfo_int80 () from /lib/ld-linux.so.2
> (gdb) bt
> #0  0x04001092 in _dl_sysinfo_int80 () from /lib/ld-linux.so.2
> #1  0x0495fd27 in syscall () at ../sysdeps/unix/sysv/linux/i386/syscall.S:29
> #2  0x0010922c in main () at scalar_exit_group.c:14
> (gdb) c
> Continuing.
> ../../multi-target-v1/gdb/inferior.c:285: internal-error: inferior*
> find_inferior_pid(process_stratum_target*, int): Assertion `pid != 0' failed.
> A problem internal to GDB has been detected,
> further debugging may prove unreliable.
> Quit this debugging session? (y or n) 
> 
> So, that looks to be a regression with the valgrind gdbserver.

Thanks.  I'll have to try reproducing this.

> 
> I did another trial using an abbreviation for -no-connection, but then
> that does not work:
> (gdb) add-inferior -no-connection
> [New inferior 2]
> Added inferior 2
> (gdb) add-inferior -no-conn
> [New inferior 3]
> Added inferior 3 on connection 1 (remote lvgdb --pid=17046)
> (gdb) 
> 
> Maybe add-inferior should better be converted to the option framework ?

Right, here's what I said in patch #17 about this:

 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 I tried converting "add-inferior" to the gdb::option framework, as a
 preparatory patch, but that stumbled on the fact that gdb::option does
 not support file options yet, for "add-inferior -exec".  I have a WIP
 patchset that adds that, but it's not a trivial patch, mainly due to
 need to integrate readline's filename completion, so I deferred that
 to some other time.
 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

Here's that WIP patchset in question:

 https://github.com/palves/gdb/commits/palves/filename-options

Thanks,
Pedro Alves


  reply	other threads:[~2019-09-08 20:06 UTC|newest]

Thread overview: 67+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2019-09-06 23:28 Pedro Alves
2019-09-06 23:28 ` [PATCH 06/23] Don't check target is running in remote_target::mourn_inferior Pedro Alves
2019-09-06 23:28 ` [PATCH 16/23] Fix reconnecting to a gdbserver already debugging multiple processes, II Pedro Alves
2019-09-06 23:28 ` [PATCH 03/23] Make "show remote exec-file" inferior-aware Pedro Alves
2019-09-06 23:28 ` [PATCH 19/23] gdbarch-selftests.c: No longer error out if debugging something Pedro Alves
2019-09-06 23:28 ` [PATCH 20/23] Revert 'Remove unused struct serial::name field' Pedro Alves
2019-09-06 23:47   ` Christian Biesinger via gdb-patches
2019-09-08 19:30     ` Pedro Alves
2019-09-06 23:28 ` [PATCH 09/23] switch inferior/thread before calling target methods Pedro Alves
2019-09-06 23:28 ` [PATCH 11/23] tfile_target::close: trace_fd can't be -1 Pedro Alves
2019-09-06 23:28 ` [PATCH 08/23] Introduce switch_to_inferior_no_thread Pedro Alves
2019-09-09 18:42   ` Tom Tromey
2019-10-17  1:07     ` Pedro Alves
2019-09-06 23:28 ` [PATCH 18/23] Add multi-target tests Pedro Alves
2019-10-09 16:01   ` Aktemur, Tankut Baris
2019-10-17  0:55     ` Pedro Alves
2019-09-06 23:28 ` [PATCH 17/23] Multi-target support Pedro Alves
2019-09-11 17:11   ` Tom Tromey
2019-10-17  1:54     ` Pedro Alves
2019-09-06 23:28 ` [PATCH 02/23] Don't rely on inferior_ptid in record_full_wait Pedro Alves
2020-07-31  3:17   ` Tom Tromey
2020-08-01 16:14     ` Simon Marchi
2020-08-01 19:32       ` John Baldwin
2020-08-01 20:47         ` Tom Tromey
2020-08-01 20:46       ` Tom Tromey
2020-08-01 22:56         ` Simon Marchi
2020-08-02 17:52           ` Tom Tromey
2020-08-03  0:08             ` Simon Marchi
2019-09-06 23:28 ` [PATCH 13/23] Delete exit_inferior_silent(int pid) Pedro Alves
2019-09-06 23:28 ` [PATCH 15/23] Fix reconnecting to a gdbserver already debugging multiple processes, I Pedro Alves
2019-09-06 23:28 ` [PATCH 10/23] Some get_last_target_status tweaks Pedro Alves
2019-09-09 18:53   ` Tom Tromey
2019-10-17  1:14     ` Pedro Alves
2019-09-06 23:28 ` [PATCH 01/23] Preserve selected thread in all-stop w/ background execution Pedro Alves
2019-10-09  9:36   ` Aktemur, Tankut Baris
2019-10-16 23:54     ` [PATCH v1.1 " Pedro Alves
2019-10-17 10:21       ` Aktemur, Tankut Baris
2019-09-06 23:33 ` [PATCH 23/23] Multi-target: NEWS and user manual Pedro Alves
2019-09-07  6:33   ` Eli Zaretskii
2019-10-17  2:08     ` Pedro Alves
2019-10-17  7:55       ` Eli Zaretskii
2019-10-17  2:42     ` Pedro Alves
2019-10-17  8:14       ` Eli Zaretskii
2019-10-17 15:31         ` Pedro Alves
2019-09-06 23:34 ` [PATCH 04/23] exceptions.c:print_flush: Remove obsolete check Pedro Alves
2019-09-09 18:07   ` Tom Tromey
2019-09-06 23:35 ` [PATCH 05/23] Make target_ops::has_execution take an 'inferior *' instead of a ptid_t Pedro Alves
2019-09-09 18:12   ` Tom Tromey
2019-09-06 23:36 ` [PATCH 07/23] Delete unnecessary code from kill_command Pedro Alves
2019-10-01 10:19   ` Aktemur, Tankut Baris
2019-10-01 13:28     ` Aktemur, Tankut Baris
2019-09-06 23:36 ` [PATCH 14/23] Tweak handling of remote errors in response to resumption packet Pedro Alves
2019-10-09 13:35   ` Aktemur, Tankut Baris
2019-10-17  0:54     ` [PATCH 14.5/23] Avoid another inferior_ptid reference in gdb/remote.c (Re: [PATCH 14/23] Tweak handling of remote errors in response to resumption packet) Pedro Alves
2019-09-06 23:36 ` [PATCH 12/23] Use all_non_exited_inferiors in infrun.c Pedro Alves
2019-09-06 23:37 ` [PATCH 21/23] Add "info connections" command, "info inferiors" connection number/string Pedro Alves
2019-09-09 20:18   ` Tom Tromey
2019-10-17  2:21     ` Pedro Alves
2019-10-17 14:23       ` Tom Tromey
2019-09-06 23:37 ` [PATCH 22/23] Require always-non-stop for multi-target resumptions Pedro Alves
2019-09-07 11:19 ` [PATCH 00/23] Multi-target support Philippe Waroquiers
2019-09-08 20:06   ` Pedro Alves [this message]
2019-09-08 20:50     ` Philippe Waroquiers
2019-10-16 19:08       ` Pedro Alves
2019-10-16 19:14       ` [PATCH] Avoid inferior_ptid reference in gdb/remote.c (Re: [PATCH 00/23] Multi-target support) Pedro Alves
2019-09-09 19:09 ` [PATCH 00/23] Multi-target support Tom Tromey
2019-09-09 20:22 ` Tom Tromey

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=6bed10d6-482f-917d-54f5-34c079ee9547@redhat.com \
    --to=palves@redhat.com \
    --cc=gdb-patches@sourceware.org \
    --cc=philippe.waroquiers@skynet.be \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox