VirtualBox

source: vbox/trunk/include/VBox/HostServices/DragAndDropSvc.h@ 74334

Last change on this file since 74334 was 74234, checked in by vboxsync, 6 years ago

DnD/DragAndDropSvc.h: Added a protocol TODO list.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 38.7 KB
Line 
1/** @file
2 * Drag and Drop service - Common header for host service and guest clients.
3 */
4
5/*
6 * Copyright (C) 2011-2018 Oracle Corporation
7 *
8 * This file is part of VirtualBox Open Source Edition (OSE), as
9 * available from http://www.virtualbox.org. This file is free software;
10 * you can redistribute it and/or modify it under the terms of the GNU
11 * General Public License (GPL) as published by the Free Software
12 * Foundation, in version 2 as it comes in the "COPYING" file of the
13 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
14 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
15 *
16 * The contents of this file may alternatively be used under the terms
17 * of the Common Development and Distribution License Version 1.0
18 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
19 * VirtualBox OSE distribution, in which case the provisions of the
20 * CDDL are applicable instead of those of the GPL.
21 *
22 * You may elect to license modified versions of this file under the
23 * terms and conditions of either the GPL or the CDDL or both.
24 */
25
26/**
27 * Protocol handling and notes:
28 * All client/server components should be backwards compatible.
29 *
30 ******************************************************************************
31 *
32 * Protocol changelog:
33 *
34 * Protocol v1 (VBox < 5.0, deprecated):
35 * | Initial implementation which only implemented host to guest transfers.
36 * | For file transfers all file information such as the file name and file size were
37 * transferred with every file data chunk being sent.
38 *
39 * Protocol v2 (VBox 5.0 - VBox 5.0.8, deprecated):
40 * + Added support for guest to host transfers.
41 * + Added protocol version support through VBOXDNDCONNECTMSG. The host takes the installed
42 * Guest Additions version as indicator which protocol to use for communicating with the guest.
43 * The guest itself uses VBOXDNDCONNECTMSG to report its supported protocol version to the DnD service.
44 *
45 * Protocol v3 (VBox 5.0.10 and up, current):
46 * + Added VBOXDNDDISCONNECTMSG for being able to track client disconnects on host side (Main).
47 * + Added context IDs for every HGCM message. Not used yet and must be 0.
48 * + Added VBOXDNDSNDDATAHDR and VBOXDNDCBSNDDATAHDRDATA to support (simple) accounting of objects
49 * being transferred, along with supplying separate meta data size (which is part of the total size being sent).
50 * + Added new HOST_DND_HG_SND_DATA_HDR + GUEST_DND_GH_SND_DATA_HDR commands which now allow specifying an optional
51 * compression type and defining a checksum for the overall data transfer.
52 * + Enhannced VBOXDNDGHSENDDATAMSG to support (rolling) checksums for the supplied data block.
53 * + VBOXDNDHGSENDDATAMSG and VBOXDNDGHSENDDATAMSG can now contain an optional checksum for the current data block.
54 * | VBOXDNDHGSENDFILEDATAMSG and VBOXDNDGHSENDFILEDATAMSG are now sharing the same HGCM mesasge.
55 * - Removed unused HOST_DND_GH_RECV_DIR, HOST_DND_GH_RECV_FILE_DATA and HOST_DND_GH_RECV_FILE_HDR commands.
56 *
57 * Protocol TODO:
58 *
59 * - Split up messages which use VBOXDNDHGACTIONMSG into own functions and remove parameters which
60 * are not actually needed / used by a function. Why does HOST_DND_HG_EVT_MOVE need all the format stuff, for example?
61 */
62
63#ifndef ___VBox_HostService_DragAndDropSvc_h
64#define ___VBox_HostService_DragAndDropSvc_h
65
66#include <VBox/hgcmsvc.h>
67#include <VBox/VMMDevCoreTypes.h>
68#include <VBox/VBoxGuestCoreTypes.h>
69
70/*
71 * The mode of operations.
72 */
73#define VBOX_DRAG_AND_DROP_MODE_OFF 0
74#define VBOX_DRAG_AND_DROP_MODE_HOST_TO_GUEST 1
75#define VBOX_DRAG_AND_DROP_MODE_GUEST_TO_HOST 2
76#define VBOX_DRAG_AND_DROP_MODE_BIDIRECTIONAL 3
77
78#define DND_IGNORE_ACTION UINT32_C(0)
79#define DND_COPY_ACTION RT_BIT_32(0)
80#define DND_MOVE_ACTION RT_BIT_32(1)
81#define DND_LINK_ACTION RT_BIT_32(2)
82
83#define hasDnDCopyAction(a) ((a) & DND_COPY_ACTION)
84#define hasDnDMoveAction(a) ((a) & DND_MOVE_ACTION)
85#define hasDnDLinkAction(a) ((a) & DND_LINK_ACTION)
86
87#define isDnDIgnoreAction(a) ((a) == DND_IGNORE_ACTION)
88#define isDnDCopyAction(a) ((a) == DND_COPY_ACTION)
89#define isDnDMoveAction(a) ((a) == DND_MOVE_ACTION)
90#define isDnDLinkAction(a) ((a) == DND_LINK_ACTION)
91
92/** @def VBOX_DND_FORMATS_DEFAULT
93 * Default drag'n drop formats.
94 * Note: If you add new entries here, make sure you test those
95 * with all supported guest OSes!
96 */
97#define VBOX_DND_FORMATS_DEFAULT \
98 "text/uri-list", \
99 /* Text. */ \
100 "text/html", \
101 "text/plain;charset=utf-8", \
102 "text/plain;charset=utf-16", \
103 "text/plain", \
104 "text/richtext", \
105 "UTF8_STRING", \
106 "TEXT", \
107 "STRING", \
108 /* OpenOffice formats. */ \
109 /* See: https://wiki.openoffice.org/wiki/Documentation/DevGuide/OfficeDev/Common_Application_Features#OpenOffice.org_Clipboard_Data_Formats */ \
110 "application/x-openoffice-embed-source-xml;windows_formatname=\"Star Embed Source (XML)\"", \
111 "application/x-openoffice;windows_formatname=\"Bitmap\""
112
113namespace DragAndDropSvc {
114
115/******************************************************************************
116* Typedefs, constants and inlines *
117******************************************************************************/
118
119/**
120 * The service functions which are callable by host.
121 * Note: When adding new functions to this table, make sure that the actual ID
122 * does *not* overlap with the eGuestFn enumeration below!
123 */
124enum eHostFn
125{
126 /** The host just has set a new DnD mode. */
127 HOST_DND_SET_MODE = 100,
128
129 /*
130 * Host -> Guest messages
131 */
132
133 /** The host entered the VM window for starting an actual
134 * DnD operation. */
135 HOST_DND_HG_EVT_ENTER = 200,
136 /** The host's DnD cursor moved within the VM window. */
137 HOST_DND_HG_EVT_MOVE = 201,
138 /** The host left the guest VM window. */
139 HOST_DND_HG_EVT_LEAVE = 202,
140 /** The host issued a "drop" event, meaning that the host is
141 * ready to transfer data over to the guest. */
142 HOST_DND_HG_EVT_DROPPED = 203,
143 /** The host requested to cancel the current DnD operation on
144 * the guest side. This can happen on user request on the host's
145 * UI side or due to some host error which has happened.
146 *
147 * Note: This is a fire-and-forget message, as the host should
148 * not rely on an answer from the guest side in order to
149 * properly cancel the operation. */
150 HOST_DND_HG_EVT_CANCEL = 204,
151 /** Sends the data header at the beginning of a (new)
152 * data transfer. */
153 HOST_DND_HG_SND_DATA_HDR = 210,
154 /**
155 * Sends the actual meta data, based on
156 * the format(s) specified by HOST_DND_HG_EVT_ENTER.
157 *
158 * Protocol v1/v2: If the guest supplied buffer too small to send
159 * the actual data, the host will send a HOST_DND_HG_SND_MORE_DATA
160 * message as follow-up.
161 * Protocol v3+: The incoming meta data size is specified upfront in the
162 * HOST_DND_HG_SND_DATA_HDR message and must be handled accordingly.
163 */
164 HOST_DND_HG_SND_DATA = 205,
165 /** Sent when the actual buffer for HOST_DND_HG_SND_DATA was too small. */
166 /** @todo Deprecated function; do not use anymore. */
167 HOST_DND_HG_SND_MORE_DATA = 206,
168 /** Directory entry to be sent to the guest. */
169 HOST_DND_HG_SND_DIR = 207,
170 /** File data chunk to send to the guest. */
171 HOST_DND_HG_SND_FILE_DATA = 208,
172 /** File header to send to the guest.
173 * Note: Only for protocol version 2 and up (>= VBox 5.0). */
174 HOST_DND_HG_SND_FILE_HDR = 209,
175
176 /*
177 * Guest -> Host messages
178 */
179
180 /** The host asks the guest whether a DnD operation
181 * is in progress when the mouse leaves the guest window. */
182 HOST_DND_GH_REQ_PENDING = 600,
183 /** The host informs the guest that a DnD drop operation
184 * has been started and that the host wants the data in
185 * a specific MIME type. */
186 HOST_DND_GH_EVT_DROPPED = 601,
187 /** Blow the type up to 32-bit. */
188 HOST_DND_32BIT_HACK = 0x7fffffff
189};
190
191/**
192 * The service functions which are called by guest.
193 * Note: When adding new functions to this table, make sure that the actual ID
194 * does *not* overlap with the eHostFn enumeration above!
195 */
196enum eGuestFn
197{
198 /* Guest sends a connection request to the HGCM service,
199 * along with some additional information like supported
200 * protocol version and flags.
201 * Note: New since protocol version 2. */
202 GUEST_DND_CONNECT = 10,
203
204 /* Sent when a guest client disconnected from the HGCM service. */
205 GUEST_DND_DISCONNECT = 11,
206
207 /**
208 * Guest waits for a new message the host wants to process
209 * on the guest side. This can be a blocking call.
210 */
211 GUEST_DND_GET_NEXT_HOST_MSG = 300,
212
213 /*
214 * Host -> Guest operation messages.
215 */
216
217 /** The guest acknowledges that the pending DnD data from
218 * the host can be dropped on the currently selected source
219 * on the guest. */
220 GUEST_DND_HG_ACK_OP = 400,
221 /** The guest requests the actual DnD data to be sent
222 * from the host. */
223 GUEST_DND_HG_REQ_DATA = 401,
224 /** Reports back the guest's progress on a host -> guest operation. */
225 GUEST_DND_HG_EVT_PROGRESS = 402,
226
227 /*
228 * Guest -> Host operation messages.
229 */
230
231 /**
232 * The guests acknowledges that it currently has a drag'n drop
233 * operation in progress on the guest, which eventually could be
234 * dragged over to the host.
235 */
236 GUEST_DND_GH_ACK_PENDING = 500,
237 /** Sends the data header at the beginning of a (new)
238 * data transfer. */
239 GUEST_DND_GH_SND_DATA_HDR = 503,
240 /**
241 * Sends data of the requested format to the host. There can
242 * be more than one message if the actual data does not fit
243 * into one.
244 */
245 GUEST_DND_GH_SND_DATA = 501,
246 /** Reports an error back to the host. */
247 GUEST_DND_GH_EVT_ERROR = 502,
248 /** Guest sends a directory entry to the host. */
249 GUEST_DND_GH_SND_DIR = 700,
250 /** Guest sends file data to the host. */
251 /* Note: On protocol version 1 this also contains the file name
252 * and other attributes. */
253 GUEST_DND_GH_SND_FILE_DATA = 701,
254 /** Guest sends a file header to the host, marking the
255 * beginning of a (new) file transfer.
256 * Note: Available since protocol version 2 (VBox 5.0). */
257 GUEST_DND_GH_SND_FILE_HDR = 702,
258 /** Blow the type up to 32-bit. */
259 GUEST_DND_32BIT_HACK = 0x7fffffff
260};
261
262/**
263 * DnD operation progress states.
264 */
265typedef enum DNDPROGRESS
266{
267 DND_PROGRESS_UNKNOWN = 0,
268 DND_PROGRESS_RUNNING = 1,
269 DND_PROGRESS_COMPLETE,
270 DND_PROGRESS_CANCELLED,
271 DND_PROGRESS_ERROR,
272 /** Blow the type up to 32-bit. */
273 DND_PROGRESS_32BIT_HACK = 0x7fffffff
274} DNDPROGRESS, *PDNDPROGRESS;
275
276#pragma pack (1)
277
278/*
279 * Host events
280 */
281
282/**
283 * Action message for telling the guest about the currently ongoing
284 * drag and drop action when entering the guest's area, moving around in it
285 * and dropping content into it from the host.
286 *
287 * Used by:
288 * HOST_DND_HG_EVT_ENTER
289 * HOST_DND_HG_EVT_MOVE
290 * HOST_DND_HG_EVT_DROPPED
291 */
292typedef struct VBOXDNDHGACTIONMSG
293{
294 VBGLIOCHGCMCALL hdr;
295
296 union
297 {
298 struct
299 {
300 HGCMFunctionParameter uScreenId; /* OUT uint32_t */
301 HGCMFunctionParameter uX; /* OUT uint32_t */
302 HGCMFunctionParameter uY; /* OUT uint32_t */
303 HGCMFunctionParameter uDefAction; /* OUT uint32_t */
304 HGCMFunctionParameter uAllActions; /* OUT uint32_t */
305 HGCMFunctionParameter pvFormats; /* OUT ptr */
306 HGCMFunctionParameter cbFormats; /* OUT uint32_t */
307 } v1;
308 struct
309 {
310 /** Context ID. */
311 HGCMFunctionParameter uContext;
312 HGCMFunctionParameter uScreenId; /* OUT uint32_t */
313 HGCMFunctionParameter uX; /* OUT uint32_t */
314 HGCMFunctionParameter uY; /* OUT uint32_t */
315 HGCMFunctionParameter uDefAction; /* OUT uint32_t */
316 HGCMFunctionParameter uAllActions; /* OUT uint32_t */
317 HGCMFunctionParameter pvFormats; /* OUT ptr */
318 HGCMFunctionParameter cbFormats; /* OUT uint32_t */
319 } v3;
320 } u;
321} VBOXDNDHGACTIONMSG;
322
323/**
324 * Tells the guest that the host has left its drag and drop area on the guest.
325 *
326 * Used by:
327 * HOST_DND_HG_EVT_LEAVE
328 */
329typedef struct VBOXDNDHGLEAVEMSG
330{
331 VBGLIOCHGCMCALL hdr;
332 union
333 {
334 struct
335 {
336 /** Context ID. */
337 HGCMFunctionParameter uContext;
338 } v3;
339 } u;
340} VBOXDNDHGLEAVEMSG;
341
342/**
343 * Tells the guest that the host wants to cancel the current drag and drop operation.
344 *
345 * Used by:
346 * HOST_DND_HG_EVT_CANCEL
347 */
348typedef struct VBOXDNDHGCANCELMSG
349{
350 VBGLIOCHGCMCALL hdr;
351 union
352 {
353 struct
354 {
355 /** Context ID. */
356 HGCMFunctionParameter uContext;
357 } v3;
358 } u;
359} VBOXDNDHGCANCELMSG;
360
361/**
362 * Sends the header of an incoming (meta) data block.
363 *
364 * Used by:
365 * HOST_DND_HG_SND_DATA_HDR
366 * GUEST_DND_GH_SND_DATA_HDR
367 *
368 * New since protocol v3.
369 */
370typedef struct VBOXDNDHGSENDDATAHDRMSG
371{
372 VBGLIOCHGCMCALL hdr;
373
374 /** Context ID. Unused at the moment. */
375 HGCMFunctionParameter uContext; /* OUT uint32_t */
376 /** Data transfer flags. Not yet used and must be 0. */
377 HGCMFunctionParameter uFlags; /* OUT uint32_t */
378 /** Screen ID where the data originates from. */
379 HGCMFunctionParameter uScreenId; /* OUT uint32_t */
380 /** Total size (in bytes) to transfer. */
381 HGCMFunctionParameter cbTotal; /* OUT uint64_t */
382 /**
383 * Total meta data size (in bytes) to transfer.
384 * This size also is part of cbTotal already, so:
385 *
386 * cbTotal = cbMeta + additional size for files etc.
387 */
388 HGCMFunctionParameter cbMeta; /* OUT uint64_t */
389 /** Meta data format. */
390 HGCMFunctionParameter pvMetaFmt; /* OUT ptr */
391 /** Size (in bytes) of meta data format. */
392 HGCMFunctionParameter cbMetaFmt; /* OUT uint32_t */
393 /* Number of objects (files/directories) to transfer. */
394 HGCMFunctionParameter cObjects; /* OUT uint64_t */
395 /** Compression type. */
396 HGCMFunctionParameter enmCompression; /* OUT uint32_t */
397 /** Checksum type. */
398 HGCMFunctionParameter enmChecksumType; /* OUT uint32_t */
399 /** Checksum buffer for the entire data to be transferred. */
400 HGCMFunctionParameter pvChecksum; /* OUT ptr */
401 /** Size (in bytes) of checksum. */
402 HGCMFunctionParameter cbChecksum; /* OUT uint32_t */
403} VBOXDNDHGSENDDATAHDRMSG;
404
405/**
406 * Sends a (meta) data block to the guest.
407 *
408 * Used by:
409 * HOST_DND_HG_SND_DATA
410 */
411typedef struct VBOXDNDHGSENDDATAMSG
412{
413 VBGLIOCHGCMCALL hdr;
414
415 union
416 {
417 struct
418 {
419 HGCMFunctionParameter uScreenId; /* OUT uint32_t */
420 HGCMFunctionParameter pvFormat; /* OUT ptr */
421 HGCMFunctionParameter cbFormat; /* OUT uint32_t */
422 HGCMFunctionParameter pvData; /* OUT ptr */
423 HGCMFunctionParameter cbData; /* OUT uint32_t */
424 } v1;
425 /* No changes in v2. */
426 struct
427 {
428 /** Context ID. Unused at the moment. */
429 HGCMFunctionParameter uContext; /* OUT uint32_t */
430 /** Data block to send. */
431 HGCMFunctionParameter pvData; /* OUT ptr */
432 /** Size (in bytes) of data block to send. */
433 HGCMFunctionParameter cbData; /* OUT uint32_t */
434 /** Checksum of data block, based on the checksum
435 * type in the data header. Optional. */
436 HGCMFunctionParameter pvChecksum; /* OUT ptr */
437 /** Size (in bytes) of checksum to send. */
438 HGCMFunctionParameter cbChecksum; /* OUT uint32_t */
439 } v3;
440 } u;
441} VBOXDNDHGSENDDATAMSG;
442
443/**
444 * Sends more (meta) data in case the data didn't fit
445 * into the current XXX_DND_HG_SND_DATA message.
446 *
447 ** @todo Deprecated since protocol v3. Don't use! Will be removed.
448 *
449 * Used by:
450 * HOST_DND_HG_SND_MORE_DATA
451 */
452typedef struct VBOXDNDHGSENDMOREDATAMSG
453{
454 VBGLIOCHGCMCALL hdr;
455
456 HGCMFunctionParameter pvData; /* OUT ptr */
457 HGCMFunctionParameter cbData; /* OUT uint32_t */
458} VBOXDNDHGSENDMOREDATAMSG;
459
460/**
461 * Directory entry event.
462 *
463 * Used by:
464 * HOST_DND_HG_SND_DIR
465 * GUEST_DND_GH_SND_DIR
466 */
467typedef struct VBOXDNDHGSENDDIRMSG
468{
469 VBGLIOCHGCMCALL hdr;
470
471 union
472 {
473 struct
474 {
475 /** Directory name. */
476 HGCMFunctionParameter pvName; /* OUT ptr */
477 /** Size (in bytes) of directory name. */
478 HGCMFunctionParameter cbName; /* OUT uint32_t */
479 /** Directory mode. */
480 HGCMFunctionParameter fMode; /* OUT uint32_t */
481 } v1;
482 struct
483 {
484 /** Context ID. Unused at the moment. */
485 HGCMFunctionParameter uContext; /* OUT uint32_t */
486 /** Directory name. */
487 HGCMFunctionParameter pvName; /* OUT ptr */
488 /** Size (in bytes) of directory name. */
489 HGCMFunctionParameter cbName; /* OUT uint32_t */
490 /** Directory mode. */
491 HGCMFunctionParameter fMode; /* OUT uint32_t */
492 } v3;
493 } u;
494} VBOXDNDHGSENDDIRMSG;
495
496/**
497 * File header message, marking the start of transferring a new file.
498 * Note: Only for protocol version 2 and up.
499 *
500 * Used by:
501 * HOST_DND_HG_SND_FILE_HDR
502 * GUEST_DND_GH_SND_FILE_HDR
503 */
504typedef struct VBOXDNDHGSENDFILEHDRMSG
505{
506 VBGLIOCHGCMCALL hdr;
507
508 /** Context ID. Unused at the moment. */
509 HGCMFunctionParameter uContext; /* OUT uint32_t */
510 /** File path. */
511 HGCMFunctionParameter pvName; /* OUT ptr */
512 /** Size (in bytes) of file path. */
513 HGCMFunctionParameter cbName; /* OUT uint32_t */
514 /** Optional flags; unused at the moment. */
515 HGCMFunctionParameter uFlags; /* OUT uint32_t */
516 /** File creation mode. */
517 HGCMFunctionParameter fMode; /* OUT uint32_t */
518 /** Total size (in bytes). */
519 HGCMFunctionParameter cbTotal; /* OUT uint64_t */
520} VBOXDNDHGSENDFILEHDRMSG;
521
522/**
523 * HG: File data (chunk) event.
524 *
525 * Used by:
526 * HOST_DND_HG_SND_FILE
527 */
528typedef struct VBOXDNDHGSENDFILEDATAMSG
529{
530 VBGLIOCHGCMCALL hdr;
531
532 union
533 {
534 /* Note: Protocol v1 sends the file name + file mode
535 * every time a file data chunk is being sent. */
536 struct
537 {
538 /** File name. */
539 HGCMFunctionParameter pvName; /* OUT ptr */
540 /** Size (in bytes) of file name. */
541 HGCMFunctionParameter cbName; /* OUT uint32_t */
542 /** Current data chunk. */
543 HGCMFunctionParameter pvData; /* OUT ptr */
544 /** Size (in bytes) of current data chunk. */
545 HGCMFunctionParameter cbData; /* OUT uint32_t */
546 /** File mode. */
547 HGCMFunctionParameter fMode; /* OUT uint32_t */
548 } v1;
549 struct
550 {
551 /** Note: pvName is now part of the VBOXDNDHGSENDFILEHDRMSG message. */
552 /** Note: cbName is now part of the VBOXDNDHGSENDFILEHDRMSG message. */
553 /** Context ID. Unused at the moment. */
554 HGCMFunctionParameter uContext; /* OUT uint32_t */
555 /** Current data chunk. */
556 HGCMFunctionParameter pvData; /* OUT ptr */
557 /** Size (in bytes) of current data chunk. */
558 HGCMFunctionParameter cbData; /* OUT uint32_t */
559 /** Note: fMode is now part of the VBOXDNDHGSENDFILEHDRMSG message. */
560 } v2;
561 struct
562 {
563 /** Context ID. Unused at the moment. */
564 HGCMFunctionParameter uContext; /* OUT uint32_t */
565 /** Current data chunk. */
566 HGCMFunctionParameter pvData; /* OUT ptr */
567 /** Size (in bytes) of current data chunk. */
568 HGCMFunctionParameter cbData; /* OUT uint32_t */
569 /** Checksum of data block, based on the checksum
570 * type in the data header. Optional. */
571 HGCMFunctionParameter pvChecksum; /* OUT ptr */
572 /** Size (in bytes) of curren data chunk checksum. */
573 HGCMFunctionParameter cbChecksum; /* OUT uint32_t */
574 } v3;
575 } u;
576} VBOXDNDHGSENDFILEDATAMSG;
577
578/**
579 * Asks the guest if a guest->host DnD operation is in progress.
580 *
581 * Used by:
582 * HOST_DND_GH_REQ_PENDING
583 */
584typedef struct VBOXDNDGHREQPENDINGMSG
585{
586 VBGLIOCHGCMCALL hdr;
587
588 union
589 {
590 struct
591 {
592 /** Screen ID. */
593 HGCMFunctionParameter uScreenId; /* OUT uint32_t */
594 } v1;
595 struct
596 {
597 /** Context ID. Unused at the moment. */
598 HGCMFunctionParameter uContext; /* OUT uint32_t */
599 /** Screen ID. */
600 HGCMFunctionParameter uScreenId; /* OUT uint32_t */
601 } v3;
602 } u;
603} VBOXDNDGHREQPENDINGMSG;
604
605/**
606 * Tells the guest that the host has dropped the ongoing guest->host
607 * DnD operation on a valid target on the host.
608 *
609 * Used by:
610 * HOST_DND_GH_EVT_DROPPED
611 */
612typedef struct VBOXDNDGHDROPPEDMSG
613{
614 VBGLIOCHGCMCALL hdr;
615
616 union
617 {
618 struct
619 {
620 /** Requested format for sending the data. */
621 HGCMFunctionParameter pvFormat; /* OUT ptr */
622 /** Size (in bytes) of requested format. */
623 HGCMFunctionParameter cbFormat; /* OUT uint32_t */
624 /** Drop action peformed on the host. */
625 HGCMFunctionParameter uAction; /* OUT uint32_t */
626 } v1;
627 struct
628 {
629 /** Context ID. Unused at the moment. */
630 HGCMFunctionParameter uContext; /* OUT uint32_t */
631 /** Requested format for sending the data. */
632 HGCMFunctionParameter pvFormat; /* OUT ptr */
633 /** Size (in bytes) of requested format. */
634 HGCMFunctionParameter cbFormat; /* OUT uint32_t */
635 /** Drop action peformed on the host. */
636 HGCMFunctionParameter uAction; /* OUT uint32_t */
637 } v3;
638 } u;
639} VBOXDNDGHDROPPEDMSG;
640
641/*
642 * Guest events
643 */
644
645/**
646 * Asks the host for the next command to process, along
647 * with the needed amount of parameters and an optional blocking
648 * flag.
649 *
650 * Used by:
651 * GUEST_DND_GET_NEXT_HOST_MSG
652 */
653typedef struct VBOXDNDNEXTMSGMSG
654{
655 VBGLIOCHGCMCALL hdr;
656
657 /** Message ID. */
658 HGCMFunctionParameter uMsg; /* OUT uint32_t */
659 /** Number of parameters the message needs. */
660 HGCMFunctionParameter cParms; /* OUT uint32_t */
661 /** Whether or not to block (wait) for a
662 * new message to arrive. */
663 HGCMFunctionParameter fBlock; /* OUT uint32_t */
664} VBOXDNDNEXTMSGMSG;
665
666/**
667 * Guest connection request. Used to tell the DnD protocol
668 * version to the (host) service.
669 *
670 * Used by:
671 * GUEST_DND_CONNECT
672 */
673typedef struct VBOXDNDCONNECTMSG
674{
675 VBGLIOCHGCMCALL hdr;
676
677 union
678 {
679 struct
680 {
681 /** Protocol version to use. */
682 HGCMFunctionParameter uProtocol; /* OUT uint32_t */
683 /** Connection flags. Optional. */
684 HGCMFunctionParameter uFlags; /* OUT uint32_t */
685 } v2;
686 struct
687 {
688 /** Context ID. Unused at the moment. */
689 HGCMFunctionParameter uContext; /* OUT uint32_t */
690 /** Protocol version to use. */
691 HGCMFunctionParameter uProtocol; /* OUT uint32_t */
692 /** Connection flags. Optional. */
693 HGCMFunctionParameter uFlags; /* OUT uint32_t */
694 } v3;
695 } u;
696} VBOXDNDCONNECTMSG;
697
698/**
699 * Acknowledges a host operation along with the allowed
700 * action(s) on the guest.
701 *
702 * Used by:
703 * GUEST_DND_HG_ACK_OP
704 */
705typedef struct VBOXDNDHGACKOPMSG
706{
707 VBGLIOCHGCMCALL hdr;
708
709 union
710 {
711 struct
712 {
713 HGCMFunctionParameter uAction; /* OUT uint32_t */
714 } v1;
715 struct
716 {
717 /** Context ID. Unused at the moment. */
718 HGCMFunctionParameter uContext; /* OUT uint32_t */
719 HGCMFunctionParameter uAction; /* OUT uint32_t */
720 } v3;
721 } u;
722} VBOXDNDHGACKOPMSG;
723
724/**
725 * HG request for data event.
726 *
727 * Used by:
728 * GUEST_DND_HG_REQ_DATA
729 */
730typedef struct VBOXDNDHGREQDATAMSG
731{
732 VBGLIOCHGCMCALL hdr;
733
734 union
735 {
736 struct
737 {
738 HGCMFunctionParameter pvFormat; /* OUT ptr */
739 } v1;
740 struct
741 {
742 /** Context ID. Unused at the moment. */
743 HGCMFunctionParameter uContext; /* OUT uint32_t */
744 HGCMFunctionParameter pvFormat; /* OUT ptr */
745 HGCMFunctionParameter cbFormat; /* OUT uint32_t */
746 } v3;
747 } u;
748} VBOXDNDHGREQDATAMSG;
749
750typedef struct VBOXDNDHGEVTPROGRESSMSG
751{
752 VBGLIOCHGCMCALL hdr;
753
754 union
755 {
756 struct
757 {
758 HGCMFunctionParameter uStatus; /* OUT uint32_t */
759 HGCMFunctionParameter uPercent; /* OUT uint32_t */
760 HGCMFunctionParameter rc; /* OUT uint32_t */
761 } v1;
762 struct
763 {
764 /** Context ID. Unused at the moment. */
765 HGCMFunctionParameter uContext; /* OUT uint32_t */
766 HGCMFunctionParameter uStatus; /* OUT uint32_t */
767 HGCMFunctionParameter uPercent; /* OUT uint32_t */
768 HGCMFunctionParameter rc; /* OUT uint32_t */
769 } v3;
770 } u;
771} VBOXDNDHGEVTPROGRESSMSG;
772
773/**
774 * Acknowledges a pending drag and drop event
775 * to the host.
776 *
777 * Used by:
778 * GUEST_DND_GH_ACK_PENDING
779 */
780typedef struct VBOXDNDGHACKPENDINGMSG
781{
782 VBGLIOCHGCMCALL hdr;
783
784 union
785 {
786 struct
787 {
788 HGCMFunctionParameter uDefAction; /* OUT uint32_t */
789 HGCMFunctionParameter uAllActions; /* OUT uint32_t */
790 HGCMFunctionParameter pvFormats; /* OUT ptr */
791 } v1;
792 struct
793 {
794 /** Context ID. Unused at the moment. */
795 HGCMFunctionParameter uContext; /* OUT uint32_t */
796 HGCMFunctionParameter uDefAction; /* OUT uint32_t */
797 HGCMFunctionParameter uAllActions; /* OUT uint32_t */
798 HGCMFunctionParameter pvFormats; /* OUT ptr */
799 HGCMFunctionParameter cbFormats; /* OUT uint32_t */
800 } v3;
801 } u;
802} VBOXDNDGHACKPENDINGMSG;
803
804/**
805 * Sends the header of an incoming data block
806 * to the host.
807 *
808 * Used by:
809 * GUEST_DND_GH_SND_DATA_HDR
810 *
811 * New since protocol v3.
812 */
813typedef struct VBOXDNDHGSENDDATAHDRMSG VBOXDNDGHSENDDATAHDRMSG;
814
815/**
816 * Sends a (meta) data block to the host.
817 *
818 * Used by:
819 * GUEST_DND_GH_SND_DATA
820 */
821typedef struct VBOXDNDGHSENDDATAMSG
822{
823 VBGLIOCHGCMCALL hdr;
824
825 union
826 {
827 struct
828 {
829 HGCMFunctionParameter pvData; /* OUT ptr */
830 /** Total bytes to send. This can be more than
831 * the data block specified in pvData above, e.g.
832 * when sending over file objects afterwards. */
833 HGCMFunctionParameter cbTotalBytes; /* OUT uint32_t */
834 } v1;
835 struct
836 {
837 /** Context ID. Unused at the moment. */
838 HGCMFunctionParameter uContext; /* OUT uint32_t */
839 /** Data block to send. */
840 HGCMFunctionParameter pvData; /* OUT ptr */
841 /** Size (in bytes) of data block to send. */
842 HGCMFunctionParameter cbData; /* OUT uint32_t */
843 /** (Rolling) Checksum, based on checksum type in data header. */
844 HGCMFunctionParameter pvChecksum; /* OUT ptr */
845 /** Size (in bytes) of checksum. */
846 HGCMFunctionParameter cbChecksum; /* OUT uint32_t */
847 } v3;
848 } u;
849} VBOXDNDGHSENDDATAMSG;
850
851/**
852 * Sends a directory entry to the host.
853 *
854 * Used by:
855 * GUEST_DND_GH_SND_DIR
856 */
857typedef struct VBOXDNDHGSENDDIRMSG VBOXDNDGHSENDDIRMSG;
858
859/**
860 * Sends a file header to the host.
861 *
862 * Used by:
863 * GUEST_DND_GH_SND_FILE_HDR
864 *
865 * New since protocol v2.
866 */
867typedef struct VBOXDNDHGSENDFILEHDRMSG VBOXDNDGHSENDFILEHDRMSG;
868
869/**
870 * Sends file data to the host.
871 *
872 * Used by:
873 * GUEST_DND_GH_SND_FILE_DATA
874 */
875typedef struct VBOXDNDHGSENDFILEDATAMSG VBOXDNDGHSENDFILEDATAMSG;
876
877/**
878 * Sends a guest error event to the host.
879 *
880 * Used by:
881 * GUEST_DND_GH_EVT_ERROR
882 */
883typedef struct VBOXDNDGHEVTERRORMSG
884{
885 VBGLIOCHGCMCALL hdr;
886
887 union
888 {
889 struct
890 {
891 HGCMFunctionParameter rc; /* OUT uint32_t */
892 } v1;
893 struct
894 {
895 /** Context ID. Unused at the moment. */
896 HGCMFunctionParameter uContext; /* OUT uint32_t */
897 HGCMFunctionParameter rc; /* OUT uint32_t */
898 } v3;
899 } u;
900} VBOXDNDGHEVTERRORMSG;
901
902#pragma pack()
903
904/** Builds a callback magic out of the function ID and the version
905 * of the callback data. */
906#define VBOX_DND_CB_MAGIC_MAKE(uFn, uVer) \
907 RT_MAKE_U32(uVer, uFn)
908
909/*
910 * Callback magics.
911 */
912enum eDnDCallbackMagics
913{
914 CB_MAGIC_DND_CONNECT = VBOX_DND_CB_MAGIC_MAKE(GUEST_DND_CONNECT, 0),
915 CB_MAGIC_DND_HG_GET_NEXT_HOST_MSG = VBOX_DND_CB_MAGIC_MAKE(GUEST_DND_GET_NEXT_HOST_MSG, 0),
916 CB_MAGIC_DND_HG_ACK_OP = VBOX_DND_CB_MAGIC_MAKE(GUEST_DND_HG_ACK_OP, 0),
917 CB_MAGIC_DND_HG_REQ_DATA = VBOX_DND_CB_MAGIC_MAKE(GUEST_DND_HG_REQ_DATA, 0),
918 CB_MAGIC_DND_HG_EVT_PROGRESS = VBOX_DND_CB_MAGIC_MAKE(GUEST_DND_HG_EVT_PROGRESS, 0),
919 CB_MAGIC_DND_GH_ACK_PENDING = VBOX_DND_CB_MAGIC_MAKE(GUEST_DND_GH_ACK_PENDING, 0),
920 CB_MAGIC_DND_GH_SND_DATA = VBOX_DND_CB_MAGIC_MAKE(GUEST_DND_GH_SND_DATA, 0),
921 CB_MAGIC_DND_GH_SND_DATA_HDR = VBOX_DND_CB_MAGIC_MAKE(GUEST_DND_GH_SND_DATA_HDR, 0),
922 CB_MAGIC_DND_GH_SND_DIR = VBOX_DND_CB_MAGIC_MAKE(GUEST_DND_GH_SND_DIR, 0),
923 CB_MAGIC_DND_GH_SND_FILE_HDR = VBOX_DND_CB_MAGIC_MAKE(GUEST_DND_GH_SND_FILE_HDR, 0),
924 CB_MAGIC_DND_GH_SND_FILE_DATA = VBOX_DND_CB_MAGIC_MAKE(GUEST_DND_GH_SND_FILE_DATA, 0),
925 CB_MAGIC_DND_GH_EVT_ERROR = VBOX_DND_CB_MAGIC_MAKE(GUEST_DND_GH_EVT_ERROR, 0)
926};
927
928typedef struct VBOXDNDCBHEADERDATA
929{
930 /** Magic number to identify the structure. */
931 uint32_t uMagic;
932 /** Context ID to identify callback data. */
933 uint32_t uContextID;
934} VBOXDNDCBHEADERDATA, *PVBOXDNDCBHEADERDATA;
935
936typedef struct VBOXDNDCBCONNECTMSGDATA
937{
938 /** Callback data header. */
939 VBOXDNDCBHEADERDATA hdr;
940 uint32_t uProtocol;
941 uint32_t uFlags;
942} VBOXDNDCBCONNECTMSGDATA, *PVBOXDNDCBCONNECTMSGDATA;
943
944typedef struct VBOXDNDCBDISCONNECTMSGDATA
945{
946 /** Callback data header. */
947 VBOXDNDCBHEADERDATA hdr;
948} VBOXDNDCBDISCONNECTMSGDATA, *PVBOXDNDCBDISCONNECTMSGDATA;
949
950typedef struct VBOXDNDCBHGGETNEXTHOSTMSG
951{
952 /** Callback data header. */
953 VBOXDNDCBHEADERDATA hdr;
954 uint32_t uMsg;
955 uint32_t cParms;
956} VBOXDNDCBHGGETNEXTHOSTMSG, *PVBOXDNDCBHGGETNEXTHOSTMSG;
957
958typedef struct VBOXDNDCBHGGETNEXTHOSTMSGDATA
959{
960 /** Callback data header. */
961 VBOXDNDCBHEADERDATA hdr;
962 uint32_t uMsg;
963 uint32_t cParms;
964 PVBOXHGCMSVCPARM paParms;
965} VBOXDNDCBHGGETNEXTHOSTMSGDATA, *PVBOXDNDCBHGGETNEXTHOSTMSGDATA;
966
967typedef struct VBOXDNDCBHGACKOPDATA
968{
969 /** Callback data header. */
970 VBOXDNDCBHEADERDATA hdr;
971 uint32_t uAction;
972} VBOXDNDCBHGACKOPDATA, *PVBOXDNDCBHGACKOPDATA;
973
974typedef struct VBOXDNDCBHGREQDATADATA
975{
976 /** Callback data header. */
977 VBOXDNDCBHEADERDATA hdr;
978 char *pszFormat;
979 uint32_t cbFormat;
980} VBOXDNDCBHGREQDATADATA, *PVBOXDNDCBHGREQDATADATA;
981
982typedef struct VBOXDNDCBHGEVTPROGRESSDATA
983{
984 /** Callback data header. */
985 VBOXDNDCBHEADERDATA hdr;
986 uint32_t uPercentage;
987 uint32_t uStatus;
988 uint32_t rc;
989} VBOXDNDCBHGEVTPROGRESSDATA, *PVBOXDNDCBHGEVTPROGRESSDATA;
990
991typedef struct VBOXDNDCBGHACKPENDINGDATA
992{
993 /** Callback data header. */
994 VBOXDNDCBHEADERDATA hdr;
995 uint32_t uDefAction;
996 uint32_t uAllActions;
997 char *pszFormat;
998 uint32_t cbFormat;
999} VBOXDNDCBGHACKPENDINGDATA, *PVBOXDNDCBGHACKPENDINGDATA;
1000
1001/**
1002 * Data header.
1003 * New since protocol v3.
1004 */
1005typedef struct VBOXDNDDATAHDR
1006{
1007 /** Data transfer flags. Not yet used and must be 0. */
1008 uint32_t uFlags;
1009 /** Screen ID where the data originates from. */
1010 uint32_t uScreenId;
1011 /** Total size (in bytes) to transfer. */
1012 uint64_t cbTotal;
1013 /** Meta data size (in bytes) to transfer.
1014 * This size also is part of cbTotal already. */
1015 uint32_t cbMeta;
1016 /** Meta format buffer. */
1017 void *pvMetaFmt;
1018 /** Size (in bytes) of meta format buffer. */
1019 uint32_t cbMetaFmt;
1020 /** Number of objects (files/directories) to transfer. */
1021 uint64_t cObjects;
1022 /** Compression type. Currently unused, so specify 0.
1023 **@todo Add IPRT compression type enumeration as soon as it's available. */
1024 uint32_t enmCompression;
1025 /** Checksum type. Currently unused, so specify RTDIGESTTYPE_INVALID. */
1026 RTDIGESTTYPE enmChecksumType;
1027 /** The actual checksum buffer for the entire data to be transferred,
1028 * based on enmChksumType. If RTDIGESTTYPE_INVALID is specified,
1029 * no checksum is being used and pvChecksum will be NULL. */
1030 void *pvChecksum;
1031 /** Size (in bytes) of checksum. */
1032 uint32_t cbChecksum;
1033} VBOXDNDDATAHDR, *PVBOXDNDSNDDATAHDR;
1034
1035/* New since protocol v3. */
1036typedef struct VBOXDNDCBSNDDATAHDRDATA
1037{
1038 /** Callback data header. */
1039 VBOXDNDCBHEADERDATA hdr;
1040 /** Actual header data. */
1041 VBOXDNDDATAHDR data;
1042} VBOXDNDCBSNDDATAHDRDATA, *PVBOXDNDCBSNDDATAHDRDATA;
1043
1044typedef struct VBOXDNDSNDDATA
1045{
1046 union
1047 {
1048 struct
1049 {
1050 /** Data block buffer. */
1051 void *pvData;
1052 /** Size (in bytes) of data block. */
1053 uint32_t cbData;
1054 /** Total metadata size (in bytes). This is transmitted
1055 * with every message because the size can change. */
1056 uint32_t cbTotalSize;
1057 } v1;
1058 /* Protocol v2: No changes. */
1059 struct
1060 {
1061 /** Data block buffer. */
1062 void *pvData;
1063 /** Size (in bytes) of data block. */
1064 uint32_t cbData;
1065 /** (Rolling) Checksum. Not yet implemented. */
1066 void *pvChecksum;
1067 /** Size (in bytes) of checksum. Not yet implemented. */
1068 uint32_t cbChecksum;
1069 } v3;
1070 } u;
1071} VBOXDNDSNDDATA, *PVBOXDNDSNDDATA;
1072
1073typedef struct VBOXDNDCBSNDDATADATA
1074{
1075 /** Callback data header. */
1076 VBOXDNDCBHEADERDATA hdr;
1077 /** Actual data. */
1078 VBOXDNDSNDDATA data;
1079} VBOXDNDCBSNDDATADATA, *PVBOXDNDCBSNDDATADATA;
1080
1081typedef struct VBOXDNDCBSNDDIRDATA
1082{
1083 /** Callback data header. */
1084 VBOXDNDCBHEADERDATA hdr;
1085 /** Directory path. */
1086 char *pszPath;
1087 /** Size (in bytes) of path. */
1088 uint32_t cbPath;
1089 /** Directory creation mode. */
1090 uint32_t fMode;
1091} VBOXDNDCBSNDDIRDATA, *PVBOXDNDCBSNDDIRDATA;
1092
1093/* Note: Only for protocol version 2 and up (>= VBox 5.0). */
1094typedef struct VBOXDNDCBSNDFILEHDRDATA
1095{
1096 /** Callback data header. */
1097 VBOXDNDCBHEADERDATA hdr;
1098 /** File path (name). */
1099 char *pszFilePath;
1100 /** Size (in bytes) of file path. */
1101 uint32_t cbFilePath;
1102 /** Total size (in bytes) of this file. */
1103 uint64_t cbSize;
1104 /** File (creation) mode. */
1105 uint32_t fMode;
1106 /** Additional flags. Not used at the moment. */
1107 uint32_t fFlags;
1108} VBOXDNDCBSNDFILEHDRDATA, *PVBOXDNDCBSNDFILEHDRDATA;
1109
1110typedef struct VBOXDNDCBSNDFILEDATADATA
1111{
1112 /** Callback data header. */
1113 VBOXDNDCBHEADERDATA hdr;
1114 /** Current file data chunk. */
1115 void *pvData;
1116 /** Size (in bytes) of current data chunk. */
1117 uint32_t cbData;
1118 union
1119 {
1120 struct
1121 {
1122 /** File path (name). */
1123 char *pszFilePath;
1124 /** Size (in bytes) of file path. */
1125 uint32_t cbFilePath;
1126 /** File (creation) mode. */
1127 uint32_t fMode;
1128 } v1;
1129 /* Protocol v2 + v3: Have the file attributes (name, size, mode, ...)
1130 in the VBOXDNDCBSNDFILEHDRDATA structure. */
1131 struct
1132 {
1133 /** Checksum for current file data chunk. */
1134 void *pvChecksum;
1135 /** Size (in bytes) of current data chunk. */
1136 uint32_t cbChecksum;
1137 } v3;
1138 } u;
1139} VBOXDNDCBSNDFILEDATADATA, *PVBOXDNDCBSNDFILEDATADATA;
1140
1141typedef struct VBOXDNDCBEVTERRORDATA
1142{
1143 /** Callback data header. */
1144 VBOXDNDCBHEADERDATA hdr;
1145 int32_t rc;
1146} VBOXDNDCBEVTERRORDATA, *PVBOXDNDCBEVTERRORDATA;
1147
1148} /* namespace DragAndDropSvc */
1149
1150#endif /* !___VBox_HostService_DragAndDropSvc_h */
1151
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