VirtualBox

source: vbox/trunk/include/VBox/vrdpapi.h@ 21169

Last change on this file since 21169 was 20973, checked in by vboxsync, 16 years ago

Remote USB protocol version 3.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 41.9 KB
Line 
1/** @file
2 * VBox Remote Desktop Protocol:
3 * Public APIs.
4 */
5
6/*
7 * Copyright (C) 2006-2007 Sun Microsystems, Inc.
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 *
17 * The contents of this file may alternatively be used under the terms
18 * of the Common Development and Distribution License Version 1.0
19 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
20 * VirtualBox OSE distribution, in which case the provisions of the
21 * CDDL are applicable instead of those of the GPL.
22 *
23 * You may elect to license modified versions of this file under the
24 * terms and conditions of either the GPL or the CDDL or both.
25 *
26 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
27 * Clara, CA 95054 USA or visit http://www.sun.com if you need
28 * additional information or have any questions.
29 */
30
31#ifndef ___VBox_vrdpapi_h
32#define ___VBox_vrdpapi_h
33
34#include <iprt/cdefs.h>
35#include <iprt/types.h>
36
37#ifdef IN_RING0
38# error "There are no VRDP APIs available in Ring-0 Host Context!"
39#endif
40#ifdef IN_RC
41# error "There are no VRDP APIs available Guest Context!"
42#endif
43
44
45/** @defgroup grp_vrdp VRDP
46 * VirtualBox Remote Desktop Protocol (VRDP) interface that lets to use
47 * the VRDP server.
48 * @{
49 */
50
51/** Default port that VRDP binds to. */
52#define VRDP_DEFAULT_PORT (3389)
53
54RT_C_DECLS_BEGIN
55
56/* Forward declaration of the VRDP server instance handle. */
57#ifdef __cplusplus
58class VRDPServer;
59typedef class VRDPServer *HVRDPSERVER;
60#else
61struct VRDPServer;
62typedef struct VRDPServer *HVRDPSERVER;
63#endif /* __cplusplus */
64
65/* Callback based VRDP server interface declarations. */
66
67#if defined(IN_VRDP)
68# define VRDPDECL(type) DECLEXPORT(type) RTCALL
69#else
70# define VRDPDECL(type) DECLIMPORT(type) RTCALL
71#endif /* IN_VRDP */
72
73/** The color mouse pointer information. */
74typedef struct _VRDPCOLORPOINTER
75{
76 uint16_t u16HotX;
77 uint16_t u16HotY;
78 uint16_t u16Width;
79 uint16_t u16Height;
80 uint16_t u16MaskLen;
81 uint16_t u16DataLen;
82 /* The mask and the bitmap follow. */
83} VRDPCOLORPOINTER;
84
85/** Audio format information packed in a 32 bit value. */
86typedef uint32_t VRDPAUDIOFORMAT;
87
88/** Constructs 32 bit value for given frequency, number of channel and bits per sample. */
89#define VRDP_AUDIO_FMT_MAKE(freq, c, bps, s) ((((s) & 0x1) << 28) + (((bps) & 0xFF) << 20) + (((c) & 0xF) << 16) + ((freq) & 0xFFFF))
90
91/** Decode frequency. */
92#define VRDP_AUDIO_FMT_SAMPLE_FREQ(a) ((a) & 0xFFFF)
93/** Decode number of channels. */
94#define VRDP_AUDIO_FMT_CHANNELS(a) (((a) >> 16) & 0xF)
95/** Decode number signess. */
96#define VRDP_AUDIO_FMT_SIGNED(a) (((a) >> 28) & 0x1)
97/** Decode number of bits per sample. */
98#define VRDP_AUDIO_FMT_BITS_PER_SAMPLE(a) (((a) >> 20) & 0xFF)
99/** Decode number of bytes per sample. */
100#define VRDP_AUDIO_FMT_BYTES_PER_SAMPLE(a) ((VRDP_AUDIO_FMT_BITS_PER_SAMPLE(a) + 7) / 8)
101
102/*
103 * Remote USB protocol.
104 */
105
106/* The initial version 1. */
107#define VRDP_USB_VERSION_1 (1)
108/* Version 2: look for VRDP_USB_VERSION_2 comments in the code. */
109#define VRDP_USB_VERSION_2 (2)
110/* Version 3: look for VRDP_USB_VERSION_3 comments in the code. */
111#define VRDP_USB_VERSION_3 (3)
112
113/* The default VRDP server version of Remote USB Protocol. */
114#define VRDP_USB_VERSION VRDP_USB_VERSION_3
115
116
117/** USB backend operations. */
118#define VRDP_USB_REQ_OPEN (0)
119#define VRDP_USB_REQ_CLOSE (1)
120#define VRDP_USB_REQ_RESET (2)
121#define VRDP_USB_REQ_SET_CONFIG (3)
122#define VRDP_USB_REQ_CLAIM_INTERFACE (4)
123#define VRDP_USB_REQ_RELEASE_INTERFACE (5)
124#define VRDP_USB_REQ_INTERFACE_SETTING (6)
125#define VRDP_USB_REQ_QUEUE_URB (7)
126#define VRDP_USB_REQ_REAP_URB (8)
127#define VRDP_USB_REQ_CLEAR_HALTED_EP (9)
128#define VRDP_USB_REQ_CANCEL_URB (10)
129
130/** USB service operations. */
131#define VRDP_USB_REQ_DEVICE_LIST (11)
132#define VRDP_USB_REQ_NEGOTIATE (12)
133
134/** An operation completion status is a byte. */
135typedef uint8_t VRDPUSBSTATUS;
136
137/** USB device identifier is an 32 bit value. */
138typedef uint32_t VRDPUSBDEVID;
139
140/** Status codes. */
141#define VRDP_USB_STATUS_SUCCESS ((VRDPUSBSTATUS)0)
142#define VRDP_USB_STATUS_ACCESS_DENIED ((VRDPUSBSTATUS)1)
143#define VRDP_USB_STATUS_DEVICE_REMOVED ((VRDPUSBSTATUS)2)
144
145/*
146 * Data structures to use with VRDPUSBRequest.
147 * The *RET* structures always represent the layout of VRDP data.
148 * The *PARM* structures normally the same as VRDP layout.
149 * However the VRDP_USB_REQ_QUEUE_URB_PARM has a pointer to
150 * URB data in place where actual data will be in VRDP layout.
151 *
152 * Since replies (*RET*) are asynchronous, the 'success'
153 * replies are not required for operations which return
154 * only the status code (VRDPUSBREQRETHDR only):
155 * VRDP_USB_REQ_OPEN
156 * VRDP_USB_REQ_RESET
157 * VRDP_USB_REQ_SET_CONFIG
158 * VRDP_USB_REQ_CLAIM_INTERFACE
159 * VRDP_USB_REQ_RELEASE_INTERFACE
160 * VRDP_USB_REQ_INTERFACE_SETTING
161 * VRDP_USB_REQ_CLEAR_HALTED_EP
162 *
163 */
164
165/* VRDP layout has no aligments. */
166#pragma pack(1)
167/* Common header for all VRDP USB packets. After the reply hdr follows *PARM* or *RET* data. */
168typedef struct _VRDPUSBPKTHDR
169{
170 /* Total length of the reply NOT including the 'length' field. */
171 uint32_t length;
172 /* The operation code for which the reply was sent by the client. */
173 uint8_t code;
174} VRDPUSBPKTHDR;
175
176/* Common header for all return structures. */
177typedef struct _VRDPUSBREQRETHDR
178{
179 /* Device status. */
180 VRDPUSBSTATUS status;
181 /* Device id. */
182 VRDPUSBDEVID id;
183} VRDPUSBREQRETHDR;
184
185
186/* VRDP_USB_REQ_OPEN
187 */
188typedef struct _VRDP_USB_REQ_OPEN_PARM
189{
190 uint8_t code;
191 VRDPUSBDEVID id;
192} VRDP_USB_REQ_OPEN_PARM;
193
194typedef struct _VRDP_USB_REQ_OPEN_RET
195{
196 VRDPUSBREQRETHDR hdr;
197} VRDP_USB_REQ_OPEN_RET;
198
199
200/* VRDP_USB_REQ_CLOSE
201 */
202typedef struct _VRDP_USB_REQ_CLOSE_PARM
203{
204 uint8_t code;
205 VRDPUSBDEVID id;
206} VRDP_USB_REQ_CLOSE_PARM;
207
208/* The close request has no returned data. */
209
210
211/* VRDP_USB_REQ_RESET
212 */
213typedef struct _VRDP_USB_REQ_RESET_PARM
214{
215 uint8_t code;
216 VRDPUSBDEVID id;
217} VRDP_USB_REQ_RESET_PARM;
218
219typedef struct _VRDP_USB_REQ_RESET_RET
220{
221 VRDPUSBREQRETHDR hdr;
222} VRDP_USB_REQ_RESET_RET;
223
224
225/* VRDP_USB_REQ_SET_CONFIG
226 */
227typedef struct _VRDP_USB_REQ_SET_CONFIG_PARM
228{
229 uint8_t code;
230 VRDPUSBDEVID id;
231 uint8_t configuration;
232} VRDP_USB_REQ_SET_CONFIG_PARM;
233
234typedef struct _VRDP_USB_REQ_SET_CONFIG_RET
235{
236 VRDPUSBREQRETHDR hdr;
237} VRDP_USB_REQ_SET_CONFIG_RET;
238
239
240/* VRDP_USB_REQ_CLAIM_INTERFACE
241 */
242typedef struct _VRDP_USB_REQ_CLAIM_INTERFACE_PARM
243{
244 uint8_t code;
245 VRDPUSBDEVID id;
246 uint8_t iface;
247} VRDP_USB_REQ_CLAIM_INTERFACE_PARM;
248
249typedef struct _VRDP_USB_REQ_CLAIM_INTERFACE_RET
250{
251 VRDPUSBREQRETHDR hdr;
252} VRDP_USB_REQ_CLAIM_INTERFACE_RET;
253
254
255/* VRDP_USB_REQ_RELEASE_INTERFACE
256 */
257typedef struct _VRDP_USB_REQ_RELEASE_INTERFACE_PARM
258{
259 uint8_t code;
260 VRDPUSBDEVID id;
261 uint8_t iface;
262} VRDP_USB_REQ_RELEASE_INTERFACE_PARM;
263
264typedef struct _VRDP_USB_REQ_RELEASE_INTERFACE_RET
265{
266 VRDPUSBREQRETHDR hdr;
267} VRDP_USB_REQ_RELEASE_INTERFACE_RET;
268
269
270/* VRDP_USB_REQ_INTERFACE_SETTING
271 */
272typedef struct _VRDP_USB_REQ_INTERFACE_SETTING_PARM
273{
274 uint8_t code;
275 VRDPUSBDEVID id;
276 uint8_t iface;
277 uint8_t setting;
278} VRDP_USB_REQ_INTERFACE_SETTING_PARM;
279
280typedef struct _VRDP_USB_REQ_INTERFACE_SETTING_RET
281{
282 VRDPUSBREQRETHDR hdr;
283} VRDP_USB_REQ_INTERFACE_SETTING_RET;
284
285
286/* VRDP_USB_REQ_QUEUE_URB
287 */
288
289#define VRDP_USB_TRANSFER_TYPE_CTRL (0)
290#define VRDP_USB_TRANSFER_TYPE_ISOC (1)
291#define VRDP_USB_TRANSFER_TYPE_BULK (2)
292#define VRDP_USB_TRANSFER_TYPE_INTR (3)
293#define VRDP_USB_TRANSFER_TYPE_MSG (4)
294
295#define VRDP_USB_DIRECTION_SETUP (0)
296#define VRDP_USB_DIRECTION_IN (1)
297#define VRDP_USB_DIRECTION_OUT (2)
298
299typedef struct _VRDP_USB_REQ_QUEUE_URB_PARM
300{
301 uint8_t code;
302 VRDPUSBDEVID id;
303 uint32_t handle; /* Distinguishes that particular URB. Later used in CancelURB and returned by ReapURB */
304 uint8_t type;
305 uint8_t ep;
306 uint8_t direction;
307 uint32_t urblen; /* Length of the URB. */
308 uint32_t datalen; /* Length of the data. */
309 void *data; /* In RDP layout the data follow. */
310} VRDP_USB_REQ_QUEUE_URB_PARM;
311
312/* The queue URB has no explicit return. The reap URB reply will be
313 * eventually the indirect result.
314 */
315
316
317/* VRDP_USB_REQ_REAP_URB
318 * Notificationg from server to client that server expects an URB
319 * from any device.
320 * Only sent if negotiated URB return method is polling.
321 * Normally, the client will send URBs back as soon as they are ready.
322 */
323typedef struct _VRDP_USB_REQ_REAP_URB_PARM
324{
325 uint8_t code;
326} VRDP_USB_REQ_REAP_URB_PARM;
327
328
329#define VRDP_USB_XFER_OK (0)
330#define VRDP_USB_XFER_STALL (1)
331#define VRDP_USB_XFER_DNR (2)
332#define VRDP_USB_XFER_CRC (3)
333/* VRDP_USB_VERSION_2: New error codes. */
334#define VRDP_USB_XFER_BS (4)
335#define VRDP_USB_XFER_DTM (5)
336#define VRDP_USB_XFER_PCF (6)
337#define VRDP_USB_XFER_UPID (7)
338#define VRDP_USB_XFER_DO (8)
339#define VRDP_USB_XFER_DU (9)
340#define VRDP_USB_XFER_BO (10)
341#define VRDP_USB_XFER_BU (11)
342#define VRDP_USB_XFER_ERR (12) /* VBox protocol error. */
343
344#define VRDP_USB_REAP_FLAG_CONTINUED (0x0)
345#define VRDP_USB_REAP_FLAG_LAST (0x1)
346/* VRDP_USB_VERSION_3: Fragmented URBs. */
347#define VRDP_USB_REAP_FLAG_FRAGMENT (0x2)
348
349#define VRDP_USB_REAP_VALID_FLAGS (VRDP_USB_REAP_FLAG_LAST)
350/* VRDP_USB_VERSION_3: Fragmented URBs. */
351#define VRDP_USB_REAP_VALID_FLAGS_3 (VRDP_USB_REAP_FLAG_LAST | VRDP_USB_REAP_FLAG_FRAGMENT)
352
353typedef struct _VRDPUSBREQREAPURBBODY
354{
355 VRDPUSBDEVID id; /* From which device the URB arrives. */
356 uint8_t flags; /* VRDP_USB_REAP_FLAG_* */
357 uint8_t error; /* VRDP_USB_XFER_* */
358 uint32_t handle; /* Handle of returned URB. Not 0. */
359 uint32_t len; /* Length of data actually transferred. */
360 /* Data follow. */
361} VRDPUSBREQREAPURBBODY;
362
363typedef struct _VRDP_USB_REQ_REAP_URB_RET
364{
365 /* The REAP URB has no header, only completed URBs are returned. */
366 VRDPUSBREQREAPURBBODY body;
367 /* Another body may follow, depending on flags. */
368} VRDP_USB_REQ_REAP_URB_RET;
369
370
371/* VRDP_USB_REQ_CLEAR_HALTED_EP
372 */
373typedef struct _VRDP_USB_REQ_CLEAR_HALTED_EP_PARM
374{
375 uint8_t code;
376 VRDPUSBDEVID id;
377 uint8_t ep;
378} VRDP_USB_REQ_CLEAR_HALTED_EP_PARM;
379
380typedef struct _VRDP_USB_REQ_CLEAR_HALTED_EP_RET
381{
382 VRDPUSBREQRETHDR hdr;
383} VRDP_USB_REQ_CLEAR_HALTED_EP_RET;
384
385
386/* VRDP_USB_REQ_CANCEL_URB
387 */
388typedef struct _VRDP_USB_REQ_CANCEL_URB_PARM
389{
390 uint8_t code;
391 VRDPUSBDEVID id;
392 uint32_t handle;
393} VRDP_USB_REQ_CANCEL_URB_PARM;
394
395/* The cancel URB request has no return. */
396
397
398/* VRDP_USB_REQ_DEVICE_LIST
399 *
400 * Server polls USB devices on client by sending this request
401 * periodically. Client sends back a list of all devices
402 * connected to it. Each device is assigned with an identifier,
403 * that is used to distinguish the particular device.
404 */
405typedef struct _VRDP_USB_REQ_DEVICE_LIST_PARM
406{
407 uint8_t code;
408} VRDP_USB_REQ_DEVICE_LIST_PARM;
409
410/* Data is a list of the following variable length structures. */
411typedef struct _VRDPUSBDEVICEDESC
412{
413 /* Offset of the next structure. 0 if last. */
414 uint16_t oNext;
415
416 /* Identifier of the device assigned by client. */
417 VRDPUSBDEVID id;
418
419 /** USB version number. */
420 uint16_t bcdUSB;
421 /** Device class. */
422 uint8_t bDeviceClass;
423 /** Device subclass. */
424 uint8_t bDeviceSubClass;
425 /** Device protocol */
426 uint8_t bDeviceProtocol;
427 /** Vendor ID. */
428 uint16_t idVendor;
429 /** Product ID. */
430 uint16_t idProduct;
431 /** Revision, integer part. */
432 uint16_t bcdRev;
433 /** Manufacturer string. */
434 uint16_t oManufacturer;
435 /** Product string. */
436 uint16_t oProduct;
437 /** Serial number string. */
438 uint16_t oSerialNumber;
439 /** Physical USB port the device is connected to. */
440 uint16_t idPort;
441
442} VRDPUSBDEVICEDESC;
443
444typedef struct _VRDP_USB_REQ_DEVICE_LIST_RET
445{
446 VRDPUSBDEVICEDESC body;
447 /* Other devices may follow.
448 * The list ends with (uint16_t)0,
449 * which means that an empty list consists of 2 zero bytes.
450 */
451} VRDP_USB_REQ_DEVICE_LIST_RET;
452
453typedef struct _VRDPUSBREQNEGOTIATEPARM
454{
455 uint8_t code;
456
457 /* Remote USB Protocol version. */
458 /* VRDP_USB_VERSION_3: the 32 bit field is splitted to 16 bit version and 16 bit flags.
459 * Version 1 and 2 servers therefore have 'flags' == 0.
460 * Version 3+ servers can send some capabilities in this field, this way it is possible to add
461 * a new capability without increasing the protocol version.
462 */
463 uint16_t version;
464 uint16_t flags;
465
466} VRDPUSBREQNEGOTIATEPARM;
467
468#define VRDP_USB_CAPS_FLAG_ASYNC (0x0)
469#define VRDP_USB_CAPS_FLAG_POLL (0x1)
470/* VRDP_USB_VERSION_2: New flag. */
471#define VRDP_USB_CAPS2_FLAG_VERSION (0x2) /* The client is negotiating the protocol version. */
472
473
474#define VRDP_USB_CAPS_VALID_FLAGS (VRDP_USB_CAPS_FLAG_POLL)
475/* VRDP_USB_VERSION_2: A set of valid flags. */
476#define VRDP_USB_CAPS2_VALID_FLAGS (VRDP_USB_CAPS_FLAG_POLL | VRDP_USB_CAPS2_FLAG_VERSION)
477
478typedef struct _VRDPUSBREQNEGOTIATERET
479{
480 uint8_t flags;
481} VRDPUSBREQNEGOTIATERET;
482
483typedef struct _VRDPUSBREQNEGOTIATERET_2
484{
485 uint8_t flags;
486 uint32_t u32Version; /* This field presents only if the VRDP_USB_CAPS2_FLAG_VERSION flag is set. */
487} VRDPUSBREQNEGOTIATERET_2;
488#pragma pack()
489
490#define VRDP_CLIPBOARD_FORMAT_NULL (0x0)
491#define VRDP_CLIPBOARD_FORMAT_UNICODE_TEXT (0x1)
492#define VRDP_CLIPBOARD_FORMAT_BITMAP (0x2)
493#define VRDP_CLIPBOARD_FORMAT_HTML (0x4)
494
495#define VRDP_CLIPBOARD_FUNCTION_FORMAT_ANNOUNCE (0)
496#define VRDP_CLIPBOARD_FUNCTION_DATA_READ (1)
497#define VRDP_CLIPBOARD_FUNCTION_DATA_WRITE (2)
498
499
500/** Indexes of information values. */
501
502/** Whether a client is connected at the moment.
503 * uint32_t
504 */
505#define VRDP_QI_ACTIVE (0)
506
507/** How many times a client connected up to current moment.
508 * uint32_t
509 */
510#define VRDP_QI_NUMBER_OF_CLIENTS (1)
511
512/** When last connection was established.
513 * int64_t time in milliseconds since 1970-01-01 00:00:00 UTC
514 */
515#define VRDP_QI_BEGIN_TIME (2)
516
517/** When last connection was terminated or current time if connection still active.
518 * int64_t time in milliseconds since 1970-01-01 00:00:00 UTC
519 */
520#define VRDP_QI_END_TIME (3)
521
522/** How many bytes were sent in last (current) connection.
523 * uint64_t
524 */
525#define VRDP_QI_BYTES_SENT (4)
526
527/** How many bytes were sent in all connections.
528 * uint64_t
529 */
530#define VRDP_QI_BYTES_SENT_TOTAL (5)
531
532/** How many bytes were received in last (current) connection.
533 * uint64_t
534 */
535#define VRDP_QI_BYTES_RECEIVED (6)
536
537/** How many bytes were received in all connections.
538 * uint64_t
539 */
540#define VRDP_QI_BYTES_RECEIVED_TOTAL (7)
541
542/** Login user name supplied by the client.
543 * UTF8 nul terminated string.
544 */
545#define VRDP_QI_USER (8)
546
547/** Login domain supplied by the client.
548 * UTF8 nul terminated string.
549 */
550#define VRDP_QI_DOMAIN (9)
551
552/** The client name supplied by the client.
553 * UTF8 nul terminated string.
554 */
555#define VRDP_QI_CLIENT_NAME (10)
556
557/** IP address of the client.
558 * UTF8 nul terminated string.
559 */
560#define VRDP_QI_CLIENT_IP (11)
561
562/** The client software version number.
563 * uint32_t.
564 */
565#define VRDP_QI_CLIENT_VERSION (12)
566
567/** Public key exchange method used when connection was established.
568 * Values: 0 - RDP4 public key exchange scheme.
569 * 1 - X509 sertificates were sent to client.
570 * uint32_t.
571 */
572#define VRDP_QI_ENCRYPTION_STYLE (13)
573
574
575/** Hints what has been intercepted by the application. */
576#define VRDP_CLIENT_INTERCEPT_AUDIO (0x1)
577#define VRDP_CLIENT_INTERCEPT_USB (0x2)
578#define VRDP_CLIENT_INTERCEPT_CLIPBOARD (0x4)
579
580
581/** The version of the VRDP server interface. */
582#define VRDP_INTERFACE_VERSION_1 (1)
583#define VRDP_INTERFACE_VERSION_2 (2)
584
585/** The header that does not change when the interface changes. */
586typedef struct _VRDPINTERFACEHDR
587{
588 /** The version of the interface. */
589 uint64_t u64Version;
590
591 /** The size of the structure. */
592 uint64_t u64Size;
593
594} VRDPINTERFACEHDR;
595
596/** The VRDP server entry points. Interface version 1. */
597typedef struct _VRDPENTRYPOINTS_1
598{
599 /** The header. */
600 VRDPINTERFACEHDR header;
601
602 /** Destroy the server instance.
603 *
604 * @param hServer The server instance handle.
605 *
606 * @return IPRT status code.
607 */
608 DECLR3CALLBACKMEMBER(void, VRDPDestroy,(HVRDPSERVER hServer));
609
610 /** The server should start to accept clients connections.
611 *
612 * @param hServer The server instance handle.
613 * @param fEnable Whether to enable or disable client connections.
614 * When is false, all existing clients are disconnected.
615 *
616 * @return IPRT status code.
617 */
618 DECLR3CALLBACKMEMBER(int, VRDPEnableConnections,(HVRDPSERVER hServer,
619 bool fEnable));
620
621 /** The server should disconnect the client.
622 *
623 * @param hServer The server instance handle.
624 * @param u32ClientId The client identifier.
625 * @param fReconnect Whether to send a "REDIRECT to the same server" packet to the
626 * client before disconnecting.
627 *
628 * @return IPRT status code.
629 */
630 DECLR3CALLBACKMEMBER(void, VRDPDisconnect,(HVRDPSERVER hServer,
631 uint32_t u32ClientId,
632 bool fReconnect));
633
634 /**
635 * Inform the server that the display was resized.
636 * The server will query information about display
637 * from the application via callbacks.
638 *
639 * @param hServer Handle of VRDP server instance.
640 */
641 DECLR3CALLBACKMEMBER(void, VRDPResize,(HVRDPSERVER hServer));
642
643 /**
644 * Send a update.
645 *
646 * @param hServer Handle of VRDP server instance.
647 * @param uScreenId The screen index.
648 * @param pvUpdate Pointer to VBoxGuest.h::VRDPORDERHDR structure with extra data.
649 * @param cbUpdate Size of the update data.
650 */
651 DECLR3CALLBACKMEMBER(void, VRDPUpdate,(HVRDPSERVER hServer,
652 unsigned uScreenId,
653 void *pvUpdate,
654 uint32_t cbUpdate));
655
656 /**
657 * Set the mouse pointer shape.
658 *
659 * @param hServer Handle of VRDP server instance.
660 * @param pPointer The pointer shape information.
661 */
662 DECLR3CALLBACKMEMBER(void, VRDPColorPointer,(HVRDPSERVER hServer,
663 const VRDPCOLORPOINTER *pPointer));
664
665 /**
666 * Hide the mouse pointer.
667 *
668 * @param hServer Handle of VRDP server instance.
669 */
670 DECLR3CALLBACKMEMBER(void, VRDPHidePointer,(HVRDPSERVER hServer));
671
672 /**
673 * Queues the samples to be sent to clients.
674 *
675 * @param hServer Handle of VRDP server instance.
676 * @param pvSamples Address of samples to be sent.
677 * @param cSamples Number of samples.
678 * @param format Encoded audio format for these samples.
679 *
680 * @note Initialized to NULL when the application audio callbacks are NULL.
681 */
682 DECLR3CALLBACKMEMBER(void, VRDPAudioSamples,(HVRDPSERVER hServer,
683 const void *pvSamples,
684 uint32_t cSamples,
685 VRDPAUDIOFORMAT format));
686
687 /**
688 * Sets the sound volume on clients.
689 *
690 * @param hServer Handle of VRDP server instance.
691 * @param left 0..0xFFFF volume level for left channel.
692 * @param right 0..0xFFFF volume level for right channel.
693 *
694 * @note Initialized to NULL when the application audio callbacks are NULL.
695 */
696 DECLR3CALLBACKMEMBER(void, VRDPAudioVolume,(HVRDPSERVER hServer,
697 uint16_t u16Left,
698 uint16_t u16Right));
699
700 /**
701 * Sends a USB request.
702 *
703 * @param hServer Handle of VRDP server instance.
704 * @param u32ClientId An identifier that allows the server to find the corresponding client.
705 * The identifier is always passed by the server as a parameter
706 * of the FNVRDPUSBCALLBACK. Note that the value is the same as
707 * in the VRDPSERVERCALLBACK functions.
708 * @param pvParm Function specific parameters buffer.
709 * @param cbParm Size of the buffer.
710 *
711 * @note Initialized to NULL when the application USB callbacks are NULL.
712 */
713 DECLR3CALLBACKMEMBER(void, VRDPUSBRequest,(HVRDPSERVER hServer,
714 uint32_t u32ClientId,
715 void *pvParm,
716 uint32_t cbParm));
717
718 /**
719 * Called by the application when (VRDP_CLIPBOARD_FUNCTION_*):
720 * - (0) guest announces available clipboard formats;
721 * - (1) guest requests clipboard data;
722 * - (2) guest responds to the client's request for clipboard data.
723 *
724 * @param hServer The VRDP server handle.
725 * @param u32Function The cause of the call.
726 * @param u32Format Bitmask of announced formats or the format of data.
727 * @param pvData Points to: (1) buffer to be filled with clients data;
728 * (2) data from the host.
729 * @param cbData Size of 'pvData' buffer in bytes.
730 * @param pcbActualRead Size of the copied data in bytes.
731 *
732 * @note Initialized to NULL when the application clipboard callbacks are NULL.
733 */
734 DECLR3CALLBACKMEMBER(void, VRDPClipboard,(HVRDPSERVER hServer,
735 uint32_t u32Function,
736 uint32_t u32Format,
737 void *pvData,
738 uint32_t cbData,
739 uint32_t *pcbActualRead));
740
741 /**
742 * Query various information from the VRDP server.
743 *
744 * @param hServer The VRDP server handle.
745 * @param index VRDP_QI_* identifier of information to be returned.
746 * @param pvBuffer Address of memory buffer to which the information must be written.
747 * @param cbBuffer Size of the memory buffer in bytes.
748 * @param pcbOut Size in bytes of returned information value.
749 *
750 * @remark The caller must check the *pcbOut. 0 there means no information was returned.
751 * A value greater than cbBuffer means that information is too big to fit in the
752 * buffer, in that case no information was placed to the buffer.
753 */
754 DECLR3CALLBACKMEMBER(void, VRDPQueryInfo,(HVRDPSERVER hServer,
755 uint32_t index,
756 void *pvBuffer,
757 uint32_t cbBuffer,
758 uint32_t *pcbOut));
759} VRDPENTRYPOINTS_1;
760
761/** The VRDP server entry points. Interface version 2.
762 * A new entry point VRDPRedirect has been added relative to version 1.
763 */
764typedef struct _VRDPENTRYPOINTS_2
765{
766 /** The header. */
767 VRDPINTERFACEHDR header;
768
769 /** Destroy the server instance.
770 *
771 * @param hServer The server instance handle.
772 *
773 * @return IPRT status code.
774 */
775 DECLR3CALLBACKMEMBER(void, VRDPDestroy,(HVRDPSERVER hServer));
776
777 /** The server should start to accept clients connections.
778 *
779 * @param hServer The server instance handle.
780 * @param fEnable Whether to enable or disable client connections.
781 * When is false, all existing clients are disconnected.
782 *
783 * @return IPRT status code.
784 */
785 DECLR3CALLBACKMEMBER(int, VRDPEnableConnections,(HVRDPSERVER hServer,
786 bool fEnable));
787
788 /** The server should disconnect the client.
789 *
790 * @param hServer The server instance handle.
791 * @param u32ClientId The client identifier.
792 * @param fReconnect Whether to send a "REDIRECT to the same server" packet to the
793 * client before disconnecting.
794 *
795 * @return IPRT status code.
796 */
797 DECLR3CALLBACKMEMBER(void, VRDPDisconnect,(HVRDPSERVER hServer,
798 uint32_t u32ClientId,
799 bool fReconnect));
800
801 /**
802 * Inform the server that the display was resized.
803 * The server will query information about display
804 * from the application via callbacks.
805 *
806 * @param hServer Handle of VRDP server instance.
807 */
808 DECLR3CALLBACKMEMBER(void, VRDPResize,(HVRDPSERVER hServer));
809
810 /**
811 * Send a update.
812 *
813 * @param hServer Handle of VRDP server instance.
814 * @param uScreenId The screen index.
815 * @param pvUpdate Pointer to VBoxGuest.h::VRDPORDERHDR structure with extra data.
816 * @param cbUpdate Size of the update data.
817 */
818 DECLR3CALLBACKMEMBER(void, VRDPUpdate,(HVRDPSERVER hServer,
819 unsigned uScreenId,
820 void *pvUpdate,
821 uint32_t cbUpdate));
822
823 /**
824 * Set the mouse pointer shape.
825 *
826 * @param hServer Handle of VRDP server instance.
827 * @param pPointer The pointer shape information.
828 */
829 DECLR3CALLBACKMEMBER(void, VRDPColorPointer,(HVRDPSERVER hServer,
830 const VRDPCOLORPOINTER *pPointer));
831
832 /**
833 * Hide the mouse pointer.
834 *
835 * @param hServer Handle of VRDP server instance.
836 */
837 DECLR3CALLBACKMEMBER(void, VRDPHidePointer,(HVRDPSERVER hServer));
838
839 /**
840 * Queues the samples to be sent to clients.
841 *
842 * @param hServer Handle of VRDP server instance.
843 * @param pvSamples Address of samples to be sent.
844 * @param cSamples Number of samples.
845 * @param format Encoded audio format for these samples.
846 *
847 * @note Initialized to NULL when the application audio callbacks are NULL.
848 */
849 DECLR3CALLBACKMEMBER(void, VRDPAudioSamples,(HVRDPSERVER hServer,
850 const void *pvSamples,
851 uint32_t cSamples,
852 VRDPAUDIOFORMAT format));
853
854 /**
855 * Sets the sound volume on clients.
856 *
857 * @param hServer Handle of VRDP server instance.
858 * @param left 0..0xFFFF volume level for left channel.
859 * @param right 0..0xFFFF volume level for right channel.
860 *
861 * @note Initialized to NULL when the application audio callbacks are NULL.
862 */
863 DECLR3CALLBACKMEMBER(void, VRDPAudioVolume,(HVRDPSERVER hServer,
864 uint16_t u16Left,
865 uint16_t u16Right));
866
867 /**
868 * Sends a USB request.
869 *
870 * @param hServer Handle of VRDP server instance.
871 * @param u32ClientId An identifier that allows the server to find the corresponding client.
872 * The identifier is always passed by the server as a parameter
873 * of the FNVRDPUSBCALLBACK. Note that the value is the same as
874 * in the VRDPSERVERCALLBACK functions.
875 * @param pvParm Function specific parameters buffer.
876 * @param cbParm Size of the buffer.
877 *
878 * @note Initialized to NULL when the application USB callbacks are NULL.
879 */
880 DECLR3CALLBACKMEMBER(void, VRDPUSBRequest,(HVRDPSERVER hServer,
881 uint32_t u32ClientId,
882 void *pvParm,
883 uint32_t cbParm));
884
885 /**
886 * Called by the application when (VRDP_CLIPBOARD_FUNCTION_*):
887 * - (0) guest announces available clipboard formats;
888 * - (1) guest requests clipboard data;
889 * - (2) guest responds to the client's request for clipboard data.
890 *
891 * @param hServer The VRDP server handle.
892 * @param u32Function The cause of the call.
893 * @param u32Format Bitmask of announced formats or the format of data.
894 * @param pvData Points to: (1) buffer to be filled with clients data;
895 * (2) data from the host.
896 * @param cbData Size of 'pvData' buffer in bytes.
897 * @param pcbActualRead Size of the copied data in bytes.
898 *
899 * @note Initialized to NULL when the application clipboard callbacks are NULL.
900 */
901 DECLR3CALLBACKMEMBER(void, VRDPClipboard,(HVRDPSERVER hServer,
902 uint32_t u32Function,
903 uint32_t u32Format,
904 void *pvData,
905 uint32_t cbData,
906 uint32_t *pcbActualRead));
907
908 /**
909 * Query various information from the VRDP server.
910 *
911 * @param hServer The VRDP server handle.
912 * @param index VRDP_QI_* identifier of information to be returned.
913 * @param pvBuffer Address of memory buffer to which the information must be written.
914 * @param cbBuffer Size of the memory buffer in bytes.
915 * @param pcbOut Size in bytes of returned information value.
916 *
917 * @remark The caller must check the *pcbOut. 0 there means no information was returned.
918 * A value greater than cbBuffer means that information is too big to fit in the
919 * buffer, in that case no information was placed to the buffer.
920 */
921 DECLR3CALLBACKMEMBER(void, VRDPQueryInfo,(HVRDPSERVER hServer,
922 uint32_t index,
923 void *pvBuffer,
924 uint32_t cbBuffer,
925 uint32_t *pcbOut));
926
927 /**
928 * The server should redirect the client to the specified server.
929 *
930 * @param hServer The server instance handle.
931 * @param u32ClientId The client identifier.
932 * @param pszServer The server to redirect the client to.
933 * @param pszUser The username to use for the redirection.
934 * Can be NULL.
935 * @param pszDomain The domain. Can be NULL.
936 * @param pszPassword The password. Can be NULL.
937 * @param u32SessionId The ID of the session to redirect to.
938 * @param pszCookie The routing token used by a load balancer to
939 * route the redirection. Can be NULL.
940 */
941 DECLR3CALLBACKMEMBER(void, VRDPRedirect,(HVRDPSERVER hServer,
942 uint32_t u32ClientId,
943 const char *pszServer,
944 const char *pszUser,
945 const char *pszDomain,
946 const char *pszPassword,
947 uint32_t u32SessionId,
948 const char *pszCookie));
949} VRDPENTRYPOINTS_2;
950
951#define VRDP_QP_NETWORK_PORT (1)
952#define VRDP_QP_NETWORK_ADDRESS (2)
953#define VRDP_QP_NUMBER_MONITORS (3)
954
955#pragma pack(1)
956/* A framebuffer description. */
957typedef struct _VRDPFRAMEBUFFERINFO
958{
959 const uint8_t *pu8Bits;
960 int xOrigin;
961 int yOrigin;
962 unsigned cWidth;
963 unsigned cHeight;
964 unsigned cBitsPerPixel;
965 unsigned cbLine;
966} VRDPFRAMEBUFFERINFO;
967
968#define VRDP_INPUT_SCANCODE 0
969#define VRDP_INPUT_POINT 1
970#define VRDP_INPUT_CAD 2
971#define VRDP_INPUT_RESET 3
972#define VRDP_INPUT_SYNCH 4
973
974typedef struct _VRDPINPUTSCANCODE
975{
976 unsigned uScancode;
977} VRDPINPUTSCANCODE;
978
979#define VRDP_INPUT_POINT_BUTTON1 0x01
980#define VRDP_INPUT_POINT_BUTTON2 0x02
981#define VRDP_INPUT_POINT_BUTTON3 0x04
982#define VRDP_INPUT_POINT_WHEEL_UP 0x08
983#define VRDP_INPUT_POINT_WHEEL_DOWN 0x10
984
985typedef struct _VRDPINPUTPOINT
986{
987 int x;
988 int y;
989 unsigned uButtons;
990} VRDPINPUTPOINT;
991
992#define VRDP_INPUT_SYNCH_SCROLL 0x01
993#define VRDP_INPUT_SYNCH_NUMLOCK 0x02
994#define VRDP_INPUT_SYNCH_CAPITAL 0x04
995
996typedef struct _VRDPINPUTSYNCH
997{
998 unsigned uLockStatus;
999} VRDPINPUTSYNCH;
1000#pragma pack()
1001
1002/** The VRDP server callbacks. Interface version 1. */
1003typedef struct _VRDPCALLBACKS_1
1004{
1005 /** The header. */
1006 VRDPINTERFACEHDR header;
1007
1008 /**
1009 * Query various information, on how the VRDP server must operate, from the application.
1010 *
1011 * @param pvCallback The callback specific pointer.
1012 * @param index VRDP_QP_* identifier of information to be returned.
1013 * @param pvBuffer Address of memory buffer to which the information must be written.
1014 * @param cbBuffer Size of the memory buffer in bytes.
1015 * @param pcbOut Size in bytes of returned information value.
1016 *
1017 * @return IPRT status code. VINF_BUFFER_OVERFLOW if the buffer is too small for the value.
1018 */
1019 DECLR3CALLBACKMEMBER(int, VRDPCallbackQueryProperty,(void *pvCallback,
1020 uint32_t index,
1021 void *pvBuffer,
1022 uint32_t cbBuffer,
1023 uint32_t *pcbOut));
1024
1025 /* A client is logging in, the application must decide whether
1026 * to let to connect the client. The server will drop the connection,
1027 * when an error code is returned by the callback.
1028 *
1029 * @param pvCallback The callback specific pointer.
1030 * @param u32ClientId An unique client identifier generated by the server.
1031 * @param pszUser The username.
1032 * @param pszPassword The password.
1033 * @param pszDomain The domain.
1034 *
1035 * @return IPRT status code.
1036 */
1037 DECLR3CALLBACKMEMBER(int, VRDPCallbackClientLogon,(void *pvCallback,
1038 uint32_t u32ClientId,
1039 const char *pszUser,
1040 const char *pszPassword,
1041 const char *pszDomain));
1042
1043 /* The client has been successfully connected.
1044 *
1045 * @param pvCallback The callback specific pointer.
1046 * @param u32ClientId An unique client identifier generated by the server.
1047 */
1048 DECLR3CALLBACKMEMBER(void, VRDPCallbackClientConnect,(void *pvCallback,
1049 uint32_t u32ClientId));
1050
1051 /* The client has been disconnected.
1052 *
1053 * @param pvCallback The callback specific pointer.
1054 * @param u32ClientId An unique client identifier generated by the server.
1055 * @param fu32Intercepted What was intercepted by the client (VRDP_CLIENT_INTERCEPT_*).
1056 */
1057 DECLR3CALLBACKMEMBER(void, VRDPCallbackClientDisconnect,(void *pvCallback,
1058 uint32_t u32ClientId,
1059 uint32_t fu32Intercepted));
1060 /* The client supports one of RDP channels.
1061 *
1062 * @param pvCallback The callback specific pointer.
1063 * @param u32ClientId An unique client identifier generated by the server.
1064 * @param fu32Intercept What the client wants to intercept. One of VRDP_CLIENT_INTERCEPT_* flags.
1065 * @param ppvIntercept The value to be passed to the channel specific callback.
1066 *
1067 * @return IPRT status code.
1068 */
1069 DECLR3CALLBACKMEMBER(int, VRDPCallbackIntercept,(void *pvCallback,
1070 uint32_t u32ClientId,
1071 uint32_t fu32Intercept,
1072 void **ppvIntercept));
1073
1074 /**
1075 * Called by the server when a reply is received from a client.
1076 *
1077 * @param pvCallback The callback specific pointer.
1078 * @param ppvIntercept The value returned by VRDPCallbackIntercept for the VRDP_CLIENT_INTERCEPT_USB.
1079 * @param u32ClientId Identifies the client that sent the reply.
1080 * @param u8Code The operation code VRDP_USB_REQ_*.
1081 * @param pvRet Points to data received from the client.
1082 * @param cbRet Size of the data in bytes.
1083 *
1084 * @return IPRT status code.
1085 */
1086 DECLR3CALLBACKMEMBER(int, VRDPCallbackUSB,(void *pvCallback,
1087 void *pvIntercept,
1088 uint32_t u32ClientId,
1089 uint8_t u8Code,
1090 const void *pvRet,
1091 uint32_t cbRet));
1092
1093 /**
1094 * Called by the server when (VRDP_CLIPBOARD_FUNCTION_*):
1095 * - (0) client announces available clipboard formats;
1096 * - (1) client requests clipboard data.
1097 *
1098 * @param pvCallback The callback specific pointer.
1099 * @param ppvIntercept The value returned by VRDPCallbackIntercept for the VRDP_CLIENT_INTERCEPT_CLIPBOARD.
1100 * @param u32ClientId Identifies the RDP client that sent the reply.
1101 * @param u32Function The cause of the callback.
1102 * @param u32Format Bitmask of reported formats or the format of received data.
1103 * @param pvData Reserved.
1104 * @param cbData Reserved.
1105 *
1106 * @return IPRT status code.
1107 */
1108 DECLR3CALLBACKMEMBER(int, VRDPCallbackClipboard,(void *pvCallback,
1109 void *pvIntercept,
1110 uint32_t u32ClientId,
1111 uint32_t u32Function,
1112 uint32_t u32Format,
1113 const void *pvData,
1114 uint32_t cbData));
1115
1116 /* The framebuffer information is queried.
1117 *
1118 * @param pvCallback The callback specific pointer.
1119 * @param uScreenId The framebuffer index.
1120 * @param pInfo The information structure to ber filled.
1121 *
1122 * @return Whether the framebuffer is available.
1123 */
1124 DECLR3CALLBACKMEMBER(bool, VRDPCallbackFramebufferQuery,(void *pvCallback,
1125 unsigned uScreenId,
1126 VRDPFRAMEBUFFERINFO *pInfo));
1127
1128 /* The framebuffer is locked.
1129 *
1130 * @param pvCallback The callback specific pointer.
1131 * @param uScreenId The framebuffer index.
1132 */
1133 DECLR3CALLBACKMEMBER(void, VRDPCallbackFramebufferLock,(void *pvCallback,
1134 unsigned uScreenId));
1135
1136 /* The framebuffer is unlocked.
1137 *
1138 * @param pvCallback The callback specific pointer.
1139 * @param uScreenId The framebuffer index.
1140 */
1141 DECLR3CALLBACKMEMBER(void, VRDPCallbackFramebufferUnlock,(void *pvCallback,
1142 unsigned uScreenId));
1143
1144 /* Input from the client.
1145 *
1146 * @param pvCallback The callback specific pointer.
1147 * @param pvInput The input information.
1148 * @param cbInput The size of the input information.
1149 */
1150 DECLR3CALLBACKMEMBER(void, VRDPCallbackInput,(void *pvCallback,
1151 int type,
1152 const void *pvInput,
1153 unsigned cbInput));
1154
1155 /* Video mode hint from the client.
1156 *
1157 * @param pvCallback The callback specific pointer.
1158 * @param cWidth Requested width.
1159 * @param cHeight Requested height.
1160 * @param cBitsPerPixel Requested color depth.
1161 * @param uScreenId The framebuffer index.
1162 */
1163 DECLR3CALLBACKMEMBER(void, VRDPCallbackVideoModeHint,(void *pvCallback,
1164 unsigned cWidth,
1165 unsigned cHeight,
1166 unsigned cBitsPerPixel,
1167 unsigned uScreenId));
1168
1169} VRDPCALLBACKS_1;
1170
1171/* Callbacks are the same for the version 1 and version 2 interfaces. */
1172typedef VRDPCALLBACKS_1 VRDPCALLBACKS_2;
1173
1174/**
1175 * Create a new VRDP server instance. The instance is fully functional but refuses
1176 * client connections until the entry point VRDPEnableConnections is called by the application.
1177 *
1178 * The caller prepares the callbacks structure. The header.u64Version field
1179 * must be initialized with the version of the insterface to use.
1180 * The server will initialize the callbacks table to match the requested interface.
1181 *
1182 * @param pCallback Pointer to the application callbacks which let the server to fetch
1183 * the configuration data and to access the desktop.
1184 * @param pvCallback The callback specific pointer to be passed back to the application.
1185 * @param ppEntryPoints Where to store the pointer to the VRDP entry points structure.
1186 * @param phServer Pointer to the created server instance handle.
1187 *
1188 * @return IPRT status code.
1189 */
1190VRDPDECL(int) VRDPCreateServer (const VRDPINTERFACEHDR *pCallbacks,
1191 void *pvCallback,
1192 VRDPINTERFACEHDR **ppEntryPoints,
1193 HVRDPSERVER *phServer);
1194
1195typedef DECLCALLBACK(int) FNVRDPCREATESERVER (const VRDPINTERFACEHDR *pCallbacks,
1196 void *pvCallback,
1197 VRDPINTERFACEHDR **ppEntryPoints,
1198 HVRDPSERVER *phServer);
1199typedef FNVRDPCREATESERVER *PFNVRDPCREATESERVER;
1200
1201RT_C_DECLS_END
1202
1203/** @} */
1204
1205#endif
1206
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette