]> git.proxmox.com Git - qemu.git/blame - ui/spice-display.h
i82378/i82374: Do not create DMA controller twice
[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
35#define NUM_SURFACES 1024
36
5ff4e36c
AL
37/*
38 * Internal enum to differenciate between options for
39 * io calls that have a sync (old) version and an _async (new)
40 * version:
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
44 * calls
45 */
46typedef enum qxl_async_io {
47 QXL_SYNC,
48 QXL_ASYNC,
49} qxl_async_io;
50
2e1a98c9
AL
51enum {
52 QXL_COOKIE_TYPE_IO,
81fb6f15 53 QXL_COOKIE_TYPE_RENDER_UPDATE_AREA,
2e1a98c9
AL
54};
55
56typedef struct QXLCookie {
57 int type;
58 uint64_t io;
59 union {
60 uint32_t surface_id;
81fb6f15
AL
61 QXLRect area;
62 struct {
63 QXLRect area;
64 int redraw;
65 } render;
2e1a98c9
AL
66 } u;
67} QXLCookie;
68
69QXLCookie *qxl_cookie_new(int type, uint64_t io);
70
e0c64d08
GH
71typedef struct SimpleSpiceDisplay SimpleSpiceDisplay;
72typedef struct SimpleSpiceUpdate SimpleSpiceUpdate;
73
74struct SimpleSpiceDisplay {
a3e22260
GH
75 DisplayState *ds;
76 void *buf;
77 int bufsize;
78 QXLWorker *worker;
79 QXLInstance qxl;
80 uint32_t unique;
81 QemuPfConv *conv;
82
a3e22260
GH
83 QXLRect dirty;
84 int notify;
85 int running;
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;
93 SimpleSpiceUpdate *update;
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;
e0c64d08 103};
a3e22260
GH
104
105int qemu_spice_rect_is_empty(const QXLRect* r);
106void qemu_spice_rect_union(QXLRect *dest, const QXLRect *r);
107
a3e22260
GH
108void qemu_spice_destroy_update(SimpleSpiceDisplay *sdpy, SimpleSpiceUpdate *update);
109void qemu_spice_create_host_memslot(SimpleSpiceDisplay *ssd);
110void qemu_spice_create_host_primary(SimpleSpiceDisplay *ssd);
111void qemu_spice_destroy_host_primary(SimpleSpiceDisplay *ssd);
1dfb4dd9
LC
112void qemu_spice_vm_change_state_handler(void *opaque, int running,
113 RunState state);
a963f876 114void qemu_spice_display_init_common(SimpleSpiceDisplay *ssd, DisplayState *ds);
a3e22260
GH
115
116void qemu_spice_display_update(SimpleSpiceDisplay *ssd,
117 int x, int y, int w, int h);
118void qemu_spice_display_resize(SimpleSpiceDisplay *ssd);
119void qemu_spice_display_refresh(SimpleSpiceDisplay *ssd);
bb5a8cd5 120void qemu_spice_cursor_refresh_unlocked(SimpleSpiceDisplay *ssd);
5c59d118 121
5ff4e36c
AL
122void qemu_spice_add_memslot(SimpleSpiceDisplay *ssd, QXLDevMemSlot *memslot,
123 qxl_async_io async);
5c59d118
GH
124void qemu_spice_del_memslot(SimpleSpiceDisplay *ssd, uint32_t gid,
125 uint32_t sid);
126void qemu_spice_create_primary_surface(SimpleSpiceDisplay *ssd, uint32_t id,
5ff4e36c
AL
127 QXLDevSurfaceCreate *surface,
128 qxl_async_io async);
129void qemu_spice_destroy_primary_surface(SimpleSpiceDisplay *ssd,
130 uint32_t id, qxl_async_io async);
5c59d118 131void qemu_spice_wakeup(SimpleSpiceDisplay *ssd);
5c59d118
GH
132void qemu_spice_start(SimpleSpiceDisplay *ssd);
133void qemu_spice_stop(SimpleSpiceDisplay *ssd);