[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [Qemu-devel] [PATCH v2 3/6] migration: Check field save returns
From: |
Peter Xu |
Subject: |
Re: [Qemu-devel] [PATCH v2 3/6] migration: Check field save returns |
Date: |
Tue, 26 Sep 2017 10:42:41 +0800 |
User-agent: |
Mutt/1.5.24 (2015-08-30) |
On Mon, Sep 25, 2017 at 12:29:14PM +0100, Dr. David Alan Gilbert (git) wrote:
> From: "Dr. David Alan Gilbert" <address@hidden>
>
> Check the return values from vmstate_save_state for fields and also the
> return values from 'put' for fields that use that.
>
> Signed-off-by: Dr. David Alan Gilbert <address@hidden>
> ---
> migration/vmstate.c | 15 ++++++++++++---
> 1 file changed, 12 insertions(+), 3 deletions(-)
>
> diff --git a/migration/vmstate.c b/migration/vmstate.c
> index ae8abd3c32..848e8448c6 100644
> --- a/migration/vmstate.c
> +++ b/migration/vmstate.c
> @@ -347,6 +347,7 @@ int vmstate_save_state(QEMUFile *f, const
> VMStateDescription *vmsd,
> }
> for (i = 0; i < n_elems; i++) {
> void *curr_elem = first_elem + size * i;
> + ret = 0;
>
> vmsd_desc_field_start(vmsd, vmdesc_loop, field, i, n_elems);
> old_offset = qemu_ftell_fast(f);
> @@ -357,11 +358,19 @@ int vmstate_save_state(QEMUFile *f, const
> VMStateDescription *vmsd,
> if (!curr_elem && size) {
> /* if null pointer write placeholder and do not follow */
> assert(field->flags & VMS_ARRAY_OF_POINTER);
> - vmstate_info_nullptr.put(f, curr_elem, size, NULL, NULL);
> + ret = vmstate_info_nullptr.put(f, curr_elem, size, NULL,
> + NULL);
> } else if (field->flags & VMS_STRUCT) {
> - vmstate_save_state(f, field->vmsd, curr_elem,
> vmdesc_loop);
> + ret = vmstate_save_state(f, field->vmsd, curr_elem,
> + vmdesc_loop);
> } else {
> - field->info->put(f, curr_elem, size, field, vmdesc_loop);
> + ret = field->info->put(f, curr_elem, size, field,
> + vmdesc_loop);
> + }
> + if (ret) {
> + error_report("Save of field %s/%s failed",
> + vmsd->name, field->name);
I would prefer to prefix the function name (also there is one
error_report in previous patch) but that's optional.
Reviewed-by: Peter Xu <address@hidden>
> + return ret;
> }
>
> written_bytes = qemu_ftell_fast(f) - old_offset;
> --
> 2.13.5
>
--
Peter Xu
- [Qemu-devel] [PATCH v2 0/6] migration: let pre_save fail, Dr. David Alan Gilbert (git), 2017/09/25
- [Qemu-devel] [PATCH v2 2/6] migration: check pre_save return in vmstate_save_state, Dr. David Alan Gilbert (git), 2017/09/25
- [Qemu-devel] [PATCH v2 3/6] migration: Check field save returns, Dr. David Alan Gilbert (git), 2017/09/25
- [Qemu-devel] [PATCH v2 1/6] migration: pre_save return int, Dr. David Alan Gilbert (git), 2017/09/25
- Re: [Qemu-devel] [PATCH v2 1/6] migration: pre_save return int, Peter Xu, 2017/09/25
- Re: [Qemu-devel] [PATCH v2 1/6] migration: pre_save return int, Cornelia Huck, 2017/09/26
- Re: [Qemu-devel] [PATCH v2 1/6] migration: pre_save return int, Juan Quintela, 2017/09/27
- [Qemu-devel] [PATCH v2 4/6] migration: wire vmstate_save_state errors up to vmstate_subsection_save, Dr. David Alan Gilbert (git), 2017/09/25