All of lore.kernel.org
 help / color / mirror / Atom feed
From: zhanghailiang <zhang.zhanghailiang@huawei.com>
To: "Dr. David Alan Gilbert" <dgilbert@redhat.com>
Cc: aarcange@redhat.com, yamahata@private.email.ne.jp,
	quintela@redhat.com, liang.z.li@intel.com,
	peter.huangpeng@huawei.com, qemu-devel@nongnu.org,
	luis@cs.umu.se, amit.shah@redhat.com, pbonzini@redhat.com,
	david@gibson.dropbear.id.au
Subject: Re: [Qemu-devel] [PATCH v7 15/42] Return path: Source handling of return path
Date: Tue, 18 Aug 2015 19:29:02 +0800	[thread overview]
Message-ID: <55D316FE.2040500@huawei.com> (raw)
In-Reply-To: <20150818104521.GB2314@work-vm>

On 2015/8/18 18:45, Dr. David Alan Gilbert wrote:
> * zhanghailiang (zhang.zhanghailiang@huawei.com) wrote:
>> Hi Dave,
>>
>> On 2015/6/16 18:26, Dr. David Alan Gilbert (git) wrote:
>>> From: "Dr. David Alan Gilbert" <dgilbert@redhat.com>
>>>
>>> Open a return path, and handle messages that are received upon it.
>>>
>>> Signed-off-by: Dr. David Alan Gilbert <dgilbert@redhat.com>
>>> ---
>>>   include/migration/migration.h |   8 ++
>>>   migration/migration.c         | 177 +++++++++++++++++++++++++++++++++++++++++-
>>>   trace-events                  |  12 +++
>>>   3 files changed, 196 insertions(+), 1 deletion(-)
>>>
>>> diff --git a/include/migration/migration.h b/include/migration/migration.h
>>> index 36caab9..868f59a 100644
>>> --- a/include/migration/migration.h
>>> +++ b/include/migration/migration.h
>>> @@ -77,6 +77,14 @@ struct MigrationState
>>>
>>>       int state;
>>>       MigrationParams params;
>>> +
>>> +    /* State related to return path */
>>> +    struct {
>>> +        QEMUFile     *file;
>>
>> There is already a 'file' member in MigrationState,
>> and since for migration, there is only one path direction, just from source side
>> to destination side, so it is ok to use that name.
>>
>> But for post-copy and COLO, we need two-way communication,
>> So we can rename the original 'file' member of MigrationState to 'ouput_file',
>> and add a new 'input_file' member. For MigrationIncomingState struct, rename its original
>> 'file' member to 'input_file',and add a new 'output_file'.
>> IMHO, this will make things more clear.
>
> Would the following be clearer:
>

Yes, it is clearer and  more graceful :)

>    On the source make the existing migration file:
>         QEMUFile  *to_dst_file;
>    and for the return path
>         QEMUFile  *from_dst_dile;
>                             ^
                      from_dst_file

