On 02/15/2013 07:46 PM, Paolo Bonzini wrote:
> Always use qemu_file_get_error to detect errors, since that is how
> QEMUFile itself drops I/O after an error occurs.  There is no need
> to propagate and check return values all the time.
> 
> Also remove the "complete" member, since we know that it is set (via
> migrate_fd_cleanup) only when the state changes.
> 
> Signed-off-by: Paolo Bonzini <pbonz...@redhat.com>
> ---
>  include/migration/migration.h |    1 -
>  migration.c                   |   46 ++++++++++++----------------------------
>  2 files changed, 14 insertions(+), 33 deletions(-)
> 
> diff --git a/include/migration/migration.h b/include/migration/migration.h
> index a8c9639..4928642 100644
> --- a/include/migration/migration.h
> +++ b/include/migration/migration.h
> @@ -53,7 +53,6 @@ struct MigrationState
>      int64_t dirty_pages_rate;
>      bool enabled_capabilities[MIGRATION_CAPABILITY_MAX];
>      int64_t xbzrle_cache_size;
> -    bool complete;
>  };
>  
>  void process_incoming_migration(QEMUFile *f);
> diff --git a/migration.c b/migration.c
> index 6834d61..75dd38a 100644
> --- a/migration.c
> +++ b/migration.c
> @@ -525,6 +525,10 @@ static void buffered_flush(MigrationState *s)
>  
>      DPRINTF("flushing %zu byte(s) of data\n", s->buffer_size);
>  
> +    if (qemu_file_get_error(s->file)) {
> +        s->buffer_size = 0;
> +        return;
> +    }
>      qemu_fflush(s->file);
>  
>      while (s->bytes_xfer < s->xfer_limit && offset < s->buffer_size) {
> @@ -592,7 +596,6 @@ static int buffered_close(void *opaque)
>      while (!qemu_file_get_error(s->file) && s->buffer_size) {
>          buffered_flush(s);
>      }
> -    s->complete = true;
>      return migrate_fd_close(s);
>  }
>  
> @@ -655,37 +658,21 @@ static void *buffered_file_thread(void *opaque)
>      int64_t initial_time = qemu_get_clock_ms(rt_clock);
>      int64_t max_size = 0;
>      bool last_round = false;
> -    int ret;
>  
>      qemu_mutex_lock_iothread();
>      DPRINTF("beginning savevm\n");
> -    ret = qemu_savevm_state_begin(s->file, &s->params);
> -    qemu_mutex_unlock_iothread();
> +    qemu_savevm_state_begin(s->file, &s->params);
>  
> -    while (ret >= 0) {
> +    while (s->state == MIG_STATE_ACTIVE) {
>          int64_t current_time = qemu_get_clock_ms(rt_clock);
>          uint64_t pending_size;
>  
> -        qemu_mutex_lock_iothread();
> -        if (s->state != MIG_STATE_ACTIVE) {
> -            DPRINTF("put_ready returning because of non-active state\n");
> -            qemu_mutex_unlock_iothread();
> -            break;
> -        }
> -        if (s->complete) {
> -            qemu_mutex_unlock_iothread();
> -            break;
> -        }
>          if (s->bytes_xfer < s->xfer_limit) {
>              DPRINTF("iterate\n");
>              pending_size = qemu_savevm_state_pending(s->file, max_size);
>              DPRINTF("pending size %lu max %lu\n", pending_size, max_size);
>              if (pending_size && pending_size >= max_size) {
> -                ret = qemu_savevm_state_iterate(s->file);
> -                if (ret < 0) {
> -                    qemu_mutex_unlock_iothread();
> -                    break;
> -                }
> +                qemu_savevm_state_iterate(s->file);
>              } else {
>                  int old_vm_running = runstate_is_running();
>                  int64_t start_time, end_time;
> @@ -694,13 +681,8 @@ static void *buffered_file_thread(void *opaque)
>                  start_time = qemu_get_clock_ms(rt_clock);
>                  qemu_system_wakeup_request(QEMU_WAKEUP_REASON_OTHER);
>                  vm_stop_force_state(RUN_STATE_FINISH_MIGRATE);
> -                ret = qemu_savevm_state_complete(s->file);
> -                if (ret < 0) {
> -                    qemu_mutex_unlock_iothread();
> -                    break;
> -                } else {
> -                    migrate_fd_completed(s);
> -                }
> +                qemu_savevm_state_complete(s->file);
> +                migrate_fd_completed(s);
>                  end_time = qemu_get_clock_ms(rt_clock);
>                  s->total_time = end_time - s->total_time;
>                  s->downtime = end_time - start_time;
> @@ -731,12 +713,13 @@ static void *buffered_file_thread(void *opaque)
>              g_usleep((initial_time + BUFFER_DELAY - current_time)*1000);
>          }
>          buffered_flush(s);
> -        ret = qemu_file_get_error(s->file);
> +        qemu_mutex_lock_iothread();
> +        if (qemu_file_get_error(s->file)) {
> +            migrate_fd_error(s);
> +        }
>      }
>  
> -    if (ret < 0) {
> -        migrate_fd_error(s);
> -    }
> +    qemu_mutex_unlock_iothread();
>      g_free(s->buffer);
>      return NULL;
>  }
> @@ -759,7 +742,6 @@ void migrate_fd_connect(MigrationState *s)
>      s->buffer_capacity = 0;
>  
>      s->xfer_limit = s->bandwidth_limit / XFER_LIMIT_RATIO;
> -    s->complete = false;
>  
>      s->file = qemu_fopen_ops(s, &buffered_file_ops);
>  
> 
Reviewed-by: Orit Wasserman <owass...@redhat.com>

Reply via email to