2 * Copyright (C) 2010 Red Hat, Inc.
4 * This program is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU General Public License as
6 * published by the Free Software Foundation; either version 2 or
7 * (at your option) version 3 of the License.
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, see <http://www.gnu.org/licenses/>.
18 #include <spice/ipc_ring.h>
19 #include <spice/enums.h>
20 #include <spice/qxl_dev.h>
22 #include "qemu-thread.h"
27 #define NUM_MEMSLOTS 8
28 #define MEMSLOT_GENERATION_BITS 8
29 #define MEMSLOT_SLOT_BITS 8
31 #define MEMSLOT_GROUP_HOST 0
32 #define MEMSLOT_GROUP_GUEST 1
33 #define NUM_MEMSLOTS_GROUPS 2
35 #define NUM_SURFACES 1024
38 * Internal enum to differenciate between options for
39 * io calls that have a sync (old) version and an _async (new)
41 * QXL_SYNC: use the old version
42 * QXL_ASYNC: use the new version and make sure there are no two
43 * happening at the same time. This is used for guest initiated
46 typedef enum qxl_async_io
{
53 QXL_COOKIE_TYPE_RENDER_UPDATE_AREA
,
56 typedef struct QXLCookie
{
69 QXLCookie
*qxl_cookie_new(int type
, uint64_t io
);
71 typedef struct SimpleSpiceDisplay SimpleSpiceDisplay
;
72 typedef struct SimpleSpiceUpdate SimpleSpiceUpdate
;
74 struct SimpleSpiceDisplay
{
88 * All struct members below this comment can be accessed from
89 * both spice server and qemu (iothread) context and any access
90 * to them must be protected by the lock.
93 SimpleSpiceUpdate
*update
;
98 struct SimpleSpiceUpdate
{
105 int qemu_spice_rect_is_empty(const QXLRect
* r
);
106 void qemu_spice_rect_union(QXLRect
*dest
, const QXLRect
*r
);
108 void qemu_spice_destroy_update(SimpleSpiceDisplay
*sdpy
, SimpleSpiceUpdate
*update
);
109 void qemu_spice_create_host_memslot(SimpleSpiceDisplay
*ssd
);
110 void qemu_spice_create_host_primary(SimpleSpiceDisplay
*ssd
);
111 void qemu_spice_destroy_host_primary(SimpleSpiceDisplay
*ssd
);
112 void qemu_spice_vm_change_state_handler(void *opaque
, int running
,
114 void qemu_spice_display_init_common(SimpleSpiceDisplay
*ssd
, DisplayState
*ds
);
116 void qemu_spice_display_update(SimpleSpiceDisplay
*ssd
,
117 int x
, int y
, int w
, int h
);
118 void qemu_spice_display_resize(SimpleSpiceDisplay
*ssd
);
119 void qemu_spice_display_refresh(SimpleSpiceDisplay
*ssd
);
120 void qemu_spice_cursor_refresh_unlocked(SimpleSpiceDisplay
*ssd
);
122 void qemu_spice_add_memslot(SimpleSpiceDisplay
*ssd
, QXLDevMemSlot
*memslot
,
124 void qemu_spice_del_memslot(SimpleSpiceDisplay
*ssd
, uint32_t gid
,
126 void qemu_spice_create_primary_surface(SimpleSpiceDisplay
*ssd
, uint32_t id
,
127 QXLDevSurfaceCreate
*surface
,
129 void qemu_spice_destroy_primary_surface(SimpleSpiceDisplay
*ssd
,
130 uint32_t id
, qxl_async_io async
);
131 void qemu_spice_wakeup(SimpleSpiceDisplay
*ssd
);
132 void qemu_spice_start(SimpleSpiceDisplay
*ssd
);
133 void qemu_spice_stop(SimpleSpiceDisplay
*ssd
);