blob: 8f582fdc6cd669d18e3b2dd8b9782d64aa5cf694 [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"
aliguori19a490b2009-03-06 20:27:13 +000034#include "audio/audio.h"
Paolo Bonzini1de7afc2012-12-17 18:20:00 +010035#include "qemu/bitmap.h"
aliguori19a490b2009-03-06 20:27:13 +000036#include <zlib.h>
Corentin Chary6f9c78c2010-07-07 20:57:51 +020037#include <stdbool.h>
aliguori19a490b2009-03-06 20:27:13 +000038
aliguori19a490b2009-03-06 20:27:13 +000039#include "keymaps.h"
Corentin Chary148954f2011-02-04 09:06:01 +010040#include "vnc-palette.h"
41#include "vnc-enc-zrle.h"
Wenchao Xiafb6ba0d2014-06-18 08:43:49 +020042#include "qapi-types.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
Peter Lievenb4c85dd2014-01-08 10:08:33 +010080/* VNC_DIRTY_PIXELS_PER_BIT is the number of dirty pixels represented
Peter Lievenbea60dd2014-06-30 10:57:51 +020081 * by one bit in the dirty bitmap, should be a power of 2 */
Peter Lievenb4c85dd2014-01-08 10:08:33 +010082#define VNC_DIRTY_PIXELS_PER_BIT 16
83
Peter Lievenbea60dd2014-06-30 10:57:51 +020084/* VNC_MAX_WIDTH must be a multiple of VNC_DIRTY_PIXELS_PER_BIT. */
85
86#define VNC_MAX_WIDTH ROUND_UP(2560, VNC_DIRTY_PIXELS_PER_BIT)
87#define VNC_MAX_HEIGHT 2048
88
Stefan Weil23bfe282011-03-03 21:37:55 +010089/* VNC_DIRTY_BITS is the number of bits in the dirty bitmap. */
Peter Lievenb4c85dd2014-01-08 10:08:33 +010090#define VNC_DIRTY_BITS (VNC_MAX_WIDTH / VNC_DIRTY_PIXELS_PER_BIT)
aliguori19a490b2009-03-06 20:27:13 +000091
Peter Lieven12b316d2014-01-08 10:08:35 +010092/* VNC_DIRTY_BPL (BPL = bits per line) might be greater than
93 * VNC_DIRTY_BITS due to alignment */
94#define VNC_DIRTY_BPL(x) (sizeof((x)->dirty) / VNC_MAX_HEIGHT * BITS_PER_BYTE)
95
Corentin Chary999342a2011-02-04 09:05:55 +010096#define VNC_STAT_RECT 64
97#define VNC_STAT_COLS (VNC_MAX_WIDTH / VNC_STAT_RECT)
98#define VNC_STAT_ROWS (VNC_MAX_HEIGHT / VNC_STAT_RECT)
99
aliguori19a490b2009-03-06 20:27:13 +0000100#define VNC_AUTH_CHALLENGE_SIZE 16
101
102typedef struct VncDisplay VncDisplay;
103
aliguori5fb6c7a2009-03-06 20:27:23 +0000104#ifdef CONFIG_VNC_TLS
105#include "vnc-tls.h"
106#include "vnc-auth-vencrypt.h"
107#endif
aliguori2f9606b2009-03-06 20:27:28 +0000108#ifdef CONFIG_VNC_SASL
109#include "vnc-auth-sasl.h"
110#endif
Tim Hardeck7536ee42013-01-21 11:04:44 +0100111#ifdef CONFIG_VNC_WS
112#include "vnc-ws.h"
113#endif
aliguori2f9606b2009-03-06 20:27:28 +0000114
Corentin Chary999342a2011-02-04 09:05:55 +0100115struct VncRectStat
116{
117 /* time of last 10 updates, to find update frequency */
118 struct timeval times[10];
119 int idx;
120
121 double freq; /* Update frequency (in Hz) */
122 bool updated; /* Already updated during this refresh */
123};
124
125typedef struct VncRectStat VncRectStat;
126
Stefano Stabellini1fc62412009-08-03 10:54:32 +0100127struct VncSurface
128{
Corentin Chary999342a2011-02-04 09:05:55 +0100129 struct timeval last_freq_check;
Peter Lievenbea60dd2014-06-30 10:57:51 +0200130 DECLARE_BITMAP(dirty[VNC_MAX_HEIGHT],
131 VNC_MAX_WIDTH / VNC_DIRTY_PIXELS_PER_BIT);
Corentin Chary999342a2011-02-04 09:05:55 +0100132 VncRectStat stats[VNC_STAT_ROWS][VNC_STAT_COLS];
Gerd Hoffmann9f649162012-10-10 13:29:43 +0200133 pixman_image_t *fb;
134 pixman_format_code_t format;
Stefano Stabellini1fc62412009-08-03 10:54:32 +0100135};
aliguori5fb6c7a2009-03-06 20:27:23 +0000136
Gerd Hoffmann8cf36482011-11-24 18:10:49 +0100137typedef enum VncShareMode {
138 VNC_SHARE_MODE_CONNECTING = 1,
139 VNC_SHARE_MODE_SHARED,
140 VNC_SHARE_MODE_EXCLUSIVE,
141 VNC_SHARE_MODE_DISCONNECTED,
142} VncShareMode;
143
144typedef enum VncSharePolicy {
145 VNC_SHARE_POLICY_IGNORE = 1,
146 VNC_SHARE_POLICY_ALLOW_EXCLUSIVE,
147 VNC_SHARE_POLICY_FORCE_SHARED,
148} VncSharePolicy;
149
aliguori19a490b2009-03-06 20:27:13 +0000150struct VncDisplay
151{
Amit Shah41b4bef2010-02-05 16:34:05 +0530152 QTAILQ_HEAD(, VncState) clients;
Gerd Hoffmann8cf36482011-11-24 18:10:49 +0100153 int num_exclusive;
154 VncSharePolicy share_policy;
aliguori19a490b2009-03-06 20:27:13 +0000155 int lsock;
Tim Hardeck7536ee42013-01-21 11:04:44 +0100156#ifdef CONFIG_VNC_WS
157 int lwebsock;
158 bool websocket;
159 char *ws_display;
160#endif
Gerd Hoffmannd39fa6d2013-02-28 17:16:48 +0100161 DisplaySurface *ds;
Gerd Hoffmann21ef45d2013-02-28 11:34:31 +0100162 DisplayChangeListener dcl;
Anthony Liguoric227f092009-10-01 16:12:16 -0500163 kbd_layout_t *kbd_layout;
Gerd Hoffmann3a0558b2010-03-10 17:12:02 +0100164 int lock_key_sync;
Corentin Charybd023f92010-07-07 20:58:02 +0200165 QemuMutex mutex;
aliguori19a490b2009-03-06 20:27:13 +0000166
Gerd Hoffmannd467b672010-05-21 11:54:34 +0200167 QEMUCursor *cursor;
168 int cursor_msize;
169 uint8_t *cursor_mask;
170
Stefano Stabellini1fc62412009-08-03 10:54:32 +0100171 struct VncSurface guest; /* guest visible surface (aka ds->surface) */
Gerd Hoffmann9f649162012-10-10 13:29:43 +0200172 pixman_image_t *server; /* vnc server surface */
Stefano Stabellini1fc62412009-08-03 10:54:32 +0100173
aliguori19a490b2009-03-06 20:27:13 +0000174 char *display;
175 char *password;
Gerd Hoffmann3c9405a2010-10-07 11:50:45 +0200176 time_t expires;
aliguori19a490b2009-03-06 20:27:13 +0000177 int auth;
Corentin Chary6f9c78c2010-07-07 20:57:51 +0200178 bool lossy;
Corentin Chary80e0c8c2011-02-04 09:06:08 +0100179 bool non_adaptive;
aliguori19a490b2009-03-06 20:27:13 +0000180#ifdef CONFIG_VNC_TLS
aliguori5fb6c7a2009-03-06 20:27:23 +0000181 int subauth; /* Used by VeNCrypt */
182 VncDisplayTLS tls;
aliguori19a490b2009-03-06 20:27:13 +0000183#endif
aliguori76655d62009-03-06 20:27:37 +0000184#ifdef CONFIG_VNC_SASL
185 VncDisplaySASL sasl;
186#endif
aliguori19a490b2009-03-06 20:27:13 +0000187};
188
Corentin Charyd1af0e02010-07-07 20:57:59 +0200189typedef struct VncTight {
190 int type;
191 uint8_t quality;
192 uint8_t compression;
193 uint8_t pixel24;
194 Buffer tight;
195 Buffer tmp;
196 Buffer zlib;
197 Buffer gradient;
198#ifdef CONFIG_VNC_JPEG
199 Buffer jpeg;
200#endif
201#ifdef CONFIG_VNC_PNG
202 Buffer png;
203#endif
204 int levels[4];
205 z_stream stream[4];
206} VncTight;
207
208typedef struct VncHextile {
209 VncSendHextileTile *send_tile;
210} VncHextile;
211
212typedef struct VncZlib {
213 Buffer zlib;
214 Buffer tmp;
215 z_stream stream;
216 int level;
217} VncZlib;
218
Corentin Chary148954f2011-02-04 09:06:01 +0100219typedef struct VncZrle {
220 int type;
221 Buffer fb;
222 Buffer zrle;
223 Buffer tmp;
224 Buffer zlib;
225 z_stream stream;
226 VncPalette palette;
227} VncZrle;
228
229typedef struct VncZywrle {
230 int buf[VNC_ZRLE_TILE_WIDTH * VNC_ZRLE_TILE_HEIGHT];
231} VncZywrle;
232
Corentin Charybd023f92010-07-07 20:58:02 +0200233struct VncRect
234{
235 int x;
236 int y;
237 int w;
238 int h;
239};
240
241struct VncRectEntry
242{
243 struct VncRect rect;
244 QLIST_ENTRY(VncRectEntry) next;
245};
246
247struct VncJob
248{
249 VncState *vs;
250
251 QLIST_HEAD(, VncRectEntry) rectangles;
252 QTAILQ_ENTRY(VncJob) next;
253};
Corentin Charybd023f92010-07-07 20:58:02 +0200254
aliguori19a490b2009-03-06 20:27:13 +0000255struct VncState
256{
aliguori19a490b2009-03-06 20:27:13 +0000257 int csock;
aliguori6baebed2009-03-20 15:59:14 +0000258
Stefan Weil23bfe282011-03-03 21:37:55 +0100259 DECLARE_BITMAP(dirty[VNC_MAX_HEIGHT], VNC_DIRTY_BITS);
Corentin Chary7d964c92011-02-04 09:05:56 +0100260 uint8_t **lossy_rect; /* Not an Array to avoid costly memcpy in
261 * vnc-jobs-async.c */
aliguori6baebed2009-03-20 15:59:14 +0000262
aliguori19a490b2009-03-06 20:27:13 +0000263 VncDisplay *vd;
264 int need_update;
aliguoric522d0e2009-03-20 15:59:24 +0000265 int force_update;
aliguori19a490b2009-03-06 20:27:13 +0000266 uint32_t features;
267 int absolute;
268 int last_x;
269 int last_y;
Gerd Hoffmann14768eb2013-12-02 15:17:45 +0100270 uint32_t last_bmask;
Gerd Hoffmann5862d192010-05-25 18:25:18 +0200271 int client_width;
272 int client_height;
Gerd Hoffmann8cf36482011-11-24 18:10:49 +0100273 VncShareMode share_mode;
aliguori19a490b2009-03-06 20:27:13 +0000274
275 uint32_t vnc_encoding;
aliguori19a490b2009-03-06 20:27:13 +0000276
277 int major;
278 int minor;
279
Daniel P. Berrange7e7e2eb2011-06-23 13:31:41 +0100280 int auth;
aliguori19a490b2009-03-06 20:27:13 +0000281 char challenge[VNC_AUTH_CHALLENGE_SIZE];
aliguori19a490b2009-03-06 20:27:13 +0000282#ifdef CONFIG_VNC_TLS
Daniel P. Berrange7e7e2eb2011-06-23 13:31:41 +0100283 int subauth; /* Used by VeNCrypt */
aliguori5fb6c7a2009-03-06 20:27:23 +0000284 VncStateTLS tls;
aliguori19a490b2009-03-06 20:27:13 +0000285#endif
aliguori2f9606b2009-03-06 20:27:28 +0000286#ifdef CONFIG_VNC_SASL
287 VncStateSASL sasl;
288#endif
Tim Hardeck7536ee42013-01-21 11:04:44 +0100289#ifdef CONFIG_VNC_WS
Tim Hardeck0057a0d2013-04-23 16:33:01 +0200290#ifdef CONFIG_VNC_TLS
291 VncStateTLS ws_tls;
292#endif /* CONFIG_VNC_TLS */
Tim Hardeck7536ee42013-01-21 11:04:44 +0100293 bool encode_ws;
294 bool websocket;
Tim Hardeck0057a0d2013-04-23 16:33:01 +0200295#endif /* CONFIG_VNC_WS */
aliguori19a490b2009-03-06 20:27:13 +0000296
Wenchao Xiafb6ba0d2014-06-18 08:43:49 +0200297 VncClientInfo *info;
Luiz Capitulino4a80dba2010-01-14 14:50:56 -0200298
aliguori19a490b2009-03-06 20:27:13 +0000299 Buffer output;
300 Buffer input;
Tim Hardeck7536ee42013-01-21 11:04:44 +0100301#ifdef CONFIG_VNC_WS
302 Buffer ws_input;
303 Buffer ws_output;
304#endif
aliguori19a490b2009-03-06 20:27:13 +0000305 /* current output mode information */
306 VncWritePixels *write_pixels;
Gerd Hoffmann9f649162012-10-10 13:29:43 +0200307 PixelFormat client_pf;
308 pixman_format_code_t client_format;
309 bool client_be;
aliguori19a490b2009-03-06 20:27:13 +0000310
311 CaptureVoiceOut *audio_cap;
312 struct audsettings as;
313
314 VncReadEvent *read_handler;
315 size_t read_handler_expect;
316 /* input */
317 uint8_t modifiers_state[256];
Gerd Hoffmann7ffb82c2010-02-26 17:17:39 +0100318 QEMUPutLEDEntry *led;
aliguori19a490b2009-03-06 20:27:13 +0000319
Corentin Charybd023f92010-07-07 20:58:02 +0200320 bool abort;
Tim Hardeck6fd8e792013-01-21 11:04:45 +0100321 bool initialized;
Corentin Charybd023f92010-07-07 20:58:02 +0200322 QemuMutex output_mutex;
Corentin Chary175b2a62012-03-14 07:58:47 +0100323 QEMUBH *bh;
324 Buffer jobs_buffer;
Corentin Charybd023f92010-07-07 20:58:02 +0200325
326 /* Encoding specific, if you add something here, don't forget to
327 * update vnc_async_encoding_start()
328 */
Corentin Charyd1af0e02010-07-07 20:57:59 +0200329 VncTight tight;
330 VncZlib zlib;
331 VncHextile hextile;
Corentin Chary148954f2011-02-04 09:06:01 +0100332 VncZrle zrle;
333 VncZywrle zywrle;
aliguori19a490b2009-03-06 20:27:13 +0000334
Anthony Liguori37c34d92010-03-10 09:38:29 -0600335 Notifier mouse_mode_notifier;
336
Amit Shah41b4bef2010-02-05 16:34:05 +0530337 QTAILQ_ENTRY(VncState) next;
aliguori19a490b2009-03-06 20:27:13 +0000338};
339
aliguorie06679f2009-02-02 15:58:25 +0000340
341/*****************************************************************************
342 *
343 * Authentication modes
344 *
345 *****************************************************************************/
346
347enum {
348 VNC_AUTH_INVALID = 0,
349 VNC_AUTH_NONE = 1,
350 VNC_AUTH_VNC = 2,
351 VNC_AUTH_RA2 = 5,
352 VNC_AUTH_RA2NE = 6,
353 VNC_AUTH_TIGHT = 16,
354 VNC_AUTH_ULTRA = 17,
aliguori2f9606b2009-03-06 20:27:28 +0000355 VNC_AUTH_TLS = 18, /* Supported in GTK-VNC & VINO */
356 VNC_AUTH_VENCRYPT = 19, /* Supported in GTK-VNC & VeNCrypt */
357 VNC_AUTH_SASL = 20, /* Supported in GTK-VNC & VINO */
aliguorie06679f2009-02-02 15:58:25 +0000358};
359
aliguorie06679f2009-02-02 15:58:25 +0000360enum {
361 VNC_AUTH_VENCRYPT_PLAIN = 256,
362 VNC_AUTH_VENCRYPT_TLSNONE = 257,
363 VNC_AUTH_VENCRYPT_TLSVNC = 258,
364 VNC_AUTH_VENCRYPT_TLSPLAIN = 259,
365 VNC_AUTH_VENCRYPT_X509NONE = 260,
366 VNC_AUTH_VENCRYPT_X509VNC = 261,
367 VNC_AUTH_VENCRYPT_X509PLAIN = 262,
aliguori2f9606b2009-03-06 20:27:28 +0000368 VNC_AUTH_VENCRYPT_X509SASL = 263,
369 VNC_AUTH_VENCRYPT_TLSSASL = 264,
aliguorie06679f2009-02-02 15:58:25 +0000370};
371
aliguorie06679f2009-02-02 15:58:25 +0000372
373/*****************************************************************************
374 *
375 * Encoding types
376 *
377 *****************************************************************************/
378
379#define VNC_ENCODING_RAW 0x00000000
380#define VNC_ENCODING_COPYRECT 0x00000001
381#define VNC_ENCODING_RRE 0x00000002
382#define VNC_ENCODING_CORRE 0x00000004
383#define VNC_ENCODING_HEXTILE 0x00000005
384#define VNC_ENCODING_ZLIB 0x00000006
385#define VNC_ENCODING_TIGHT 0x00000007
386#define VNC_ENCODING_ZLIBHEX 0x00000008
387#define VNC_ENCODING_TRLE 0x0000000f
388#define VNC_ENCODING_ZRLE 0x00000010
389#define VNC_ENCODING_ZYWRLE 0x00000011
390#define VNC_ENCODING_COMPRESSLEVEL0 0xFFFFFF00 /* -256 */
391#define VNC_ENCODING_QUALITYLEVEL0 0xFFFFFFE0 /* -32 */
392#define VNC_ENCODING_XCURSOR 0xFFFFFF10 /* -240 */
393#define VNC_ENCODING_RICH_CURSOR 0xFFFFFF11 /* -239 */
394#define VNC_ENCODING_POINTER_POS 0xFFFFFF18 /* -232 */
395#define VNC_ENCODING_LASTRECT 0xFFFFFF20 /* -224 */
396#define VNC_ENCODING_DESKTOPRESIZE 0xFFFFFF21 /* -223 */
397#define VNC_ENCODING_POINTER_TYPE_CHANGE 0XFFFFFEFF /* -257 */
398#define VNC_ENCODING_EXT_KEY_EVENT 0XFFFFFEFE /* -258 */
399#define VNC_ENCODING_AUDIO 0XFFFFFEFD /* -259 */
Corentin Charyefe556a2010-07-07 20:57:56 +0200400#define VNC_ENCODING_TIGHT_PNG 0xFFFFFEFC /* -260 */
Lei Liab99e5c2013-04-25 13:29:10 +0800401#define VNC_ENCODING_LED_STATE 0XFFFFFEFB /* -261 */
aliguorie06679f2009-02-02 15:58:25 +0000402#define VNC_ENCODING_WMVi 0x574D5669
403
404/*****************************************************************************
405 *
406 * Other tight constants
407 *
408 *****************************************************************************/
409
410/*
411 * Vendors known by TightVNC: standard VNC/RealVNC, TridiaVNC, and TightVNC.
412 */
413
414#define VNC_TIGHT_CCB_RESET_MASK (0x0f)
415#define VNC_TIGHT_CCB_TYPE_MASK (0x0f << 4)
416#define VNC_TIGHT_CCB_TYPE_FILL (0x08 << 4)
417#define VNC_TIGHT_CCB_TYPE_JPEG (0x09 << 4)
Corentin Charyefe556a2010-07-07 20:57:56 +0200418#define VNC_TIGHT_CCB_TYPE_PNG (0x0A << 4)
aliguorie06679f2009-02-02 15:58:25 +0000419#define VNC_TIGHT_CCB_BASIC_MAX (0x07 << 4)
420#define VNC_TIGHT_CCB_BASIC_ZLIB (0x03 << 4)
421#define VNC_TIGHT_CCB_BASIC_FILTER (0x04 << 4)
422
423/*****************************************************************************
424 *
425 * Features
426 *
427 *****************************************************************************/
428
429#define VNC_FEATURE_RESIZE 0
430#define VNC_FEATURE_HEXTILE 1
431#define VNC_FEATURE_POINTER_TYPE_CHANGE 2
432#define VNC_FEATURE_WMVI 3
433#define VNC_FEATURE_TIGHT 4
434#define VNC_FEATURE_ZLIB 5
aliguori753b4052009-02-16 14:59:30 +0000435#define VNC_FEATURE_COPYRECT 6
Gerd Hoffmannd467b672010-05-21 11:54:34 +0200436#define VNC_FEATURE_RICH_CURSOR 7
Corentin Charyefe556a2010-07-07 20:57:56 +0200437#define VNC_FEATURE_TIGHT_PNG 8
Corentin Chary148954f2011-02-04 09:06:01 +0100438#define VNC_FEATURE_ZRLE 9
439#define VNC_FEATURE_ZYWRLE 10
Lei Liab99e5c2013-04-25 13:29:10 +0800440#define VNC_FEATURE_LED_STATE 11
aliguorie06679f2009-02-02 15:58:25 +0000441
442#define VNC_FEATURE_RESIZE_MASK (1 << VNC_FEATURE_RESIZE)
443#define VNC_FEATURE_HEXTILE_MASK (1 << VNC_FEATURE_HEXTILE)
444#define VNC_FEATURE_POINTER_TYPE_CHANGE_MASK (1 << VNC_FEATURE_POINTER_TYPE_CHANGE)
445#define VNC_FEATURE_WMVI_MASK (1 << VNC_FEATURE_WMVI)
446#define VNC_FEATURE_TIGHT_MASK (1 << VNC_FEATURE_TIGHT)
447#define VNC_FEATURE_ZLIB_MASK (1 << VNC_FEATURE_ZLIB)
aliguori753b4052009-02-16 14:59:30 +0000448#define VNC_FEATURE_COPYRECT_MASK (1 << VNC_FEATURE_COPYRECT)
Gerd Hoffmannd467b672010-05-21 11:54:34 +0200449#define VNC_FEATURE_RICH_CURSOR_MASK (1 << VNC_FEATURE_RICH_CURSOR)
Corentin Charyefe556a2010-07-07 20:57:56 +0200450#define VNC_FEATURE_TIGHT_PNG_MASK (1 << VNC_FEATURE_TIGHT_PNG)
Corentin Chary148954f2011-02-04 09:06:01 +0100451#define VNC_FEATURE_ZRLE_MASK (1 << VNC_FEATURE_ZRLE)
452#define VNC_FEATURE_ZYWRLE_MASK (1 << VNC_FEATURE_ZYWRLE)
Lei Liab99e5c2013-04-25 13:29:10 +0800453#define VNC_FEATURE_LED_STATE_MASK (1 << VNC_FEATURE_LED_STATE)
aliguorie06679f2009-02-02 15:58:25 +0000454
aliguori5fb6c7a2009-03-06 20:27:23 +0000455
Daniel P. Berrange46a183d2010-03-31 18:20:43 +0100456/* Client -> Server message IDs */
457#define VNC_MSG_CLIENT_SET_PIXEL_FORMAT 0
458#define VNC_MSG_CLIENT_SET_ENCODINGS 2
459#define VNC_MSG_CLIENT_FRAMEBUFFER_UPDATE_REQUEST 3
460#define VNC_MSG_CLIENT_KEY_EVENT 4
461#define VNC_MSG_CLIENT_POINTER_EVENT 5
462#define VNC_MSG_CLIENT_CUT_TEXT 6
463#define VNC_MSG_CLIENT_VMWARE_0 127
464#define VNC_MSG_CLIENT_CALL_CONTROL 249
465#define VNC_MSG_CLIENT_XVP 250
466#define VNC_MSG_CLIENT_SET_DESKTOP_SIZE 251
467#define VNC_MSG_CLIENT_TIGHT 252
468#define VNC_MSG_CLIENT_GII 253
469#define VNC_MSG_CLIENT_VMWARE_1 254
470#define VNC_MSG_CLIENT_QEMU 255
471
472/* Server -> Client message IDs */
473#define VNC_MSG_SERVER_FRAMEBUFFER_UPDATE 0
474#define VNC_MSG_SERVER_SET_COLOUR_MAP_ENTRIES 1
475#define VNC_MSG_SERVER_BELL 2
476#define VNC_MSG_SERVER_CUT_TEXT 3
477#define VNC_MSG_SERVER_VMWARE_0 127
478#define VNC_MSG_SERVER_CALL_CONTROL 249
479#define VNC_MSG_SERVER_XVP 250
480#define VNC_MSG_SERVER_TIGHT 252
481#define VNC_MSG_SERVER_GII 253
482#define VNC_MSG_SERVER_VMWARE_1 254
483#define VNC_MSG_SERVER_QEMU 255
484
485
486
487/* QEMU client -> server message IDs */
488#define VNC_MSG_CLIENT_QEMU_EXT_KEY_EVENT 0
489#define VNC_MSG_CLIENT_QEMU_AUDIO 1
490
491/* QEMU server -> client message IDs */
492#define VNC_MSG_SERVER_QEMU_AUDIO 1
493
494
495
496/* QEMU client -> server audio message IDs */
497#define VNC_MSG_CLIENT_QEMU_AUDIO_ENABLE 0
498#define VNC_MSG_CLIENT_QEMU_AUDIO_DISABLE 1
499#define VNC_MSG_CLIENT_QEMU_AUDIO_SET_FORMAT 2
500
501/* QEMU server -> client audio message IDs */
502#define VNC_MSG_SERVER_QEMU_AUDIO_END 0
503#define VNC_MSG_SERVER_QEMU_AUDIO_BEGIN 1
504#define VNC_MSG_SERVER_QEMU_AUDIO_DATA 2
505
506
aliguori5fb6c7a2009-03-06 20:27:23 +0000507/*****************************************************************************
508 *
509 * Internal APIs
510 *
511 *****************************************************************************/
512
513/* Event loop functions */
514void vnc_client_read(void *opaque);
515void vnc_client_write(void *opaque);
516
aliguori2f9606b2009-03-06 20:27:28 +0000517long vnc_client_read_buf(VncState *vs, uint8_t *data, size_t datalen);
518long vnc_client_write_buf(VncState *vs, const uint8_t *data, size_t datalen);
aliguori5fb6c7a2009-03-06 20:27:23 +0000519
520/* Protocol I/O functions */
521void vnc_write(VncState *vs, const void *data, size_t len);
522void vnc_write_u32(VncState *vs, uint32_t value);
523void vnc_write_s32(VncState *vs, int32_t value);
524void vnc_write_u16(VncState *vs, uint16_t value);
525void vnc_write_u8(VncState *vs, uint8_t value);
526void vnc_flush(VncState *vs);
527void vnc_read_when(VncState *vs, VncReadEvent *func, size_t expecting);
Tim Hardeck7536ee42013-01-21 11:04:44 +0100528void vnc_disconnect_finish(VncState *vs);
529void vnc_init_state(VncState *vs);
aliguori5fb6c7a2009-03-06 20:27:23 +0000530
531
532/* Buffer I/O functions */
aliguori5fb6c7a2009-03-06 20:27:23 +0000533uint32_t read_u32(uint8_t *data, size_t offset);
534
535/* Protocol stage functions */
536void vnc_client_error(VncState *vs);
aliguori2f9606b2009-03-06 20:27:28 +0000537int vnc_client_io_error(VncState *vs, int ret, int last_errno);
aliguori5fb6c7a2009-03-06 20:27:23 +0000538
539void start_client_init(VncState *vs);
540void start_auth_vnc(VncState *vs);
541
aliguori2f9606b2009-03-06 20:27:28 +0000542/* Buffer management */
543void buffer_reserve(Buffer *buffer, size_t len);
aliguori2f9606b2009-03-06 20:27:28 +0000544void buffer_reset(Buffer *buffer);
Corentin Chary5d418e32010-05-19 09:24:07 +0200545void buffer_free(Buffer *buffer);
aliguori2f9606b2009-03-06 20:27:28 +0000546void buffer_append(Buffer *buffer, const void *data, size_t len);
Tim Hardeck32ed2682013-01-21 11:04:43 +0100547void buffer_advance(Buffer *buf, size_t len);
Tim Hardeck7536ee42013-01-21 11:04:44 +0100548uint8_t *buffer_end(Buffer *buffer);
aliguori2f9606b2009-03-06 20:27:28 +0000549
550
551/* Misc helpers */
552
553char *vnc_socket_local_addr(const char *format, int fd);
554char *vnc_socket_remote_addr(const char *format, int fd);
555
Corentin Charyefe556a2010-07-07 20:57:56 +0200556static inline uint32_t vnc_has_feature(VncState *vs, int feature) {
557 return (vs->features & (1 << feature));
558}
559
Corentin Chary70a45682010-05-03 14:31:34 +0200560/* Framebuffer */
561void vnc_framebuffer_update(VncState *vs, int x, int y, int w, int h,
562 int32_t encoding);
563
Gerd Hoffmann9f649162012-10-10 13:29:43 +0200564/* server fb is in PIXMAN_x8r8g8b8 */
565#define VNC_SERVER_FB_FORMAT PIXMAN_FORMAT(32, PIXMAN_TYPE_ARGB, 0, 8, 8, 8)
566#define VNC_SERVER_FB_BITS (PIXMAN_FORMAT_BPP(VNC_SERVER_FB_FORMAT))
567#define VNC_SERVER_FB_BYTES ((VNC_SERVER_FB_BITS+7)/8)
568
569void *vnc_server_fb_ptr(VncDisplay *vd, int x, int y);
570int vnc_server_fb_stride(VncDisplay *vd);
571
Corentin Chary70a45682010-05-03 14:31:34 +0200572void vnc_convert_pixel(VncState *vs, uint8_t *buf, uint32_t v);
Corentin Chary999342a2011-02-04 09:05:55 +0100573double vnc_update_freq(VncState *vs, int x, int y, int w, int h);
Corentin Chary7d964c92011-02-04 09:05:56 +0100574void vnc_sent_lossy_rect(VncState *vs, int x, int y, int w, int h);
Corentin Chary70a45682010-05-03 14:31:34 +0200575
576/* Encodings */
Corentin Charybd023f92010-07-07 20:58:02 +0200577int vnc_send_framebuffer_update(VncState *vs, int x, int y, int w, int h);
578
Corentin Charya8852112010-05-19 09:24:09 +0200579int vnc_raw_send_framebuffer_update(VncState *vs, int x, int y, int w, int h);
Corentin Chary70a45682010-05-03 14:31:34 +0200580
Corentin Charya8852112010-05-19 09:24:09 +0200581int vnc_hextile_send_framebuffer_update(VncState *vs, int x,
Corentin Chary70a45682010-05-03 14:31:34 +0200582 int y, int w, int h);
583void vnc_hextile_set_pixel_conversion(VncState *vs, int generic);
584
Corentin Chary380282b2010-05-19 09:24:10 +0200585void *vnc_zlib_zalloc(void *x, unsigned items, unsigned size);
586void vnc_zlib_zfree(void *x, void *addr);
Corentin Charya8852112010-05-19 09:24:09 +0200587int vnc_zlib_send_framebuffer_update(VncState *vs, int x, int y, int w, int h);
Corentin Chary161c4f22010-05-19 09:24:08 +0200588void vnc_zlib_clear(VncState *vs);
Corentin Chary70a45682010-05-03 14:31:34 +0200589
Corentin Chary380282b2010-05-19 09:24:10 +0200590int vnc_tight_send_framebuffer_update(VncState *vs, int x, int y, int w, int h);
Corentin Charyefe556a2010-07-07 20:57:56 +0200591int vnc_tight_png_send_framebuffer_update(VncState *vs, int x, int y,
592 int w, int h);
Corentin Chary380282b2010-05-19 09:24:10 +0200593void vnc_tight_clear(VncState *vs);
594
Corentin Chary148954f2011-02-04 09:06:01 +0100595int vnc_zrle_send_framebuffer_update(VncState *vs, int x, int y, int w, int h);
596int vnc_zywrle_send_framebuffer_update(VncState *vs, int x, int y, int w, int h);
597void vnc_zrle_clear(VncState *vs);
598
aliguori19a490b2009-03-06 20:27:13 +0000599#endif /* __QEMU_VNC_H */