]> git.proxmox.com Git - qemu.git/blame - ui/spice-display.h
target-mips: Add ASE DSP multiply instructions
[qemu.git] / ui / spice-display.h
CommitLineData
a3e22260
GH
1/*
2 * Copyright (C) 2010 Red Hat, Inc.
3 *
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.
8 *
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.
13 *
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/>.
16 */
17
18#include <spice/ipc_ring.h>
19#include <spice/enums.h>
20#include <spice/qxl_dev.h>
21
e0c64d08 22#include "qemu-thread.h"
07536094 23#include "console.h"
a3e22260 24#include "pflib.h"
1dfb4dd9 25#include "sysemu.h"
a3e22260
GH
26
27#define NUM_MEMSLOTS 8
28#define MEMSLOT_GENERATION_BITS 8
29#define MEMSLOT_SLOT_BITS 8
30
31#define MEMSLOT_GROUP_HOST 0
32#define MEMSLOT_GROUP_GUEST 1
33#define NUM_MEMSLOTS_GROUPS 2
34
5ff4e36c
AL
35/*
36 * Internal enum to differenciate between options for
37 * io calls that have a sync (old) version and an _async (new)
38 * version:
39 * QXL_SYNC: use the old version
40 * QXL_ASYNC: use the new version and make sure there are no two
41 * happening at the same time. This is used for guest initiated
42 * calls
43 */
44typedef enum qxl_async_io {
45 QXL_SYNC,
46 QXL_ASYNC,
47} qxl_async_io;
48
2e1a98c9
AL
49enum {
50 QXL_COOKIE_TYPE_IO,
81fb6f15 51 QXL_COOKIE_TYPE_RENDER_UPDATE_AREA,
020af1c4 52 QXL_COOKIE_TYPE_POST_LOAD_MONITORS_CONFIG,
2e1a98c9
AL
53};
54
55typedef struct QXLCookie {
56 int type;
57 uint64_t io;
58 union {
59 uint32_t surface_id;
81fb6f15
AL
60 QXLRect area;
61 struct {
62 QXLRect area;
63 int redraw;
64 } render;
2e1a98c9
AL
65 } u;
66} QXLCookie;
67
68QXLCookie *qxl_cookie_new(int type, uint64_t io);
69
e0c64d08
GH
70typedef struct SimpleSpiceDisplay SimpleSpiceDisplay;
71typedef struct SimpleSpiceUpdate SimpleSpiceUpdate;
72
73struct SimpleSpiceDisplay {
a3e22260 74 DisplayState *ds;
a7310dd3 75 uint8_t *ds_mirror;
a3e22260
GH
76 void *buf;
77 int bufsize;
78 QXLWorker *worker;
79 QXLInstance qxl;
80 uint32_t unique;
81 QemuPfConv *conv;
ddd8fdc7 82 int32_t num_surfaces;
a3e22260 83
a3e22260
GH
84 QXLRect dirty;
85 int notify;
a3e22260 86
e0c64d08
GH
87 /*
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.
91 */
92 QemuMutex lock;
b1af98ba 93 QTAILQ_HEAD(, SimpleSpiceUpdate) updates;
07536094
GH
94 QEMUCursor *cursor;
95 int mouse_x, mouse_y;
e0c64d08
GH
96};
97
98struct SimpleSpiceUpdate {
a3e22260
GH
99 QXLDrawable drawable;
100 QXLImage image;
101 QXLCommandExt ext;
102 uint8_t *bitmap;
b1af98ba 103 QTAILQ_ENTRY(SimpleSpiceUpdate) next;
e0c64d08 104};
a3e22260
GH
105
106int qemu_spice_rect_is_empty(const QXLRect* r);
107void qemu_spice_rect_union(QXLRect *dest, const QXLRect *r);
108
a3e22260
GH
109void qemu_spice_destroy_update(SimpleSpiceDisplay *sdpy, SimpleSpiceUpdate *update);
110void qemu_spice_create_host_memslot(SimpleSpiceDisplay *ssd);
111void qemu_spice_create_host_primary(SimpleSpiceDisplay *ssd);
112void qemu_spice_destroy_host_primary(SimpleSpiceDisplay *ssd);
1dfb4dd9
LC
113void qemu_spice_vm_change_state_handler(void *opaque, int running,
114 RunState state);
a963f876 115void qemu_spice_display_init_common(SimpleSpiceDisplay *ssd, DisplayState *ds);
a3e22260
GH
116
117void qemu_spice_display_update(SimpleSpiceDisplay *ssd,
118 int x, int y, int w, int h);
119void qemu_spice_display_resize(SimpleSpiceDisplay *ssd);
120void qemu_spice_display_refresh(SimpleSpiceDisplay *ssd);
bb5a8cd5 121void qemu_spice_cursor_refresh_unlocked(SimpleSpiceDisplay *ssd);
5c59d118 122
5ff4e36c
AL
123void qemu_spice_add_memslot(SimpleSpiceDisplay *ssd, QXLDevMemSlot *memslot,
124 qxl_async_io async);
5c59d118
GH
125void qemu_spice_del_memslot(SimpleSpiceDisplay *ssd, uint32_t gid,
126 uint32_t sid);
127void qemu_spice_create_primary_surface(SimpleSpiceDisplay *ssd, uint32_t id,
5ff4e36c
AL
128 QXLDevSurfaceCreate *surface,
129 qxl_async_io async);
130void qemu_spice_destroy_primary_surface(SimpleSpiceDisplay *ssd,
131 uint32_t id, qxl_async_io async);
5c59d118 132void qemu_spice_wakeup(SimpleSpiceDisplay *ssd);
71d388d4
YH
133void qemu_spice_display_start(void);
134void qemu_spice_display_stop(void);
71d388d4 135int qemu_spice_display_is_running(SimpleSpiceDisplay *ssd);