Message ID | 161346807047.1296085.955420533772419632.stgit@pasha-ThinkPad-X280 |
---|---|
State | New |
Headers | show |
Series | [v2] replay: notify CPU on event | expand |
ping On 16.02.2021 12:34, Pavel Dovgalyuk wrote: > This patch enables vCPU notification to wake it up > when new async event comes in replay mode. > > The motivation of this patch is the following. > Consider recorded block async event. It is saved into the log > with one of the checkpoints. This checkpoint may be passed in > vCPU loop. In replay mode when this async event is read from > the log, and block thread task is not finished yet, vCPU thread > goes to sleep. That is why this patch adds waking up the vCPU > to process this finished event. > > Signed-off-by: Pavel Dovgalyuk <Pavel.Dovgalyuk@ispras.ru> > --- > replay/replay-events.c | 1 + > 1 file changed, 1 insertion(+) > > diff --git a/replay/replay-events.c b/replay/replay-events.c > index a1c6bb934e..92dc800219 100644 > --- a/replay/replay-events.c > +++ b/replay/replay-events.c > @@ -126,6 +126,7 @@ void replay_add_event(ReplayAsyncEventKind event_kind, > > g_assert(replay_mutex_locked()); > QTAILQ_INSERT_TAIL(&events_list, event, events); > + qemu_clock_notify(QEMU_CLOCK_VIRTUAL); > } > > void replay_bh_schedule_event(QEMUBH *bh) >
ping On 16.02.2021 12:34, Pavel Dovgalyuk wrote: > This patch enables vCPU notification to wake it up > when new async event comes in replay mode. > > The motivation of this patch is the following. > Consider recorded block async event. It is saved into the log > with one of the checkpoints. This checkpoint may be passed in > vCPU loop. In replay mode when this async event is read from > the log, and block thread task is not finished yet, vCPU thread > goes to sleep. That is why this patch adds waking up the vCPU > to process this finished event. > > Signed-off-by: Pavel Dovgalyuk <Pavel.Dovgalyuk@ispras.ru> > --- > replay/replay-events.c | 1 + > 1 file changed, 1 insertion(+) > > diff --git a/replay/replay-events.c b/replay/replay-events.c > index a1c6bb934e..92dc800219 100644 > --- a/replay/replay-events.c > +++ b/replay/replay-events.c > @@ -126,6 +126,7 @@ void replay_add_event(ReplayAsyncEventKind event_kind, > > g_assert(replay_mutex_locked()); > QTAILQ_INSERT_TAIL(&events_list, event, events); > + qemu_clock_notify(QEMU_CLOCK_VIRTUAL); > } > > void replay_bh_schedule_event(QEMUBH *bh) >
diff --git a/replay/replay-events.c b/replay/replay-events.c index a1c6bb934e..92dc800219 100644 --- a/replay/replay-events.c +++ b/replay/replay-events.c @@ -126,6 +126,7 @@ void replay_add_event(ReplayAsyncEventKind event_kind, g_assert(replay_mutex_locked()); QTAILQ_INSERT_TAIL(&events_list, event, events); + qemu_clock_notify(QEMU_CLOCK_VIRTUAL); } void replay_bh_schedule_event(QEMUBH *bh)
This patch enables vCPU notification to wake it up when new async event comes in replay mode. The motivation of this patch is the following. Consider recorded block async event. It is saved into the log with one of the checkpoints. This checkpoint may be passed in vCPU loop. In replay mode when this async event is read from the log, and block thread task is not finished yet, vCPU thread goes to sleep. That is why this patch adds waking up the vCPU to process this finished event. Signed-off-by: Pavel Dovgalyuk <Pavel.Dovgalyuk@ispras.ru> --- replay/replay-events.c | 1 + 1 file changed, 1 insertion(+)