summaryrefslogtreecommitdiff
path: root/include/VBox/HostServices/GuestControlSvc.h
diff options
context:
space:
mode:
Diffstat (limited to 'include/VBox/HostServices/GuestControlSvc.h')
-rw-r--r--include/VBox/HostServices/GuestControlSvc.h931
1 files changed, 735 insertions, 196 deletions
diff --git a/include/VBox/HostServices/GuestControlSvc.h b/include/VBox/HostServices/GuestControlSvc.h
index d7864601..a173fbea 100644
--- a/include/VBox/HostServices/GuestControlSvc.h
+++ b/include/VBox/HostServices/GuestControlSvc.h
@@ -3,7 +3,7 @@
*/
/*
- * Copyright (C) 2011-2012 Oracle Corporation
+ * Copyright (C) 2011-2013 Oracle Corporation
*
* This file is part of VirtualBox Open Source Edition (OSE), as
* available from http://www.virtualbox.org. This file is free software;
@@ -41,6 +41,45 @@ namespace guestControl {
* Typedefs, constants and inlines *
******************************************************************************/
+#define HGCMSERVICE_NAME "VBoxGuestControlSvc"
+
+/** Maximum number of concurrent guest sessions a VM can have. */
+#define VBOX_GUESTCTRL_MAX_SESSIONS 32
+/** Maximum number of concurrent guest objects (processes, files, ...)
+ * a guest session can have. */
+#define VBOX_GUESTCTRL_MAX_OBJECTS _2K
+/** Maximum of callback contexts a guest process can have. */
+#define VBOX_GUESTCTRL_MAX_CONTEXTS _64K
+
+/** Base (start) of guest control session IDs. Session
+ * ID 0 is reserved for the root process which
+ * hosts all other guest session processes. */
+#define VBOX_GUESTCTRL_SESSION_ID_BASE 1
+
+/** Builds a context ID out of the session ID, object ID and an
+ * increasing count. */
+#define VBOX_GUESTCTRL_CONTEXTID_MAKE(uSession, uObject, uCount) \
+ ( (uint32_t)((uSession) & 0x1f) << 27 \
+ | (uint32_t)((uObject) & 0x7ff) << 16 \
+ | (uint32_t)((uCount) & 0xffff) \
+ )
+/** Creates a context ID out of a session ID. */
+#define VBOX_GUESTCTRL_CONTEXTID_MAKE_SESSION(uSession) \
+ ((uint32_t)((uSession) & 0x1f) << 27)
+/** Gets the session ID out of a context ID. */
+#define VBOX_GUESTCTRL_CONTEXTID_GET_SESSION(uContextID) \
+ (((uContextID) >> 27) & 0x1f)
+/** Gets the process ID out of a context ID. */
+#define VBOX_GUESTCTRL_CONTEXTID_GET_OBJECT(uContextID) \
+ (((uContextID) >> 16) & 0x7ff)
+/** Gets the context count of a process out of a context ID. */
+#define VBOX_GUESTCTRL_CONTEXTID_GET_COUNT(uContextID) \
+ ((uContextID) & 0xffff)
+/** Filter context IDs by session. Can be used in conjunction
+ * with VbglR3GuestCtrlMsgFilterSet(). */
+#define VBOX_GUESTCTRL_FILTER_BY_SESSION(uSession) \
+ (VBOX_GUESTCTRL_CONTEXTID_MAKE_SESSION(uSession) | 0xF8000000)
+
/**
* Process status when executed in the guest.
*/
@@ -75,7 +114,26 @@ enum eProcessStatus
#define INPUT_FLAG_EOF RT_BIT(0)
/**
- * Execution flags.
+ * Guest session creation flags.
+ * Only handled internally at the moment.
+ */
+#define SESSIONCREATIONFLAG_NONE 0x0
+
+/**
+ * Guest directory removement flags.
+ * Essentially using what IPRT's RTDIRRMREC_F_
+ * defines have to offer.
+ */
+#define DIRREMOVE_FLAG_RECURSIVE RT_BIT(0)
+/** Delete the content of the directory and the directory itself. */
+#define DIRREMOVE_FLAG_CONTENT_AND_DIR RT_BIT(1)
+/** Only delete the content of the directory, omit the directory it self. */
+#define DIRREMOVE_FLAG_CONTENT_ONLY RT_BIT(2)
+/** Mask of valid flags. */
+#define DIRREMOVE_FLAG_VALID_MASK UINT32_C(0x00000003)
+
+/**
+ * Guest process creation flags.
* Note: Has to match Main's ProcessCreateFlag_* flags!
*/
#define EXECUTEPROCESSFLAG_NONE 0x0
@@ -96,6 +154,20 @@ enum eProcessStatus
#define OUTPUT_HANDLE_ID_STDERR 2
/**
+ * Guest path rename flags.
+ * Essentially using what IPRT's RTPATHRENAME_FLAGS_
+ * defines have to offer.
+ */
+/** Do not replace anything. */
+#define PATHRENAME_FLAG_NO_REPLACE UINT32_C(0)
+/** This will replace attempt any target which isn't a directory. */
+#define PATHRENAME_FLAG_REPLACE RT_BIT(0)
+/** Don't allow symbolic links as part of the path. */
+#define PATHRENAME_FLAG_NO_SYMLINKS RT_BIT(1)
+/** Mask of valid flags. */
+#define PATHRENAME_FLAG_VALID_MASK UINT32_C(0x00000002)
+
+/**
* Defines for guest process array lengths.
*/
#define GUESTPROCESS_MAX_CMD_LEN _1K
@@ -103,6 +175,7 @@ enum eProcessStatus
#define GUESTPROCESS_MAX_ENV_LEN _64K
#define GUESTPROCESS_MAX_USER_LEN 128
#define GUESTPROCESS_MAX_PASSWORD_LEN 128
+#define GUESTPROCESS_MAX_DOMAIN_LEN 256
/** @name Internal tools built into VBoxService which are used in order to
* accomplish tasks host<->guest.
@@ -134,95 +207,34 @@ enum eInputStatus
};
/**
- * The guest control callback data header. Must come first
- * on each callback structure defined below this struct.
+ * Structure keeping the context of a host callback.
*/
-typedef struct VBoxGuestCtrlCallbackHeader
+typedef struct VBoxGuestCtrlHostCbCtx
{
- /** Magic number to identify the structure. */
- uint32_t u32Magic;
- /** Context ID to identify callback data. */
- uint32_t u32ContextID;
-} CALLBACKHEADER;
-typedef CALLBACKHEADER *PCALLBACKHEADER;
+ /** HGCM Function number. */
+ uint32_t uFunction;
+ /** The context ID. */
+ uint32_t uContextID;
+ /** Protocol version of this guest session. Might
+ * be 0 if not supported. */
+ uint32_t uProtocol;
-typedef struct VBoxGuestCtrlCallbackDataClientDisconnected
-{
- /** Callback data header. */
- CALLBACKHEADER hdr;
-} CALLBACKDATACLIENTDISCONNECTED;
-typedef CALLBACKDATACLIENTDISCONNECTED *PCALLBACKDATACLIENTDISCONNECTED;
+} VBOXGUESTCTRLHOSTCBCTX, *PVBOXGUESTCTRLHOSTCBCTX;
/**
- * Data structure to pass to the service extension callback. We use this to
- * notify the host of changes to properties.
- */
-typedef struct VBoxGuestCtrlCallbackDataExecStatus
+ * Structure for low level HGCM host callback from
+ * the guest. No deep copy. */
+typedef struct VBoxGuestCtrlHostCallback
{
- /** Callback data header. */
- CALLBACKHEADER hdr;
- /** The process ID (PID). */
- uint32_t u32PID;
- /** The process status. */
- uint32_t u32Status;
- /** Optional flags, varies, based on u32Status. */
- uint32_t u32Flags;
- /** Optional data buffer (not used atm). */
- void *pvData;
- /** Size of optional data buffer (not used atm). */
- uint32_t cbData;
-} CALLBACKDATAEXECSTATUS;
-typedef CALLBACKDATAEXECSTATUS *PCALLBACKDATAEXECSTATUS;
+ VBoxGuestCtrlHostCallback(uint32_t cParms, VBOXHGCMSVCPARM paParms[])
+ : mParms(cParms), mpaParms(paParms) { }
-typedef struct VBoxGuestCtrlCallbackDataExecOut
-{
- /** Callback data header. */
- CALLBACKHEADER hdr;
- /** The process ID (PID). */
- uint32_t u32PID;
- /** The handle ID (stdout/stderr). */
- uint32_t u32HandleId;
- /** Optional flags (not used atm). */
- uint32_t u32Flags;
- /** Optional data buffer. */
- void *pvData;
- /** Size (in bytes) of optional data buffer. */
- uint32_t cbData;
-} CALLBACKDATAEXECOUT;
-typedef CALLBACKDATAEXECOUT *PCALLBACKDATAEXECOUT;
+ /** Number of HGCM parameters. */
+ uint32_t mParms;
+ /** Actual HGCM parameters. */
+ PVBOXHGCMSVCPARM mpaParms;
-typedef struct VBoxGuestCtrlCallbackDataExecInStatus
-{
- /** Callback data header. */
- CALLBACKHEADER hdr;
- /** The process ID (PID). */
- uint32_t u32PID;
- /** Current input status. */
- uint32_t u32Status;
- /** Optional flags. */
- uint32_t u32Flags;
- /** Size (in bytes) of processed input data. */
- uint32_t cbProcessed;
-} CALLBACKDATAEXECINSTATUS;
-typedef CALLBACKDATAEXECINSTATUS *PCALLBACKDATAEXECINSTATUS;
-
-enum eVBoxGuestCtrlCallbackDataMagic
-{
- CALLBACKDATAMAGIC_CLIENT_DISCONNECTED = 0x08041984,
-
- CALLBACKDATAMAGIC_EXEC_STATUS = 0x26011982,
- CALLBACKDATAMAGIC_EXEC_OUT = 0x11061949,
- CALLBACKDATAMAGIC_EXEC_IN_STATUS = 0x19091951
-};
-
-enum eVBoxGuestCtrlCallbackType
-{
- VBOXGUESTCTRLCALLBACKTYPE_UNKNOWN = 0,
-
- VBOXGUESTCTRLCALLBACKTYPE_EXEC_START = 1,
- VBOXGUESTCTRLCALLBACKTYPE_EXEC_OUTPUT = 2,
- VBOXGUESTCTRLCALLBACKTYPE_EXEC_INPUT_STATUS = 3
-};
+} VBOXGUESTCTRLHOSTCALLBACK, *PVBOXGUESTCTRLHOSTCALLBACK;
/**
* The service functions which are callable by host.
@@ -233,35 +245,40 @@ enum eHostFn
* The host asks the client to cancel all pending waits and exit.
*/
HOST_CANCEL_PENDING_WAITS = 0,
-
- /*
- * Execution handling.
+ /**
+ * The host wants to create a guest session.
*/
-
+ HOST_SESSION_CREATE = 20,
+ /**
+ * The host wants to close a guest session.
+ */
+ HOST_SESSION_CLOSE = 21,
/**
* The host wants to execute something in the guest. This can be a command line
* or starting a program.
+ ** Note: Legacy (VBox < 4.3) command.
*/
HOST_EXEC_CMD = 100,
/**
* Sends input data for stdin to a running process executed by HOST_EXEC_CMD.
+ ** Note: Legacy (VBox < 4.3) command.
*/
HOST_EXEC_SET_INPUT = 101,
/**
* Gets the current status of a running process, e.g.
* new data on stdout/stderr, process terminated etc.
+ ** Note: Legacy (VBox < 4.3) command.
*/
HOST_EXEC_GET_OUTPUT = 102,
-
- /*
- * Guest control 2.0 commands start in the 2xx number space.
+ /**
+ * Terminates a running guest process.
*/
-
+ HOST_EXEC_TERMINATE = 110,
/**
* Waits for a certain event to happen. This can be an input, output
* or status event.
*/
- HOST_EXEC_WAIT_FOR = 210,
+ HOST_EXEC_WAIT_FOR = 120,
/**
* Opens a guest file.
*/
@@ -273,23 +290,41 @@ enum eHostFn
/**
* Reads from an opened guest file.
*/
- HOST_FILE_READ = 242,
+ HOST_FILE_READ = 250,
+ /**
+ * Reads from an opened guest file at
+ * a specified offset.
+ */
+ HOST_FILE_READ_AT = 251,
/**
* Write to an opened guest file.
*/
- HOST_FILE_WRITE = 243,
+ HOST_FILE_WRITE = 260,
+ /**
+ * Write to an opened guest file at
+ * a specified offset.
+ */
+ HOST_FILE_WRITE_AT = 261,
/**
* Changes the read & write position of an opened guest file.
*/
- HOST_FILE_SEEK = 244,
+ HOST_FILE_SEEK = 270,
/**
* Gets the current file position of an opened guest file.
*/
- HOST_FILE_TELL = 245
+ HOST_FILE_TELL = 271,
+ /**
+ * Removes a directory on the guest.
+ */
+ HOST_DIR_REMOVE = 320,
+ /**
+ * Renames a path on the guest.
+ */
+ HOST_PATH_RENAME = 330
};
/**
- * The service functions which are called by guest. The numbers may not change,
+ * The service functions which are called by guest. The numbers may not change,
* so we hardcode them.
*/
enum eGuestFn
@@ -298,7 +333,7 @@ enum eGuestFn
* Guest waits for a new message the host wants to process on the guest side.
* This is a blocking call and can be deferred.
*/
- GUEST_GET_HOST_MSG = 1,
+ GUEST_MSG_WAIT = 1,
/**
* Guest asks the host to cancel all pending waits the guest itself waits on.
* This becomes necessary when the guest wants to quit but still waits for
@@ -310,30 +345,52 @@ enum eGuestFn
* detected when calling service::clientDisconnect().
*/
GUEST_DISCONNECTED = 3,
-
- /*
- * Process execution.
- * The 1xx commands are legacy guest control commands and
- * will be replaced by newer commands in the future.
+ /**
+ * Sets a message filter to only get messages which have a certain
+ * context ID scheme (that is, a specific session, object etc).
+ * Since VBox 4.3+.
*/
-
+ GUEST_MSG_FILTER_SET = 4,
+ /**
+ * Unsets (and resets) a previously set message filter.
+ */
+ GUEST_MSG_FILTER_UNSET = 5,
+ /**
+ * Skips the current assigned message returned by GUEST_MSG_WAIT.
+ * Needed for telling the host service to not keep stale
+ * host commands in the queue.
+ */
+ GUEST_MSG_SKIP = 10,
+ /**
+ * General reply to a host message. Only contains basic data
+ * along with a simple payload.
+ */
+ GUEST_MSG_REPLY = 11,
+ /**
+ * General message for updating a pending progress for
+ * a long task.
+ */
+ GUEST_MSG_PROGRESS_UPDATE = 12,
+ /**
+ * Guest reports back a guest session status.
+ */
+ GUEST_SESSION_NOTIFY = 20,
+ /**
+ * Guest wants to close a specific guest session.
+ */
+ GUEST_SESSION_CLOSE = 21,
/**
* Guests sends output from an executed process.
*/
- GUEST_EXEC_SEND_OUTPUT = 100,
+ GUEST_EXEC_OUTPUT = 100,
/**
* Guest sends a status update of an executed process to the host.
*/
- GUEST_EXEC_SEND_STATUS = 101,
+ GUEST_EXEC_STATUS = 101,
/**
* Guests sends an input status notification to the host.
*/
- GUEST_EXEC_SEND_INPUT_STATUS = 102,
-
- /*
- * Guest control 2.0 commands start in the 2xx number space.
- */
-
+ GUEST_EXEC_INPUT_STATUS = 102,
/**
* Guest notifies the host about some I/O event. This can be
* a stdout, stderr or a stdin event. The actual event only tells
@@ -341,24 +398,87 @@ enum eGuestFn
* transmitting the data.
*/
GUEST_EXEC_IO_NOTIFY = 210,
- /** Guest notifies the host about a file event, like opening,
- * closing, seeking etc.
+ /**
+ * Guest notifies the host about some directory event.
+ */
+ GUEST_DIR_NOTIFY = 230,
+ /**
+ * Guest notifies the host about some file event.
*/
GUEST_FILE_NOTIFY = 240
};
/**
+ * Guest session notification types.
+ * @sa HGCMMsgSessionNotify.
+ */
+enum GUEST_SESSION_NOTIFYTYPE
+{
+ GUEST_SESSION_NOTIFYTYPE_UNDEFINED = 0,
+ /** Something went wrong (see rc). */
+ GUEST_SESSION_NOTIFYTYPE_ERROR = 1,
+ /** Guest session has been started. */
+ GUEST_SESSION_NOTIFYTYPE_STARTED = 11,
+ /** Guest session terminated normally. */
+ GUEST_SESSION_NOTIFYTYPE_TEN = 20,
+ /** Guest session terminated via signal. */
+ GUEST_SESSION_NOTIFYTYPE_TES = 30,
+ /** Guest session terminated abnormally. */
+ GUEST_SESSION_NOTIFYTYPE_TEA = 40,
+ /** Guest session timed out and was killed. */
+ GUEST_SESSION_NOTIFYTYPE_TOK = 50,
+ /** Guest session timed out and was not killed successfully. */
+ GUEST_SESSION_NOTIFYTYPE_TOA = 60,
+ /** Service/OS is stopping, process was killed. */
+ GUEST_SESSION_NOTIFYTYPE_DWN = 150
+};
+
+/**
+ * Guest directory notification types.
+ * @sa HGCMMsgDirNotify.
+ */
+enum GUEST_DIR_NOTIFYTYPE
+{
+ GUEST_DIR_NOTIFYTYPE_UNKNOWN = 0,
+ /** Something went wrong (see rc). */
+ GUEST_DIR_NOTIFYTYPE_ERROR = 1,
+ /** Guest directory opened. */
+ GUEST_DIR_NOTIFYTYPE_OPEN = 10,
+ /** Guest directory closed. */
+ GUEST_DIR_NOTIFYTYPE_CLOSE = 20,
+ /** Information about an open guest directory. */
+ GUEST_DIR_NOTIFYTYPE_INFO = 40,
+ /** Guest directory created. */
+ GUEST_DIR_NOTIFYTYPE_CREATE = 70,
+ /** Guest directory deleted. */
+ GUEST_DIR_NOTIFYTYPE_REMOVE = 80
+};
+
+/**
* Guest file notification types.
+ * @sa HGCMMsgFileNotify.
*/
-enum eGuestFileNotifyType
+enum GUEST_FILE_NOTIFYTYPE
{
- GUESTFILENOTIFYTYPE_ERROR = 0,
- GUESTFILENOTIFYTYPE_OPEN = 10,
- GUESTFILENOTIFYTYPE_CLOSE = 20,
- GUESTFILENOTIFYTYPE_READ = 30,
- GUESTFILENOTIFYTYPE_WRITE = 40,
- GUESTFILENOTIFYTYPE_SEEK = 50,
- GUESTFILENOTIFYTYPE_TELL = 60
+ GUEST_FILE_NOTIFYTYPE_UNKNOWN = 0,
+ GUEST_FILE_NOTIFYTYPE_ERROR = 1,
+ GUEST_FILE_NOTIFYTYPE_OPEN = 10,
+ GUEST_FILE_NOTIFYTYPE_CLOSE = 20,
+ GUEST_FILE_NOTIFYTYPE_READ = 30,
+ GUEST_FILE_NOTIFYTYPE_WRITE = 40,
+ GUEST_FILE_NOTIFYTYPE_SEEK = 50,
+ GUEST_FILE_NOTIFYTYPE_TELL = 60
+};
+
+/**
+ * Guest file seeking types. Has to
+ * match FileSeekType in Main.
+ */
+enum GUEST_FILE_SEEKTYPE
+{
+ GUEST_FILE_SEEKTYPE_BEGIN = 1,
+ GUEST_FILE_SEEKTYPE_CURRENT = 4,
+ GUEST_FILE_SEEKTYPE_END = 8
};
/*
@@ -366,10 +486,14 @@ enum eGuestFileNotifyType
*/
#pragma pack (1)
-typedef struct VBoxGuestCtrlHGCMMsgType
+/**
+ * Waits for a host command to arrive. The structure then contains the
+ * actual message type + required number of parameters needed to successfully
+ * retrieve that host command (in a next round).
+ */
+typedef struct HGCMMsgCmdWaitFor
{
VBoxGuestHGCMCallInfo hdr;
-
/**
* The returned command the host wants to
* run on the guest.
@@ -377,22 +501,137 @@ typedef struct VBoxGuestCtrlHGCMMsgType
HGCMFunctionParameter msg; /* OUT uint32_t */
/** Number of parameters the message needs. */
HGCMFunctionParameter num_parms; /* OUT uint32_t */
+} HGCMMsgCmdWaitFor;
+
+/**
+ * Asks the guest control host service to set a command
+ * filter for this client. This filter will then only
+ * deliver messages to the client which match the
+ * wanted context ID (ranges).
+ */
+typedef struct HGCMMsgCmdFilterSet
+{
+ VBoxGuestHGCMCallInfo hdr;
+ /** Value to filter for after filter mask
+ * was applied. */
+ HGCMFunctionParameter value; /* IN uint32_t */
+ /** Mask to add to the current set filter. */
+ HGCMFunctionParameter mask_add; /* IN uint32_t */
+ /** Mask to remove from the current set filter. */
+ HGCMFunctionParameter mask_remove; /* IN uint32_t */
+ /** Filter flags; currently unused. */
+ HGCMFunctionParameter flags; /* IN uint32_t */
+} HGCMMsgCmdFilterSet;
-} VBoxGuestCtrlHGCMMsgType;
+/**
+ * Asks the guest control host service to disable
+ * a previously set message filter again.
+ */
+typedef struct HGCMMsgCmdFilterUnset
+{
+ VBoxGuestHGCMCallInfo hdr;
+ /** Unset flags; currently unused. */
+ HGCMFunctionParameter flags; /* IN uint32_t */
+} HGCMMsgCmdFilterUnset;
+
+/**
+ * Asks the guest control host service to skip the
+ * currently assigned host command returned by
+ * VbglR3GuestCtrlMsgWaitFor().
+ */
+typedef struct HGCMMsgCmdSkip
+{
+ VBoxGuestHGCMCallInfo hdr;
+ /** Skip flags; currently unused. */
+ HGCMFunctionParameter flags; /* IN uint32_t */
+} HGCMMsgCmdSkip;
/**
* Asks the guest control host service to cancel all pending (outstanding)
- * waits which were not processed yet. This is handy for a graceful shutdown.
+ * waits which were not processed yet. This is handy for a graceful shutdown.
+ */
+typedef struct HGCMMsgCancelPendingWaits
+{
+ VBoxGuestHGCMCallInfo hdr;
+} HGCMMsgCancelPendingWaits;
+
+typedef struct HGCMMsgCmdReply
+{
+ VBoxGuestHGCMCallInfo hdr;
+ /** Context ID. */
+ HGCMFunctionParameter context;
+ /** Message type. */
+ HGCMFunctionParameter type;
+ /** IPRT result of overall operation. */
+ HGCMFunctionParameter rc;
+ /** Optional payload to this reply. */
+ HGCMFunctionParameter payload;
+} HGCMMsgCmdReply;
+
+/**
+ * Creates a guest session.
+ */
+typedef struct HGCMMsgSessionOpen
+{
+ VBoxGuestHGCMCallInfo hdr;
+ /** Context ID. */
+ HGCMFunctionParameter context;
+ /** The guest control protocol version this
+ * session is about to use. */
+ HGCMFunctionParameter protocol;
+ /** The user name to run the guest session under. */
+ HGCMFunctionParameter username;
+ /** The user's password. */
+ HGCMFunctionParameter password;
+ /** The domain to run the guest session under. */
+ HGCMFunctionParameter domain;
+ /** Session creation flags. */
+ HGCMFunctionParameter flags;
+} HGCMMsgSessionOpen;
+
+/**
+ * Terminates (closes) a guest session.
+ */
+typedef struct HGCMMsgSessionClose
+{
+ VBoxGuestHGCMCallInfo hdr;
+ /** Context ID. */
+ HGCMFunctionParameter context;
+ /** Session termination flags. */
+ HGCMFunctionParameter flags;
+} HGCMMsgSessionClose;
+
+/**
+ * Reports back a guest session's status.
*/
-typedef struct VBoxGuestCtrlHGCMMsgCancelPendingWaits
+typedef struct HGCMMsgSessionNotify
+{
+ VBoxGuestHGCMCallInfo hdr;
+ /** Context ID. */
+ HGCMFunctionParameter context;
+ /** Notification type. */
+ HGCMFunctionParameter type;
+ /** Notification result. */
+ HGCMFunctionParameter result;
+} HGCMMsgSessionNotify;
+
+typedef struct HGCMMsgPathRename
{
VBoxGuestHGCMCallInfo hdr;
-} VBoxGuestCtrlHGCMMsgCancelPendingWaits;
+ /** UInt32: Context ID. */
+ HGCMFunctionParameter context;
+ /** Source to rename. */
+ HGCMFunctionParameter source;
+ /** Destination to rename source to. */
+ HGCMFunctionParameter dest;
+ /** UInt32: Rename flags. */
+ HGCMFunctionParameter flags;
+} HGCMMsgPathRename;
/**
* Executes a command inside the guest.
*/
-typedef struct VBoxGuestCtrlHGCMMsgExecCmd
+typedef struct HGCMMsgProcExec
{
VBoxGuestHGCMCallInfo hdr;
/** Context ID. */
@@ -411,22 +650,43 @@ typedef struct VBoxGuestCtrlHGCMMsgExecCmd
HGCMFunctionParameter cb_env;
/** The actual environment block. */
HGCMFunctionParameter env;
- /** The user name to run the executed command under. */
- HGCMFunctionParameter username;
- /** The user's password. */
- HGCMFunctionParameter password;
- /** Timeout (in msec) which either specifies the
- * overall lifetime of the process or how long it
- * can take to bring the process up and running -
- * (depends on the IGuest::ProcessCreateFlag_*). */
- HGCMFunctionParameter timeout;
-
-} VBoxGuestCtrlHGCMMsgExecCmd;
+ union
+ {
+ struct
+ {
+ /** The user name to run the executed command under.
+ * Only for VBox < 4.3 hosts. */
+ HGCMFunctionParameter username;
+ /** The user's password.
+ * Only for VBox < 4.3 hosts. */
+ HGCMFunctionParameter password;
+ /** Timeout (in msec) which either specifies the
+ * overall lifetime of the process or how long it
+ * can take to bring the process up and running -
+ * (depends on the IGuest::ProcessCreateFlag_*). */
+ HGCMFunctionParameter timeout;
+ } v1;
+ struct
+ {
+ /** Timeout (in ms) which either specifies the
+ * overall lifetime of the process or how long it
+ * can take to bring the process up and running -
+ * (depends on the IGuest::ProcessCreateFlag_*). */
+ HGCMFunctionParameter timeout;
+ /** Process priority. */
+ HGCMFunctionParameter priority;
+ /** Number of process affinity blocks. */
+ HGCMFunctionParameter num_affinity;
+ /** Pointer to process affinity blocks (uint64_t). */
+ HGCMFunctionParameter affinity;
+ } v2;
+ } u;
+} HGCMMsgProcExec;
/**
- * Injects input to a previously executed process via stdin.
+ * Sends input to a guest process via stdin.
*/
-typedef struct VBoxGuestCtrlHGCMMsgExecIn
+typedef struct HGCMMsgProcInput
{
VBoxGuestHGCMCallInfo hdr;
/** Context ID. */
@@ -439,14 +699,13 @@ typedef struct VBoxGuestCtrlHGCMMsgExecIn
HGCMFunctionParameter data;
/** Actual size of data (in bytes). */
HGCMFunctionParameter size;
-
-} VBoxGuestCtrlHGCMMsgExecIn;
+} HGCMMsgProcInput;
/**
* Retrieves ouptut from a previously executed process
* from stdout/stderr.
*/
-typedef struct VBoxGuestCtrlHGCMMsgExecOut
+typedef struct HGCMMsgProcOutput
{
VBoxGuestHGCMCallInfo hdr;
/** Context ID. */
@@ -459,14 +718,12 @@ typedef struct VBoxGuestCtrlHGCMMsgExecOut
HGCMFunctionParameter flags;
/** Data buffer. */
HGCMFunctionParameter data;
-
-} VBoxGuestCtrlHGCMMsgExecOut;
+} HGCMMsgProcOutput;
/**
- * Reports the current status of a (just) started
- * or terminated process.
+ * Reports the current status of a guest process.
*/
-typedef struct VBoxGuestCtrlHGCMMsgExecStatus
+typedef struct HGCMMsgProcStatus
{
VBoxGuestHGCMCallInfo hdr;
/** Context ID. */
@@ -479,13 +736,12 @@ typedef struct VBoxGuestCtrlHGCMMsgExecStatus
HGCMFunctionParameter flags;
/** Optional data buffer (not used atm). */
HGCMFunctionParameter data;
-
-} VBoxGuestCtrlHGCMMsgExecStatus;
+} HGCMMsgProcStatus;
/**
* Reports back the status of data written to a process.
*/
-typedef struct VBoxGuestCtrlHGCMMsgExecStatusIn
+typedef struct HGCMMsgProcStatusInput
{
VBoxGuestHGCMCallInfo hdr;
/** Context ID. */
@@ -498,81 +754,119 @@ typedef struct VBoxGuestCtrlHGCMMsgExecStatusIn
HGCMFunctionParameter flags;
/** Data written. */
HGCMFunctionParameter written;
-
-} VBoxGuestCtrlHGCMMsgExecStatusIn;
+} HGCMMsgProcStatusInput;
/*
* Guest control 2.0 messages.
*/
/**
- * Reports back the currente I/O status of a guest process.
+ * Terminates a guest process.
*/
-typedef struct VBoxGuestCtrlHGCMMsgExecIONotify
+typedef struct HGCMMsgProcTerminate
{
VBoxGuestHGCMCallInfo hdr;
/** Context ID. */
HGCMFunctionParameter context;
- /** Data written. */
- HGCMFunctionParameter written;
+ /** The process ID (PID). */
+ HGCMFunctionParameter pid;
+} HGCMMsgProcTerminate;
-} VBoxGuestCtrlHGCMMsgExecIONotify;
+/**
+ * Waits for certain events to happen.
+ */
+typedef struct HGCMMsgProcWaitFor
+{
+ VBoxGuestHGCMCallInfo hdr;
+ /** Context ID. */
+ HGCMFunctionParameter context;
+ /** The process ID (PID). */
+ HGCMFunctionParameter pid;
+ /** Wait (event) flags. */
+ HGCMFunctionParameter flags;
+ /** Timeout (in ms). */
+ HGCMFunctionParameter timeout;
+} HGCMMsgProcWaitFor;
+
+typedef struct HGCMMsgDirRemove
+{
+ VBoxGuestHGCMCallInfo hdr;
+ /** UInt32: Context ID. */
+ HGCMFunctionParameter context;
+ /** Directory to remove. */
+ HGCMFunctionParameter path;
+ /** UInt32: Removement flags. */
+ HGCMFunctionParameter flags;
+} HGCMMsgDirRemove;
/**
* Opens a guest file.
*/
-typedef struct VBoxGuestCtrlHGCMMsgFileOpen
+typedef struct HGCMMsgFileOpen
{
VBoxGuestHGCMCallInfo hdr;
- /** Context ID. */
+ /** UInt32: Context ID. */
HGCMFunctionParameter context;
/** File to open. */
HGCMFunctionParameter filename;
/** Open mode. */
HGCMFunctionParameter openmode;
- /** Disposition. */
+ /** Disposition mode. */
HGCMFunctionParameter disposition;
- /** Creation mode. */
+ /** Sharing mode. */
+ HGCMFunctionParameter sharing;
+ /** UInt32: Creation mode. */
HGCMFunctionParameter creationmode;
- /** Offset. */
+ /** UInt64: Initial offset. */
HGCMFunctionParameter offset;
-
-} VBoxGuestCtrlHGCMMsgFileOpen;
+} HGCMMsgFileOpen;
/**
* Closes a guest file.
*/
-typedef struct VBoxGuestCtrlHGCMMsgFileClose
+typedef struct HGCMMsgFileClose
{
VBoxGuestHGCMCallInfo hdr;
/** Context ID. */
HGCMFunctionParameter context;
/** File handle to close. */
HGCMFunctionParameter handle;
-
-} VBoxGuestCtrlHGCMMsgFileClose;
+} HGCMMsgFileClose;
/**
* Reads from a guest file.
*/
-typedef struct VBoxGuestCtrlHGCMMsgFileRead
+typedef struct HGCMMsgFileRead
{
VBoxGuestHGCMCallInfo hdr;
/** Context ID. */
HGCMFunctionParameter context;
/** File handle to read from. */
HGCMFunctionParameter handle;
- /** Actual size of data (in bytes). */
+ /** Size (in bytes) to read. */
HGCMFunctionParameter size;
- /** Where to put the read data into. */
- HGCMFunctionParameter data;
+} HGCMMsgFileRead;
-} VBoxGuestCtrlHGCMMsgFileRead;
+/**
+ * Reads at a specified offset from a guest file.
+ */
+typedef struct HGCMMsgFileReadAt
+{
+ VBoxGuestHGCMCallInfo hdr;
+ /** Context ID. */
+ HGCMFunctionParameter context;
+ /** File handle to read from. */
+ HGCMFunctionParameter handle;
+ /** Offset where to start reading from. */
+ HGCMFunctionParameter offset;
+ /** Actual size of data (in bytes). */
+ HGCMFunctionParameter size;
+} HGCMMsgFileReadAt;
/**
* Writes to a guest file.
*/
-typedef struct VBoxGuestCtrlHGCMMsgFileWrite
+typedef struct HGCMMsgFileWrite
{
VBoxGuestHGCMCallInfo hdr;
/** Context ID. */
@@ -583,13 +877,30 @@ typedef struct VBoxGuestCtrlHGCMMsgFileWrite
HGCMFunctionParameter size;
/** Data buffer to write to the file. */
HGCMFunctionParameter data;
+} HGCMMsgFileWrite;
-} VBoxGuestCtrlHGCMMsgFileWrite;
+/**
+ * Writes at a specified offset to a guest file.
+ */
+typedef struct HGCMMsgFileWriteAt
+{
+ VBoxGuestHGCMCallInfo hdr;
+ /** Context ID. */
+ HGCMFunctionParameter context;
+ /** File handle to write to. */
+ HGCMFunctionParameter handle;
+ /** Offset where to start reading from. */
+ HGCMFunctionParameter offset;
+ /** Actual size of data (in bytes). */
+ HGCMFunctionParameter size;
+ /** Data buffer to write to the file. */
+ HGCMFunctionParameter data;
+} HGCMMsgFileWriteAt;
/**
* Seeks the read/write position of a guest file.
*/
-typedef struct VBoxGuestCtrlHGCMMsgFileSeek
+typedef struct HGCMMsgFileSeek
{
VBoxGuestHGCMCallInfo hdr;
/** Context ID. */
@@ -600,48 +911,276 @@ typedef struct VBoxGuestCtrlHGCMMsgFileSeek
HGCMFunctionParameter method;
/** The seeking offset. */
HGCMFunctionParameter offset;
-
-} VBoxGuestCtrlHGCMMsgFileSeek;
+} HGCMMsgFileSeek;
/**
* Tells the current read/write position of a guest file.
*/
-typedef struct VBoxGuestCtrlHGCMMsgFileTell
+typedef struct HGCMMsgFileTell
{
VBoxGuestHGCMCallInfo hdr;
/** Context ID. */
HGCMFunctionParameter context;
/** File handle to get the current position for. */
HGCMFunctionParameter handle;
+} HGCMMsgFileTell;
-} VBoxGuestCtrlHGCMMsgFileTell;
+/******************************************************************************
+* HGCM replies from the guest. These are handled in Main's low-level HGCM *
+* callbacks and dispatched to the appropriate guest object. *
+******************************************************************************/
-typedef struct VBoxGuestCtrlHGCMMsgFileNotify
+typedef struct HGCMReplyFileNotify
{
VBoxGuestHGCMCallInfo hdr;
/** Context ID. */
HGCMFunctionParameter context;
- /** The file handle. */
- HGCMFunctionParameter handle;
/** Notification type. */
HGCMFunctionParameter type;
- /** Notification payload. */
- HGCMFunctionParameter payload;
-
-} VBoxGuestCtrlHGCMMsgFileNotify;
+ /** IPRT result of overall operation. */
+ HGCMFunctionParameter rc;
+ union
+ {
+ struct
+ {
+ /** Guest file handle. */
+ HGCMFunctionParameter handle;
+ } open;
+ /** Note: Close does not have any additional data (yet). */
+ struct
+ {
+ /** Actual data read (if any). */
+ HGCMFunctionParameter data;
+ } read;
+ struct
+ {
+ /** How much data (in bytes) have been successfully written. */
+ HGCMFunctionParameter written;
+ } write;
+ struct
+ {
+ HGCMFunctionParameter offset;
+ } seek;
+ struct
+ {
+ HGCMFunctionParameter offset;
+ } tell;
+ } u;
+} HGCMReplyFileNotify;
+
+typedef struct HGCMReplyDirNotify
+{
+ VBoxGuestHGCMCallInfo hdr;
+ /** Context ID. */
+ HGCMFunctionParameter context;
+ /** Notification type. */
+ HGCMFunctionParameter type;
+ /** IPRT result of overall operation. */
+ HGCMFunctionParameter rc;
+ union
+ {
+ struct
+ {
+ /** Directory information. */
+ HGCMFunctionParameter objInfo;
+ } info;
+ struct
+ {
+ /** Guest directory handle. */
+ HGCMFunctionParameter handle;
+ } open;
+ struct
+ {
+ /** Current read directory entry. */
+ HGCMFunctionParameter entry;
+ /** Extended entry object information. Optional. */
+ HGCMFunctionParameter objInfo;
+ } read;
+ } u;
+} HGCMReplyDirNotify;
#pragma pack ()
+/******************************************************************************
+* Callback data structures. *
+******************************************************************************/
+
+/**
+ * The guest control callback data header. Must come first
+ * on each callback structure defined below this struct.
+ */
+typedef struct CALLBACKDATA_HEADER
+{
+ /** Context ID to identify callback data. This is
+ * and *must* be the very first parameter in this
+ * structure to still be backwards compatible. */
+ uint32_t uContextID;
+} CALLBACKDATA_HEADER, *PCALLBACKDATA_HEADER;
+
+/*
+ * These structures make up the actual low level HGCM callback data sent from
+ * the guest back to the host.
+ */
+
+typedef struct CALLBACKDATA_CLIENT_DISCONNECTED
+{
+ /** Callback data header. */
+ CALLBACKDATA_HEADER hdr;
+} CALLBACKDATA_CLIENT_DISCONNECTED, *PCALLBACKDATA_CLIENT_DISCONNECTED;
+
+typedef struct CALLBACKDATA_MSG_REPLY
+{
+ /** Callback data header. */
+ CALLBACKDATA_HEADER hdr;
+ /** Notification type. */
+ uint32_t uType;
+ /** Notification result. Note: int vs. uint32! */
+ uint32_t rc;
+ /** Pointer to optional payload. */
+ void *pvPayload;
+ /** Payload size (in bytes). */
+ uint32_t cbPayload;
+} CALLBACKDATA_MSG_REPLY, *PCALLBACKDATA_MSG_REPLY;
+
+typedef struct CALLBACKDATA_SESSION_NOTIFY
+{
+ /** Callback data header. */
+ CALLBACKDATA_HEADER hdr;
+ /** Notification type. */
+ uint32_t uType;
+ /** Notification result. Note: int vs. uint32! */
+ uint32_t uResult;
+} CALLBACKDATA_SESSION_NOTIFY, *PCALLBACKDATA_SESSION_NOTIFY;
+
+typedef struct CALLBACKDATA_PROC_STATUS
+{
+ /** Callback data header. */
+ CALLBACKDATA_HEADER hdr;
+ /** The process ID (PID). */
+ uint32_t uPID;
+ /** The process status. */
+ uint32_t uStatus;
+ /** Optional flags, varies, based on u32Status. */
+ uint32_t uFlags;
+ /** Optional data buffer (not used atm). */
+ void *pvData;
+ /** Size of optional data buffer (not used atm). */
+ uint32_t cbData;
+} CALLBACKDATA_PROC_STATUS, *PCALLBACKDATA_PROC_STATUS;
+
+typedef struct CALLBACKDATA_PROC_OUTPUT
+{
+ /** Callback data header. */
+ CALLBACKDATA_HEADER hdr;
+ /** The process ID (PID). */
+ uint32_t uPID;
+ /** The handle ID (stdout/stderr). */
+ uint32_t uHandle;
+ /** Optional flags (not used atm). */
+ uint32_t uFlags;
+ /** Optional data buffer. */
+ void *pvData;
+ /** Size (in bytes) of optional data buffer. */
+ uint32_t cbData;
+} CALLBACKDATA_PROC_OUTPUT, *PCALLBACKDATA_PROC_OUTPUT;
+
+typedef struct CALLBACKDATA_PROC_INPUT
+{
+ /** Callback data header. */
+ CALLBACKDATA_HEADER hdr;
+ /** The process ID (PID). */
+ uint32_t uPID;
+ /** Current input status. */
+ uint32_t uStatus;
+ /** Optional flags. */
+ uint32_t uFlags;
+ /** Size (in bytes) of processed input data. */
+ uint32_t uProcessed;
+} CALLBACKDATA_PROC_INPUT, *PCALLBACKDATA_PROC_INPUT;
+
/**
- * Structure for buffering execution requests in the host service.
+ * General guest directory notification callback.
*/
-typedef struct VBoxGuestCtrlParamBuffer
+typedef struct CALLBACKDATA_DIR_NOTIFY
{
- uint32_t uMsg;
- uint32_t uParmCount;
- PVBOXHGCMSVCPARM pParms;
-} VBOXGUESTCTRPARAMBUFFER;
-typedef VBOXGUESTCTRPARAMBUFFER *PVBOXGUESTCTRPARAMBUFFER;
+ /** Callback data header. */
+ CALLBACKDATA_HEADER hdr;
+ /** Notification type. */
+ uint32_t uType;
+ /** IPRT result of overall operation. */
+ uint32_t rc;
+ union
+ {
+ struct
+ {
+ /** Size (in bytes) of directory information. */
+ uint32_t cbObjInfo;
+ /** Pointer to directory information. */
+ void *pvObjInfo;
+ } info;
+ struct
+ {
+ /** Guest directory handle. */
+ uint32_t uHandle;
+ } open;
+ /** Note: Close does not have any additional data (yet). */
+ struct
+ {
+ /** Size (in bytes) of directory entry information. */
+ uint32_t cbEntry;
+ /** Pointer to directory entry information. */
+ void *pvEntry;
+ /** Size (in bytes) of directory entry object information. */
+ uint32_t cbObjInfo;
+ /** Pointer to directory entry object information. */
+ void *pvObjInfo;
+ } read;
+ } u;
+} CALLBACKDATA_DIR_NOTIFY, *PCALLBACKDATA_DIR_NOTIFY;
+
+/**
+ * General guest file notification callback.
+ */
+typedef struct CALLBACKDATA_FILE_NOTIFY
+{
+ /** Callback data header. */
+ CALLBACKDATA_HEADER hdr;
+ /** Notification type. */
+ uint32_t uType;
+ /** IPRT result of overall operation. */
+ uint32_t rc;
+ union
+ {
+ struct
+ {
+ /** Guest file handle. */
+ uint32_t uHandle;
+ } open;
+ /** Note: Close does not have any additional data (yet). */
+ struct
+ {
+ /** How much data (in bytes) have been read. */
+ uint32_t cbData;
+ /** Actual data read (if any). */
+ void *pvData;
+ } read;
+ struct
+ {
+ /** How much data (in bytes) have been successfully written. */
+ uint32_t cbWritten;
+ } write;
+ struct
+ {
+ /** New file offset after successful seek. */
+ uint64_t uOffActual;
+ } seek;
+ struct
+ {
+ /** New file offset after successful tell. */
+ uint64_t uOffActual;
+ } tell;
+ } u;
+} CALLBACKDATA_FILE_NOTIFY, *PCALLBACKDATA_FILE_NOTIFY;
} /* namespace guestControl */