diff options
author | Gerd Hoffmann <kraxel@redhat.com> | 2010-05-11 15:23:29 +0200 |
---|---|---|
committer | Gerd Hoffmann <kraxel@redhat.com> | 2010-05-19 11:22:07 +0200 |
commit | 20da2f162af24f2dbbe0709fa986bcce8b26586c (patch) | |
tree | 0fefcb6c404539b53e64f6683f6355ad0060e3c3 /server/red_dispatcher.c | |
parent | 6bdf38daf8796a596fe992bd79b79dd312870b89 (diff) | |
download | spice-20da2f162af24f2dbbe0709fa986bcce8b26586c.tar.gz spice-20da2f162af24f2dbbe0709fa986bcce8b26586c.tar.xz spice-20da2f162af24f2dbbe0709fa986bcce8b26586c.zip |
replace worker load/save with loadvm_commands, allow keeping surface content
Add worker->loadvm_commands. qemu will uses this to send a series of
commands needed to restore state after savevm/loadvm and migration.
That will be one create-surface command per surface and one cursor-set
command for the local pointer.
The worker->save/load functions are not needed any more.
Likewise the interface->{get,set}_save_data callbacks.
Surfaces created via loadvm_commands *will* not be cleared. Also
primary surfaces are not cleared any more (unconditionally, although
we could do that conditionally on loadvm using the flags field in
QXLSurfaceCreate).
Diffstat (limited to 'server/red_dispatcher.c')
-rw-r--r-- | server/red_dispatcher.c | 29 |
1 files changed, 11 insertions, 18 deletions
diff --git a/server/red_dispatcher.c b/server/red_dispatcher.c index 3d1d6f98..2d23cbe1 100644 --- a/server/red_dispatcher.c +++ b/server/red_dispatcher.c @@ -345,40 +345,34 @@ static void qxl_worker_oom(QXLWorker *qxl_worker) } } -static void qxl_worker_save(QXLWorker *qxl_worker) +static void qxl_worker_start(QXLWorker *qxl_worker) { RedDispatcher *dispatcher = (RedDispatcher *)qxl_worker; - RedWorkeMessage message = RED_WORKER_MESSAGE_SAVE; + RedWorkeMessage message = RED_WORKER_MESSAGE_START; write_message(dispatcher->channel, &message); - read_message(dispatcher->channel, &message); - ASSERT(message == RED_WORKER_MESSAGE_READY); } -static void qxl_worker_load(QXLWorker *qxl_worker) +static void qxl_worker_stop(QXLWorker *qxl_worker) { RedDispatcher *dispatcher = (RedDispatcher *)qxl_worker; - RedWorkeMessage message = RED_WORKER_MESSAGE_LOAD; + RedWorkeMessage message = RED_WORKER_MESSAGE_STOP; write_message(dispatcher->channel, &message); read_message(dispatcher->channel, &message); ASSERT(message == RED_WORKER_MESSAGE_READY); } -static void qxl_worker_start(QXLWorker *qxl_worker) +void qxl_worker_loadvm_commands(QXLWorker *qxl_worker, + struct QXLCommandExt *ext, uint32_t count) { RedDispatcher *dispatcher = (RedDispatcher *)qxl_worker; - RedWorkeMessage message = RED_WORKER_MESSAGE_START; - - write_message(dispatcher->channel, &message); -} - -static void qxl_worker_stop(QXLWorker *qxl_worker) -{ - RedDispatcher *dispatcher = (RedDispatcher *)qxl_worker; - RedWorkeMessage message = RED_WORKER_MESSAGE_STOP; + RedWorkeMessage message = RED_WORKER_MESSAGE_LOADVM_COMMANDS; + red_printf(""); write_message(dispatcher->channel, &message); + send_data(dispatcher->channel, &count, sizeof(uint32_t)); + send_data(dispatcher->channel, ext, sizeof(QXLCommandExt) * count); read_message(dispatcher->channel, &message); ASSERT(message == RED_WORKER_MESSAGE_READY); } @@ -506,8 +500,6 @@ RedDispatcher *red_dispatcher_init(QXLInstance *qxl) dispatcher->base.minor_version = SPICE_INTERFACE_QXL_MINOR; dispatcher->base.wakeup = qxl_worker_wakeup; dispatcher->base.oom = qxl_worker_oom; - dispatcher->base.save = qxl_worker_save; - dispatcher->base.load = qxl_worker_load; dispatcher->base.start = qxl_worker_start; dispatcher->base.stop = qxl_worker_stop; dispatcher->base.update_area = qxl_worker_update_area; @@ -521,6 +513,7 @@ RedDispatcher *red_dispatcher_init(QXLInstance *qxl) dispatcher->base.reset_image_cache = qxl_worker_reset_image_cache; dispatcher->base.reset_cursor = qxl_worker_reset_cursor; dispatcher->base.destroy_surface_wait = qxl_worker_destroy_surface_wait; + dispatcher->base.loadvm_commands = qxl_worker_loadvm_commands; qxl->st->qif->get_init_info(qxl, &init_info); |