>    and then on the destination, the incoming migration stream:
>         QEMUFile  *from_src_file;
>    and then the return path on the destionation:
>         QEMUFile  *to_src_file;
>
> Dave
>
>> Thanks,
>> zhanghailiang
>>
>>
>>> +        QemuThread    rp_thread;
>>> +        bool          error;
>>> +    } rp_state;
>>> +
>>>       double mbps;
>>>       int64_t total_time;
>>>       int64_t downtime;
>>> diff --git a/migration/migration.c b/migration/migration.c
>>> index afb19a1..fb2f491 100644
>>> --- a/migration/migration.c
>>> +++ b/migration/migration.c
>>> @@ -278,6 +278,23 @@ MigrationParameters *qmp_query_migrate_parameters(Error **errp)
>>>       return params;
>>>   }
>>>
>>> +/*
>>> + * Return true if we're already in the middle of a migration
>>> + * (i.e. any of the active or setup states)
>>> + */
>>> +static bool migration_already_active(MigrationState *ms)
>>> +{
>>> +    switch (ms->state) {
>>> +    case MIGRATION_STATUS_ACTIVE:
>>> +    case MIGRATION_STATUS_SETUP:
>>> +        return true;
>>> +
>>> +    default:
>>> +        return false;
>>> +
>>> +    }
>>> +}
>>> +
>>>   static void get_xbzrle_cache_stats(MigrationInfo *info)
>>>   {
>>>       if (migrate_use_xbzrle()) {
>>> @@ -441,6 +458,21 @@ static void migrate_set_state(MigrationState *s, int old_state, int new_state)
>>>       }
>>>   }
>>>
>>> +static void migrate_fd_cleanup_src_rp(MigrationState *ms)
>>> +{
>>> +    QEMUFile *rp = ms->rp_state.file;
>>> +
>>> +    /*
>>> +     * When stuff goes wrong (e.g. failing destination) on the rp, it can get
>>> +     * cleaned up from a few threads; make sure not to do it twice in parallel
>>> +     */
>>> +    rp = atomic_cmpxchg(&ms->rp_state.file, rp, NULL);
>>> +    if (rp) {
>>> +        trace_migrate_fd_cleanup_src_rp();
>>> +        qemu_fclose(rp);
>>> +    }
>>> +}
>>> +
>>>   static void migrate_fd_cleanup(void *opaque)
>>>   {
>>>       MigrationState *s = opaque;
>>> @@ -448,6 +480,8 @@ static void migrate_fd_cleanup(void *opaque)
>>>       qemu_bh_delete(s->cleanup_bh);
>>>       s->cleanup_bh = NULL;
>>>
>>> +    migrate_fd_cleanup_src_rp(s);
>>> +
>>>       if (s->file) {
>>>           trace_migrate_fd_cleanup();
>>>           qemu_mutex_unlock_iothread();
>>> @@ -487,6 +521,11 @@ static void migrate_fd_cancel(MigrationState *s)
>>>       QEMUFile *f = migrate_get_current()->file;
>>>       trace_migrate_fd_cancel();
>>>
>>> +    if (s->rp_state.file) {
>>> +        /* shutdown the rp socket, so causing the rp thread to shutdown */
>>> +        qemu_file_shutdown(s->rp_state.file);
>>> +    }
>>> +
>>>       do {
>>>           old_state = s->state;
>>>           if (old_state != MIGRATION_STATUS_SETUP &&
>>> @@ -801,8 +840,144 @@ int64_t migrate_xbzrle_cache_size(void)
>>>       return s->xbzrle_cache_size;
>>>   }
>>>
>>> -/* migration thread support */
>>> +/*
>>> + * Something bad happened to the RP stream, mark an error
>>> + * The caller shall print something to indicate why
>>> + */
>>> +static void source_return_path_bad(MigrationState *s)
>>> +{
>>> +    s->rp_state.error = true;
>>> +    migrate_fd_cleanup_src_rp(s);
>>> +}
>>> +
>>> +/*
>>> + * Handles messages sent on the return path towards the source VM
>>> + *
>>> + */
>>> +static void *source_return_path_thread(void *opaque)
>>> +{
>>> +    MigrationState *ms = opaque;
>>> +    QEMUFile *rp = ms->rp_state.file;
>>> +    uint16_t expected_len, header_len, header_type;
>>> +    const int max_len = 512;
>>> +    uint8_t buf[max_len];
>>> +    uint32_t tmp32;
>>> +    int res;
>>> +
>>> +    trace_source_return_path_thread_entry();
>>> +    while (rp && !qemu_file_get_error(rp) &&
>>> +        migration_already_active(ms)) {
>>> +        trace_source_return_path_thread_loop_top();
>>> +        header_type = qemu_get_be16(rp);
>>> +        header_len = qemu_get_be16(rp);
>>> +
>>> +        switch (header_type) {
>>> +        case MIG_RP_MSG_SHUT:
>>> +        case MIG_RP_MSG_PONG:
>>> +            expected_len = 4;
>>> +            break;
>>> +
>>> +        default:
>>> +            error_report("RP: Received invalid message 0x%04x length 0x%04x",
>>> +                    header_type, header_len);
>>> +            source_return_path_bad(ms);
>>> +            goto out;
>>> +        }
>>>
>>> +        if (header_len > expected_len) {
>>> +            error_report("RP: Received message 0x%04x with"
>>> +                    "incorrect length %d expecting %d",
>>> +                    header_type, header_len,
>>> +                    expected_len);
>>> +            source_return_path_bad(ms);
>>> +            goto out;
>>> +        }
>>> +
>>> +        /* We know we've got a valid header by this point */
>>> +        res = qemu_get_buffer(rp, buf, header_len);
>>> +        if (res != header_len) {
>>> +            trace_source_return_path_thread_failed_read_cmd_data();
>>> +            source_return_path_bad(ms);
>>> +            goto out;
>>> +        }
>>> +
>>> +        /* OK, we have the message and the data */
>>> +        switch (header_type) {
>>> +        case MIG_RP_MSG_SHUT:
>>> +            tmp32 = be32_to_cpup((uint32_t *)buf);
>>> +            trace_source_return_path_thread_shut(tmp32);
>>> +            if (tmp32) {
>>> +                error_report("RP: Sibling indicated error %d", tmp32);
>>> +                source_return_path_bad(ms);
>>> +            }
>>> +            /*
>>> +             * We'll let the main thread deal with closing the RP
>>> +             * we could do a shutdown(2) on it, but we're the only user
>>> +             * anyway, so there's nothing gained.
>>> +             */
>>> +            goto out;
>>> +
>>> +        case MIG_RP_MSG_PONG:
>>> +            tmp32 = be32_to_cpup((uint32_t *)buf);
>>> +            trace_source_return_path_thread_pong(tmp32);
>>> +            break;
>>> +
>>> +        default:
>>> +            break;
>>> +        }
>>> +    }
>>> +    if (rp && qemu_file_get_error(rp)) {
>>> +        trace_source_return_path_thread_bad_end();
>>> +        source_return_path_bad(ms);
>>> +    }
>>> +
>>> +    trace_source_return_path_thread_end();
>>> +out:
>>> +    return NULL;
>>> +}
>>> +
>>> +__attribute__ (( unused )) /* Until later in patch series */
>>> +static int open_return_path_on_source(MigrationState *ms)
>>> +{
>>> +
>>> +    ms->rp_state.file = qemu_file_get_return_path(ms->file);
>>> +    if (!ms->rp_state.file) {
>>> +        return -1;
>>> +    }
>>> +
>>> +    trace_open_return_path_on_source();
>>> +    qemu_thread_create(&ms->rp_state.rp_thread, "return path",
>>> +                       source_return_path_thread, ms, QEMU_THREAD_JOINABLE);
>>> +
>>> +    trace_open_return_path_on_source_continue();
>>> +
>>> +    return 0;
>>> +}
>>> +
>>> +__attribute__ (( unused )) /* Until later in patch series */
>>> +/* Returns 0 if the RP was ok, otherwise there was an error on the RP */
>>> +static int await_return_path_close_on_source(MigrationState *ms)
>>> +{
>>> +    /*
>>> +     * If this is a normal exit then the destination will send a SHUT and the
>>> +     * rp_thread will exit, however if there's an error we need to cause
>>> +     * it to exit, which we can do by a shutdown.
>>> +     * (canceling must also shutdown to stop us getting stuck here if
>>> +     * the destination died at just the wrong place)
>>> +     */
>>> +    if (qemu_file_get_error(ms->file) && ms->rp_state.file) {
>>> +        qemu_file_shutdown(ms->rp_state.file);
>>> +    }
>>> +    trace_await_return_path_close_on_source_joining();
>>> +    qemu_thread_join(&ms->rp_state.rp_thread);
>>> +    trace_await_return_path_close_on_source_close();
>>> +    return ms->rp_state.error;
>>> +}
>>> +
>>> +/*
>>> + * Master migration thread on the source VM.
>>> + * It drives the migration and pumps the data down the outgoing channel.
>>> + */
>>>   static void *migration_thread(void *opaque)
>>>   {
>>>       MigrationState *s = opaque;
>>> diff --git a/trace-events b/trace-events
>>> index 5738e3f..282cde1 100644
>>> --- a/trace-events
>>> +++ b/trace-events
>>> @@ -1394,12 +1394,24 @@ flic_no_device_api(int err) "flic: no Device Contral API support %d"
>>>   flic_reset_failed(int err) "flic: reset failed %d"
>>>
>>>   # migration.c
>>> +await_return_path_close_on_source_close(void) ""
>>> +await_return_path_close_on_source_joining(void) ""
>>>   migrate_set_state(int new_state) "new state %d"
>>>   migrate_fd_cleanup(void) ""
>>> +migrate_fd_cleanup_src_rp(void) ""
>>>   migrate_fd_error(void) ""
>>>   migrate_fd_cancel(void) ""
>>>   migrate_pending(uint64_t size, uint64_t max) "pending size %" PRIu64 " max %" PRIu64
>>>   migrate_send_rp_message(int msg_type, uint16_t len) "%d: len %d"
>>> +open_return_path_on_source(void) ""
>>> +open_return_path_on_source_continue(void) ""
>>> +source_return_path_thread_bad_end(void) ""
>>> +source_return_path_thread_end(void) ""
>>> +source_return_path_thread_entry(void) ""
>>> +source_return_path_thread_failed_read_cmd_data(void) ""
>>> +source_return_path_thread_loop_top(void) ""
>>> +source_return_path_thread_pong(uint32_t val) "%x"
>>> +source_return_path_thread_shut(uint32_t val) "%x"
>>>   migrate_transferred(uint64_t tranferred, uint64_t time_spent, double bandwidth, uint64_t size) "transferred %" PRIu64 " time_spent %" PRIu64 " bandwidth %g max_size %" PRId64
>>>
>>>   # migration/rdma.c
>>>
>>
>>
> --
> Dr. David Alan Gilbert / dgilbert@redhat.com / Manchester, UK
>
> .
>

  reply	other threads:[~2015-08-18 11:30 UTC|newest]

Thread overview: 209+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-06-16 10:26 [Qemu-devel] [PATCH v7 00/42] Postcopy implementation Dr. David Alan Gilbert (git)
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 01/42] Start documenting how postcopy works Dr. David Alan Gilbert (git)
2015-06-17 11:42   ` Juan Quintela
2015-06-17 12:30     ` Dr. David Alan Gilbert
2015-06-18  7:50   ` Li, Liang Z
2015-06-18  8:10     ` Dr. David Alan Gilbert
2015-06-18  8:28     ` Paolo Bonzini
2015-06-19 17:52       ` Dr. David Alan Gilbert
2015-06-26  6:46   ` Yang Hongyang
2015-06-26  7:53     ` zhanghailiang
2015-06-26  8:00       ` Yang Hongyang
2015-06-26  8:10         ` Dr. David Alan Gilbert
2015-06-26  8:19           ` Yang Hongyang
2015-08-04  5:20   ` Amit Shah
2015-08-05 12:21     ` Dr. David Alan Gilbert
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 02/42] Provide runtime Target page information Dr. David Alan Gilbert (git)
2015-06-17 11:43   ` Juan Quintela
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 03/42] Init page sizes in qtest Dr. David Alan Gilbert (git)
2015-06-17 11:49   ` Juan Quintela
2015-07-06  6:14   ` Amit Shah
2015-08-04  5:23   ` Amit Shah
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 04/42] qemu_ram_block_from_host Dr. David Alan Gilbert (git)
2015-06-17 11:54   ` Juan Quintela
2015-07-10  8:36   ` Amit Shah
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 05/42] Add qemu_get_buffer_less_copy to avoid copies some of the time Dr. David Alan Gilbert (git)
2015-06-17 11:57   ` Juan Quintela
2015-06-17 12:33     ` Dr. David Alan Gilbert
2015-07-13  9:08   ` Amit Shah
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 06/42] Add wrapper for setting blocking status on a QEMUFile Dr. David Alan Gilbert (git)
2015-06-17 11:59   ` Juan Quintela
2015-06-17 12:34     ` Dr. David Alan Gilbert
2015-06-17 12:57       ` Juan Quintela
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 07/42] ram_debug_dump_bitmap: Dump a migration bitmap as text Dr. David Alan Gilbert (git)
2015-06-17 12:17   ` Juan Quintela
2015-06-19 17:04     ` Dr. David Alan Gilbert
2015-07-13 10:15       ` Juan Quintela
2015-07-13  9:12   ` Amit Shah
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 08/42] migrate_init: Call from savevm Dr. David Alan Gilbert (git)
2015-06-17 12:18   ` Juan Quintela
2015-07-13  9:13   ` Amit Shah
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 09/42] Rename save_live_complete to save_live_complete_precopy Dr. David Alan Gilbert (git)
2015-06-17 12:20   ` Juan Quintela
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 10/42] Return path: Open a return path on QEMUFile for sockets Dr. David Alan Gilbert (git)
2015-06-17 12:23   ` Juan Quintela
2015-06-17 17:07     ` Dr. David Alan Gilbert
2015-07-13 10:12   ` Amit Shah
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 11/42] Return path: socket_writev_buffer: Block even on non-blocking fd's Dr. David Alan Gilbert (git)
2015-06-17 12:28   ` Juan Quintela
2015-06-19 17:18     ` Dr. David Alan Gilbert
2015-07-13 12:37   ` Amit Shah
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 12/42] Migration commands Dr. David Alan Gilbert (git)
2015-06-17 12:31   ` Juan Quintela
2015-06-19 17:38     ` Dr. David Alan Gilbert
2015-07-13 12:45   ` Amit Shah
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 13/42] Return path: Control commands Dr. David Alan Gilbert (git)
2015-06-17 12:49   ` Juan Quintela
2015-06-23 18:57     ` Dr. David Alan Gilbert
2015-07-13 12:55   ` Amit Shah
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 14/42] Return path: Send responses from destination to source Dr. David Alan Gilbert (git)
2015-06-17 16:30   ` Juan Quintela
2015-06-19 18:42     ` Dr. David Alan Gilbert
2015-07-01  9:29       ` Juan Quintela
2015-08-06 12:18         ` Dr. David Alan Gilbert
2015-07-15  7:31   ` Amit Shah
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 15/42] Return path: Source handling of return path Dr. David Alan Gilbert (git)
2015-07-13 10:29   ` Juan Quintela
2015-08-18 10:23     ` Dr. David Alan Gilbert
2015-07-15  7:50   ` Amit Shah
2015-07-16 11:32     ` Dr. David Alan Gilbert
2015-08-05  8:06   ` zhanghailiang
2015-08-18 10:45     ` Dr. David Alan Gilbert
2015-08-18 11:29       ` zhanghailiang [this message]
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 16/42] Rework loadvm path for subloops Dr. David Alan Gilbert (git)
2015-07-13 10:33   ` Juan Quintela
2015-07-15  9:34   ` Amit Shah
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 17/42] Add migration-capability boolean for postcopy-ram Dr. David Alan Gilbert (git)
2015-06-16 15:43   ` Eric Blake
2015-06-16 15:58     ` Dr. David Alan Gilbert
2015-07-15  9:39       ` Amit Shah
2015-07-13 10:35   ` Juan Quintela
2015-07-15  9:40   ` Amit Shah
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 18/42] Add wrappers and handlers for sending/receiving the postcopy-ram migration messages Dr. David Alan Gilbert (git)
2015-07-13 11:02   ` Juan Quintela
2015-07-20 10:13     ` Amit Shah
2015-08-26 14:48     ` Dr. David Alan Gilbert
2015-07-20 10:06   ` Amit Shah
2015-07-27  9:55     ` Dr. David Alan Gilbert
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 19/42] MIG_CMD_PACKAGED: Send a packaged chunk of migration stream Dr. David Alan Gilbert (git)
2015-07-13 11:07   ` Juan Quintela
2015-07-21  6:11   ` Amit Shah
2015-07-27 17:28     ` Dr. David Alan Gilbert
2015-08-04  5:27   ` Amit Shah
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 20/42] Modify save_live_pending for postcopy Dr. David Alan Gilbert (git)
2015-07-13 11:12   ` Juan Quintela
2015-07-31 16:13     ` Dr. David Alan Gilbert
2015-07-21  6:17   ` Amit Shah
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 21/42] postcopy: OS support test Dr. David Alan Gilbert (git)
2015-07-13 11:20   ` Juan Quintela
2015-07-13 16:31     ` Dr. David Alan Gilbert
2015-07-21  7:29   ` Amit Shah
2015-07-27 17:38     ` Dr. David Alan Gilbert
2015-08-04  5:28   ` Amit Shah
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 22/42] migrate_start_postcopy: Command to trigger transition to postcopy Dr. David Alan Gilbert (git)
2015-07-13 11:23   ` Juan Quintela
2015-07-13 17:13     ` Dr. David Alan Gilbert
2015-07-13 18:07       ` Juan Quintela
2015-07-21  7:40         ` Amit Shah
2015-09-24  9:59           ` Dr. David Alan Gilbert
2015-09-24 14:20         ` Dr. David Alan Gilbert
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 23/42] MIGRATION_STATUS_POSTCOPY_ACTIVE: Add new migration state Dr. David Alan Gilbert (git)
2015-07-13 11:27   ` Juan Quintela
2015-07-13 15:53     ` Dr. David Alan Gilbert
2015-07-13 16:26       ` Juan Quintela
2015-07-13 16:48         ` Dr. David Alan Gilbert
2015-07-13 18:05           ` Juan Quintela
2015-07-21 10:33   ` Amit Shah
2015-09-23 17:04     ` Dr. David Alan Gilbert
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 24/42] Add qemu_savevm_state_complete_postcopy Dr. David Alan Gilbert (git)
2015-07-13 11:35   ` Juan Quintela
2015-07-13 15:33     ` Dr. David Alan Gilbert
2015-07-21 10:42   ` Amit Shah
2015-07-27 17:58     ` Dr. David Alan Gilbert
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 25/42] Postcopy: Maintain sentmap and calculate discard Dr. David Alan Gilbert (git)
2015-07-13 11:47   ` Juan Quintela
2015-09-15 17:01     ` Dr. David Alan Gilbert
2015-07-21 11:36   ` Amit Shah
2015-07-31 16:51     ` Dr. David Alan Gilbert
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 26/42] postcopy: Incoming initialisation Dr. David Alan Gilbert (git)
2015-07-13 12:04   ` Juan Quintela
2015-09-23 19:06     ` Dr. David Alan Gilbert
2015-07-22  6:19   ` Amit Shah
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 27/42] postcopy: ram_enable_notify to switch on userfault Dr. David Alan Gilbert (git)
2015-07-13 12:10   ` Juan Quintela
2015-07-13 17:36     ` Dr. David Alan Gilbert
2015-07-23  5:22   ` Amit Shah
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 28/42] Postcopy: Postcopy startup in migration thread Dr. David Alan Gilbert (git)
2015-07-13 12:56   ` Juan Quintela
2015-07-13 17:56     ` Dr. David Alan Gilbert
2015-07-13 18:09       ` Juan Quintela
2015-09-23 17:56         ` Dr. David Alan Gilbert
2015-07-23  5:53       ` Amit Shah
2015-07-23  5:55   ` Amit Shah
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 29/42] Postcopy end in migration_thread Dr. David Alan Gilbert (git)
2015-07-13 13:15   ` Juan Quintela
2015-07-23  6:41     ` Amit Shah
2015-08-04 11:31     ` Dr. David Alan Gilbert
2015-07-23  6:41   ` Amit Shah
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 30/42] Page request: Add MIG_RP_MSG_REQ_PAGES reverse command Dr. David Alan Gilbert (git)
2015-07-13 13:24   ` Juan Quintela
2015-08-06 14:15     ` Dr. David Alan Gilbert
2015-07-23  6:50   ` Amit Shah
2015-08-06 14:21     ` Dr. David Alan Gilbert
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 31/42] Page request: Process incoming page request Dr. David Alan Gilbert (git)
2015-07-14  9:18   ` Juan Quintela
2015-08-06 10:45     ` Dr. David Alan Gilbert
2015-10-20 10:29       ` Juan Quintela
2015-07-23 12:23   ` Amit Shah
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 32/42] Page request: Consume pages off the post-copy queue Dr. David Alan Gilbert (git)
2015-07-14  9:40   ` Juan Quintela
2015-09-16 18:36     ` Dr. David Alan Gilbert
2015-07-27  6:05   ` Amit Shah
2015-09-16 18:48     ` Dr. David Alan Gilbert
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 33/42] postcopy_ram.c: place_page and helpers Dr. David Alan Gilbert (git)
2015-07-14 10:05   ` Juan Quintela
2015-07-27  6:11     ` Amit Shah
2015-09-23 16:45     ` Dr. David Alan Gilbert
2015-07-27  6:11   ` Amit Shah
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 34/42] Postcopy: Use helpers to map pages during migration Dr. David Alan Gilbert (git)
2015-07-14 12:34   ` Juan Quintela
2015-07-17 17:31     ` Dr. David Alan Gilbert
2015-07-27  7:39   ` Amit Shah
2015-08-06 11:22     ` Dr. David Alan Gilbert
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 35/42] Don't sync dirty bitmaps in postcopy Dr. David Alan Gilbert (git)
2015-07-14 12:36   ` Juan Quintela
2015-07-14 13:13     ` Dr. David Alan Gilbert
2015-07-27  7:43   ` Amit Shah
2015-07-31  9:50     ` Dr. David Alan Gilbert
2015-08-04  5:46       ` Amit Shah
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 36/42] Host page!=target page: Cleanup bitmaps Dr. David Alan Gilbert (git)
2015-07-14 15:01   ` Juan Quintela
2015-07-31 15:53     ` Dr. David Alan Gilbert
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 37/42] Postcopy; Handle userfault requests Dr. David Alan Gilbert (git)
2015-07-14 15:10   ` Juan Quintela
2015-07-14 15:15     ` Dr. David Alan Gilbert
2015-07-14 15:25       ` Juan Quintela
2015-07-27 14:29   ` Amit Shah
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 38/42] Start up a postcopy/listener thread ready for incoming page data Dr. David Alan Gilbert (git)
2015-07-14 15:12   ` Juan Quintela
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 39/42] postcopy: Wire up loadvm_postcopy_handle_ commands Dr. David Alan Gilbert (git)
2015-07-14 15:14   ` Juan Quintela
2015-07-28  5:53   ` Amit Shah
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 40/42] End of migration for postcopy Dr. David Alan Gilbert (git)
2015-07-14 15:15   ` Juan Quintela
2015-07-28  5:55   ` Amit Shah
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 41/42] Disable mlock around incoming postcopy Dr. David Alan Gilbert (git)
2015-07-14 15:22   ` Juan Quintela
2015-07-28  6:02     ` Amit Shah
2015-07-28 11:32       ` Juan Quintela
2015-08-06 14:55         ` Dr. David Alan Gilbert
2015-08-07  3:05           ` zhanghailiang
2015-09-24 10:36     ` Dr. David Alan Gilbert
2015-07-28  6:02   ` Amit Shah
2015-06-16 10:26 ` [Qemu-devel] [PATCH v7 42/42] Inhibit ballooning during postcopy Dr. David Alan Gilbert (git)
2015-07-14 15:24   ` Juan Quintela
2015-07-28  6:15   ` Amit Shah
2015-07-28  9:08     ` Dr. David Alan Gilbert
2015-07-28 10:01       ` Amit Shah
2015-07-28 11:16         ` Dr. David Alan Gilbert
2015-07-28  6:21 ` [Qemu-devel] [PATCH v7 00/42] Postcopy implementation Amit Shah

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=55D316FE.2040500@huawei.com \
    --to=zhang.zhanghailiang@huawei.com \
    --cc=aarcange@redhat.com \
    --cc=amit.shah@redhat.com \
    --cc=david@gibson.dropbear.id.au \
    --cc=dgilbert@redhat.com \
    --cc=liang.z.li@intel.com \
    --cc=luis@cs.umu.se \
    --cc=pbonzini@redhat.com \
    --cc=peter.huangpeng@huawei.com \
    --cc=qemu-devel@nongnu.org \
    --cc=quintela@redhat.com \
    --cc=yamahata@private.email.ne.jp \
    /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.