xref: /qemu/include/ui/spice-display.h (revision 1de7afc984b49af164e2619e6850b9732b173b34)
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 
22*1de7afc9SPaolo Bonzini #include "qemu/thread.h"
2328ecbaeeSPaolo Bonzini #include "ui/qemu-pixman.h"
241dfb4dd9SLuiz Capitulino #include "sysemu.h"
25a3e22260SGerd Hoffmann 
26a3e22260SGerd Hoffmann #define NUM_MEMSLOTS 8
27a3e22260SGerd Hoffmann #define MEMSLOT_GENERATION_BITS 8
28a3e22260SGerd Hoffmann #define MEMSLOT_SLOT_BITS 8
29a3e22260SGerd Hoffmann 
30a3e22260SGerd Hoffmann #define MEMSLOT_GROUP_HOST  0
31a3e22260SGerd Hoffmann #define MEMSLOT_GROUP_GUEST 1
32a3e22260SGerd Hoffmann #define NUM_MEMSLOTS_GROUPS 2
33a3e22260SGerd Hoffmann 
345ff4e36cSAlon Levy /*
355ff4e36cSAlon Levy  * Internal enum to differenciate between options for
365ff4e36cSAlon Levy  * io calls that have a sync (old) version and an _async (new)
375ff4e36cSAlon Levy  * version:
385ff4e36cSAlon Levy  *  QXL_SYNC: use the old version
395ff4e36cSAlon Levy  *  QXL_ASYNC: use the new version and make sure there are no two
405ff4e36cSAlon Levy  *   happening at the same time. This is used for guest initiated
415ff4e36cSAlon Levy  *   calls
425ff4e36cSAlon Levy  */
435ff4e36cSAlon Levy typedef enum qxl_async_io {
445ff4e36cSAlon Levy     QXL_SYNC,
455ff4e36cSAlon Levy     QXL_ASYNC,
465ff4e36cSAlon Levy } qxl_async_io;
475ff4e36cSAlon Levy 
482e1a98c9SAlon Levy enum {
492e1a98c9SAlon Levy     QXL_COOKIE_TYPE_IO,
5081fb6f15SAlon Levy     QXL_COOKIE_TYPE_RENDER_UPDATE_AREA,
51020af1c4SAlon Levy     QXL_COOKIE_TYPE_POST_LOAD_MONITORS_CONFIG,
522e1a98c9SAlon Levy };
532e1a98c9SAlon Levy 
542e1a98c9SAlon Levy typedef struct QXLCookie {
552e1a98c9SAlon Levy     int      type;
562e1a98c9SAlon Levy     uint64_t io;
572e1a98c9SAlon Levy     union {
582e1a98c9SAlon Levy         uint32_t surface_id;
5981fb6f15SAlon Levy         QXLRect area;
6081fb6f15SAlon Levy         struct {
6181fb6f15SAlon Levy             QXLRect area;
6281fb6f15SAlon Levy             int redraw;
6381fb6f15SAlon Levy         } render;
642e1a98c9SAlon Levy     } u;
652e1a98c9SAlon Levy } QXLCookie;
662e1a98c9SAlon Levy 
672e1a98c9SAlon Levy QXLCookie *qxl_cookie_new(int type, uint64_t io);
682e1a98c9SAlon Levy 
69e0c64d08SGerd Hoffmann typedef struct SimpleSpiceDisplay SimpleSpiceDisplay;
70e0c64d08SGerd Hoffmann typedef struct SimpleSpiceUpdate SimpleSpiceUpdate;
71e0c64d08SGerd Hoffmann 
72e0c64d08SGerd Hoffmann struct SimpleSpiceDisplay {
73a3e22260SGerd Hoffmann     DisplayState *ds;
74a3e22260SGerd Hoffmann     void *buf;
75a3e22260SGerd Hoffmann     int bufsize;
76a3e22260SGerd Hoffmann     QXLWorker *worker;
77a3e22260SGerd Hoffmann     QXLInstance qxl;
78a3e22260SGerd Hoffmann     uint32_t unique;
79d9a86569SGerd Hoffmann     pixman_image_t *surface;
80d9a86569SGerd Hoffmann     pixman_image_t *mirror;
81ddd8fdc7SGerd Hoffmann     int32_t num_surfaces;
82a3e22260SGerd Hoffmann 
83a3e22260SGerd Hoffmann     QXLRect dirty;
84a3e22260SGerd Hoffmann     int notify;
85a3e22260SGerd Hoffmann 
86e0c64d08SGerd Hoffmann     /*
87e0c64d08SGerd Hoffmann      * All struct members below this comment can be accessed from
88e0c64d08SGerd Hoffmann      * both spice server and qemu (iothread) context and any access
89e0c64d08SGerd Hoffmann      * to them must be protected by the lock.
90e0c64d08SGerd Hoffmann      */
91e0c64d08SGerd Hoffmann     QemuMutex lock;
92b1af98baSGerd Hoffmann     QTAILQ_HEAD(, SimpleSpiceUpdate) updates;
9307536094SGerd Hoffmann     QEMUCursor *cursor;
9407536094SGerd Hoffmann     int mouse_x, mouse_y;
95e0c64d08SGerd Hoffmann };
96e0c64d08SGerd Hoffmann 
97e0c64d08SGerd Hoffmann struct SimpleSpiceUpdate {
98a3e22260SGerd Hoffmann     QXLDrawable drawable;
99a3e22260SGerd Hoffmann     QXLImage image;
100a3e22260SGerd Hoffmann     QXLCommandExt ext;
101a3e22260SGerd Hoffmann     uint8_t *bitmap;
102b1af98baSGerd Hoffmann     QTAILQ_ENTRY(SimpleSpiceUpdate) next;
103e0c64d08SGerd Hoffmann };
104a3e22260SGerd Hoffmann 
105a3e22260SGerd Hoffmann int qemu_spice_rect_is_empty(const QXLRect* r);
106a3e22260SGerd Hoffmann void qemu_spice_rect_union(QXLRect *dest, const QXLRect *r);
107a3e22260SGerd Hoffmann 
108a3e22260SGerd Hoffmann void qemu_spice_destroy_update(SimpleSpiceDisplay *sdpy, SimpleSpiceUpdate *update);
109a3e22260SGerd Hoffmann void qemu_spice_create_host_memslot(SimpleSpiceDisplay *ssd);
110a3e22260SGerd Hoffmann void qemu_spice_create_host_primary(SimpleSpiceDisplay *ssd);
111a3e22260SGerd Hoffmann void qemu_spice_destroy_host_primary(SimpleSpiceDisplay *ssd);
1121dfb4dd9SLuiz Capitulino void qemu_spice_vm_change_state_handler(void *opaque, int running,
1131dfb4dd9SLuiz Capitulino                                         RunState state);
114a963f876SGerd Hoffmann void qemu_spice_display_init_common(SimpleSpiceDisplay *ssd, DisplayState *ds);
115a3e22260SGerd Hoffmann 
116a3e22260SGerd Hoffmann void qemu_spice_display_update(SimpleSpiceDisplay *ssd,
117a3e22260SGerd Hoffmann                                int x, int y, int w, int h);
118a3e22260SGerd Hoffmann void qemu_spice_display_resize(SimpleSpiceDisplay *ssd);
119a3e22260SGerd Hoffmann void qemu_spice_display_refresh(SimpleSpiceDisplay *ssd);
120bb5a8cd5SAlon Levy void qemu_spice_cursor_refresh_unlocked(SimpleSpiceDisplay *ssd);
1215c59d118SGerd Hoffmann 
1225ff4e36cSAlon Levy void qemu_spice_add_memslot(SimpleSpiceDisplay *ssd, QXLDevMemSlot *memslot,
1235ff4e36cSAlon Levy                             qxl_async_io async);
1245c59d118SGerd Hoffmann void qemu_spice_del_memslot(SimpleSpiceDisplay *ssd, uint32_t gid,
1255c59d118SGerd Hoffmann                             uint32_t sid);
1265c59d118SGerd Hoffmann void qemu_spice_create_primary_surface(SimpleSpiceDisplay *ssd, uint32_t id,
1275ff4e36cSAlon Levy                                        QXLDevSurfaceCreate *surface,
1285ff4e36cSAlon Levy                                        qxl_async_io async);
1295ff4e36cSAlon Levy void qemu_spice_destroy_primary_surface(SimpleSpiceDisplay *ssd,
1305ff4e36cSAlon Levy                                         uint32_t id, qxl_async_io async);
1315c59d118SGerd Hoffmann void qemu_spice_wakeup(SimpleSpiceDisplay *ssd);
13271d388d4SYonit Halperin void qemu_spice_display_start(void);
13371d388d4SYonit Halperin void qemu_spice_display_stop(void);
13471d388d4SYonit Halperin int qemu_spice_display_is_running(SimpleSpiceDisplay *ssd);
135