xref: /qemu/include/ui/spice-display.h (revision 2e1a98c9c1b90ca093278c6b43244dc46604d7b7)
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 
22e0c64d08SGerd Hoffmann #include "qemu-thread.h"
2307536094SGerd Hoffmann #include "console.h"
24a3e22260SGerd Hoffmann #include "pflib.h"
251dfb4dd9SLuiz Capitulino #include "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 
35a3e22260SGerd Hoffmann #define NUM_SURFACES 1024
36a3e22260SGerd Hoffmann 
375ff4e36cSAlon Levy /*
385ff4e36cSAlon Levy  * Internal enum to differenciate between options for
395ff4e36cSAlon Levy  * io calls that have a sync (old) version and an _async (new)
405ff4e36cSAlon Levy  * version:
415ff4e36cSAlon Levy  *  QXL_SYNC: use the old version
425ff4e36cSAlon Levy  *  QXL_ASYNC: use the new version and make sure there are no two
435ff4e36cSAlon Levy  *   happening at the same time. This is used for guest initiated
445ff4e36cSAlon Levy  *   calls
455ff4e36cSAlon Levy  */
465ff4e36cSAlon Levy typedef enum qxl_async_io {
475ff4e36cSAlon Levy     QXL_SYNC,
485ff4e36cSAlon Levy     QXL_ASYNC,
495ff4e36cSAlon Levy } qxl_async_io;
505ff4e36cSAlon Levy 
51*2e1a98c9SAlon Levy enum {
52*2e1a98c9SAlon Levy     QXL_COOKIE_TYPE_IO,
53*2e1a98c9SAlon Levy };
54*2e1a98c9SAlon Levy 
55*2e1a98c9SAlon Levy typedef struct QXLCookie {
56*2e1a98c9SAlon Levy     int      type;
57*2e1a98c9SAlon Levy     uint64_t io;
58*2e1a98c9SAlon Levy     union {
59*2e1a98c9SAlon Levy         uint32_t surface_id;
60*2e1a98c9SAlon Levy     } u;
61*2e1a98c9SAlon Levy } QXLCookie;
62*2e1a98c9SAlon Levy 
63*2e1a98c9SAlon Levy QXLCookie *qxl_cookie_new(int type, uint64_t io);
64*2e1a98c9SAlon Levy 
65e0c64d08SGerd Hoffmann typedef struct SimpleSpiceDisplay SimpleSpiceDisplay;
66e0c64d08SGerd Hoffmann typedef struct SimpleSpiceUpdate SimpleSpiceUpdate;
67e0c64d08SGerd Hoffmann 
68e0c64d08SGerd Hoffmann struct SimpleSpiceDisplay {
69a3e22260SGerd Hoffmann     DisplayState *ds;
70a3e22260SGerd Hoffmann     void *buf;
71a3e22260SGerd Hoffmann     int bufsize;
72a3e22260SGerd Hoffmann     QXLWorker *worker;
73a3e22260SGerd Hoffmann     QXLInstance qxl;
74a3e22260SGerd Hoffmann     uint32_t unique;
75a3e22260SGerd Hoffmann     QemuPfConv *conv;
76a3e22260SGerd Hoffmann 
77a3e22260SGerd Hoffmann     QXLRect dirty;
78a3e22260SGerd Hoffmann     int notify;
79a3e22260SGerd Hoffmann     int running;
80a3e22260SGerd Hoffmann 
81e0c64d08SGerd Hoffmann     /*
82e0c64d08SGerd Hoffmann      * All struct members below this comment can be accessed from
83e0c64d08SGerd Hoffmann      * both spice server and qemu (iothread) context and any access
84e0c64d08SGerd Hoffmann      * to them must be protected by the lock.
85e0c64d08SGerd Hoffmann      */
86e0c64d08SGerd Hoffmann     QemuMutex lock;
87e0c64d08SGerd Hoffmann     SimpleSpiceUpdate *update;
8807536094SGerd Hoffmann     QEMUCursor *cursor;
8907536094SGerd Hoffmann     int mouse_x, mouse_y;
90e0c64d08SGerd Hoffmann };
91e0c64d08SGerd Hoffmann 
92e0c64d08SGerd Hoffmann struct SimpleSpiceUpdate {
93a3e22260SGerd Hoffmann     QXLDrawable drawable;
94a3e22260SGerd Hoffmann     QXLImage image;
95a3e22260SGerd Hoffmann     QXLCommandExt ext;
96a3e22260SGerd Hoffmann     uint8_t *bitmap;
97e0c64d08SGerd Hoffmann };
98a3e22260SGerd Hoffmann 
99a3e22260SGerd Hoffmann int qemu_spice_rect_is_empty(const QXLRect* r);
100a3e22260SGerd Hoffmann void qemu_spice_rect_union(QXLRect *dest, const QXLRect *r);
101a3e22260SGerd Hoffmann 
102a3e22260SGerd Hoffmann void qemu_spice_destroy_update(SimpleSpiceDisplay *sdpy, SimpleSpiceUpdate *update);
103a3e22260SGerd Hoffmann void qemu_spice_create_host_memslot(SimpleSpiceDisplay *ssd);
104a3e22260SGerd Hoffmann void qemu_spice_create_host_primary(SimpleSpiceDisplay *ssd);
105a3e22260SGerd Hoffmann void qemu_spice_destroy_host_primary(SimpleSpiceDisplay *ssd);
1061dfb4dd9SLuiz Capitulino void qemu_spice_vm_change_state_handler(void *opaque, int running,
1071dfb4dd9SLuiz Capitulino                                         RunState state);
108a963f876SGerd Hoffmann void qemu_spice_display_init_common(SimpleSpiceDisplay *ssd, DisplayState *ds);
109a3e22260SGerd Hoffmann 
110a3e22260SGerd Hoffmann void qemu_spice_display_update(SimpleSpiceDisplay *ssd,
111a3e22260SGerd Hoffmann                                int x, int y, int w, int h);
112a3e22260SGerd Hoffmann void qemu_spice_display_resize(SimpleSpiceDisplay *ssd);
113a3e22260SGerd Hoffmann void qemu_spice_display_refresh(SimpleSpiceDisplay *ssd);
114bb5a8cd5SAlon Levy void qemu_spice_cursor_refresh_unlocked(SimpleSpiceDisplay *ssd);
1155c59d118SGerd Hoffmann 
1165ff4e36cSAlon Levy void qemu_spice_add_memslot(SimpleSpiceDisplay *ssd, QXLDevMemSlot *memslot,
1175ff4e36cSAlon Levy                             qxl_async_io async);
1185c59d118SGerd Hoffmann void qemu_spice_del_memslot(SimpleSpiceDisplay *ssd, uint32_t gid,
1195c59d118SGerd Hoffmann                             uint32_t sid);
1205c59d118SGerd Hoffmann void qemu_spice_create_primary_surface(SimpleSpiceDisplay *ssd, uint32_t id,
1215ff4e36cSAlon Levy                                        QXLDevSurfaceCreate *surface,
1225ff4e36cSAlon Levy                                        qxl_async_io async);
1235ff4e36cSAlon Levy void qemu_spice_destroy_primary_surface(SimpleSpiceDisplay *ssd,
1245ff4e36cSAlon Levy                                         uint32_t id, qxl_async_io async);
1255c59d118SGerd Hoffmann void qemu_spice_wakeup(SimpleSpiceDisplay *ssd);
1265c59d118SGerd Hoffmann void qemu_spice_start(SimpleSpiceDisplay *ssd);
1275c59d118SGerd Hoffmann void qemu_spice_stop(SimpleSpiceDisplay *ssd);
128