set proper migration status on ->write error (v5)
If ->write fails, declare migration status as MIG_STATE_ERROR. Also, in buffered_file.c, ->close the object in case of an error. Fixes "migrate -d "exec:dd of=file", where dd fails to open file. Signed-off-by: Marcelo Tosatti <mtosatti@redhat.com> Signed-off-by: Luiz Capitulino <lcapitulino@redhat.com> Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
This commit is contained in:
parent
027c9e21e2
commit
e447b1a603
@ -230,8 +230,10 @@ static void buffered_rate_tick(void *opaque)
|
|||||||
{
|
{
|
||||||
QEMUFileBuffered *s = opaque;
|
QEMUFileBuffered *s = opaque;
|
||||||
|
|
||||||
if (s->has_error)
|
if (s->has_error) {
|
||||||
|
buffered_close(s);
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
qemu_mod_timer(s->timer, qemu_get_clock(rt_clock) + 100);
|
qemu_mod_timer(s->timer, qemu_get_clock(rt_clock) + 100);
|
||||||
|
|
||||||
|
@ -316,8 +316,14 @@ ssize_t migrate_fd_put_buffer(void *opaque, const void *data, size_t size)
|
|||||||
if (ret == -1)
|
if (ret == -1)
|
||||||
ret = -(s->get_error(s));
|
ret = -(s->get_error(s));
|
||||||
|
|
||||||
if (ret == -EAGAIN)
|
if (ret == -EAGAIN) {
|
||||||
qemu_set_fd_handler2(s->fd, NULL, NULL, migrate_fd_put_notify, s);
|
qemu_set_fd_handler2(s->fd, NULL, NULL, migrate_fd_put_notify, s);
|
||||||
|
} else if (ret < 0) {
|
||||||
|
if (s->mon) {
|
||||||
|
monitor_resume(s->mon);
|
||||||
|
}
|
||||||
|
s->state = MIG_STATE_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user