All of lore.kernel.org
 help / color / mirror / Atom feed
From: Pavel Hrdina <phrdina@redhat.com>
To: Luiz Capitulino <lcapitulino@redhat.com>
Cc: qemu-devel@nongnu.org
Subject: Re: [Qemu-devel] [PATCH 12/18] savevm: add error parameter to qemu_loadvm_state()
Date: Thu, 06 Sep 2012 10:33:01 +0200	[thread overview]
Message-ID: <50485FBD.2030203@redhat.com> (raw)
In-Reply-To: <20120830140917.419a80f5@doriath.home>

On 08/30/2012 07:09 PM, Luiz Capitulino wrote:
> On Wed, 15 Aug 2012 09:41:53 +0200
> Pavel Hrdina <phrdina@redhat.com> wrote:
>
>> Signed-off-by: Pavel Hrdina <phrdina@redhat.com>
>> ---
>>   migration.c |  2 +-
>>   savevm.c    | 44 ++++++++++++++++++++++++++++----------------
>>   sysemu.h    |  3 ++-
>>   3 files changed, 31 insertions(+), 18 deletions(-)
>>
>> diff --git a/migration.c b/migration.c
>> index ec2f267..f048faf 100644
>> --- a/migration.c
>> +++ b/migration.c
>> @@ -88,7 +88,7 @@ int qemu_start_incoming_migration(const char *uri, Error **errp)
>>   
>>   void process_incoming_migration(QEMUFile *f)
>>   {
>> -    if (qemu_loadvm_state(f) < 0) {
>> +    if (qemu_loadvm_state(f, NULL) < 0) {
>>           fprintf(stderr, "load of migration failed\n");
>>           exit(0);
>>       }
>> diff --git a/savevm.c b/savevm.c
>> index 0d54115..500eb72 100644
>> --- a/savevm.c
>> +++ b/savevm.c
>> @@ -1916,7 +1916,8 @@ typedef struct LoadStateEntry {
>>       int version_id;
>>   } LoadStateEntry;
>>   
>> -int qemu_loadvm_state(QEMUFile *f)
>> +int qemu_loadvm_state(QEMUFile *f,
>> +                      Error **errp)
>>   {
>>       QLIST_HEAD(, LoadStateEntry) loadvm_handlers =
>>           QLIST_HEAD_INITIALIZER(loadvm_handlers);
>> @@ -1925,21 +1926,26 @@ int qemu_loadvm_state(QEMUFile *f)
>>       unsigned int v;
>>       int ret;
>>   
>> -    if (qemu_savevm_state_blocked(NULL)) {
>> -        return -EINVAL;
>> +    if (qemu_savevm_state_blocked(errp)) {
>> +        return -ENOTSUP;
>>       }
>>   
>>       v = qemu_get_be32(f);
>> -    if (v != QEMU_VM_FILE_MAGIC)
>> +    if (v != QEMU_VM_FILE_MAGIC) {
>> +        error_set(errp, ERROR_CLASS_GENERIC_ERROR,
>> +                  "Unknown vm-state file magic");
>>           return -EINVAL;
>> +    }
>>   
>>       v = qemu_get_be32(f);
>>       if (v == QEMU_VM_FILE_VERSION_COMPAT) {
>> -        fprintf(stderr, "SaveVM v2 format is obsolete and don't work anymore\n");
>> +        error_set(errp, QERR_NOT_SUPPORTED);
>>           return -ENOTSUP;
>>       }
>> -    if (v != QEMU_VM_FILE_VERSION)
>> +    if (v != QEMU_VM_FILE_VERSION) {
>> +        error_set(errp, QERR_NOT_SUPPORTED);
>>           return -ENOTSUP;
>> +    }
>>   
>>       while ((section_type = qemu_get_byte(f)) != QEMU_VM_EOF) {
>>           uint32_t instance_id, version_id, section_id;
>> @@ -1961,15 +1967,18 @@ int qemu_loadvm_state(QEMUFile *f)
>>               /* Find savevm section */
>>               se = find_se(idstr, instance_id);
>>               if (se == NULL) {
>> -                fprintf(stderr, "Unknown savevm section or instance '%s' %d\n", idstr, instance_id);
>> +                error_set(errp, ERROR_CLASS_GENERIC_ERROR,
>> +                          "Unknown savevm section or instance '%s' %d",
>> +                          idstr, instance_id);
>>                   ret = -EINVAL;
>>                   goto out;
>>               }
>>   
>>               /* Validate version */
>>               if (version_id > se->version_id) {
>> -                fprintf(stderr, "savevm: unsupported version %d for '%s' v%d\n",
>> -                        version_id, idstr, se->version_id);
>> +                error_set(errp, ERROR_CLASS_GENERIC_ERROR,
>> +                          "savevm: unsupported version %d for '%s' v%d",
>> +                          version_id, idstr, se->version_id);
>>                   ret = -EINVAL;
>>                   goto out;
>>               }
>> @@ -1984,8 +1993,7 @@ int qemu_loadvm_state(QEMUFile *f)
>>   
>>               ret = vmstate_load(f, le->se, le->version_id);
>>               if (ret < 0) {
>> -                fprintf(stderr, "qemu: warning: error while loading state for instance 0x%x of device '%s'\n",
>> -                        instance_id, idstr);
>> +                error_set(errp, QERR_GENERIC_ERROR, ret);
>>                   goto out;
>>               }
>>               break;
>> @@ -1999,20 +2007,21 @@ int qemu_loadvm_state(QEMUFile *f)
>>                   }
>>               }
>>               if (le == NULL) {
>> -                fprintf(stderr, "Unknown savevm section %d\n", section_id);
>> +                error_set(errp, ERROR_CLASS_GENERIC_ERROR,
>> +                          "Unknown savevm section %d", section_id);
> You sure that this error message will be printed to the terminal? This has
> to be done by the caller.

While loading snapshot yes, but while migrating no. I think, that we 
should rewrite migration error propagation too.
>
>>                   ret = -EINVAL;
>>                   goto out;
>>               }
>>   
>>               ret = vmstate_load(f, le->se, le->version_id);
>>               if (ret < 0) {
>> -                fprintf(stderr, "qemu: warning: error while loading state section id %d\n",
>> -                        section_id);
>> +                error_set(errp, QERR_GENERIC_ERROR, ret);
>>                   goto out;
>>               }
>>               break;
>>           default:
>> -            fprintf(stderr, "Unknown savevm section type %d\n", section_type);
>> +            error_set(errp, ERROR_CLASS_GENERIC_ERROR,
>> +                      "Unknown savevm section type %d", section_type);
>>               ret = -EINVAL;
>>               goto out;
>>           }
>> @@ -2030,6 +2039,9 @@ out:
>>   
>>       if (ret == 0) {
>>           ret = qemu_file_get_error(f);
>> +        if (ret < 0) {
>> +            error_set(errp, QERR_GENERIC_ERROR, ret);
>> +        }
>>       }
>>   
>>       return ret;
>> @@ -2297,7 +2309,7 @@ int load_vmstate(const char *name)
>>       }
>>   
>>       qemu_system_reset(VMRESET_SILENT);
>> -    ret = qemu_loadvm_state(f);
>> +    ret = qemu_loadvm_state(f, NULL);
>>   
>>       qemu_fclose(f);
>>       if (ret < 0) {
>> diff --git a/sysemu.h b/sysemu.h
>> index 35d6d67..651d96e 100644
>> --- a/sysemu.h
>> +++ b/sysemu.h
>> @@ -85,7 +85,8 @@ int qemu_savevm_state_iterate(QEMUFile *f,
>>   int qemu_savevm_state_complete(QEMUFile *f,
>>                                  Error **errp);
>>   void qemu_savevm_state_cancel(QEMUFile *f);
>> -int qemu_loadvm_state(QEMUFile *f);
>> +int qemu_loadvm_state(QEMUFile *f,
>> +                      Error **errp);
>>   
>>   /* SLIRP */
>>   void do_info_slirp(Monitor *mon);

  reply	other threads:[~2012-09-06  8:33 UTC|newest]

Thread overview: 41+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2012-08-15  7:41 [Qemu-devel] [PATCH 00/18] qapi: Convert savevm, loadvm, delvm and info snapshots Pavel Hrdina
2012-08-15  7:41 ` [Qemu-devel] [PATCH 01/18] qerror: introduce QERR_GENERIC_ERROR Pavel Hrdina
2012-08-30 12:11   ` Luiz Capitulino
2012-09-06  8:34     ` Pavel Hrdina
2012-08-15  7:41 ` [Qemu-devel] [PATCH 02/18] block: add error parameter to bdrv_snapshot_create() and related functions Pavel Hrdina
2012-08-30 14:47   ` Luiz Capitulino
2012-08-31  6:26     ` Markus Armbruster
2012-08-31 12:18       ` Kevin Wolf
2012-08-31 13:13         ` Luiz Capitulino
2012-08-31 13:09       ` Luiz Capitulino
2012-09-06  9:07     ` Pavel Hrdina
2012-09-10 17:03       ` Luiz Capitulino
2012-08-15  7:41 ` [Qemu-devel] [PATCH 03/18] block: add error parameter to bdrv_snapshot_goto() " Pavel Hrdina
2012-08-30 15:07   ` Luiz Capitulino
2012-08-15  7:41 ` [Qemu-devel] [PATCH 04/18] block: add error parameter to bdrv_snapshot_delete() " Pavel Hrdina
2012-08-15  7:41 ` [Qemu-devel] [PATCH 05/18] block: add error parameter to bdrv_snapshot_list() " Pavel Hrdina
2012-08-15  7:41 ` [Qemu-devel] [PATCH 06/18] block: add error parameter to bdrv_snapshot_find() Pavel Hrdina
2012-08-15  7:41 ` [Qemu-devel] [PATCH 07/18] block: add error parameter to del_existing_snapshots() Pavel Hrdina
2012-08-15  7:41 ` [Qemu-devel] [PATCH 08/18] savevm: add error parameter to qemu_savevm_state_begin() Pavel Hrdina
2012-08-15  7:41 ` [Qemu-devel] [PATCH 09/18] savevm: add error parameter to qemu_savevm_state_iterate() Pavel Hrdina
2012-08-15  7:41 ` [Qemu-devel] [PATCH 10/18] savevm: add error parameter to qemu_savevm_state_complete() Pavel Hrdina
2012-08-15  7:41 ` [Qemu-devel] [PATCH 11/18] savevm: add error parameter to qemu_savevm_state() Pavel Hrdina
2012-08-15  7:41 ` [Qemu-devel] [PATCH 12/18] savevm: add error parameter to qemu_loadvm_state() Pavel Hrdina
2012-08-30 17:09   ` Luiz Capitulino
2012-09-06  8:33     ` Pavel Hrdina [this message]
2012-08-15  7:41 ` [Qemu-devel] [PATCH 13/18] qapi: Convert savevm Pavel Hrdina
2012-08-15 19:49   ` Eric Blake
2012-08-16 10:16     ` Pavel Hrdina
2012-08-15  7:41 ` [Qemu-devel] [PATCH 14/18] qapi: Convert loadvm Pavel Hrdina
2012-08-16  3:31   ` Eric Blake
2012-08-16  4:34     ` Eric Blake
2012-08-15  7:41 ` [Qemu-devel] [PATCH 15/18] qapi: Convert delvm Pavel Hrdina
2012-08-15  7:41 ` [Qemu-devel] [PATCH 16/18] qapi: Convert info snapshots Pavel Hrdina
2012-08-16  4:36   ` Eric Blake
2012-08-16 10:17     ` Pavel Hrdina
2012-08-15  7:41 ` [Qemu-devel] [PATCH 17/18] hmp: allow "bool" parameter to be optional Pavel Hrdina
2012-08-16  4:39   ` Eric Blake
2012-08-15  7:41 ` [Qemu-devel] [PATCH 18/18] vm-snapshot-save: add force parameter Pavel Hrdina
2012-08-16  5:00   ` Eric Blake
2012-08-16 10:19     ` Pavel Hrdina
2012-08-30 17:15 ` [Qemu-devel] [PATCH 00/18] qapi: Convert savevm, loadvm, delvm and info snapshots Luiz Capitulino

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=50485FBD.2030203@redhat.com \
    --to=phrdina@redhat.com \
    --cc=lcapitulino@redhat.com \
    --cc=qemu-devel@nongnu.org \
    /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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.