1a3e22260SGerd Hoffmann /* 2a3e22260SGerd Hoffmann * Copyright (C) 2010 Red Hat, Inc. 3a3e22260SGerd Hoffmann * 4a3e22260SGerd Hoffmann * This program is free software; you can redistribute it and/or 5a3e22260SGerd Hoffmann * modify it under the terms of the GNU General Public License as 6a3e22260SGerd Hoffmann * published by the Free Software Foundation; either version 2 or 7a3e22260SGerd Hoffmann * (at your option) version 3 of the License. 8a3e22260SGerd Hoffmann * 9a3e22260SGerd Hoffmann * This program is distributed in the hope that it will be useful, 10a3e22260SGerd Hoffmann * but WITHOUT ANY WARRANTY; without even the implied warranty of 11a3e22260SGerd Hoffmann * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 12a3e22260SGerd Hoffmann * GNU General Public License for more details. 13a3e22260SGerd Hoffmann * 14a3e22260SGerd Hoffmann * You should have received a copy of the GNU General Public License 15a3e22260SGerd Hoffmann * along with this program; if not, see <http://www.gnu.org/licenses/>. 16a3e22260SGerd Hoffmann */ 17a3e22260SGerd Hoffmann 18a3e22260SGerd Hoffmann #include <spice/ipc_ring.h> 19a3e22260SGerd Hoffmann #include <spice/enums.h> 20a3e22260SGerd Hoffmann #include <spice/qxl_dev.h> 21a3e22260SGerd Hoffmann 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" 26a3e22260SGerd Hoffmann 27a3e22260SGerd Hoffmann #define NUM_MEMSLOTS 8 28a3e22260SGerd Hoffmann #define MEMSLOT_GENERATION_BITS 8 29a3e22260SGerd Hoffmann #define MEMSLOT_SLOT_BITS 8 30a3e22260SGerd Hoffmann 31a3e22260SGerd Hoffmann #define MEMSLOT_GROUP_HOST 0 32a3e22260SGerd Hoffmann #define MEMSLOT_GROUP_GUEST 1 33a3e22260SGerd Hoffmann #define NUM_MEMSLOTS_GROUPS 2 34a3e22260SGerd Hoffmann 355ff4e36cSAlon Levy /* 365ff4e36cSAlon Levy * Internal enum to differenciate between options for 375ff4e36cSAlon Levy * io calls that have a sync (old) version and an _async (new) 385ff4e36cSAlon Levy * version: 395ff4e36cSAlon Levy * QXL_SYNC: use the old version 405ff4e36cSAlon Levy * QXL_ASYNC: use the new version and make sure there are no two 415ff4e36cSAlon Levy * happening at the same time. This is used for guest initiated 425ff4e36cSAlon Levy * calls 435ff4e36cSAlon Levy */ 445ff4e36cSAlon Levy typedef enum qxl_async_io { 455ff4e36cSAlon Levy QXL_SYNC, 465ff4e36cSAlon Levy QXL_ASYNC, 475ff4e36cSAlon Levy } qxl_async_io; 485ff4e36cSAlon Levy 492e1a98c9SAlon Levy enum { 502e1a98c9SAlon Levy QXL_COOKIE_TYPE_IO, 5181fb6f15SAlon Levy QXL_COOKIE_TYPE_RENDER_UPDATE_AREA, 52020af1c4SAlon Levy QXL_COOKIE_TYPE_POST_LOAD_MONITORS_CONFIG, 532e1a98c9SAlon Levy }; 542e1a98c9SAlon Levy 552e1a98c9SAlon Levy typedef struct QXLCookie { 562e1a98c9SAlon Levy int type; 572e1a98c9SAlon Levy uint64_t io; 582e1a98c9SAlon Levy union { 592e1a98c9SAlon Levy uint32_t surface_id; 6081fb6f15SAlon Levy QXLRect area; 6181fb6f15SAlon Levy struct { 6281fb6f15SAlon Levy QXLRect area; 6381fb6f15SAlon Levy int redraw; 6481fb6f15SAlon Levy } render; 652e1a98c9SAlon Levy } u; 662e1a98c9SAlon Levy } QXLCookie; 672e1a98c9SAlon Levy 682e1a98c9SAlon Levy QXLCookie *qxl_cookie_new(int type, uint64_t io); 692e1a98c9SAlon Levy 70e0c64d08SGerd Hoffmann typedef struct SimpleSpiceDisplay SimpleSpiceDisplay; 71e0c64d08SGerd Hoffmann typedef struct SimpleSpiceUpdate SimpleSpiceUpdate; 72e0c64d08SGerd Hoffmann 73e0c64d08SGerd Hoffmann struct SimpleSpiceDisplay { 74*71874c17SGerd Hoffmann DisplaySurface *ds; 757c20b4a3SGerd Hoffmann DisplayChangeListener dcl; 76a3e22260SGerd Hoffmann void *buf; 77a3e22260SGerd Hoffmann int bufsize; 78a3e22260SGerd Hoffmann QXLWorker *worker; 79a3e22260SGerd Hoffmann QXLInstance qxl; 80a3e22260SGerd Hoffmann uint32_t unique; 81d9a86569SGerd Hoffmann pixman_image_t *surface; 82d9a86569SGerd Hoffmann pixman_image_t *mirror; 83ddd8fdc7SGerd Hoffmann int32_t num_surfaces; 84a3e22260SGerd Hoffmann 85a3e22260SGerd Hoffmann QXLRect dirty; 86a3e22260SGerd Hoffmann int notify; 87a3e22260SGerd Hoffmann 88e0c64d08SGerd Hoffmann /* 89e0c64d08SGerd Hoffmann * All struct members below this comment can be accessed from 90e0c64d08SGerd Hoffmann * both spice server and qemu (iothread) context and any access 91e0c64d08SGerd Hoffmann * to them must be protected by the lock. 92e0c64d08SGerd Hoffmann */ 93e0c64d08SGerd Hoffmann QemuMutex lock; 94b1af98baSGerd Hoffmann QTAILQ_HEAD(, SimpleSpiceUpdate) updates; 9507536094SGerd Hoffmann QEMUCursor *cursor; 9607536094SGerd Hoffmann int mouse_x, mouse_y; 97e0c64d08SGerd Hoffmann }; 98e0c64d08SGerd Hoffmann 99e0c64d08SGerd Hoffmann struct SimpleSpiceUpdate { 100a3e22260SGerd Hoffmann QXLDrawable drawable; 101a3e22260SGerd Hoffmann QXLImage image; 102a3e22260SGerd Hoffmann QXLCommandExt ext; 103a3e22260SGerd Hoffmann uint8_t *bitmap; 104b1af98baSGerd Hoffmann QTAILQ_ENTRY(SimpleSpiceUpdate) next; 105e0c64d08SGerd Hoffmann }; 106a3e22260SGerd Hoffmann 107a3e22260SGerd Hoffmann int qemu_spice_rect_is_empty(const QXLRect* r); 108a3e22260SGerd Hoffmann void qemu_spice_rect_union(QXLRect *dest, const QXLRect *r); 109a3e22260SGerd Hoffmann 110a3e22260SGerd Hoffmann void qemu_spice_destroy_update(SimpleSpiceDisplay *sdpy, SimpleSpiceUpdate *update); 111a3e22260SGerd Hoffmann void qemu_spice_create_host_memslot(SimpleSpiceDisplay *ssd); 112a3e22260SGerd Hoffmann void qemu_spice_create_host_primary(SimpleSpiceDisplay *ssd); 113a3e22260SGerd Hoffmann void qemu_spice_destroy_host_primary(SimpleSpiceDisplay *ssd); 1141dfb4dd9SLuiz Capitulino void qemu_spice_vm_change_state_handler(void *opaque, int running, 1151dfb4dd9SLuiz Capitulino RunState state); 116a963f876SGerd Hoffmann void qemu_spice_display_init_common(SimpleSpiceDisplay *ssd, DisplayState *ds); 117a3e22260SGerd Hoffmann 118a3e22260SGerd Hoffmann void qemu_spice_display_update(SimpleSpiceDisplay *ssd, 119a3e22260SGerd Hoffmann int x, int y, int w, int h); 120c12aeb86SGerd Hoffmann void qemu_spice_display_switch(SimpleSpiceDisplay *ssd, 121c12aeb86SGerd Hoffmann DisplaySurface *surface); 122a3e22260SGerd Hoffmann void qemu_spice_display_refresh(SimpleSpiceDisplay *ssd); 123bb5a8cd5SAlon Levy void qemu_spice_cursor_refresh_unlocked(SimpleSpiceDisplay *ssd); 1245c59d118SGerd Hoffmann 1255ff4e36cSAlon Levy void qemu_spice_add_memslot(SimpleSpiceDisplay *ssd, QXLDevMemSlot *memslot, 1265ff4e36cSAlon Levy qxl_async_io async); 1275c59d118SGerd Hoffmann void qemu_spice_del_memslot(SimpleSpiceDisplay *ssd, uint32_t gid, 1285c59d118SGerd Hoffmann uint32_t sid); 1295c59d118SGerd Hoffmann void qemu_spice_create_primary_surface(SimpleSpiceDisplay *ssd, uint32_t id, 1305ff4e36cSAlon Levy QXLDevSurfaceCreate *surface, 1315ff4e36cSAlon Levy qxl_async_io async); 1325ff4e36cSAlon Levy void qemu_spice_destroy_primary_surface(SimpleSpiceDisplay *ssd, 1335ff4e36cSAlon Levy uint32_t id, qxl_async_io async); 1345c59d118SGerd Hoffmann void qemu_spice_wakeup(SimpleSpiceDisplay *ssd); 13571d388d4SYonit Halperin void qemu_spice_display_start(void); 13671d388d4SYonit Halperin void qemu_spice_display_stop(void); 13771d388d4SYonit Halperin int qemu_spice_display_is_running(SimpleSpiceDisplay *ssd); 138