128ecbaeeSPaolo Bonzini /* 228ecbaeeSPaolo Bonzini * Copyright (C) 2010 Red Hat, Inc. 328ecbaeeSPaolo Bonzini * 428ecbaeeSPaolo Bonzini * This program is free software; you can redistribute it and/or 528ecbaeeSPaolo Bonzini * modify it under the terms of the GNU General Public License as 628ecbaeeSPaolo Bonzini * published by the Free Software Foundation; either version 2 or 728ecbaeeSPaolo Bonzini * (at your option) version 3 of the License. 828ecbaeeSPaolo Bonzini * 928ecbaeeSPaolo Bonzini * This program is distributed in the hope that it will be useful, 1028ecbaeeSPaolo Bonzini * but WITHOUT ANY WARRANTY; without even the implied warranty of 1128ecbaeeSPaolo Bonzini * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 1228ecbaeeSPaolo Bonzini * GNU General Public License for more details. 1328ecbaeeSPaolo Bonzini * 1428ecbaeeSPaolo Bonzini * You should have received a copy of the GNU General Public License 1528ecbaeeSPaolo Bonzini * along with this program; if not, see <http://www.gnu.org/licenses/>. 1628ecbaeeSPaolo Bonzini */ 1728ecbaeeSPaolo Bonzini 1828ecbaeeSPaolo Bonzini #include <spice/ipc_ring.h> 1928ecbaeeSPaolo Bonzini #include <spice/enums.h> 2028ecbaeeSPaolo Bonzini #include <spice/qxl_dev.h> 2128ecbaeeSPaolo Bonzini 221de7afc9SPaolo Bonzini #include "qemu/thread.h" 2328ecbaeeSPaolo Bonzini #include "ui/qemu-pixman.h" 240b087861SPeter Maydell #include "ui/console.h" 259c17d615SPaolo Bonzini #include "sysemu/sysemu.h" 2628ecbaeeSPaolo Bonzini 2728ecbaeeSPaolo Bonzini #define NUM_MEMSLOTS 8 2828ecbaeeSPaolo Bonzini #define MEMSLOT_GENERATION_BITS 8 2928ecbaeeSPaolo Bonzini #define MEMSLOT_SLOT_BITS 8 3028ecbaeeSPaolo Bonzini 3128ecbaeeSPaolo Bonzini #define MEMSLOT_GROUP_HOST 0 3228ecbaeeSPaolo Bonzini #define MEMSLOT_GROUP_GUEST 1 3328ecbaeeSPaolo Bonzini #define NUM_MEMSLOTS_GROUPS 2 3428ecbaeeSPaolo Bonzini 3528ecbaeeSPaolo Bonzini /* 3628ecbaeeSPaolo Bonzini * Internal enum to differenciate between options for 3728ecbaeeSPaolo Bonzini * io calls that have a sync (old) version and an _async (new) 3828ecbaeeSPaolo Bonzini * version: 3928ecbaeeSPaolo Bonzini * QXL_SYNC: use the old version 4028ecbaeeSPaolo Bonzini * QXL_ASYNC: use the new version and make sure there are no two 4128ecbaeeSPaolo Bonzini * happening at the same time. This is used for guest initiated 4228ecbaeeSPaolo Bonzini * calls 4328ecbaeeSPaolo Bonzini */ 4428ecbaeeSPaolo Bonzini typedef enum qxl_async_io { 4528ecbaeeSPaolo Bonzini QXL_SYNC, 4628ecbaeeSPaolo Bonzini QXL_ASYNC, 4728ecbaeeSPaolo Bonzini } qxl_async_io; 4828ecbaeeSPaolo Bonzini 4928ecbaeeSPaolo Bonzini enum { 5028ecbaeeSPaolo Bonzini QXL_COOKIE_TYPE_IO, 5128ecbaeeSPaolo Bonzini QXL_COOKIE_TYPE_RENDER_UPDATE_AREA, 5228ecbaeeSPaolo Bonzini QXL_COOKIE_TYPE_POST_LOAD_MONITORS_CONFIG, 5328ecbaeeSPaolo Bonzini }; 5428ecbaeeSPaolo Bonzini 5528ecbaeeSPaolo Bonzini typedef struct QXLCookie { 5628ecbaeeSPaolo Bonzini int type; 5728ecbaeeSPaolo Bonzini uint64_t io; 5828ecbaeeSPaolo Bonzini union { 5928ecbaeeSPaolo Bonzini uint32_t surface_id; 6028ecbaeeSPaolo Bonzini QXLRect area; 6128ecbaeeSPaolo Bonzini struct { 6228ecbaeeSPaolo Bonzini QXLRect area; 6328ecbaeeSPaolo Bonzini int redraw; 6428ecbaeeSPaolo Bonzini } render; 6528ecbaeeSPaolo Bonzini } u; 6628ecbaeeSPaolo Bonzini } QXLCookie; 6728ecbaeeSPaolo Bonzini 6828ecbaeeSPaolo Bonzini QXLCookie *qxl_cookie_new(int type, uint64_t io); 6928ecbaeeSPaolo Bonzini 7028ecbaeeSPaolo Bonzini typedef struct SimpleSpiceDisplay SimpleSpiceDisplay; 7128ecbaeeSPaolo Bonzini typedef struct SimpleSpiceUpdate SimpleSpiceUpdate; 7228ecbaeeSPaolo Bonzini 7328ecbaeeSPaolo Bonzini struct SimpleSpiceDisplay { 7428ecbaeeSPaolo Bonzini DisplayState *ds; 757c20b4a3SGerd Hoffmann DisplayChangeListener dcl; 7628ecbaeeSPaolo Bonzini void *buf; 7728ecbaeeSPaolo Bonzini int bufsize; 7828ecbaeeSPaolo Bonzini QXLWorker *worker; 7928ecbaeeSPaolo Bonzini QXLInstance qxl; 8028ecbaeeSPaolo Bonzini uint32_t unique; 8128ecbaeeSPaolo Bonzini pixman_image_t *surface; 8228ecbaeeSPaolo Bonzini pixman_image_t *mirror; 8328ecbaeeSPaolo Bonzini int32_t num_surfaces; 8428ecbaeeSPaolo Bonzini 8528ecbaeeSPaolo Bonzini QXLRect dirty; 8628ecbaeeSPaolo Bonzini int notify; 8728ecbaeeSPaolo Bonzini 8828ecbaeeSPaolo Bonzini /* 8928ecbaeeSPaolo Bonzini * All struct members below this comment can be accessed from 9028ecbaeeSPaolo Bonzini * both spice server and qemu (iothread) context and any access 9128ecbaeeSPaolo Bonzini * to them must be protected by the lock. 9228ecbaeeSPaolo Bonzini */ 9328ecbaeeSPaolo Bonzini QemuMutex lock; 9428ecbaeeSPaolo Bonzini QTAILQ_HEAD(, SimpleSpiceUpdate) updates; 9528ecbaeeSPaolo Bonzini QEMUCursor *cursor; 9628ecbaeeSPaolo Bonzini int mouse_x, mouse_y; 9728ecbaeeSPaolo Bonzini }; 9828ecbaeeSPaolo Bonzini 9928ecbaeeSPaolo Bonzini struct SimpleSpiceUpdate { 10028ecbaeeSPaolo Bonzini QXLDrawable drawable; 10128ecbaeeSPaolo Bonzini QXLImage image; 10228ecbaeeSPaolo Bonzini QXLCommandExt ext; 10328ecbaeeSPaolo Bonzini uint8_t *bitmap; 10428ecbaeeSPaolo Bonzini QTAILQ_ENTRY(SimpleSpiceUpdate) next; 10528ecbaeeSPaolo Bonzini }; 10628ecbaeeSPaolo Bonzini 10728ecbaeeSPaolo Bonzini int qemu_spice_rect_is_empty(const QXLRect* r); 10828ecbaeeSPaolo Bonzini void qemu_spice_rect_union(QXLRect *dest, const QXLRect *r); 10928ecbaeeSPaolo Bonzini 11028ecbaeeSPaolo Bonzini void qemu_spice_destroy_update(SimpleSpiceDisplay *sdpy, SimpleSpiceUpdate *update); 11128ecbaeeSPaolo Bonzini void qemu_spice_create_host_memslot(SimpleSpiceDisplay *ssd); 11228ecbaeeSPaolo Bonzini void qemu_spice_create_host_primary(SimpleSpiceDisplay *ssd); 11328ecbaeeSPaolo Bonzini void qemu_spice_destroy_host_primary(SimpleSpiceDisplay *ssd); 11428ecbaeeSPaolo Bonzini void qemu_spice_vm_change_state_handler(void *opaque, int running, 11528ecbaeeSPaolo Bonzini RunState state); 11628ecbaeeSPaolo Bonzini void qemu_spice_display_init_common(SimpleSpiceDisplay *ssd, DisplayState *ds); 11728ecbaeeSPaolo Bonzini 11828ecbaeeSPaolo Bonzini void qemu_spice_display_update(SimpleSpiceDisplay *ssd, 11928ecbaeeSPaolo Bonzini int x, int y, int w, int h); 120*c12aeb86SGerd Hoffmann void qemu_spice_display_switch(SimpleSpiceDisplay *ssd, 121*c12aeb86SGerd Hoffmann DisplaySurface *surface); 12228ecbaeeSPaolo Bonzini void qemu_spice_display_refresh(SimpleSpiceDisplay *ssd); 12328ecbaeeSPaolo Bonzini void qemu_spice_cursor_refresh_unlocked(SimpleSpiceDisplay *ssd); 12428ecbaeeSPaolo Bonzini 12528ecbaeeSPaolo Bonzini void qemu_spice_add_memslot(SimpleSpiceDisplay *ssd, QXLDevMemSlot *memslot, 12628ecbaeeSPaolo Bonzini qxl_async_io async); 12728ecbaeeSPaolo Bonzini void qemu_spice_del_memslot(SimpleSpiceDisplay *ssd, uint32_t gid, 12828ecbaeeSPaolo Bonzini uint32_t sid); 12928ecbaeeSPaolo Bonzini void qemu_spice_create_primary_surface(SimpleSpiceDisplay *ssd, uint32_t id, 13028ecbaeeSPaolo Bonzini QXLDevSurfaceCreate *surface, 13128ecbaeeSPaolo Bonzini qxl_async_io async); 13228ecbaeeSPaolo Bonzini void qemu_spice_destroy_primary_surface(SimpleSpiceDisplay *ssd, 13328ecbaeeSPaolo Bonzini uint32_t id, qxl_async_io async); 13428ecbaeeSPaolo Bonzini void qemu_spice_wakeup(SimpleSpiceDisplay *ssd); 13528ecbaeeSPaolo Bonzini void qemu_spice_display_start(void); 13628ecbaeeSPaolo Bonzini void qemu_spice_display_stop(void); 13728ecbaeeSPaolo Bonzini int qemu_spice_display_is_running(SimpleSpiceDisplay *ssd); 138