Move VNC structs into header file ("Daniel P. Berrange")
This patch moves the definitions of VncState and VncDisplay structs out into a vnc.h header file. This is to allow the code for TLS and SASL auth mechanisms to be moved out of the main vnc.c file. vnc.c | 109 ------------------------------------------------ vnc.h | 149 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-- 2 files changed, 148 insertions(+), 110 deletions(-) Signed-off-by: Daniel P. Berrange <berrange@redhat.com> Signed-off-by: Anthony Liguori <aliguori@us.ibm.com> git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@6722 c046a42c-6fe2-441c-8c8c-71466251a162
This commit is contained in:
parent
0483755a4d
commit
19a490bfca
110
vnc.c
110
vnc.c
@ -3,6 +3,7 @@
|
|||||||
*
|
*
|
||||||
* Copyright (C) 2006 Anthony Liguori <anthony@codemonkey.ws>
|
* Copyright (C) 2006 Anthony Liguori <anthony@codemonkey.ws>
|
||||||
* Copyright (C) 2006 Fabrice Bellard
|
* Copyright (C) 2006 Fabrice Bellard
|
||||||
|
* Copyright (C) 2009 Red Hat, Inc
|
||||||
*
|
*
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
* of this software and associated documentation files (the "Software"), to deal
|
* of this software and associated documentation files (the "Software"), to deal
|
||||||
@ -23,26 +24,16 @@
|
|||||||
* THE SOFTWARE.
|
* THE SOFTWARE.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "qemu-common.h"
|
#include "vnc.h"
|
||||||
#include "monitor.h"
|
|
||||||
#include "console.h"
|
|
||||||
#include "sysemu.h"
|
#include "sysemu.h"
|
||||||
#include "qemu_socket.h"
|
#include "qemu_socket.h"
|
||||||
#include "qemu-timer.h"
|
#include "qemu-timer.h"
|
||||||
#include "audio/audio.h"
|
|
||||||
#include <zlib.h>
|
|
||||||
|
|
||||||
#define VNC_REFRESH_INTERVAL (1000 / 30)
|
#define VNC_REFRESH_INTERVAL (1000 / 30)
|
||||||
|
|
||||||
#include "vnc.h"
|
|
||||||
#include "vnc_keysym.h"
|
#include "vnc_keysym.h"
|
||||||
#include "d3des.h"
|
#include "d3des.h"
|
||||||
|
|
||||||
#ifdef CONFIG_VNC_TLS
|
|
||||||
#include <gnutls/gnutls.h>
|
|
||||||
#include <gnutls/x509.h>
|
|
||||||
#endif /* CONFIG_VNC_TLS */
|
|
||||||
|
|
||||||
// #define _VNC_DEBUG 1
|
// #define _VNC_DEBUG 1
|
||||||
|
|
||||||
#ifdef _VNC_DEBUG
|
#ifdef _VNC_DEBUG
|
||||||
@ -65,103 +56,6 @@ static void vnc_debug_gnutls_log(int level, const char* str) {
|
|||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
typedef struct Buffer
|
|
||||||
{
|
|
||||||
size_t capacity;
|
|
||||||
size_t offset;
|
|
||||||
uint8_t *buffer;
|
|
||||||
} Buffer;
|
|
||||||
|
|
||||||
typedef struct VncState VncState;
|
|
||||||
|
|
||||||
typedef int VncReadEvent(VncState *vs, uint8_t *data, size_t len);
|
|
||||||
|
|
||||||
typedef void VncWritePixels(VncState *vs, void *data, int size);
|
|
||||||
|
|
||||||
typedef void VncSendHextileTile(VncState *vs,
|
|
||||||
int x, int y, int w, int h,
|
|
||||||
void *last_bg,
|
|
||||||
void *last_fg,
|
|
||||||
int *has_bg, int *has_fg);
|
|
||||||
|
|
||||||
#define VNC_MAX_WIDTH 2048
|
|
||||||
#define VNC_MAX_HEIGHT 2048
|
|
||||||
#define VNC_DIRTY_WORDS (VNC_MAX_WIDTH / (16 * 32))
|
|
||||||
|
|
||||||
#define VNC_AUTH_CHALLENGE_SIZE 16
|
|
||||||
|
|
||||||
typedef struct VncDisplay VncDisplay;
|
|
||||||
|
|
||||||
struct VncDisplay
|
|
||||||
{
|
|
||||||
int lsock;
|
|
||||||
DisplayState *ds;
|
|
||||||
VncState *clients;
|
|
||||||
kbd_layout_t *kbd_layout;
|
|
||||||
|
|
||||||
char *display;
|
|
||||||
char *password;
|
|
||||||
int auth;
|
|
||||||
#ifdef CONFIG_VNC_TLS
|
|
||||||
int subauth;
|
|
||||||
int x509verify;
|
|
||||||
|
|
||||||
char *x509cacert;
|
|
||||||
char *x509cacrl;
|
|
||||||
char *x509cert;
|
|
||||||
char *x509key;
|
|
||||||
#endif
|
|
||||||
};
|
|
||||||
|
|
||||||
struct VncState
|
|
||||||
{
|
|
||||||
QEMUTimer *timer;
|
|
||||||
int csock;
|
|
||||||
DisplayState *ds;
|
|
||||||
VncDisplay *vd;
|
|
||||||
int need_update;
|
|
||||||
uint32_t dirty_row[VNC_MAX_HEIGHT][VNC_DIRTY_WORDS];
|
|
||||||
char *old_data;
|
|
||||||
uint32_t features;
|
|
||||||
int absolute;
|
|
||||||
int last_x;
|
|
||||||
int last_y;
|
|
||||||
|
|
||||||
uint32_t vnc_encoding;
|
|
||||||
uint8_t tight_quality;
|
|
||||||
uint8_t tight_compression;
|
|
||||||
|
|
||||||
int major;
|
|
||||||
int minor;
|
|
||||||
|
|
||||||
char challenge[VNC_AUTH_CHALLENGE_SIZE];
|
|
||||||
|
|
||||||
#ifdef CONFIG_VNC_TLS
|
|
||||||
int wiremode;
|
|
||||||
gnutls_session_t tls_session;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
Buffer output;
|
|
||||||
Buffer input;
|
|
||||||
/* current output mode information */
|
|
||||||
VncWritePixels *write_pixels;
|
|
||||||
VncSendHextileTile *send_hextile_tile;
|
|
||||||
DisplaySurface clientds, serverds;
|
|
||||||
|
|
||||||
CaptureVoiceOut *audio_cap;
|
|
||||||
struct audsettings as;
|
|
||||||
|
|
||||||
VncReadEvent *read_handler;
|
|
||||||
size_t read_handler_expect;
|
|
||||||
/* input */
|
|
||||||
uint8_t modifiers_state[256];
|
|
||||||
|
|
||||||
Buffer zlib;
|
|
||||||
Buffer zlib_tmp;
|
|
||||||
z_stream zlib_stream[4];
|
|
||||||
|
|
||||||
VncState *next;
|
|
||||||
};
|
|
||||||
|
|
||||||
static VncDisplay *vnc_display; /* needed for info vnc */
|
static VncDisplay *vnc_display; /* needed for info vnc */
|
||||||
static DisplayChangeListener *dcl;
|
static DisplayChangeListener *dcl;
|
||||||
|
150
vnc.h
150
vnc.h
@ -1,5 +1,149 @@
|
|||||||
#ifndef __VNCTIGHT_H
|
/*
|
||||||
#define __VNCTIGHT_H
|
* QEMU VNC display driver
|
||||||
|
*
|
||||||
|
* Copyright (C) 2006 Anthony Liguori <anthony@codemonkey.ws>
|
||||||
|
* Copyright (C) 2006 Fabrice Bellard
|
||||||
|
* Copyright (C) 2009 Red Hat, Inc
|
||||||
|
*
|
||||||
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
* of this software and associated documentation files (the "Software"), to deal
|
||||||
|
* in the Software without restriction, including without limitation the rights
|
||||||
|
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
* copies of the Software, and to permit persons to whom the Software is
|
||||||
|
* furnished to do so, subject to the following conditions:
|
||||||
|
*
|
||||||
|
* The above copyright notice and this permission notice shall be included in
|
||||||
|
* all copies or substantial portions of the Software.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||||
|
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||||
|
* THE SOFTWARE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __QEMU_VNC_H
|
||||||
|
#define __QEMU_VNC_H
|
||||||
|
|
||||||
|
#include "qemu-common.h"
|
||||||
|
#include "console.h"
|
||||||
|
#include "monitor.h"
|
||||||
|
#include "audio/audio.h"
|
||||||
|
#include <zlib.h>
|
||||||
|
|
||||||
|
#ifdef CONFIG_VNC_TLS
|
||||||
|
#include <gnutls/gnutls.h>
|
||||||
|
#include <gnutls/x509.h>
|
||||||
|
#endif /* CONFIG_VNC_TLS */
|
||||||
|
|
||||||
|
#include "keymaps.h"
|
||||||
|
|
||||||
|
/*****************************************************************************
|
||||||
|
*
|
||||||
|
* Core data structures
|
||||||
|
*
|
||||||
|
*****************************************************************************/
|
||||||
|
|
||||||
|
typedef struct Buffer
|
||||||
|
{
|
||||||
|
size_t capacity;
|
||||||
|
size_t offset;
|
||||||
|
uint8_t *buffer;
|
||||||
|
} Buffer;
|
||||||
|
|
||||||
|
typedef struct VncState VncState;
|
||||||
|
|
||||||
|
typedef int VncReadEvent(VncState *vs, uint8_t *data, size_t len);
|
||||||
|
|
||||||
|
typedef void VncWritePixels(VncState *vs, void *data, int size);
|
||||||
|
|
||||||
|
typedef void VncSendHextileTile(VncState *vs,
|
||||||
|
int x, int y, int w, int h,
|
||||||
|
void *last_bg,
|
||||||
|
void *last_fg,
|
||||||
|
int *has_bg, int *has_fg);
|
||||||
|
|
||||||
|
#define VNC_MAX_WIDTH 2048
|
||||||
|
#define VNC_MAX_HEIGHT 2048
|
||||||
|
#define VNC_DIRTY_WORDS (VNC_MAX_WIDTH / (16 * 32))
|
||||||
|
|
||||||
|
#define VNC_AUTH_CHALLENGE_SIZE 16
|
||||||
|
|
||||||
|
typedef struct VncDisplay VncDisplay;
|
||||||
|
|
||||||
|
struct VncDisplay
|
||||||
|
{
|
||||||
|
int lsock;
|
||||||
|
DisplayState *ds;
|
||||||
|
VncState *clients;
|
||||||
|
kbd_layout_t *kbd_layout;
|
||||||
|
|
||||||
|
char *display;
|
||||||
|
char *password;
|
||||||
|
int auth;
|
||||||
|
#ifdef CONFIG_VNC_TLS
|
||||||
|
int subauth;
|
||||||
|
int x509verify;
|
||||||
|
|
||||||
|
char *x509cacert;
|
||||||
|
char *x509cacrl;
|
||||||
|
char *x509cert;
|
||||||
|
char *x509key;
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
|
||||||
|
struct VncState
|
||||||
|
{
|
||||||
|
QEMUTimer *timer;
|
||||||
|
int csock;
|
||||||
|
DisplayState *ds;
|
||||||
|
VncDisplay *vd;
|
||||||
|
int need_update;
|
||||||
|
uint32_t dirty_row[VNC_MAX_HEIGHT][VNC_DIRTY_WORDS];
|
||||||
|
char *old_data;
|
||||||
|
uint32_t features;
|
||||||
|
int absolute;
|
||||||
|
int last_x;
|
||||||
|
int last_y;
|
||||||
|
|
||||||
|
uint32_t vnc_encoding;
|
||||||
|
uint8_t tight_quality;
|
||||||
|
uint8_t tight_compression;
|
||||||
|
|
||||||
|
int major;
|
||||||
|
int minor;
|
||||||
|
|
||||||
|
char challenge[VNC_AUTH_CHALLENGE_SIZE];
|
||||||
|
|
||||||
|
#ifdef CONFIG_VNC_TLS
|
||||||
|
int wiremode;
|
||||||
|
gnutls_session_t tls_session;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
Buffer output;
|
||||||
|
Buffer input;
|
||||||
|
/* current output mode information */
|
||||||
|
VncWritePixels *write_pixels;
|
||||||
|
VncSendHextileTile *send_hextile_tile;
|
||||||
|
DisplaySurface clientds, serverds;
|
||||||
|
|
||||||
|
CaptureVoiceOut *audio_cap;
|
||||||
|
struct audsettings as;
|
||||||
|
|
||||||
|
VncReadEvent *read_handler;
|
||||||
|
size_t read_handler_expect;
|
||||||
|
/* input */
|
||||||
|
uint8_t modifiers_state[256];
|
||||||
|
|
||||||
|
Buffer zlib;
|
||||||
|
Buffer zlib_tmp;
|
||||||
|
z_stream zlib_stream[4];
|
||||||
|
|
||||||
|
VncState *next;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
/*****************************************************************************
|
/*****************************************************************************
|
||||||
*
|
*
|
||||||
@ -111,4 +255,4 @@ enum {
|
|||||||
#define VNC_FEATURE_ZLIB_MASK (1 << VNC_FEATURE_ZLIB)
|
#define VNC_FEATURE_ZLIB_MASK (1 << VNC_FEATURE_ZLIB)
|
||||||
#define VNC_FEATURE_COPYRECT_MASK (1 << VNC_FEATURE_COPYRECT)
|
#define VNC_FEATURE_COPYRECT_MASK (1 << VNC_FEATURE_COPYRECT)
|
||||||
|
|
||||||
#endif /* __VNCTIGHT_H */
|
#endif /* __QEMU_VNC_H */
|
||||||
|
Loading…
Reference in New Issue
Block a user