blob: 8da81b8d6eba60088f3bd065b3be0d95d640aa76 [file] [log] [blame]
aliguori19a490b2009-03-06 20:27:13 +00001/*
2 * QEMU VNC display driver
3 *
4 * Copyright (C) 2006 Anthony Liguori <anthony@codemonkey.ws>
5 * Copyright (C) 2006 Fabrice Bellard
6 * Copyright (C) 2009 Red Hat, Inc
7 *
8 * Permission is hereby granted, free of charge, to any person obtaining a copy
9 * of this software and associated documentation files (the "Software"), to deal
10 * in the Software without restriction, including without limitation the rights
11 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
12 * copies of the Software, and to permit persons to whom the Software is
13 * furnished to do so, subject to the following conditions:
14 *
15 * The above copyright notice and this permission notice shall be included in
16 * all copies or substantial portions of the Software.
17 *
18 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
21 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
22 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
23 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
24 * THE SOFTWARE.
25 */
26
27#ifndef __QEMU_VNC_H
28#define __QEMU_VNC_H
29
30#include "qemu-common.h"
Paolo Bonzini1de7afc2012-12-17 18:20:00 +010031#include "qemu/queue.h"
32#include "qemu/thread.h"
Paolo Bonzini28ecbae2012-11-28 12:06:30 +010033#include "ui/console.h"
Paolo Bonzini83c90892012-12-17 18:19:49 +010034#include "monitor/monitor.h"
aliguori19a490b2009-03-06 20:27:13 +000035#include "audio/audio.h"
Paolo Bonzini1de7afc2012-12-17 18:20:00 +010036#include "qemu/bitmap.h"
aliguori19a490b2009-03-06 20:27:13 +000037#include <zlib.h>
Corentin Chary6f9c78c2010-07-07 20:57:51 +020038#include <stdbool.h>
aliguori19a490b2009-03-06 20:27:13 +000039
aliguori19a490b2009-03-06 20:27:13 +000040#include "keymaps.h"
Corentin Chary148954f2011-02-04 09:06:01 +010041#include "vnc-palette.h"
42#include "vnc-enc-zrle.h"
aliguori19a490b2009-03-06 20:27:13 +000043
aliguori5fb6c7a2009-03-06 20:27:23 +000044// #define _VNC_DEBUG 1
45
46#ifdef _VNC_DEBUG
47#define VNC_DEBUG(fmt, ...) do { fprintf(stderr, fmt, ## __VA_ARGS__); } while (0)
48#else
49#define VNC_DEBUG(fmt, ...) do { } while (0)
50#endif
51
aliguori19a490b2009-03-06 20:27:13 +000052/*****************************************************************************
53 *
54 * Core data structures
55 *
56 *****************************************************************************/
57
58typedef struct Buffer
59{
60 size_t capacity;
61 size_t offset;
62 uint8_t *buffer;
63} Buffer;
64
65typedef struct VncState VncState;
Corentin Charybd023f92010-07-07 20:58:02 +020066typedef struct VncJob VncJob;
67typedef struct VncRect VncRect;
68typedef struct VncRectEntry VncRectEntry;
aliguori19a490b2009-03-06 20:27:13 +000069
70typedef int VncReadEvent(VncState *vs, uint8_t *data, size_t len);
71
Gerd Hoffmann9f649162012-10-10 13:29:43 +020072typedef void VncWritePixels(VncState *vs, void *data, int size);
aliguori19a490b2009-03-06 20:27:13 +000073
74typedef void VncSendHextileTile(VncState *vs,
75 int x, int y, int w, int h,
76 void *last_bg,
77 void *last_fg,
78 int *has_bg, int *has_fg);
79
Stefan Weil23bfe282011-03-03 21:37:55 +010080/* VNC_MAX_WIDTH must be a multiple of 16. */
Brian Jackson3f54bfb2010-02-08 14:22:29 -060081#define VNC_MAX_WIDTH 2560
aliguori19a490b2009-03-06 20:27:13 +000082#define VNC_MAX_HEIGHT 2048
Stefan Weil23bfe282011-03-03 21:37:55 +010083
Peter Lievenb4c85dd2014-01-08 10:08:33 +010084/* VNC_DIRTY_PIXELS_PER_BIT is the number of dirty pixels represented
85 * by one bit in the dirty bitmap */
86#define VNC_DIRTY_PIXELS_PER_BIT 16
87
Stefan Weil23bfe282011-03-03 21:37:55 +010088/* VNC_DIRTY_BITS is the number of bits in the dirty bitmap. */
Peter Lievenb4c85dd2014-01-08 10:08:33 +010089#define VNC_DIRTY_BITS (VNC_MAX_WIDTH / VNC_DIRTY_PIXELS_PER_BIT)
aliguori19a490b2009-03-06 20:27:13 +000090
Peter Lieven12b316d2014-01-08 10:08:35 +010091/* VNC_DIRTY_BPL (BPL = bits per line) might be greater than
92 * VNC_DIRTY_BITS due to alignment */
93#define VNC_DIRTY_BPL(x) (sizeof((x)->dirty) / VNC_MAX_HEIGHT * BITS_PER_BYTE)
94
Corentin Chary999342a2011-02-04 09:05:55 +010095#define VNC_STAT_RECT 64
96#define VNC_STAT_COLS (VNC_MAX_WIDTH / VNC_STAT_RECT)
97#define VNC_STAT_ROWS (VNC_MAX_HEIGHT / VNC_STAT_RECT)
98
aliguori19a490b2009-03-06 20:27:13 +000099#define VNC_AUTH_CHALLENGE_SIZE 16
100
101typedef struct VncDisplay VncDisplay;
102
aliguori5fb6c7a2009-03-06 20:27:23 +0000103#ifdef CONFIG_VNC_TLS
104#include "vnc-tls.h"
105#include "vnc-auth-vencrypt.h"
106#endif
aliguori2f9606b2009-03-06 20:27:28 +0000107#ifdef CONFIG_VNC_SASL
108#include "vnc-auth-sasl.h"
109#endif
Tim Hardeck7536ee42013-01-21 11:04:44 +0100110#ifdef CONFIG_VNC_WS
111#include "vnc-ws.h"
112#endif
aliguori2f9606b2009-03-06 20:27:28 +0000113
Corentin Chary999342a2011-02-04 09:05:55 +0100114struct VncRectStat
115{
116 /* time of last 10 updates, to find update frequency */
117 struct timeval times[10];
118 int idx;
119
120 double freq; /* Update frequency (in Hz) */
121 bool updated; /* Already updated during this refresh */
122};
123
124typedef struct VncRectStat VncRectStat;
125
Stefano Stabellini1fc62412009-08-03 10:54:32 +0100126struct VncSurface
127{
Corentin Chary999342a2011-02-04 09:05:55 +0100128 struct timeval last_freq_check;
Stefan Weil23bfe282011-03-03 21:37:55 +0100129 DECLARE_BITMAP(dirty[VNC_MAX_HEIGHT], VNC_MAX_WIDTH / 16);
Corentin Chary999342a2011-02-04 09:05:55 +0100130 VncRectStat stats[VNC_STAT_ROWS][VNC_STAT_COLS];
Gerd Hoffmann9f649162012-10-10 13:29:43 +0200131 pixman_image_t *fb;
132 pixman_format_code_t format;
Stefano Stabellini1fc62412009-08-03 10:54:32 +0100133};
aliguori5fb6c7a2009-03-06 20:27:23 +0000134
Gerd Hoffmann8cf36482011-11-24 18:10:49 +0100135typedef enum VncShareMode {
136 VNC_SHARE_MODE_CONNECTING = 1,
137 VNC_SHARE_MODE_SHARED,
138 VNC_SHARE_MODE_EXCLUSIVE,
139 VNC_SHARE_MODE_DISCONNECTED,
140} VncShareMode;
141
142typedef enum VncSharePolicy {
143 VNC_SHARE_POLICY_IGNORE = 1,
144 VNC_SHARE_POLICY_ALLOW_EXCLUSIVE,
145 VNC_SHARE_POLICY_FORCE_SHARED,
146} VncSharePolicy;
147
aliguori19a490b2009-03-06 20:27:13 +0000148struct VncDisplay
149{
Amit Shah41b4bef2010-02-05 16:34:05 +0530150 QTAILQ_HEAD(, VncState) clients;
Gerd Hoffmann8cf36482011-11-24 18:10:49 +0100151 int num_exclusive;
152 VncSharePolicy share_policy;
aliguori19a490b2009-03-06 20:27:13 +0000153 int lsock;
Tim Hardeck7536ee42013-01-21 11:04:44 +0100154#ifdef CONFIG_VNC_WS
155 int lwebsock;
156 bool websocket;
157 char *ws_display;
158#endif
Gerd Hoffmannd39fa6d2013-02-28 17:16:48 +0100159 DisplaySurface *ds;
Gerd Hoffmann21ef45d2013-02-28 11:34:31 +0100160 DisplayChangeListener dcl;
Anthony Liguoric227f092009-10-01 16:12:16 -0500161 kbd_layout_t *kbd_layout;
Gerd Hoffmann3a0558b2010-03-10 17:12:02 +0100162 int lock_key_sync;
Corentin Charybd023f92010-07-07 20:58:02 +0200163 QemuMutex mutex;
aliguori19a490b2009-03-06 20:27:13 +0000164
Gerd Hoffmannd467b672010-05-21 11:54:34 +0200165 QEMUCursor *cursor;
166 int cursor_msize;
167 uint8_t *cursor_mask;
168
Stefano Stabellini1fc62412009-08-03 10:54:32 +0100169 struct VncSurface guest; /* guest visible surface (aka ds->surface) */
Gerd Hoffmann9f649162012-10-10 13:29:43 +0200170 pixman_image_t *server; /* vnc server surface */
Stefano Stabellini1fc62412009-08-03 10:54:32 +0100171
aliguori19a490b2009-03-06 20:27:13 +0000172 char *display;
173 char *password;
Gerd Hoffmann3c9405a2010-10-07 11:50:45 +0200174 time_t expires;
aliguori19a490b2009-03-06 20:27:13 +0000175 int auth;
Corentin Chary6f9c78c2010-07-07 20:57:51 +0200176 bool lossy;
Corentin Chary80e0c8c2011-02-04 09:06:08 +0100177 bool non_adaptive;
aliguori19a490b2009-03-06 20:27:13 +0000178#ifdef CONFIG_VNC_TLS
aliguori5fb6c7a2009-03-06 20:27:23 +0000179 int subauth; /* Used by VeNCrypt */
180 VncDisplayTLS tls;
aliguori19a490b2009-03-06 20:27:13 +0000181#endif
aliguori76655d62009-03-06 20:27:37 +0000182#ifdef CONFIG_VNC_SASL
183 VncDisplaySASL sasl;
184#endif
aliguori19a490b2009-03-06 20:27:13 +0000185};
186
Corentin Charyd1af0e02010-07-07 20:57:59 +0200187typedef struct VncTight {
188 int type;
189 uint8_t quality;
190 uint8_t compression;
191 uint8_t pixel24;
192 Buffer tight;
193 Buffer tmp;
194 Buffer zlib;
195 Buffer gradient;
196#ifdef CONFIG_VNC_JPEG
197 Buffer jpeg;
198#endif
199#ifdef CONFIG_VNC_PNG
200 Buffer png;
201#endif
202 int levels[4];
203 z_stream stream[4];
204} VncTight;
205
206typedef struct VncHextile {
207 VncSendHextileTile *send_tile;
208} VncHextile;
209
210typedef struct VncZlib {
211 Buffer zlib;
212 Buffer tmp;
213 z_stream stream;
214 int level;
215} VncZlib;
216
Corentin Chary148954f2011-02-04 09:06:01 +0100217typedef struct VncZrle {
218 int type;
219 Buffer fb;
220 Buffer zrle;
221 Buffer tmp;
222 Buffer zlib;
223 z_stream stream;
224 VncPalette palette;
225} VncZrle;
226
227typedef struct VncZywrle {
228 int buf[VNC_ZRLE_TILE_WIDTH * VNC_ZRLE_TILE_HEIGHT];
229} VncZywrle;
230
Corentin Charybd023f92010-07-07 20:58:02 +0200231struct VncRect
232{
233 int x;
234 int y;
235 int w;
236 int h;
237};
238
239struct VncRectEntry
240{
241 struct VncRect rect;
242 QLIST_ENTRY(VncRectEntry) next;
243};
244
245struct VncJob
246{
247 VncState *vs;
248
249 QLIST_HEAD(, VncRectEntry) rectangles;
250 QTAILQ_ENTRY(VncJob) next;
251};
Corentin Charybd023f92010-07-07 20:58:02 +0200252
aliguori19a490b2009-03-06 20:27:13 +0000253struct VncState
254{
aliguori19a490b2009-03-06 20:27:13 +0000255 int csock;
aliguori6baebed2009-03-20 15:59:14 +0000256
Stefan Weil23bfe282011-03-03 21:37:55 +0100257 DECLARE_BITMAP(dirty[VNC_MAX_HEIGHT], VNC_DIRTY_BITS);
Corentin Chary7d964c92011-02-04 09:05:56 +0100258 uint8_t **lossy_rect; /* Not an Array to avoid costly memcpy in
259 * vnc-jobs-async.c */
aliguori6baebed2009-03-20 15:59:14 +0000260
aliguori19a490b2009-03-06 20:27:13 +0000261 VncDisplay *vd;
262 int need_update;
aliguoric522d0e2009-03-20 15:59:24 +0000263 int force_update;
aliguori19a490b2009-03-06 20:27:13 +0000264 uint32_t features;
265 int absolute;
266 int last_x;
267 int last_y;
Gerd Hoffmann14768eb2013-12-02 15:17:45 +0100268 uint32_t last_bmask;
Gerd Hoffmann5862d192010-05-25 18:25:18 +0200269 int client_width;
270 int client_height;
Gerd Hoffmann8cf36482011-11-24 18:10:49 +0100271 VncShareMode share_mode;
aliguori19a490b2009-03-06 20:27:13 +0000272
273 uint32_t vnc_encoding;
aliguori19a490b2009-03-06 20:27:13 +0000274
275 int major;
276 int minor;
277
Daniel P. Berrange7e7e2eb2011-06-23 13:31:41 +0100278 int auth;
aliguori19a490b2009-03-06 20:27:13 +0000279 char challenge[VNC_AUTH_CHALLENGE_SIZE];
aliguori19a490b2009-03-06 20:27:13 +0000280#ifdef CONFIG_VNC_TLS
Daniel P. Berrange7e7e2eb2011-06-23 13:31:41 +0100281 int subauth; /* Used by VeNCrypt */
aliguori5fb6c7a2009-03-06 20:27:23 +0000282 VncStateTLS tls;
aliguori19a490b2009-03-06 20:27:13 +0000283#endif
aliguori2f9606b2009-03-06 20:27:28 +0000284#ifdef CONFIG_VNC_SASL
285 VncStateSASL sasl;
286#endif
Tim Hardeck7536ee42013-01-21 11:04:44 +0100287#ifdef CONFIG_VNC_WS
Tim Hardeck0057a0d2013-04-23 16:33:01 +0200288#ifdef CONFIG_VNC_TLS
289 VncStateTLS ws_tls;
290#endif /* CONFIG_VNC_TLS */
Tim Hardeck7536ee42013-01-21 11:04:44 +0100291 bool encode_ws;
292 bool websocket;
Tim Hardeck0057a0d2013-04-23 16:33:01 +0200293#endif /* CONFIG_VNC_WS */
aliguori19a490b2009-03-06 20:27:13 +0000294
Luiz Capitulino4a80dba2010-01-14 14:50:56 -0200295 QObject *info;
296
aliguori19a490b2009-03-06 20:27:13 +0000297 Buffer output;
298 Buffer input;
Tim Hardeck7536ee42013-01-21 11:04:44 +0100299#ifdef CONFIG_VNC_WS
300 Buffer ws_input;
301 Buffer ws_output;
302#endif
aliguori19a490b2009-03-06 20:27:13 +0000303 /* current output mode information */
304 VncWritePixels *write_pixels;
Gerd Hoffmann9f649162012-10-10 13:29:43 +0200305 PixelFormat client_pf;
306 pixman_format_code_t client_format;
307 bool client_be;
aliguori19a490b2009-03-06 20:27:13 +0000308
309 CaptureVoiceOut *audio_cap;
310 struct audsettings as;
311
312 VncReadEvent *read_handler;
313 size_t read_handler_expect;
314 /* input */
315 uint8_t modifiers_state[256];
Gerd Hoffmann7ffb82c2010-02-26 17:17:39 +0100316 QEMUPutLEDEntry *led;
aliguori19a490b2009-03-06 20:27:13 +0000317
Corentin Charybd023f92010-07-07 20:58:02 +0200318 bool abort;
Tim Hardeck6fd8e792013-01-21 11:04:45 +0100319 bool initialized;
Corentin Charybd023f92010-07-07 20:58:02 +0200320 QemuMutex output_mutex;
Corentin Chary175b2a62012-03-14 07:58:47 +0100321 QEMUBH *bh;
322 Buffer jobs_buffer;
Corentin Charybd023f92010-07-07 20:58:02 +0200323
324 /* Encoding specific, if you add something here, don't forget to
325 * update vnc_async_encoding_start()
326 */
Corentin Charyd1af0e02010-07-07 20:57:59 +0200327 VncTight tight;
328 VncZlib zlib;
329 VncHextile hextile;
Corentin Chary148954f2011-02-04 09:06:01 +0100330 VncZrle zrle;
331 VncZywrle zywrle;
aliguori19a490b2009-03-06 20:27:13 +0000332
Anthony Liguori37c34d92010-03-10 09:38:29 -0600333 Notifier mouse_mode_notifier;
334
Amit Shah41b4bef2010-02-05 16:34:05 +0530335 QTAILQ_ENTRY(VncState) next;
aliguori19a490b2009-03-06 20:27:13 +0000336};
337
aliguorie06679f2009-02-02 15:58:25 +0000338
339/*****************************************************************************
340 *
341 * Authentication modes
342 *
343 *****************************************************************************/
344
345enum {
346 VNC_AUTH_INVALID = 0,
347 VNC_AUTH_NONE = 1,
348 VNC_AUTH_VNC = 2,
349 VNC_AUTH_RA2 = 5,
350 VNC_AUTH_RA2NE = 6,
351 VNC_AUTH_TIGHT = 16,
352 VNC_AUTH_ULTRA = 17,
aliguori2f9606b2009-03-06 20:27:28 +0000353 VNC_AUTH_TLS = 18, /* Supported in GTK-VNC & VINO */
354 VNC_AUTH_VENCRYPT = 19, /* Supported in GTK-VNC & VeNCrypt */
355 VNC_AUTH_SASL = 20, /* Supported in GTK-VNC & VINO */
aliguorie06679f2009-02-02 15:58:25 +0000356};
357
aliguorie06679f2009-02-02 15:58:25 +0000358enum {
359 VNC_AUTH_VENCRYPT_PLAIN = 256,
360 VNC_AUTH_VENCRYPT_TLSNONE = 257,
361 VNC_AUTH_VENCRYPT_TLSVNC = 258,
362 VNC_AUTH_VENCRYPT_TLSPLAIN = 259,
363 VNC_AUTH_VENCRYPT_X509NONE = 260,
364 VNC_AUTH_VENCRYPT_X509VNC = 261,
365 VNC_AUTH_VENCRYPT_X509PLAIN = 262,
aliguori2f9606b2009-03-06 20:27:28 +0000366 VNC_AUTH_VENCRYPT_X509SASL = 263,
367 VNC_AUTH_VENCRYPT_TLSSASL = 264,
aliguorie06679f2009-02-02 15:58:25 +0000368};
369
aliguorie06679f2009-02-02 15:58:25 +0000370
371/*****************************************************************************
372 *
373 * Encoding types
374 *
375 *****************************************************************************/
376
377#define VNC_ENCODING_RAW 0x00000000
378#define VNC_ENCODING_COPYRECT 0x00000001
379#define VNC_ENCODING_RRE 0x00000002
380#define VNC_ENCODING_CORRE 0x00000004
381#define VNC_ENCODING_HEXTILE 0x00000005
382#define VNC_ENCODING_ZLIB 0x00000006
383#define VNC_ENCODING_TIGHT 0x00000007
384#define VNC_ENCODING_ZLIBHEX 0x00000008
385#define VNC_ENCODING_TRLE 0x0000000f
386#define VNC_ENCODING_ZRLE 0x00000010
387#define VNC_ENCODING_ZYWRLE 0x00000011
388#define VNC_ENCODING_COMPRESSLEVEL0 0xFFFFFF00 /* -256 */
389#define VNC_ENCODING_QUALITYLEVEL0 0xFFFFFFE0 /* -32 */
390#define VNC_ENCODING_XCURSOR 0xFFFFFF10 /* -240 */
391#define VNC_ENCODING_RICH_CURSOR 0xFFFFFF11 /* -239 */
392#define VNC_ENCODING_POINTER_POS 0xFFFFFF18 /* -232 */
393#define VNC_ENCODING_LASTRECT 0xFFFFFF20 /* -224 */
394#define VNC_ENCODING_DESKTOPRESIZE 0xFFFFFF21 /* -223 */
395#define VNC_ENCODING_POINTER_TYPE_CHANGE 0XFFFFFEFF /* -257 */
396#define VNC_ENCODING_EXT_KEY_EVENT 0XFFFFFEFE /* -258 */
397#define VNC_ENCODING_AUDIO 0XFFFFFEFD /* -259 */
Corentin Charyefe556a2010-07-07 20:57:56 +0200398#define VNC_ENCODING_TIGHT_PNG 0xFFFFFEFC /* -260 */
Lei Liab99e5c2013-04-25 13:29:10 +0800399#define VNC_ENCODING_LED_STATE 0XFFFFFEFB /* -261 */
aliguorie06679f2009-02-02 15:58:25 +0000400#define VNC_ENCODING_WMVi 0x574D5669
401
402/*****************************************************************************
403 *
404 * Other tight constants
405 *
406 *****************************************************************************/
407
408/*
409 * Vendors known by TightVNC: standard VNC/RealVNC, TridiaVNC, and TightVNC.
410 */
411
412#define VNC_TIGHT_CCB_RESET_MASK (0x0f)
413#define VNC_TIGHT_CCB_TYPE_MASK (0x0f << 4)
414#define VNC_TIGHT_CCB_TYPE_FILL (0x08 << 4)
415#define VNC_TIGHT_CCB_TYPE_JPEG (0x09 << 4)
Corentin Charyefe556a2010-07-07 20:57:56 +0200416#define VNC_TIGHT_CCB_TYPE_PNG (0x0A << 4)
aliguorie06679f2009-02-02 15:58:25 +0000417#define VNC_TIGHT_CCB_BASIC_MAX (0x07 << 4)
418#define VNC_TIGHT_CCB_BASIC_ZLIB (0x03 << 4)
419#define VNC_TIGHT_CCB_BASIC_FILTER (0x04 << 4)
420
421/*****************************************************************************
422 *
423 * Features
424 *
425 *****************************************************************************/
426
427#define VNC_FEATURE_RESIZE 0
428#define VNC_FEATURE_HEXTILE 1
429#define VNC_FEATURE_POINTER_TYPE_CHANGE 2
430#define VNC_FEATURE_WMVI 3
431#define VNC_FEATURE_TIGHT 4
432#define VNC_FEATURE_ZLIB 5
aliguori753b4052009-02-16 14:59:30 +0000433#define VNC_FEATURE_COPYRECT 6
Gerd Hoffmannd467b672010-05-21 11:54:34 +0200434#define VNC_FEATURE_RICH_CURSOR 7
Corentin Charyefe556a2010-07-07 20:57:56 +0200435#define VNC_FEATURE_TIGHT_PNG 8
Corentin Chary148954f2011-02-04 09:06:01 +0100436#define VNC_FEATURE_ZRLE 9
437#define VNC_FEATURE_ZYWRLE 10
Lei Liab99e5c2013-04-25 13:29:10 +0800438#define VNC_FEATURE_LED_STATE 11
aliguorie06679f2009-02-02 15:58:25 +0000439
440#define VNC_FEATURE_RESIZE_MASK (1 << VNC_FEATURE_RESIZE)
441#define VNC_FEATURE_HEXTILE_MASK (1 << VNC_FEATURE_HEXTILE)
442#define VNC_FEATURE_POINTER_TYPE_CHANGE_MASK (1 << VNC_FEATURE_POINTER_TYPE_CHANGE)
443#define VNC_FEATURE_WMVI_MASK (1 << VNC_FEATURE_WMVI)
444#define VNC_FEATURE_TIGHT_MASK (1 << VNC_FEATURE_TIGHT)
445#define VNC_FEATURE_ZLIB_MASK (1 << VNC_FEATURE_ZLIB)
aliguori753b4052009-02-16 14:59:30 +0000446#define VNC_FEATURE_COPYRECT_MASK (1 << VNC_FEATURE_COPYRECT)
Gerd Hoffmannd467b672010-05-21 11:54:34 +0200447#define VNC_FEATURE_RICH_CURSOR_MASK (1 << VNC_FEATURE_RICH_CURSOR)
Corentin Charyefe556a2010-07-07 20:57:56 +0200448#define VNC_FEATURE_TIGHT_PNG_MASK (1 << VNC_FEATURE_TIGHT_PNG)
Corentin Chary148954f2011-02-04 09:06:01 +0100449#define VNC_FEATURE_ZRLE_MASK (1 << VNC_FEATURE_ZRLE)
450#define VNC_FEATURE_ZYWRLE_MASK (1 << VNC_FEATURE_ZYWRLE)
Lei Liab99e5c2013-04-25 13:29:10 +0800451#define VNC_FEATURE_LED_STATE_MASK (1 << VNC_FEATURE_LED_STATE)
aliguorie06679f2009-02-02 15:58:25 +0000452
aliguori5fb6c7a2009-03-06 20:27:23 +0000453
Daniel P. Berrange46a183d2010-03-31 18:20:43 +0100454/* Client -> Server message IDs */
455#define VNC_MSG_CLIENT_SET_PIXEL_FORMAT 0
456#define VNC_MSG_CLIENT_SET_ENCODINGS 2
457#define VNC_MSG_CLIENT_FRAMEBUFFER_UPDATE_REQUEST 3
458#define VNC_MSG_CLIENT_KEY_EVENT 4
459#define VNC_MSG_CLIENT_POINTER_EVENT 5
460#define VNC_MSG_CLIENT_CUT_TEXT 6
461#define VNC_MSG_CLIENT_VMWARE_0 127
462#define VNC_MSG_CLIENT_CALL_CONTROL 249
463#define VNC_MSG_CLIENT_XVP 250
464#define VNC_MSG_CLIENT_SET_DESKTOP_SIZE 251
465#define VNC_MSG_CLIENT_TIGHT 252
466#define VNC_MSG_CLIENT_GII 253
467#define VNC_MSG_CLIENT_VMWARE_1 254
468#define VNC_MSG_CLIENT_QEMU 255
469
470/* Server -> Client message IDs */
471#define VNC_MSG_SERVER_FRAMEBUFFER_UPDATE 0
472#define VNC_MSG_SERVER_SET_COLOUR_MAP_ENTRIES 1
473#define VNC_MSG_SERVER_BELL 2
474#define VNC_MSG_SERVER_CUT_TEXT 3
475#define VNC_MSG_SERVER_VMWARE_0 127
476#define VNC_MSG_SERVER_CALL_CONTROL 249
477#define VNC_MSG_SERVER_XVP 250
478#define VNC_MSG_SERVER_TIGHT 252
479#define VNC_MSG_SERVER_GII 253
480#define VNC_MSG_SERVER_VMWARE_1 254
481#define VNC_MSG_SERVER_QEMU 255
482
483
484
485/* QEMU client -> server message IDs */
486#define VNC_MSG_CLIENT_QEMU_EXT_KEY_EVENT 0
487#define VNC_MSG_CLIENT_QEMU_AUDIO 1
488
489/* QEMU server -> client message IDs */
490#define VNC_MSG_SERVER_QEMU_AUDIO 1
491
492
493
494/* QEMU client -> server audio message IDs */
495#define VNC_MSG_CLIENT_QEMU_AUDIO_ENABLE 0
496#define VNC_MSG_CLIENT_QEMU_AUDIO_DISABLE 1
497#define VNC_MSG_CLIENT_QEMU_AUDIO_SET_FORMAT 2
498
499/* QEMU server -> client audio message IDs */
500#define VNC_MSG_SERVER_QEMU_AUDIO_END 0
501#define VNC_MSG_SERVER_QEMU_AUDIO_BEGIN 1
502#define VNC_MSG_SERVER_QEMU_AUDIO_DATA 2
503
504
aliguori5fb6c7a2009-03-06 20:27:23 +0000505/*****************************************************************************
506 *
507 * Internal APIs
508 *
509 *****************************************************************************/
510
511/* Event loop functions */
512void vnc_client_read(void *opaque);
513void vnc_client_write(void *opaque);
514
aliguori2f9606b2009-03-06 20:27:28 +0000515long vnc_client_read_buf(VncState *vs, uint8_t *data, size_t datalen);
516long vnc_client_write_buf(VncState *vs, const uint8_t *data, size_t datalen);
aliguori5fb6c7a2009-03-06 20:27:23 +0000517
518/* Protocol I/O functions */
519void vnc_write(VncState *vs, const void *data, size_t len);
520void vnc_write_u32(VncState *vs, uint32_t value);
521void vnc_write_s32(VncState *vs, int32_t value);
522void vnc_write_u16(VncState *vs, uint16_t value);
523void vnc_write_u8(VncState *vs, uint8_t value);
524void vnc_flush(VncState *vs);
525void vnc_read_when(VncState *vs, VncReadEvent *func, size_t expecting);
Tim Hardeck7536ee42013-01-21 11:04:44 +0100526void vnc_disconnect_finish(VncState *vs);
527void vnc_init_state(VncState *vs);
aliguori5fb6c7a2009-03-06 20:27:23 +0000528
529
530/* Buffer I/O functions */
aliguori5fb6c7a2009-03-06 20:27:23 +0000531uint32_t read_u32(uint8_t *data, size_t offset);
532
533/* Protocol stage functions */
534void vnc_client_error(VncState *vs);
aliguori2f9606b2009-03-06 20:27:28 +0000535int vnc_client_io_error(VncState *vs, int ret, int last_errno);
aliguori5fb6c7a2009-03-06 20:27:23 +0000536
537void start_client_init(VncState *vs);
538void start_auth_vnc(VncState *vs);
539
aliguori2f9606b2009-03-06 20:27:28 +0000540/* Buffer management */
541void buffer_reserve(Buffer *buffer, size_t len);
aliguori2f9606b2009-03-06 20:27:28 +0000542void buffer_reset(Buffer *buffer);
Corentin Chary5d418e32010-05-19 09:24:07 +0200543void buffer_free(Buffer *buffer);
aliguori2f9606b2009-03-06 20:27:28 +0000544void buffer_append(Buffer *buffer, const void *data, size_t len);
Tim Hardeck32ed2682013-01-21 11:04:43 +0100545void buffer_advance(Buffer *buf, size_t len);
Tim Hardeck7536ee42013-01-21 11:04:44 +0100546uint8_t *buffer_end(Buffer *buffer);
aliguori2f9606b2009-03-06 20:27:28 +0000547
548
549/* Misc helpers */
550
551char *vnc_socket_local_addr(const char *format, int fd);
552char *vnc_socket_remote_addr(const char *format, int fd);
553
Corentin Charyefe556a2010-07-07 20:57:56 +0200554static inline uint32_t vnc_has_feature(VncState *vs, int feature) {
555 return (vs->features & (1 << feature));
556}
557
Corentin Chary70a45682010-05-03 14:31:34 +0200558/* Framebuffer */
559void vnc_framebuffer_update(VncState *vs, int x, int y, int w, int h,
560 int32_t encoding);
561
Gerd Hoffmann9f649162012-10-10 13:29:43 +0200562/* server fb is in PIXMAN_x8r8g8b8 */
563#define VNC_SERVER_FB_FORMAT PIXMAN_FORMAT(32, PIXMAN_TYPE_ARGB, 0, 8, 8, 8)
564#define VNC_SERVER_FB_BITS (PIXMAN_FORMAT_BPP(VNC_SERVER_FB_FORMAT))
565#define VNC_SERVER_FB_BYTES ((VNC_SERVER_FB_BITS+7)/8)
566
567void *vnc_server_fb_ptr(VncDisplay *vd, int x, int y);
568int vnc_server_fb_stride(VncDisplay *vd);
569
Corentin Chary70a45682010-05-03 14:31:34 +0200570void vnc_convert_pixel(VncState *vs, uint8_t *buf, uint32_t v);
Corentin Chary999342a2011-02-04 09:05:55 +0100571double vnc_update_freq(VncState *vs, int x, int y, int w, int h);
Corentin Chary7d964c92011-02-04 09:05:56 +0100572void vnc_sent_lossy_rect(VncState *vs, int x, int y, int w, int h);
Corentin Chary70a45682010-05-03 14:31:34 +0200573
574/* Encodings */
Corentin Charybd023f92010-07-07 20:58:02 +0200575int vnc_send_framebuffer_update(VncState *vs, int x, int y, int w, int h);
576
Corentin Charya8852112010-05-19 09:24:09 +0200577int vnc_raw_send_framebuffer_update(VncState *vs, int x, int y, int w, int h);
Corentin Chary70a45682010-05-03 14:31:34 +0200578
Corentin Charya8852112010-05-19 09:24:09 +0200579int vnc_hextile_send_framebuffer_update(VncState *vs, int x,
Corentin Chary70a45682010-05-03 14:31:34 +0200580 int y, int w, int h);
581void vnc_hextile_set_pixel_conversion(VncState *vs, int generic);
582
Corentin Chary380282b2010-05-19 09:24:10 +0200583void *vnc_zlib_zalloc(void *x, unsigned items, unsigned size);
584void vnc_zlib_zfree(void *x, void *addr);
Corentin Charya8852112010-05-19 09:24:09 +0200585int vnc_zlib_send_framebuffer_update(VncState *vs, int x, int y, int w, int h);
Corentin Chary161c4f22010-05-19 09:24:08 +0200586void vnc_zlib_clear(VncState *vs);
Corentin Chary70a45682010-05-03 14:31:34 +0200587
Corentin Chary380282b2010-05-19 09:24:10 +0200588int vnc_tight_send_framebuffer_update(VncState *vs, int x, int y, int w, int h);
Corentin Charyefe556a2010-07-07 20:57:56 +0200589int vnc_tight_png_send_framebuffer_update(VncState *vs, int x, int y,
590 int w, int h);
Corentin Chary380282b2010-05-19 09:24:10 +0200591void vnc_tight_clear(VncState *vs);
592
Corentin Chary148954f2011-02-04 09:06:01 +0100593int vnc_zrle_send_framebuffer_update(VncState *vs, int x, int y, int w, int h);
594int vnc_zywrle_send_framebuffer_update(VncState *vs, int x, int y, int w, int h);
595void vnc_zrle_clear(VncState *vs);
596
aliguori19a490b2009-03-06 20:27:13 +0000597#endif /* __QEMU_VNC_H */