VirtualBox

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

Last change on this file since 4675 was 4071, checked in by vboxsync, 17 years ago

Biggest check-in ever. New source code headers for all (C) innotek files.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 53.0 KB
Line 
1/** @file
2 * VBox Remote Desktop Protocol:
3 * Public APIs.
4 */
5
6/*
7 * Copyright (C) 2006-2007 innotek GmbH
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 as published by the Free Software Foundation,
13 * in version 2 as it comes in the "COPYING" file of the VirtualBox OSE
14 * distribution. VirtualBox OSE is distributed in the hope that it will
15 * be useful, but WITHOUT ANY WARRANTY of any kind.
16 */
17
18#ifndef ___VBox_vrdpapi_h
19#define ___VBox_vrdpapi_h
20
21#ifdef VRDP_NO_COM
22#include <iprt/cdefs.h>
23#include <iprt/types.h>
24#else
25#include <VBox/cdefs.h>
26#include <VBox/types.h>
27#endif /* VRDP_NO_COM */
28
29#ifdef IN_RING0
30# error "There are no VRDP APIs available in Ring-0 Host Context!"
31#endif
32#ifdef IN_GC
33# error "There are no VRDP APIs available Guest Context!"
34#endif
35
36
37/** @defgroup grp_vrdp VRDP
38 * VirtualBox Remote Desktop Protocol (VRDP) interface that lets to use
39 * the VRDP server.
40 * @{
41 */
42
43/** Default port that VRDP binds to. */
44#define VRDP_DEFAULT_PORT (3389)
45
46__BEGIN_DECLS
47
48/* Forward declaration of the VRDP server instance handle. */
49#ifdef __cplusplus
50class VRDPServer;
51typedef class VRDPServer *HVRDPSERVER;
52#else
53struct VRDPServer;
54typedef struct VRDPServer *HVRDPSERVER;
55#endif /* __cplusplus */
56
57#ifdef VRDP_NO_COM
58/* New, callback based VRDP server interface declarations. */
59
60#if defined(IN_VRDP)
61# define VRDPDECL(type) DECLEXPORT(type) RTCALL
62#else
63# define VRDPDECL(type) DECLIMPORT(type) RTCALL
64#endif /* IN_VRDP */
65
66/** The color mouse pointer information. */
67typedef struct _VRDPCOLORPOINTER
68{
69 uint16_t u16HotX;
70 uint16_t u16HotY;
71 uint16_t u16Width;
72 uint16_t u16Height;
73 uint16_t u16MaskLen;
74 uint16_t u16DataLen;
75 /* The mask and the bitmap follow. */
76} VRDPCOLORPOINTER;
77
78/** Audio format information packed in a 32 bit value. */
79typedef uint32_t VRDPAUDIOFORMAT;
80
81/** Constructs 32 bit value for given frequency, number of channel and bits per sample. */
82#define VRDP_AUDIO_FMT_MAKE(freq, c, bps, s) ((((s) & 0x1) << 28) + (((bps) & 0xFF) << 20) + (((c) & 0xF) << 16) + ((freq) & 0xFFFF))
83
84/** Decode frequency. */
85#define VRDP_AUDIO_FMT_SAMPLE_FREQ(a) ((a) & 0xFFFF)
86/** Decode number of channels. */
87#define VRDP_AUDIO_FMT_CHANNELS(a) (((a) >> 16) & 0xF)
88/** Decode number signess. */
89#define VRDP_AUDIO_FMT_SIGNED(a) (((a) >> 28) & 0x1)
90/** Decode number of bits per sample. */
91#define VRDP_AUDIO_FMT_BITS_PER_SAMPLE(a) (((a) >> 20) & 0xFF)
92/** Decode number of bytes per sample. */
93#define VRDP_AUDIO_FMT_BYTES_PER_SAMPLE(a) ((VRDP_AUDIO_FMT_BITS_PER_SAMPLE(a) + 7) / 8)
94
95/*
96 * Remote USB protocol.
97 */
98
99/* The version of Remote USB Protocol. */
100#define VRDP_USB_VERSION (1)
101
102/** USB backend operations. */
103#define VRDP_USB_REQ_OPEN (0)
104#define VRDP_USB_REQ_CLOSE (1)
105#define VRDP_USB_REQ_RESET (2)
106#define VRDP_USB_REQ_SET_CONFIG (3)
107#define VRDP_USB_REQ_CLAIM_INTERFACE (4)
108#define VRDP_USB_REQ_RELEASE_INTERFACE (5)
109#define VRDP_USB_REQ_INTERFACE_SETTING (6)
110#define VRDP_USB_REQ_QUEUE_URB (7)
111#define VRDP_USB_REQ_REAP_URB (8)
112#define VRDP_USB_REQ_CLEAR_HALTED_EP (9)
113#define VRDP_USB_REQ_CANCEL_URB (10)
114
115/** USB service operations. */
116#define VRDP_USB_REQ_DEVICE_LIST (11)
117#define VRDP_USB_REQ_NEGOTIATE (12)
118
119/** An operation completion status is a byte. */
120typedef uint8_t VRDPUSBSTATUS;
121
122/** USB device identifier is an 32 bit value. */
123typedef uint32_t VRDPUSBDEVID;
124
125/** Status codes. */
126#define VRDP_USB_STATUS_SUCCESS ((VRDPUSBSTATUS)0)
127#define VRDP_USB_STATUS_ACCESS_DENIED ((VRDPUSBSTATUS)1)
128#define VRDP_USB_STATUS_DEVICE_REMOVED ((VRDPUSBSTATUS)2)
129
130/*
131 * Data structures to use with VRDPUSBRequest.
132 * The *RET* structures always represent the layout of VRDP data.
133 * The *PARM* structures normally the same as VRDP layout.
134 * However the VRDP_USB_REQ_QUEUE_URB_PARM has a pointer to
135 * URB data in place where actual data will be in VRDP layout.
136 *
137 * Since replies (*RET*) are asynchronous, the 'success'
138 * replies are not required for operations which return
139 * only the status code (VRDPUSBREQRETHDR only):
140 * VRDP_USB_REQ_OPEN
141 * VRDP_USB_REQ_RESET
142 * VRDP_USB_REQ_SET_CONFIG
143 * VRDP_USB_REQ_CLAIM_INTERFACE
144 * VRDP_USB_REQ_RELEASE_INTERFACE
145 * VRDP_USB_REQ_INTERFACE_SETTING
146 * VRDP_USB_REQ_CLEAR_HALTED_EP
147 *
148 */
149
150/* VRDP layout has no aligments. */
151#pragma pack(1)
152/* Common header for all VRDP USB packets. After the reply hdr follows *PARM* or *RET* data. */
153typedef struct _VRDPUSBPKTHDR
154{
155 /* Total length of the reply NOT including the 'length' field. */
156 uint32_t length;
157 /* The operation code for which the reply was sent by the client. */
158 uint8_t code;
159} VRDPUSBPKTHDR;
160
161/* Common header for all return structures. */
162typedef struct _VRDPUSBREQRETHDR
163{
164 /* Device status. */
165 VRDPUSBSTATUS status;
166 /* Device id. */
167 VRDPUSBDEVID id;
168} VRDPUSBREQRETHDR;
169
170
171/* VRDP_USB_REQ_OPEN
172 */
173typedef struct _VRDP_USB_REQ_OPEN_PARM
174{
175 uint8_t code;
176 VRDPUSBDEVID id;
177} VRDP_USB_REQ_OPEN_PARM;
178
179typedef struct _VRDP_USB_REQ_OPEN_RET
180{
181 VRDPUSBREQRETHDR hdr;
182} VRDP_USB_REQ_OPEN_RET;
183
184
185/* VRDP_USB_REQ_CLOSE
186 */
187typedef struct _VRDP_USB_REQ_CLOSE_PARM
188{
189 uint8_t code;
190 VRDPUSBDEVID id;
191} VRDP_USB_REQ_CLOSE_PARM;
192
193/* The close request has no returned data. */
194
195
196/* VRDP_USB_REQ_RESET
197 */
198typedef struct _VRDP_USB_REQ_RESET_PARM
199{
200 uint8_t code;
201 VRDPUSBDEVID id;
202} VRDP_USB_REQ_RESET_PARM;
203
204typedef struct _VRDP_USB_REQ_RESET_RET
205{
206 VRDPUSBREQRETHDR hdr;
207} VRDP_USB_REQ_RESET_RET;
208
209
210/* VRDP_USB_REQ_SET_CONFIG
211 */
212typedef struct _VRDP_USB_REQ_SET_CONFIG_PARM
213{
214 uint8_t code;
215 VRDPUSBDEVID id;
216 uint8_t configuration;
217} VRDP_USB_REQ_SET_CONFIG_PARM;
218
219typedef struct _VRDP_USB_REQ_SET_CONFIG_RET
220{
221 VRDPUSBREQRETHDR hdr;
222} VRDP_USB_REQ_SET_CONFIG_RET;
223
224
225/* VRDP_USB_REQ_CLAIM_INTERFACE
226 */
227typedef struct _VRDP_USB_REQ_CLAIM_INTERFACE_PARM
228{
229 uint8_t code;
230 VRDPUSBDEVID id;
231 uint8_t iface;
232} VRDP_USB_REQ_CLAIM_INTERFACE_PARM;
233
234typedef struct _VRDP_USB_REQ_CLAIM_INTERFACE_RET
235{
236 VRDPUSBREQRETHDR hdr;
237} VRDP_USB_REQ_CLAIM_INTERFACE_RET;
238
239
240/* VRDP_USB_REQ_RELEASE_INTERFACE
241 */
242typedef struct _VRDP_USB_REQ_RELEASE_INTERFACE_PARM
243{
244 uint8_t code;
245 VRDPUSBDEVID id;
246 uint8_t iface;
247} VRDP_USB_REQ_RELEASE_INTERFACE_PARM;
248
249typedef struct _VRDP_USB_REQ_RELEASE_INTERFACE_RET
250{
251 VRDPUSBREQRETHDR hdr;
252} VRDP_USB_REQ_RELEASE_INTERFACE_RET;
253
254
255/* VRDP_USB_REQ_INTERFACE_SETTING
256 */
257typedef struct _VRDP_USB_REQ_INTERFACE_SETTING_PARM
258{
259 uint8_t code;
260 VRDPUSBDEVID id;
261 uint8_t iface;
262 uint8_t setting;
263} VRDP_USB_REQ_INTERFACE_SETTING_PARM;
264
265typedef struct _VRDP_USB_REQ_INTERFACE_SETTING_RET
266{
267 VRDPUSBREQRETHDR hdr;
268} VRDP_USB_REQ_INTERFACE_SETTING_RET;
269
270
271/* VRDP_USB_REQ_QUEUE_URB
272 */
273
274#define VRDP_USB_TRANSFER_TYPE_CTRL (0)
275#define VRDP_USB_TRANSFER_TYPE_ISOC (1)
276#define VRDP_USB_TRANSFER_TYPE_BULK (2)
277#define VRDP_USB_TRANSFER_TYPE_INTR (3)
278#define VRDP_USB_TRANSFER_TYPE_MSG (4)
279
280#define VRDP_USB_DIRECTION_SETUP (0)
281#define VRDP_USB_DIRECTION_IN (1)
282#define VRDP_USB_DIRECTION_OUT (2)
283
284typedef struct _VRDP_USB_REQ_QUEUE_URB_PARM
285{
286 uint8_t code;
287 VRDPUSBDEVID id;
288 uint32_t handle; /* Distinguishes that particular URB. Later used in CancelURB and returned by ReapURB */
289 uint8_t type;
290 uint8_t ep;
291 uint8_t direction;
292 uint32_t urblen; /* Length of the URB. */
293 uint32_t datalen; /* Length of the data. */
294 void *data; /* In RDP layout the data follow. */
295} VRDP_USB_REQ_QUEUE_URB_PARM;
296
297/* The queue URB has no explicit return. The reap URB reply will be
298 * eventually the indirect result.
299 */
300
301
302/* VRDP_USB_REQ_REAP_URB
303 * Notificationg from server to client that server expects an URB
304 * from any device.
305 * Only sent if negotiated URB return method is polling.
306 * Normally, the client will send URBs back as soon as they are ready.
307 */
308typedef struct _VRDP_USB_REQ_REAP_URB_PARM
309{
310 uint8_t code;
311} VRDP_USB_REQ_REAP_URB_PARM;
312
313
314#define VRDP_USB_XFER_OK (0)
315#define VRDP_USB_XFER_STALL (1)
316#define VRDP_USB_XFER_DNR (2)
317#define VRDP_USB_XFER_CRC (3)
318
319#define VRDP_USB_REAP_FLAG_CONTINUED (0x0)
320#define VRDP_USB_REAP_FLAG_LAST (0x1)
321
322#define VRDP_USB_REAP_VALID_FLAGS (VRDP_USB_REAP_FLAG_LAST)
323
324typedef struct _VRDPUSBREQREAPURBBODY
325{
326 VRDPUSBDEVID id; /* From which device the URB arrives. */
327 uint8_t flags; /* VRDP_USB_REAP_FLAG_* */
328 uint8_t error; /* VRDP_USB_XFER_* */
329 uint32_t handle; /* Handle of returned URB. Not 0. */
330 uint32_t len; /* Length of data actually transferred. */
331 /* Data follow. */
332} VRDPUSBREQREAPURBBODY;
333
334typedef struct _VRDP_USB_REQ_REAP_URB_RET
335{
336 /* The REAP URB has no header, only completed URBs are returned. */
337 VRDPUSBREQREAPURBBODY body;
338 /* Another body may follow, depending on flags. */
339} VRDP_USB_REQ_REAP_URB_RET;
340
341
342/* VRDP_USB_REQ_CLEAR_HALTED_EP
343 */
344typedef struct _VRDP_USB_REQ_CLEAR_HALTED_EP_PARM
345{
346 uint8_t code;
347 VRDPUSBDEVID id;
348 uint8_t ep;
349} VRDP_USB_REQ_CLEAR_HALTED_EP_PARM;
350
351typedef struct _VRDP_USB_REQ_CLEAR_HALTED_EP_RET
352{
353 VRDPUSBREQRETHDR hdr;
354} VRDP_USB_REQ_CLEAR_HALTED_EP_RET;
355
356
357/* VRDP_USB_REQ_CANCEL_URB
358 */
359typedef struct _VRDP_USB_REQ_CANCEL_URB_PARM
360{
361 uint8_t code;
362 VRDPUSBDEVID id;
363 uint32_t handle;
364} VRDP_USB_REQ_CANCEL_URB_PARM;
365
366/* The cancel URB request has no return. */
367
368
369/* VRDP_USB_REQ_DEVICE_LIST
370 *
371 * Server polls USB devices on client by sending this request
372 * periodically. Client sends back a list of all devices
373 * connected to it. Each device is assigned with an identifier,
374 * that is used to distinguish the particular device.
375 */
376typedef struct _VRDP_USB_REQ_DEVICE_LIST_PARM
377{
378 uint8_t code;
379} VRDP_USB_REQ_DEVICE_LIST_PARM;
380
381/* Data is a list of the following variable length structures. */
382typedef struct _VRDPUSBDEVICEDESC
383{
384 /* Offset of the next structure. 0 if last. */
385 uint16_t oNext;
386
387 /* Identifier of the device assigned by client. */
388 VRDPUSBDEVID id;
389
390 /** USB version number. */
391 uint16_t bcdUSB;
392 /** Device class. */
393 uint8_t bDeviceClass;
394 /** Device subclass. */
395 uint8_t bDeviceSubClass;
396 /** Device protocol */
397 uint8_t bDeviceProtocol;
398 /** Vendor ID. */
399 uint16_t idVendor;
400 /** Product ID. */
401 uint16_t idProduct;
402 /** Revision, integer part. */
403 uint16_t bcdRev;
404 /** Manufacturer string. */
405 uint16_t oManufacturer;
406 /** Product string. */
407 uint16_t oProduct;
408 /** Serial number string. */
409 uint16_t oSerialNumber;
410 /** Physical USB port the device is connected to. */
411 uint16_t idPort;
412
413} VRDPUSBDEVICEDESC;
414
415typedef struct _VRDP_USB_REQ_DEVICE_LIST_RET
416{
417 VRDPUSBDEVICEDESC body;
418 /* Other devices may follow.
419 * The list ends with (uint16_t)0,
420 * which means that an empty list consists of 2 zero bytes.
421 */
422} VRDP_USB_REQ_DEVICE_LIST_RET;
423
424typedef struct _VRDPUSBREQNEGOTIATEPARM
425{
426 uint8_t code;
427
428 /* Remote USB Protocol version. */
429 uint32_t version;
430
431} VRDPUSBREQNEGOTIATEPARM;
432
433#define VRDP_USB_CAPS_FLAG_ASYNC (0x0)
434#define VRDP_USB_CAPS_FLAG_POLL (0x1)
435
436#define VRDP_USB_CAPS_VALID_FLAGS (VRDP_USB_CAPS_FLAG_POLL)
437
438typedef struct _VRDPUSBREQNEGOTIATERET
439{
440 uint8_t flags;
441} VRDPUSBREQNEGOTIATERET;
442#pragma pack()
443
444#define VRDP_CLIPBOARD_FORMAT_NULL (0x0)
445#define VRDP_CLIPBOARD_FORMAT_UNICODE_TEXT (0x1)
446#define VRDP_CLIPBOARD_FORMAT_BITMAP (0x2)
447#define VRDP_CLIPBOARD_FORMAT_HTML (0x4)
448
449#define VRDP_CLIPBOARD_FUNCTION_FORMAT_ANNOUNCE (0)
450#define VRDP_CLIPBOARD_FUNCTION_DATA_READ (1)
451#define VRDP_CLIPBOARD_FUNCTION_DATA_WRITE (2)
452
453
454/** Indexes of information values. */
455
456/** Whether a client is connected at the moment.
457 * uint32_t
458 */
459#define VRDP_QI_ACTIVE (0)
460
461/** How many times a client connected up to current moment.
462 * uint32_t
463 */
464#define VRDP_QI_NUMBER_OF_CLIENTS (1)
465
466/** When last connection was established.
467 * int64_t time in milliseconds since 1970-01-01 00:00:00 UTC
468 */
469#define VRDP_QI_BEGIN_TIME (2)
470
471/** When last connection was terminated or current time if connection still active.
472 * int64_t time in milliseconds since 1970-01-01 00:00:00 UTC
473 */
474#define VRDP_QI_END_TIME (3)
475
476/** How many bytes were sent in last (current) connection.
477 * uint64_t
478 */
479#define VRDP_QI_BYTES_SENT (4)
480
481/** How many bytes were sent in all connections.
482 * uint64_t
483 */
484#define VRDP_QI_BYTES_SENT_TOTAL (5)
485
486/** How many bytes were received in last (current) connection.
487 * uint64_t
488 */
489#define VRDP_QI_BYTES_RECEIVED (6)
490
491/** How many bytes were received in all connections.
492 * uint64_t
493 */
494#define VRDP_QI_BYTES_RECEIVED_TOTAL (7)
495
496/** Login user name supplied by the client.
497 * UTF8 nul terminated string.
498 */
499#define VRDP_QI_USER (8)
500
501/** Login domain supplied by the client.
502 * UTF8 nul terminated string.
503 */
504#define VRDP_QI_DOMAIN (9)
505
506/** The client name supplied by the client.
507 * UTF8 nul terminated string.
508 */
509#define VRDP_QI_CLIENT_NAME (10)
510
511/** IP address of the client.
512 * UTF8 nul terminated string.
513 */
514#define VRDP_QI_CLIENT_IP (11)
515
516/** The client software version number.
517 * uint32_t.
518 */
519#define VRDP_QI_CLIENT_VERSION (12)
520
521/** Public key exchange method used when connection was established.
522 * Values: 0 - RDP4 public key exchange scheme.
523 * 1 - X509 sertificates were sent to client.
524 * uint32_t.
525 */
526#define VRDP_QI_ENCRYPTION_STYLE (13)
527
528
529/** Hints what has been intercepted by the application. */
530#define VRDP_CLIENT_INTERCEPT_AUDIO (0x1)
531#define VRDP_CLIENT_INTERCEPT_USB (0x2)
532#define VRDP_CLIENT_INTERCEPT_CLIPBOARD (0x4)
533
534
535/** The version of the VRDP server interface. */
536#define VRDP_INTERFACE_VERSION_1 (1)
537
538/** The header that does not change when the interface changes. */
539typedef struct _VRDPINTERFACEHDR
540{
541 /** The version of the interface. */
542 uint64_t u64Version;
543
544 /** The size of the structure. */
545 uint64_t u64Size;
546
547} VRDPINTERFACEHDR;
548
549/** The VRDP server entry points. Interface version 1. */
550typedef struct _VRDPENTRYPOINTS_1
551{
552 /** The header. */
553 VRDPINTERFACEHDR header;
554
555 /** Destroy the server instance.
556 *
557 * @param hServer The server instance handle.
558 *
559 * @return IPRT status code.
560 */
561 DECLCALLBACKMEMBER(void, VRDPDestroy)(HVRDPSERVER hServer);
562
563 /** The server should start to accept clients connections.
564 *
565 * @param hServer The server instance handle.
566 * @param fEnable Whether to enable or disable client connections.
567 * When is false, all existing clients are disconnected.
568 *
569 * @return IPRT status code.
570 */
571 DECLCALLBACKMEMBER(int, VRDPEnableConnections)(HVRDPSERVER hServer,
572 bool fEnable);
573
574 /** The server should disconnect the client.
575 *
576 * @param hServer The server instance handle.
577 * @param u32ClientId The client identifier.
578 * @param fReconnect Whether to send a "REDIRECT to the same server" packet to the
579 * client before disconnecting.
580 *
581 * @return IPRT status code.
582 */
583 DECLCALLBACKMEMBER(void, VRDPDisconnect)(HVRDPSERVER hServer,
584 uint32_t u32ClientId,
585 bool fReconnect);
586
587 /**
588 * Inform the server that the display was resized.
589 * The server will query information about display
590 * from the application via callbacks.
591 *
592 * @param hServer Handle of VRDP server instance.
593 */
594 DECLCALLBACKMEMBER(void, VRDPResize)(HVRDPSERVER hServer);
595
596 /**
597 * Send a update.
598 *
599 * @param hServer Handle of VRDP server instance.
600 * @param uScreenId The screen index.
601 * @param pvUpdate Pointer to VBoxGuest.h::VRDPORDERHDR structure with extra data.
602 * @param cbUpdate Size of the update data.
603 */
604 DECLCALLBACKMEMBER(void, VRDPUpdate)(HVRDPSERVER hServer,
605 unsigned uScreenId,
606 void *pvUpdate,
607 uint32_t cbUpdate);
608
609 /**
610 * Set the mouse pointer shape.
611 *
612 * @param hServer Handle of VRDP server instance.
613 * @param pPointer The pointer shape information.
614 */
615 DECLCALLBACKMEMBER(void, VRDPColorPointer)(HVRDPSERVER hServer,
616 const VRDPCOLORPOINTER *pPointer);
617
618 /**
619 * Hide the mouse pointer.
620 *
621 * @param hServer Handle of VRDP server instance.
622 */
623 DECLCALLBACKMEMBER(void, VRDPHidePointer)(HVRDPSERVER hServer);
624
625 /**
626 * Queues the samples to be sent to clients.
627 *
628 * @param hServer Handle of VRDP server instance.
629 * @param pvSamples Address of samples to be sent.
630 * @param cSamples Number of samples.
631 * @param format Encoded audio format for these samples.
632 *
633 * @note Initialized to NULL when the application audio callbacks are NULL.
634 */
635 DECLCALLBACKMEMBER(void, VRDPAudioSamples)(HVRDPSERVER hServer,
636 const void *pvSamples,
637 uint32_t cSamples,
638 VRDPAUDIOFORMAT format);
639
640 /**
641 * Sets the sound volume on clients.
642 *
643 * @param hServer Handle of VRDP server instance.
644 * @param left 0..0xFFFF volume level for left channel.
645 * @param right 0..0xFFFF volume level for right channel.
646 *
647 * @note Initialized to NULL when the application audio callbacks are NULL.
648 */
649 DECLCALLBACKMEMBER(void, VRDPAudioVolume)(HVRDPSERVER hServer,
650 uint16_t u16Left,
651 uint16_t u16Right);
652
653 /**
654 * Sends a USB request.
655 *
656 * @param hServer Handle of VRDP server instance.
657 * @param u32ClientId An identifier that allows the server to find the corresponding client.
658 * The identifier is always passed by the server as a parameter
659 * of the FNVRDPUSBCALLBACK. Note that the value is the same as
660 * in the VRDPSERVERCALLBACK functions.
661 * @param pvParm Function specific parameters buffer.
662 * @param cbParm Size of the buffer.
663 *
664 * @note Initialized to NULL when the application USB callbacks are NULL.
665 */
666 DECLCALLBACKMEMBER(void, VRDPUSBRequest)(HVRDPSERVER hServer,
667 uint32_t u32ClientId,
668 void *pvParm,
669 uint32_t cbParm);
670
671 /**
672 * Called by the application when (VRDP_CLIPBOARD_FUNCTION_*):
673 * - (0) guest announces available clipboard formats;
674 * - (1) guest requests clipboard data;
675 * - (2) guest responds to the client's request for clipboard data.
676 *
677 * @param hServer The VRDP server handle.
678 * @param u32Function The cause of the call.
679 * @param u32Format Bitmask of announced formats or the format of data.
680 * @param pvData Points to: (1) buffer to be filled with clients data;
681 * (2) data from the host.
682 * @param cbData Size of 'pvData' buffer in bytes.
683 * @param pcbActualRead Size of the copied data in bytes.
684 *
685 * @note Initialized to NULL when the application clipboard callbacks are NULL.
686 */
687 DECLCALLBACKMEMBER(void, VRDPClipboard)(HVRDPSERVER hServer,
688 uint32_t u32Function,
689 uint32_t u32Format,
690 void *pvData,
691 uint32_t cbData,
692 uint32_t *pcbActualRead);
693
694 /**
695 * Query various information from the VRDP server.
696 *
697 * @param hServer The VRDP server handle.
698 * @param index VRDP_QI_* identifier of information to be returned.
699 * @param pvBuffer Address of memory buffer to which the information must be written.
700 * @param cbBuffer Size of the memory buffer in bytes.
701 * @param pcbOut Size in bytes of returned information value.
702 *
703 * @remark The caller must check the *pcbOut. 0 there means no information was returned.
704 * A value greater than cbBuffer means that information is too big to fit in the
705 * buffer, in that case no information was placed to the buffer.
706 */
707 DECLCALLBACKMEMBER(void, VRDPQueryInfo)(HVRDPSERVER hServer,
708 uint32_t index,
709 void *pvBuffer,
710 uint32_t cbBuffer,
711 uint32_t *pcbOut);
712} VRDPENTRYPOINTS_1;
713
714#define VRDP_QP_NETWORK_PORT (1)
715#define VRDP_QP_NETWORK_ADDRESS (2)
716#define VRDP_QP_NUMBER_MONITORS (3)
717
718#pragma pack(1)
719/* A framebuffer description. */
720typedef struct _VRDPFRAMEBUFFERINFO
721{
722 const uint8_t *pu8Bits;
723 int xOrigin;
724 int yOrigin;
725 unsigned cWidth;
726 unsigned cHeight;
727 unsigned cBitsPerPixel;
728 unsigned cbLine;
729} VRDPFRAMEBUFFERINFO;
730
731#define VRDP_INPUT_SCANCODE 0
732#define VRDP_INPUT_POINT 1
733#define VRDP_INPUT_CAD 2
734#define VRDP_INPUT_RESET 3
735
736typedef struct _VRDPINPUTSCANCODE
737{
738 unsigned uScancode;
739} VRDPINPUTSCANCODE;
740
741#define VRDP_INPUT_POINT_BUTTON1 0x01
742#define VRDP_INPUT_POINT_BUTTON2 0x02
743#define VRDP_INPUT_POINT_BUTTON3 0x04
744#define VRDP_INPUT_POINT_WHEEL_UP 0x08
745#define VRDP_INPUT_POINT_WHEEL_DOWN 0x10
746
747typedef struct _VRDPINPUTPOINT
748{
749 int x;
750 int y;
751 unsigned uButtons;
752} VRDPINPUTPOINT;
753#pragma pack()
754
755/** The VRDP server callbacks. Interface version 1. */
756typedef struct _VRDPCALLBACKS_1
757{
758 /** The header. */
759 VRDPINTERFACEHDR header;
760
761 /**
762 * Query various information, on how the VRDP server must operate, from the application.
763 *
764 * @param pvCallback The callback specific pointer.
765 * @param index VRDP_QP_* identifier of information to be returned.
766 * @param pvBuffer Address of memory buffer to which the information must be written.
767 * @param cbBuffer Size of the memory buffer in bytes.
768 * @param pcbOut Size in bytes of returned information value.
769 *
770 * @return IPRT status code. VINF_BUFFER_OVERFLOW if the buffer is too small for the value.
771 */
772 DECLCALLBACKMEMBER(int, VRDPCallbackQueryProperty)(void *pvCallback,
773 uint32_t index,
774 void *pvBuffer,
775 uint32_t cbBuffer,
776 uint32_t *pcbOut);
777
778 /* A client is logging in, the application must decide whether
779 * to let to connect the client. The server will drop the connection,
780 * when an error code is returned by the callback.
781 *
782 * @param pvCallback The callback specific pointer.
783 * @param u32ClientId An unique client identifier generated by the server.
784 * @param pszUser The username.
785 * @param pszPassword The password.
786 * @param pszDomain The domain.
787 *
788 * @return IPRT status code.
789 */
790 DECLCALLBACKMEMBER(int, VRDPCallbackClientLogon)(void *pvCallback,
791 uint32_t u32ClientId,
792 const char *pszUser,
793 const char *pszPassword,
794 const char *pszDomain);
795
796 /* The client has been successfully connected.
797 *
798 * @param pvCallback The callback specific pointer.
799 * @param u32ClientId An unique client identifier generated by the server.
800 */
801 DECLCALLBACKMEMBER(void, VRDPCallbackClientConnect)(void *pvCallback,
802 uint32_t u32ClientId);
803
804 /* The client has been disconnected.
805 *
806 * @param pvCallback The callback specific pointer.
807 * @param u32ClientId An unique client identifier generated by the server.
808 * @param fu32Intercepted What was intercepted by the client (VRDP_CLIENT_INTERCEPT_*).
809 */
810 DECLCALLBACKMEMBER(void, VRDPCallbackClientDisconnect)(void *pvCallback,
811 uint32_t u32ClientId,
812 uint32_t fu32Intercepted);
813 /* The client supports one of RDP channels.
814 *
815 * @param pvCallback The callback specific pointer.
816 * @param u32ClientId An unique client identifier generated by the server.
817 * @param fu32Intercept What the client wants to intercept. One of VRDP_CLIENT_INTERCEPT_* flags.
818 * @param ppvIntercept The value to be passed to the channel specific callback.
819 *
820 * @return IPRT status code.
821 */
822 DECLCALLBACKMEMBER(int, VRDPCallbackIntercept)(void *pvCallback,
823 uint32_t u32ClientId,
824 uint32_t fu32Intercept,
825 void **ppvIntercept);
826
827 /**
828 * Called by the server when a reply is received from a client.
829 *
830 * @param pvCallback The callback specific pointer.
831 * @param ppvIntercept The value returned by VRDPCallbackIntercept for the VRDP_CLIENT_INTERCEPT_USB.
832 * @param u32ClientId Identifies the client that sent the reply.
833 * @param u8Code The operation code VRDP_USB_REQ_*.
834 * @param pvRet Points to data received from the client.
835 * @param cbRet Size of the data in bytes.
836 *
837 * @return IPRT status code.
838 */
839 DECLCALLBACKMEMBER(int, VRDPCallbackUSB)(void *pvCallback,
840 void *pvIntercept,
841 uint32_t u32ClientId,
842 uint8_t u8Code,
843 const void *pvRet,
844 uint32_t cbRet);
845
846 /**
847 * Called by the server when (VRDP_CLIPBOARD_FUNCTION_*):
848 * - (0) client announces available clipboard formats;
849 * - (1) client requests clipboard data.
850 *
851 * @param pvCallback The callback specific pointer.
852 * @param ppvIntercept The value returned by VRDPCallbackIntercept for the VRDP_CLIENT_INTERCEPT_CLIPBOARD.
853 * @param u32ClientId Identifies the RDP client that sent the reply.
854 * @param u32Function The cause of the callback.
855 * @param u32Format Bitmask of reported formats or the format of received data.
856 * @param pvData Reserved.
857 * @param cbData Reserved.
858 *
859 * @return IPRT status code.
860 */
861 DECLCALLBACKMEMBER(int, VRDPCallbackClipboard)(void *pvCallback,
862 void *pvIntercept,
863 uint32_t u32ClientId,
864 uint32_t u32Function,
865 uint32_t u32Format,
866 const void *pvData,
867 uint32_t cbData);
868
869 /* The framebuffer information is queried.
870 *
871 * @param pvCallback The callback specific pointer.
872 * @param uScreenId The framebuffer index.
873 * @param pInfo The information structure to ber filled.
874 *
875 * @return Whether the framebuffer is available.
876 */
877 DECLCALLBACKMEMBER(bool, VRDPCallbackFramebufferQuery)(void *pvCallback,
878 unsigned uScreenId,
879 VRDPFRAMEBUFFERINFO *pInfo);
880
881 /* The framebuffer is locked.
882 *
883 * @param pvCallback The callback specific pointer.
884 * @param uScreenId The framebuffer index.
885 */
886 DECLCALLBACKMEMBER(void, VRDPCallbackFramebufferLock)(void *pvCallback,
887 unsigned uScreenId);
888
889 /* The framebuffer is unlocked.
890 *
891 * @param pvCallback The callback specific pointer.
892 * @param uScreenId The framebuffer index.
893 */
894 DECLCALLBACKMEMBER(void, VRDPCallbackFramebufferUnlock)(void *pvCallback,
895 unsigned uScreenId);
896
897 /* Input from the client.
898 *
899 * @param pvCallback The callback specific pointer.
900 * @param pvInput The input information.
901 * @param cbInput The size of the input information.
902 */
903 DECLCALLBACKMEMBER(void, VRDPCallbackInput)(void *pvCallback,
904 int type,
905 const void *pvInput,
906 unsigned cbInput);
907
908 /* Video mode hint from the client.
909 *
910 * @param pvCallback The callback specific pointer.
911 * @param cWidth Requested width.
912 * @param cHeight Requested height.
913 * @param cBitsPerPixel Requested color depth.
914 * @param uScreenId The framebuffer index.
915 */
916 DECLCALLBACKMEMBER(void, VRDPCallbackVideoModeHint)(void *pvCallback,
917 unsigned cWidth,
918 unsigned cHeight,
919 unsigned cBitsPerPixel,
920 unsigned uScreenId);
921
922} VRDPCALLBACKS_1;
923
924/**
925 * Create a new VRDP server instance. The instance is fully functional but refuses
926 * client connections until the entry point VRDPEnableConnections is called by the application.
927 *
928 * The caller prepares the callbacks structure. The header.u64Version field
929 * must be initialized with the version of the insterface to use.
930 * The server will initialize the callbacks table to match the requested interface.
931 *
932 * @param pCallback Pointer to the application callbacks which let the server to fetch
933 * the configuration data and to access the desktop.
934 * @param pvCallback The callback specific pointer to be passed back to the application.
935 * @param ppEntryPoints Where to store the pointer to the VRDP entry points structure.
936 * @param phServer Pointer to the created server instance handle.
937 *
938 * @return IPRT status code.
939 */
940VRDPDECL(int) VRDPCreateServer (const VRDPINTERFACEHDR *pCallbacks,
941 void *pvCallback,
942 VRDPINTERFACEHDR **ppEntryPoints,
943 HVRDPSERVER *phServer);
944
945typedef VRDPDECL(int) FNVRDPCREATESERVER (const VRDPINTERFACEHDR *pCallbacks,
946 void *pvCallback,
947 VRDPINTERFACEHDR **ppEntryPoints,
948 HVRDPSERVER *phServer);
949typedef FNVRDPCREATESERVER *PFNVRDPCREATESERVER;
950#else
951/**
952 * Start server for the specified IConsole.
953 *
954 * @return VBox status code
955 * @param pconsole Pointer to IConsole instance to fetch display, mouse and keyboard interfaces.
956 * @param pvrdpserver Pointer to IVRDPServer instance to fetch configuration.
957 * @param phserver Pointer to server instance handle,
958 * created by the function.
959 */
960VRDPR3DECL(int) VRDPStartServer (IConsole *pconsole, IVRDPServer *pvrdpserver, HVRDPSERVER *phserver);
961
962
963/**
964 * Shutdown server.
965 *
966 * @param hserver Handle of VRDP server instance to be stopped.
967 */
968VRDPR3DECL(void) VRDPShutdownServer (HVRDPSERVER hserver);
969
970
971/**
972 * Send framebuffer bitmap to client.
973 *
974 * @param hserver Handle of VRDP server instance.
975 * @param x top left horizontal coordinate in framebuffer.
976 * @param y top left vertical coordinate in framebuffer.
977 * @param w width of rectangle.
978 * @param h height of rectangle.
979 */
980VRDPR3DECL(void) VRDPSendUpdateBitmap (HVRDPSERVER hserver, unsigned uScreenId, unsigned x, unsigned y, unsigned w, unsigned h);
981
982/**
983 * Inform client that display was resized.
984 * New width and height are taken from the current framebuffer.
985 *
986 * @param hserver Handle of VRDP server instance.
987 */
988VRDPR3DECL(void) VRDPSendResize (HVRDPSERVER hserver);
989
990/**
991 * Send an update in accelerated mode.
992 *
993 * @param hserver Handle of VRDP server instance.
994 * @param pvUpdate The update information. Actually pointer to VBoxGuest.h::VBVACMDHDR structure with extra data.
995 * @param cbUpdate Size of the update data.
996 */
997VRDPR3DECL(void) VRDPSendUpdate (HVRDPSERVER hserver, unsigned uScreenId, void *pvUpdate, uint32_t cbUpdate);
998
999/** @todo comment the structure. */
1000typedef struct _VRDPCOLORPOINTER
1001{
1002 uint16_t u16HotX;
1003 uint16_t u16HotY;
1004 uint16_t u16Width;
1005 uint16_t u16Height;
1006 uint16_t u16MaskLen;
1007 uint16_t u16DataLen;
1008 uint32_t vrdpInternal;
1009} VRDPCOLORPOINTER;
1010
1011typedef VRDPCOLORPOINTER *PVRDPCOLORPOINTER;
1012
1013/**
1014 * Set mouse pointer shape.
1015 *
1016 * @param hserver Handle of VRDP server instance.
1017 * @param porder The pointer shape information.
1018 */
1019VRDPR3DECL(void) VRDPSendColorPointer (HVRDPSERVER hserver, PVRDPCOLORPOINTER pdata);
1020
1021/**
1022 * Hide mouse pointer.
1023 *
1024 * @param hserver Handle of VRDP server instance.
1025 */
1026VRDPR3DECL(void) VRDPSendHidePointer (HVRDPSERVER hserver);
1027
1028/** Audio format information packed in a 32 bit value. */
1029typedef uint32_t VRDPAUDIOFORMAT;
1030
1031/** Constructs 32 bit value for given frequency, number of channel and bits per sample. */
1032#define VRDP_AUDIO_FMT_MAKE(freq, c, bps, s) ((((s) & 0x1) << 28) + (((bps) & 0xFF) << 20) + (((c) & 0xF) << 16) + ((freq) & 0xFFFF))
1033
1034/** Decode frequency. */
1035#define VRDP_AUDIO_FMT_SAMPLE_FREQ(a) ((a) & 0xFFFF)
1036/** Decode number of channels. */
1037#define VRDP_AUDIO_FMT_CHANNELS(a) (((a) >> 16) & 0xF)
1038/** Decode number signess. */
1039#define VRDP_AUDIO_FMT_SIGNED(a) (((a) >> 28) & 0x1)
1040/** Decode number of bits per sample. */
1041#define VRDP_AUDIO_FMT_BITS_PER_SAMPLE(a) (((a) >> 20) & 0xFF)
1042/** Decode number of bytes per sample. */
1043#define VRDP_AUDIO_FMT_BYTES_PER_SAMPLE(a) ((VRDP_AUDIO_FMT_BITS_PER_SAMPLE(a) + 7) / 8)
1044
1045/**
1046 * Queues the samples to be sent to client.
1047 *
1048 * @param hserver Handle of VRDP server instance.
1049 * @param pvSamples Address of samples to be sent.
1050 * @param cSamples Number of samples.
1051 * @param format Encoded audio format for these samples.
1052 */
1053VRDPR3DECL(void) VRDPSendAudioSamples (HVRDPSERVER hserver, void *pvSamples, uint32_t cSamples, VRDPAUDIOFORMAT format);
1054
1055/**
1056 * Sets sound volume on client.
1057 *
1058 * @param hserver Handle of VRDP server instance.
1059 * @param left 0..0xFFFF volume level for left channel.
1060 * @param right 0..0xFFFF volume level for right channel.
1061 */
1062VRDPR3DECL(void) VRDPSendAudioVolume (HVRDPSERVER hserver, uint16_t left, uint16_t right);
1063
1064
1065/*
1066 * Remote USB backend protocol.
1067 */
1068
1069/* The version of Remote USB Protocol. */
1070#define VRDP_USB_VERSION (1)
1071
1072/** USB backend operations. */
1073#define VRDP_USB_REQ_OPEN (0)
1074#define VRDP_USB_REQ_CLOSE (1)
1075#define VRDP_USB_REQ_RESET (2)
1076#define VRDP_USB_REQ_SET_CONFIG (3)
1077#define VRDP_USB_REQ_CLAIM_INTERFACE (4)
1078#define VRDP_USB_REQ_RELEASE_INTERFACE (5)
1079#define VRDP_USB_REQ_INTERFACE_SETTING (6)
1080#define VRDP_USB_REQ_QUEUE_URB (7)
1081#define VRDP_USB_REQ_REAP_URB (8)
1082#define VRDP_USB_REQ_CLEAR_HALTED_EP (9)
1083#define VRDP_USB_REQ_CANCEL_URB (10)
1084
1085/** USB service operations. */
1086#define VRDP_USB_REQ_DEVICE_LIST (11)
1087#define VRDP_USB_REQ_NEGOTIATE (12)
1088
1089/** An operation completion status is a byte. */
1090typedef uint8_t VRDPUSBSTATUS;
1091
1092/** USB device identifier is an 32 bit value. */
1093typedef uint32_t VRDPUSBDEVID;
1094
1095/** Status codes. */
1096#define VRDP_USB_STATUS_SUCCESS ((VRDPUSBSTATUS)0)
1097#define VRDP_USB_STATUS_ACCESS_DENIED ((VRDPUSBSTATUS)1)
1098#define VRDP_USB_STATUS_DEVICE_REMOVED ((VRDPUSBSTATUS)2)
1099
1100/*
1101 * Data structures to use with VRDPSendUSBRequest.
1102 * The *RET* structures always represent the layout of VRDP data.
1103 * The *PARM* structures normally the same as VRDP layout.
1104 * However the VRDP_USB_REQ_QUEUE_URB_PARM has a pointer to
1105 * URB data in place where actual data will be in VRDP layout.
1106 *
1107 * Since replies (*RET*) are asynchronous, the 'success'
1108 * replies are not required for operations which return
1109 * only the status code (VRDPUSBREQRETHDR only):
1110 * VRDP_USB_REQ_OPEN
1111 * VRDP_USB_REQ_RESET
1112 * VRDP_USB_REQ_SET_CONFIG
1113 * VRDP_USB_REQ_CLAIM_INTERFACE
1114 * VRDP_USB_REQ_RELEASE_INTERFACE
1115 * VRDP_USB_REQ_INTERFACE_SETTING
1116 * VRDP_USB_REQ_CLEAR_HALTED_EP
1117 *
1118 */
1119
1120/* VRDP layout has no aligments. */
1121#pragma pack(1)
1122
1123/* Common header for all VRDP USB packets. After the reply hdr follows *PARM* or *RET* data. */
1124typedef struct _VRDPUSBPKTHDR
1125{
1126 /* Total length of the reply NOT including the 'length' field. */
1127 uint32_t length;
1128 /* The operation code for which the reply was sent by the client. */
1129 uint8_t code;
1130} VRDPUSBPKTHDR;
1131
1132/* Common header for all return structures. */
1133typedef struct _VRDPUSBREQRETHDR
1134{
1135 /* Device status. */
1136 VRDPUSBSTATUS status;
1137 /* Device id. */
1138 VRDPUSBDEVID id;
1139} VRDPUSBREQRETHDR;
1140
1141
1142/* VRDP_USB_REQ_OPEN
1143 */
1144typedef struct _VRDP_USB_REQ_OPEN_PARM
1145{
1146 uint8_t code;
1147 VRDPUSBDEVID id;
1148} VRDP_USB_REQ_OPEN_PARM;
1149
1150typedef struct _VRDP_USB_REQ_OPEN_RET
1151{
1152 VRDPUSBREQRETHDR hdr;
1153} VRDP_USB_REQ_OPEN_RET;
1154
1155
1156/* VRDP_USB_REQ_CLOSE
1157 */
1158typedef struct _VRDP_USB_REQ_CLOSE_PARM
1159{
1160 uint8_t code;
1161 VRDPUSBDEVID id;
1162} VRDP_USB_REQ_CLOSE_PARM;
1163
1164/* The close request has no returned data. */
1165
1166
1167/* VRDP_USB_REQ_RESET
1168 */
1169typedef struct _VRDP_USB_REQ_RESET_PARM
1170{
1171 uint8_t code;
1172 VRDPUSBDEVID id;
1173} VRDP_USB_REQ_RESET_PARM;
1174
1175typedef struct _VRDP_USB_REQ_RESET_RET
1176{
1177 VRDPUSBREQRETHDR hdr;
1178} VRDP_USB_REQ_RESET_RET;
1179
1180
1181/* VRDP_USB_REQ_SET_CONFIG
1182 */
1183typedef struct _VRDP_USB_REQ_SET_CONFIG_PARM
1184{
1185 uint8_t code;
1186 VRDPUSBDEVID id;
1187 uint8_t configuration;
1188} VRDP_USB_REQ_SET_CONFIG_PARM;
1189
1190typedef struct _VRDP_USB_REQ_SET_CONFIG_RET
1191{
1192 VRDPUSBREQRETHDR hdr;
1193} VRDP_USB_REQ_SET_CONFIG_RET;
1194
1195
1196/* VRDP_USB_REQ_CLAIM_INTERFACE
1197 */
1198typedef struct _VRDP_USB_REQ_CLAIM_INTERFACE_PARM
1199{
1200 uint8_t code;
1201 VRDPUSBDEVID id;
1202 uint8_t iface;
1203} VRDP_USB_REQ_CLAIM_INTERFACE_PARM;
1204
1205typedef struct _VRDP_USB_REQ_CLAIM_INTERFACE_RET
1206{
1207 VRDPUSBREQRETHDR hdr;
1208} VRDP_USB_REQ_CLAIM_INTERFACE_RET;
1209
1210
1211/* VRDP_USB_REQ_RELEASE_INTERFACE
1212 */
1213typedef struct _VRDP_USB_REQ_RELEASE_INTERFACE_PARM
1214{
1215 uint8_t code;
1216 VRDPUSBDEVID id;
1217 uint8_t iface;
1218} VRDP_USB_REQ_RELEASE_INTERFACE_PARM;
1219
1220typedef struct _VRDP_USB_REQ_RELEASE_INTERFACE_RET
1221{
1222 VRDPUSBREQRETHDR hdr;
1223} VRDP_USB_REQ_RELEASE_INTERFACE_RET;
1224
1225
1226/* VRDP_USB_REQ_INTERFACE_SETTING
1227 */
1228typedef struct _VRDP_USB_REQ_INTERFACE_SETTING_PARM
1229{
1230 uint8_t code;
1231 VRDPUSBDEVID id;
1232 uint8_t iface;
1233 uint8_t setting;
1234} VRDP_USB_REQ_INTERFACE_SETTING_PARM;
1235
1236typedef struct _VRDP_USB_REQ_INTERFACE_SETTING_RET
1237{
1238 VRDPUSBREQRETHDR hdr;
1239} VRDP_USB_REQ_INTERFACE_SETTING_RET;
1240
1241
1242/* VRDP_USB_REQ_QUEUE_URB
1243 */
1244
1245#define VRDP_USB_TRANSFER_TYPE_CTRL (0)
1246#define VRDP_USB_TRANSFER_TYPE_ISOC (1)
1247#define VRDP_USB_TRANSFER_TYPE_BULK (2)
1248#define VRDP_USB_TRANSFER_TYPE_INTR (3)
1249#define VRDP_USB_TRANSFER_TYPE_MSG (4)
1250
1251#define VRDP_USB_DIRECTION_SETUP (0)
1252#define VRDP_USB_DIRECTION_IN (1)
1253#define VRDP_USB_DIRECTION_OUT (2)
1254
1255typedef struct _VRDP_USB_REQ_QUEUE_URB_PARM
1256{
1257 uint8_t code;
1258 VRDPUSBDEVID id;
1259 uint32_t handle; /* Distinguishes that particular URB. Later used in CancelURB and returned by ReapURB */
1260 uint8_t type;
1261 uint8_t ep;
1262 uint8_t direction;
1263 uint32_t urblen; /* Length of the URB. */
1264 uint32_t datalen; /* Length of the data. */
1265 void *data; /* In RDP layout the data follow. */
1266} VRDP_USB_REQ_QUEUE_URB_PARM;
1267
1268/* The queue URB has no explicit return. The reap URB reply will be
1269 * eventually the indirect result.
1270 */
1271
1272
1273/* VRDP_USB_REQ_REAP_URB
1274 * Notificationg from server to client that server expects an URB
1275 * from any device.
1276 * Only sent if negotiated URB return method is polling.
1277 * Normally, the client will send URBs back as soon as they are ready.
1278 */
1279typedef struct _VRDP_USB_REQ_REAP_URB_PARM
1280{
1281 uint8_t code;
1282} VRDP_USB_REQ_REAP_URB_PARM;
1283
1284
1285#define VRDP_USB_XFER_OK (0)
1286#define VRDP_USB_XFER_STALL (1)
1287#define VRDP_USB_XFER_DNR (2)
1288#define VRDP_USB_XFER_CRC (3)
1289
1290#define VRDP_USB_REAP_FLAG_CONTINUED (0x0)
1291#define VRDP_USB_REAP_FLAG_LAST (0x1)
1292
1293#define VRDP_USB_REAP_VALID_FLAGS (VRDP_USB_REAP_FLAG_LAST)
1294
1295typedef struct _VRDPUSBREQREAPURBBODY
1296{
1297 VRDPUSBDEVID id; /* From which device the URB arrives. */
1298 uint8_t flags; /* VRDP_USB_REAP_FLAG_* */
1299 uint8_t error; /* VRDP_USB_XFER_* */
1300 uint32_t handle; /* Handle of returned URB. Not 0. */
1301 uint32_t len; /* Length of data actually transferred. */
1302 /* Data follow. */
1303} VRDPUSBREQREAPURBBODY;
1304
1305typedef struct _VRDP_USB_REQ_REAP_URB_RET
1306{
1307 /* The REAP URB has no header, only completed URBs are returned. */
1308 VRDPUSBREQREAPURBBODY body;
1309 /* Another body may follow, depending on flags. */
1310} VRDP_USB_REQ_REAP_URB_RET;
1311
1312
1313/* VRDP_USB_REQ_CLEAR_HALTED_EP
1314 */
1315typedef struct _VRDP_USB_REQ_CLEAR_HALTED_EP_PARM
1316{
1317 uint8_t code;
1318 VRDPUSBDEVID id;
1319 uint8_t ep;
1320} VRDP_USB_REQ_CLEAR_HALTED_EP_PARM;
1321
1322typedef struct _VRDP_USB_REQ_CLEAR_HALTED_EP_RET
1323{
1324 VRDPUSBREQRETHDR hdr;
1325} VRDP_USB_REQ_CLEAR_HALTED_EP_RET;
1326
1327
1328/* VRDP_USB_REQ_CANCEL_URB
1329 */
1330typedef struct _VRDP_USB_REQ_CANCEL_URB_PARM
1331{
1332 uint8_t code;
1333 VRDPUSBDEVID id;
1334 uint32_t handle;
1335} VRDP_USB_REQ_CANCEL_URB_PARM;
1336
1337/* The cancel URB request has no return. */
1338
1339
1340/* VRDP_USB_REQ_DEVICE_LIST
1341 *
1342 * Server polls USB devices on client by sending this request
1343 * periodically. Client sends back a list of all devices
1344 * connected to it. Each device is assigned with an identifier,
1345 * that is used to distinguish the particular device.
1346 */
1347typedef struct _VRDP_USB_REQ_DEVICE_LIST_PARM
1348{
1349 uint8_t code;
1350} VRDP_USB_REQ_DEVICE_LIST_PARM;
1351
1352/* Data is a list of the following variable length structures. */
1353typedef struct _VRDPUSBDEVICEDESC
1354{
1355 /* Offset of the next structure. 0 if last. */
1356 uint16_t oNext;
1357
1358 /* Identifier of the device assigned by client. */
1359 VRDPUSBDEVID id;
1360
1361 /** USB version number. */
1362 uint16_t bcdUSB;
1363 /** Device class. */
1364 uint8_t bDeviceClass;
1365 /** Device subclass. */
1366 uint8_t bDeviceSubClass;
1367 /** Device protocol */
1368 uint8_t bDeviceProtocol;
1369 /** Vendor ID. */
1370 uint16_t idVendor;
1371 /** Product ID. */
1372 uint16_t idProduct;
1373 /** Revision, integer part. */
1374 uint16_t bcdRev;
1375 /** Manufacturer string. */
1376 uint16_t oManufacturer;
1377 /** Product string. */
1378 uint16_t oProduct;
1379 /** Serial number string. */
1380 uint16_t oSerialNumber;
1381 /** Physical USB port the device is connected to. */
1382 uint16_t idPort;
1383
1384} VRDPUSBDEVICEDESC;
1385
1386typedef struct _VRDP_USB_REQ_DEVICE_LIST_RET
1387{
1388 VRDPUSBDEVICEDESC body;
1389 /* Other devices may follow.
1390 * The list ends with (uint16_t)0,
1391 * which means that an empty list consists of 2 zero bytes.
1392 */
1393} VRDP_USB_REQ_DEVICE_LIST_RET;
1394
1395typedef struct _VRDPUSBREQNEGOTIATEPARM
1396{
1397 uint8_t code;
1398
1399 /* Remote USB Protocol version. */
1400 uint32_t version;
1401
1402} VRDPUSBREQNEGOTIATEPARM;
1403
1404#define VRDP_USB_CAPS_FLAG_ASYNC (0x0)
1405#define VRDP_USB_CAPS_FLAG_POLL (0x1)
1406
1407#define VRDP_USB_CAPS_VALID_FLAGS (VRDP_USB_CAPS_FLAG_POLL)
1408
1409typedef struct _VRDPUSBREQNEGOTIATERET
1410{
1411 uint8_t flags;
1412} VRDPUSBREQNEGOTIATERET;
1413
1414#pragma pack()
1415
1416
1417#define VRDP_CLIPBOARD_FORMAT_NULL (0x0)
1418#define VRDP_CLIPBOARD_FORMAT_UNICODE_TEXT (0x1)
1419#define VRDP_CLIPBOARD_FORMAT_BITMAP (0x2)
1420#define VRDP_CLIPBOARD_FORMAT_HTML (0x4)
1421
1422#define VRDP_CLIPBOARD_FUNCTION_FORMAT_ANNOUNCE (0)
1423#define VRDP_CLIPBOARD_FUNCTION_DATA_READ (1)
1424#define VRDP_CLIPBOARD_FUNCTION_DATA_WRITE (2)
1425
1426/**
1427 * Called by the host when (VRDP_CLIPBOARD_FUNCTION_*):
1428 * - (0) guest announces available clipboard formats;
1429 * - (1) guest requests clipboard data;
1430 * - (2) guest responds to the client's request for clipboard data.
1431 *
1432 * @param hserver The VRDP server handle.
1433 * @param u32Function The cause of the call.
1434 * @param u32Format Bitmask of announced formats or the format of data.
1435 * @param pvData Points to: (1) buffer to be filled with clients data;
1436 * (2) data from the host.
1437 * @param cbData Size of 'pvData' buffer in bytes.
1438 * @param pcbActualRead Size of the copied data in bytes.
1439 *
1440 */
1441VRDPR3DECL(void) VRDPClipboard (HVRDPSERVER hserver,
1442 uint32_t u32Function,
1443 uint32_t u32Format,
1444 void *pvData,
1445 uint32_t cbData,
1446 uint32_t *pcbActualRead);
1447
1448/**
1449 * Sends a USB request.
1450 *
1451 * @param hserver Handle of VRDP server instance.
1452 * @param u32ClientId An identifier that allows the server to find the corresponding client.
1453 * The identifier is always passed by the server as a parameter
1454 * of the FNVRDPUSBCALLBACK. Note that the value is the same as
1455 * in the VRDPSERVERCALLBACK functions.
1456 * @param pvParm Function specific parameters buffer.
1457 * @param cbParm Size of the buffer.
1458 */
1459VRDPR3DECL(void) VRDPSendUSBRequest (HVRDPSERVER hserver,
1460 uint32_t u32ClientId,
1461 void *pvParm,
1462 uint32_t cbRarm);
1463
1464
1465/**
1466 * Called by the server when a reply is received from a client.
1467 *
1468 * @param pvCallback Callback specific value returned by VRDPSERVERCALLBACK::pfnInterceptUSB.
1469 * @param u32ClientId Identifies the client that sent the reply.
1470 * @param u8Code The operation code VRDP_USB_REQ_*.
1471 * @param pvRet Points to data received from the client.
1472 * @param cbRet Size of the data in bytes.
1473 *
1474 * @return VBox error code.
1475 */
1476typedef DECLCALLBACK(int) FNVRDPUSBCALLBACK (void *pvCallback,
1477 uint32_t u32ClientId,
1478 uint8_t u8Code,
1479 const void *pvRet,
1480 uint32_t cbRet);
1481
1482typedef FNVRDPUSBCALLBACK *PFNVRDPUSBCALLBACK;
1483
1484/**
1485 * Called by the server when (VRDP_CLIPBOARD_FUNCTION_*):
1486 * - (0) client announces available clipboard formats;
1487 * - (1) client requests clipboard data.
1488 *
1489 * @param pvCallback Callback specific value returned by VRDPSERVERCALLBACK::pfnInterceptClipboard.
1490 * @param u32ClientId Identifies the RDP client that sent the reply.
1491 * @param u32Function The cause of the callback.
1492 * @param u32Format Bitmask of reported formats or the format of received data.
1493 * @param pvData Reserved.
1494 * @param cbData Reserved.
1495 *
1496 * @return VBox error code.
1497 */
1498typedef DECLCALLBACK(int) FNVRDPCLIPBOARDCALLBACK (void *pvCallback,
1499 uint32_t u32ClientId,
1500 uint32_t u32Function,
1501 uint32_t u32Format,
1502 const void *pvData,
1503 uint32_t cbData);
1504
1505typedef FNVRDPCLIPBOARDCALLBACK *PFNVRDPCLIPBOARDCALLBACK;
1506
1507#define VRDP_CLIENT_INTERCEPT_AUDIO (0x1)
1508#define VRDP_CLIENT_INTERCEPT_USB (0x2)
1509#define VRDP_CLIENT_INTERCEPT_CLIPBOARD (0x4)
1510
1511typedef struct _VRDPSERVERCALLBACK
1512{
1513 /* A client is logging in.
1514 *
1515 * @param pvUser The callback specific pointer.
1516 * @param u32ClientId An unique client identifier generated by the server.
1517 * @param pszUser The username.
1518 * @param pszPassword The password.
1519 * @param pszDomain The domain.
1520 *
1521 * @return VBox error code.
1522 */
1523 DECLCALLBACKMEMBER(int, pfnClientLogon) (void *pvUser,
1524 uint32_t u32ClientId,
1525 const char *pszUser,
1526 const char *pszPassword,
1527 const char *pszDomain);
1528 /* The client has connected.
1529 *
1530 * @param pvUser The callback specific pointer.
1531 * @param u32ClientId An unique client identifier generated by the server.
1532 */
1533 DECLCALLBACKMEMBER(void, pfnClientConnect) (void *pvUser,
1534 uint32_t u32ClientId);
1535 /* The client has been disconnected.
1536 *
1537 * @param pvUser The callback specific pointer.
1538 * @param u32ClientId An unique client identifier generated by the server.
1539 * @param fu32Intercepted What was intercepted by the client (VRDP_CLIENT_INTERCEPT_*).
1540 */
1541 DECLCALLBACKMEMBER(void, pfnClientDisconnect) (void *pvUser,
1542 uint32_t u32ClientId,
1543 uint32_t fu32Intercepted);
1544 /* The client supports audio channel.
1545 */
1546 DECLCALLBACKMEMBER(void, pfnInterceptAudio) (void *pvUser,
1547 uint32_t u32ClientId);
1548 /* The client supports USB channel.
1549 */
1550 DECLCALLBACKMEMBER(void, pfnInterceptUSB) (void *pvUser,
1551 uint32_t u32ClientId,
1552 PFNVRDPUSBCALLBACK *ppfn,
1553 void **ppv);
1554 /* The client supports clipboard channel.
1555 */
1556 DECLCALLBACKMEMBER(void, pfnInterceptClipboard) (void *pvUser,
1557 uint32_t u32ClientId,
1558 PFNVRDPCLIPBOARDCALLBACK *ppfn,
1559 void **ppv);
1560} VRDPSERVERCALLBACK;
1561
1562/**
1563 * Set a callback pointers table that will be called by the server in certain situations.
1564 *
1565 * @param hserver Handle of VRDP server instance.
1566 * @param pCallback Pointer to VRDPSERVERCALLBACK structure with function pointers.
1567 * @param pvUser An pointer to be passed to the callback functions.
1568 */
1569VRDPR3DECL(void) VRDPSetCallback (HVRDPSERVER hserver, VRDPSERVERCALLBACK *pCallback, void *pvUser);
1570
1571/** Indexes of information values. */
1572
1573/** Whether a client is connected at the moment.
1574 * uint32_t
1575 */
1576#define VRDP_QI_ACTIVE (0)
1577
1578/** How many times a client connected up to current moment.
1579 * uint32_t
1580 */
1581#define VRDP_QI_NUMBER_OF_CLIENTS (1)
1582
1583/** When last connection was established.
1584 * int64_t time in milliseconds since 1970-01-01 00:00:00 UTC
1585 */
1586#define VRDP_QI_BEGIN_TIME (2)
1587
1588/** When last connection was terminated or current time if connection still active.
1589 * int64_t time in milliseconds since 1970-01-01 00:00:00 UTC
1590 */
1591#define VRDP_QI_END_TIME (3)
1592
1593/** How many bytes were sent in last (current) connection.
1594 * uint64_t
1595 */
1596#define VRDP_QI_BYTES_SENT (4)
1597
1598/** How many bytes were sent in all connections.
1599 * uint64_t
1600 */
1601#define VRDP_QI_BYTES_SENT_TOTAL (5)
1602
1603/** How many bytes were received in last (current) connection.
1604 * uint64_t
1605 */
1606#define VRDP_QI_BYTES_RECEIVED (6)
1607
1608/** How many bytes were received in all connections.
1609 * uint64_t
1610 */
1611#define VRDP_QI_BYTES_RECEIVED_TOTAL (7)
1612
1613/** Login user name supplied by the client.
1614 * UTF8 nul terminated string.
1615 */
1616#define VRDP_QI_USER (8)
1617
1618/** Login domain supplied by the client.
1619 * UTF8 nul terminated string.
1620 */
1621#define VRDP_QI_DOMAIN (9)
1622
1623/** The client name supplied by the client.
1624 * UTF8 nul terminated string.
1625 */
1626#define VRDP_QI_CLIENT_NAME (10)
1627
1628/** IP address of the client.
1629 * UTF8 nul terminated string.
1630 */
1631#define VRDP_QI_CLIENT_IP (11)
1632
1633/** The client software version number.
1634 * uint32_t.
1635 */
1636#define VRDP_QI_CLIENT_VERSION (12)
1637
1638/** Public key exchange method used when connection was established.
1639 * Values: 0 - RDP4 public key exchange scheme.
1640 * 1 - X509 sertificates were sent to client.
1641 * uint32_t.
1642 */
1643#define VRDP_QI_ENCRYPTION_STYLE (13)
1644
1645/**
1646 * Query various information from the VRDP server.
1647 *
1648 * @param index VRDP_QI_* identifier of information to be returned.
1649 * @param pvBuffer Address of memory buffer to which the information must be written.
1650 * @param cbBuffer Size of the memory buffer in bytes.
1651 * @param pcbOut Size in bytes of returned information value.
1652 *
1653 * @remark The caller must check the *pcbOut. 0 there means no information was returned.
1654 * A value greater than cbBuffer means that information is too big to fit in the
1655 * buffer, in that case no information was placed to the buffer.
1656 */
1657VRDPR3DECL(void) VRDPQueryInfo (HVRDPSERVER hserver, uint32_t index, void *pvBuffer, uint32_t cbBuffer, uint32_t *pcbOut);
1658#endif /* VRDP_NO_COM */
1659
1660__END_DECLS
1661
1662/** @} */
1663
1664#endif
1665
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