From: "Charles James Leonardo Quarra Cappiello" <charsquarra@hotmail.com>
To: gdb@sources.redhat.com
Subject: Re: questions / suggestions about gdb
Date: Wed, 08 May 2002 06:55:00 -0000 [thread overview]
Message-ID: <F67eEslC3R76pfSC30000010c4e@hotmail.com> (raw)
Ok, thank you for the explanation! ; )
Charles Quarra
>From: Michael Elizabeth Chastain <mec@shout.net>
>To: charsquarra@hotmail.com, gdb@sources.redhat.com
>Subject: Re: questions / suggestions about gdb
>Date: Wed, 8 May 2002 07:48:17 -0500
>
> > I'm an often user of gdb, and i was wondering, since debuggers cant go
>to
> > past states (no inversibility of the run), it would be nice if two
>instances
> > of the debugger could run synchronized with a given step offset, so when
>the
> > advanced instance break, the retarded instance stops, keeping an
>analogous
> > state which can be studied.
>
>This is not feasible.
>
>Suppose that the advanced instance makes a system call, such as reading
>from a network connection. Later on, the retarded instance will make
>the system call. How are you going to arrange for the retarded instance
>to receive the same data that the advanced instance received?
>
>Basically, you have to write a wrapping layer that understands every
>system call on the target system.
>
>Besides system calls, you have to handle many other forms of
>nondeterministic
>instructions:
>
> signal delivery
>
> the hard part is not trapping the signal in the advanced process.
> once the signal is trapped, the hard part is figuring out how many
> instructions have elapsed in the advanced process so that the signal
> can be delivered at exactly the right point in the retarded process
>
> memory-mapped input
>
> suppose the advanced process reads from a memory-mapped input device.
> how can you make the device provide the same data a second time,
> when the retarded process hits it? At the gdb level, you can't.
> You need big hooks in the OS memory management code here.
>
> multi-threading
>
> If the process is multi-threaded, it is hard to record the thread
> switches from the advanced process, and it's even harder to make
> them happen at the same time in the retarded process
>
>I've done work along these lines and I might resume it in the future.
>However, the idea of keeping the "retarded" process running in parallel
>in real time is difficult and unworkable.
>
>Michael C
_________________________________________________________________
Join the worldÂs largest e-mail service with MSN Hotmail.
http://www.hotmail.com
next reply other threads:[~2002-05-08 13:55 UTC|newest]
Thread overview: 13+ messages / expand[flat|nested] mbox.gz Atom feed top
2002-05-08 6:55 Charles James Leonardo Quarra Cappiello [this message]
-- strict thread matches above, loose matches on Subject: below --
2002-05-08 5:48 Michael Elizabeth Chastain
2002-05-08 6:47 ` Eli Zaretskii
2002-05-08 6:58 ` Petr Sorfa
2002-05-08 6:53 ` Petr Sorfa
2002-05-07 15:18 Charles James Leonardo Quarra Cappiello
2002-05-07 13:36 Charles James Leonardo Quarra Cappiello
2002-05-07 15:02 ` Andrew Cagney
2002-05-07 12:06 Charles James Leonardo Quarra Cappiello
2002-05-07 13:03 ` Daniel Jacobowitz
2002-05-07 11:58 Charles James Leonardo Quarra Cappiello
2002-05-07 12:00 ` Daniel Jacobowitz
2002-05-07 12:22 ` William A. Gatliff
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=F67eEslC3R76pfSC30000010c4e@hotmail.com \
--to=charsquarra@hotmail.com \
--cc=gdb@sources.redhat.com \
/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