From: "Pavel Dovgalyuk" <dovgaluk@ispras.ru>
To: 'Paolo Bonzini' <pbonzini@redhat.com>,
'Pavel Dovgalyuk' <Pavel.Dovgaluk@ispras.ru>,
qemu-devel@nongnu.org
Cc: kwolf@redhat.com, peter.maydell@linaro.org, war2jordan@live.com,
crosthwaite.peter@gmail.com, boost.lists@gmail.com,
quintela@redhat.com, ciro.santilli@gmail.com,
jasowang@redhat.com, mst@redhat.com, zuban32s@gmail.com,
armbru@redhat.com, maria.klimushenkova@ispras.ru,
kraxel@redhat.com, thomas.dullien@googlemail.com,
mreitz@redhat.com, alex.bennee@linaro.org, dgilbert@redhat.com,
rth@twiddle.net
Subject: Re: [Qemu-devel] [PATCH v6 00/25] Fixing record/replay and adding reverse debugging
Date: Thu, 13 Sep 2018 16:40:03 +0300 [thread overview]
Message-ID: <000a01d44b67$46df48e0$d49ddaa0$@ru> (raw)
In-Reply-To: <f6586d6f-54b3-ae20-e9fd-aa0fd5cb4309@redhat.com>
> From: Paolo Bonzini [mailto:pbonzini@redhat.com]
> On 12/09/2018 10:17, Pavel Dovgalyuk wrote:
> > GDB remote protocol supports reverse debugging of the targets.
> > It includes 'reverse step' and 'reverse continue' operations.
> > The first one finds the previous step of the execution,
> > and the second one is intended to stop at the last breakpoint that
> > would happen when the program is executed normally.
> >
> > Reverse debugging is possible in the replay mode, when at least
> > one snapshot was created at the record or replay phase.
> > QEMU can use these snapshots for travelling back in time with GDB.
> >
> > Running the execution in replay mode allows using GDB reverse debugging
> > commands:
> > - reverse-stepi (or rsi): Steps one instruction to the past.
> > QEMU loads on of the prior snapshots and proceeds to the desired
> > instruction forward. When that step is reaches, execution stops.
> > - reverse-continue (or rc): Runs execution "backwards".
> > QEMU tries to find breakpoint or watchpoint by loaded prior snapshot
> > and replaying the execution. Then QEMU loads snapshots again and
> > replays to the latest breakpoint. When there are no breakpoints in
> > the examined section of the execution, QEMU finds one more snapshot
> > and tries again. After the first snapshot is processed, execution
> > stops at this snapshot.
> >
> > The set of patches include the following modifications:
> > - fixes of record/replay caused by the QEMU core changes
> > - gdbstub update for reverse debugging support
> > - functions that automatically perform reverse step and reverse
> > continue operations
> > - hmp/qmp commands for manipulating the replay process
> > - improvement of the snapshotting for saving the execution step
> > in the snapshot parameters
> > - adding new clock for correct timer events from vnc and slirp
> > - other record/replay fixes
> >
> > The patches are available in the repository:
> > https://github.com/ispras/qemu/tree/rr-180911
> >
> > v6 changes:
> > - rebased to the new version of master
> > - fixed build of linux-user configurations
> > - added new clock for slirp and vnc timers
> >
> > v5 changes:
> > - multiple fixes of record/replay bugs appeared after QEMU core update
> > - changed reverse debugging to 'since 3.1'
> >
> > v4 changes:
> > - changed 'since 2.13' to 'since 3.0' in json (as suggested by Eric Blake)
> >
> > v3 changes:
> > - Fixed PS/2 bug with save/load vm, which caused failures of the replay.
> > - Rebased to the new code base.
> > - Minor fixes.
> >
> > v2 changes:
> > - documented reverse debugging
> > - fixed start vmstate loading in record mode
> > - documented qcow2 changes (as suggested by Eric Blake)
> > - made icount SnapshotInfo field optional (as suggested by Eric Blake)
> > - renamed qmp commands (as suggested by Eric Blake)
> > - minor changes
> >
> > ---
> >
> > Pavel Dovgalyuk (25):
> > block: implement bdrv_snapshot_goto for blkreplay
> > replay: disable default snapshot for record/replay
> > replay: update docs for record/replay with block devices
> > replay: don't drain/flush bdrv queue while RR is working
> > replay: finish record/replay before closing the disks
> > qcow2: introduce icount field for snapshots
> > migration: introduce icount field for snapshots
> > replay: provide and accessor for rr filename
> > replay: introduce info hmp/qmp command
> > replay: introduce breakpoint at the specified step
> > replay: implement replay-seek command to proceed to the desired step
> > replay: flush events when exiting
> > replay: refine replay-time module
> > translator: fix breakpoint processing
> > replay: flush rr queue before loading the vmstate
> > gdbstub: add reverse step support in replay mode
> > gdbstub: add reverse continue support in replay mode
> > replay: describe reverse debugging in docs/replay.txt
> > replay: allow loading any snapshots before recording
> > replay: wake up vCPU when replaying
> > replay: replay BH for IDE trim operation
> > replay: add BH oneshot event for block layer
> > timer: introduce new virtual clock
> > slirp: fix ipv6 timers
> > ui: fix virtual timers
> >
> >
> > accel/tcg/translator.c | 9 +
> > block/blkreplay.c | 8 +
> > block/block-backend.c | 3
> > block/io.c | 22 +++
> > block/qapi.c | 17 ++-
> > block/qcow2-snapshot.c | 9 +
> > block/qcow2.h | 2
> > blockdev.c | 10 ++
> > cpus.c | 50 +++++---
> > docs/interop/qcow2.txt | 4 +
> > docs/replay.txt | 45 +++++++
> > exec.c | 6 +
> > gdbstub.c | 50 +++++++-
> > hmp-commands-info.hx | 14 ++
> > hmp-commands.hx | 30 +++++
> > hmp.h | 3
> > hw/ide/core.c | 3
> > include/block/snapshot.h | 1
> > include/qemu/timer.h | 9 +
> > include/sysemu/replay.h | 26 ++++
> > migration/savevm.c | 15 +-
> > qapi/block-core.json | 5 +
> > qapi/block.json | 3
> > qapi/misc.json | 68 +++++++++++
> > replay/Makefile.objs | 3
> > replay/replay-debugging.c | 287 +++++++++++++++++++++++++++++++++++++++++++++
> > replay/replay-events.c | 30 +++--
> > replay/replay-internal.h | 9 +
> > replay/replay-snapshot.c | 17 ++-
> > replay/replay-time.c | 32 ++---
> > replay/replay.c | 38 ++++++
> > slirp/ip6_icmp.c | 7 +
> > stubs/Makefile.objs | 1
> > stubs/replay-user.c | 9 +
> > stubs/replay.c | 10 ++
> > ui/input.c | 8 +
> > util/qemu-timer.c | 2
> > vl.c | 18 ++-
> > 38 files changed, 791 insertions(+), 92 deletions(-)
> > create mode 100644 replay/replay-debugging.c
> > create mode 100644 stubs/replay-user.c
> >
>
> For now I'm queuing 12, 14, 19, 20 (pending question to you) and 23-25.
What about patch 21?
Pavel Dovgalyuk
next prev parent reply other threads:[~2018-09-13 13:40 UTC|newest]
Thread overview: 52+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-09-12 8:17 [Qemu-devel] [PATCH v6 00/25] Fixing record/replay and adding reverse debugging Pavel Dovgalyuk
2018-09-12 8:17 ` [Qemu-devel] [PATCH v6 01/25] block: implement bdrv_snapshot_goto for blkreplay Pavel Dovgalyuk
2018-09-12 8:18 ` [Qemu-devel] [PATCH v6 02/25] replay: disable default snapshot for record/replay Pavel Dovgalyuk
2018-09-12 8:18 ` [Qemu-devel] [PATCH v6 03/25] replay: update docs for record/replay with block devices Pavel Dovgalyuk
2018-09-12 8:18 ` [Qemu-devel] [PATCH v6 04/25] replay: don't drain/flush bdrv queue while RR is working Pavel Dovgalyuk
2018-09-12 8:18 ` [Qemu-devel] [PATCH v6 05/25] replay: finish record/replay before closing the disks Pavel Dovgalyuk
2018-09-12 8:18 ` [Qemu-devel] [PATCH v6 06/25] qcow2: introduce icount field for snapshots Pavel Dovgalyuk
2018-09-12 8:18 ` [Qemu-devel] [PATCH v6 07/25] migration: " Pavel Dovgalyuk
2018-09-12 8:18 ` [Qemu-devel] [PATCH v6 08/25] replay: provide and accessor for rr filename Pavel Dovgalyuk
2018-09-12 8:18 ` [Qemu-devel] [PATCH v6 09/25] replay: introduce info hmp/qmp command Pavel Dovgalyuk
2018-09-12 8:18 ` [Qemu-devel] [PATCH v6 10/25] replay: introduce breakpoint at the specified step Pavel Dovgalyuk
2018-09-12 8:18 ` [Qemu-devel] [PATCH v6 11/25] replay: implement replay-seek command to proceed to the desired step Pavel Dovgalyuk
2018-09-12 8:18 ` [Qemu-devel] [PATCH v6 12/25] replay: flush events when exiting Pavel Dovgalyuk
2018-09-12 8:19 ` [Qemu-devel] [PATCH v6 13/25] replay: refine replay-time module Pavel Dovgalyuk
2018-09-12 8:19 ` [Qemu-devel] [PATCH v6 14/25] translator: fix breakpoint processing Pavel Dovgalyuk
2018-09-12 8:19 ` [Qemu-devel] [PATCH v6 15/25] replay: flush rr queue before loading the vmstate Pavel Dovgalyuk
2018-09-12 8:19 ` [Qemu-devel] [PATCH v6 16/25] gdbstub: add reverse step support in replay mode Pavel Dovgalyuk
2018-09-12 8:19 ` [Qemu-devel] [PATCH v6 17/25] gdbstub: add reverse continue " Pavel Dovgalyuk
2018-09-12 8:19 ` [Qemu-devel] [PATCH v6 18/25] replay: describe reverse debugging in docs/replay.txt Pavel Dovgalyuk
2018-09-12 8:19 ` [Qemu-devel] [PATCH v6 19/25] replay: allow loading any snapshots before recording Pavel Dovgalyuk
2018-09-12 8:19 ` [Qemu-devel] [PATCH v6 20/25] replay: wake up vCPU when replaying Pavel Dovgalyuk
2018-09-13 10:12 ` Paolo Bonzini
2018-09-13 11:06 ` Pavel Dovgalyuk
2018-09-12 8:19 ` [Qemu-devel] [PATCH v6 21/25] replay: replay BH for IDE trim operation Pavel Dovgalyuk
2018-09-13 17:05 ` John Snow
2018-09-14 5:48 ` Pavel Dovgalyuk
2018-09-14 7:27 ` Pavel Dovgalyuk
2018-09-14 14:17 ` John Snow
2018-09-14 14:00 ` John Snow
2018-09-14 15:19 ` Paolo Bonzini
2018-09-14 15:59 ` Peter Maydell
2018-09-12 8:19 ` [Qemu-devel] [PATCH v6 22/25] replay: add BH oneshot event for block layer Pavel Dovgalyuk
2018-09-13 10:22 ` Paolo Bonzini
2018-09-13 11:13 ` Pavel Dovgalyuk
2018-09-13 13:45 ` Paolo Bonzini
2018-09-14 6:17 ` Pavel Dovgalyuk
2018-09-12 8:20 ` [Qemu-devel] [PATCH v6 23/25] timer: introduce new virtual clock Pavel Dovgalyuk
2018-09-12 8:20 ` [Qemu-devel] [PATCH v6 24/25] slirp: fix ipv6 timers Pavel Dovgalyuk
2018-09-12 8:45 ` Samuel Thibault
2018-09-12 8:20 ` [Qemu-devel] [PATCH v6 25/25] ui: fix virtual timers Pavel Dovgalyuk
2018-09-13 10:27 ` [Qemu-devel] [PATCH v6 00/25] Fixing record/replay and adding reverse debugging Paolo Bonzini
2018-09-13 13:40 ` Pavel Dovgalyuk [this message]
2018-09-13 13:46 ` Paolo Bonzini
[not found] <CANzW0mvSX5nWuinDU68W2yJzgoQSGAHPqpz0G36A6NKwRsz_4A@mail.gmail.com>
2018-10-01 14:14 ` dovgaluk
2018-10-01 18:22 ` Artem Pisarenko
2018-10-02 7:02 ` Artem Pisarenko
2018-10-03 6:47 ` dovgaluk
2018-10-04 13:15 ` Artem Pisarenko
2018-10-09 9:04 ` Pavel Dovgalyuk
2018-10-09 11:23 ` Artem Pisarenko
2018-10-09 11:26 ` Pavel Dovgalyuk
2018-10-09 12:59 ` Artem Pisarenko
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='000a01d44b67$46df48e0$d49ddaa0$@ru' \
--to=dovgaluk@ispras.ru \
--cc=Pavel.Dovgaluk@ispras.ru \
--cc=alex.bennee@linaro.org \
--cc=armbru@redhat.com \
--cc=boost.lists@gmail.com \
--cc=ciro.santilli@gmail.com \
--cc=crosthwaite.peter@gmail.com \
--cc=dgilbert@redhat.com \
--cc=jasowang@redhat.com \
--cc=kraxel@redhat.com \
--cc=kwolf@redhat.com \
--cc=maria.klimushenkova@ispras.ru \
--cc=mreitz@redhat.com \
--cc=mst@redhat.com \
--cc=pbonzini@redhat.com \
--cc=peter.maydell@linaro.org \
--cc=qemu-devel@nongnu.org \
--cc=quintela@redhat.com \
--cc=rth@twiddle.net \
--cc=thomas.dullien@googlemail.com \
--cc=war2jordan@live.com \
--cc=zuban32s@gmail.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;
as well as URLs for NNTP newsgroup(s).