GuestControlSvc.h revision 4d8251400411b4dcf2c86b5b0376a326ff45938c
/** @file
* Guest control service:
* Common header for host service and guest clients.
*/
/*
* Copyright (C) 2010 Oracle Corporation
*
* This file is part of VirtualBox Open Source Edition (OSE), as
* available from http://www.virtualbox.org. This file is free software;
* General Public License (GPL) as published by the Free Software
* Foundation, in version 2 as it comes in the "COPYING" file of the
* VirtualBox OSE distribution. VirtualBox OSE is distributed in the
* hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
*
* The contents of this file may alternatively be used under the terms
* of the Common Development and Distribution License Version 1.0
* (CDDL) only, as it comes in the "COPYING.CDDL" file of the
* VirtualBox OSE distribution, in which case the provisions of the
* CDDL are applicable instead of those of the GPL.
*
* You may elect to license modified versions of this file under the
* terms and conditions of either the GPL or the CDDL or both.
*/
#include <VBox/VBoxGuest2.h>
/** Everything defined in this file lives in this namespace. */
/******************************************************************************
* Typedefs, constants and inlines *
******************************************************************************/
/**
* Process status when executed in the guest.
*/
enum eProcessStatus
{
/** Process is in an undefined state. */
PROC_STS_UNDEFINED = 0,
/** Process has been started. */
PROC_STS_STARTED = 1,
/** Process terminated normally. */
PROC_STS_TEN = 2,
/** Process terminated via signal. */
PROC_STS_TES = 3,
/** Process terminated abnormally. */
PROC_STS_TEA = 4,
/** Process timed out and was killed. */
PROC_STS_TOK = 5,
/** Process timed out and was not killed successfully. */
PROC_STS_TOA = 6,
/** Service is stopping, process was killed. */
PROC_STS_DWN = 7,
/** Something went wrong (error code in flags). */
PROC_STS_ERROR = 8
};
typedef struct _VBoxGuestCtrlCallbackHeader
{
/** Magic number to identify the structure. */
/** Context ID to identify callback data. */
/**
* Data structure to pass to the service extension callback. We use this to
* notify the host of changes to properties.
*/
typedef struct _VBoxGuestCtrlExecCallbackData
{
/** Callback data header. */
/** The process ID (PID). */
/* The process status. */
/** Optional flags (not used atm). */
/** Optional data buffer (not used atm). */
void *pvData;
/** Size of optional data buffer (not used atm). */
typedef struct _VBoxGuestCtrlExecOutCallbackData
{
/** Callback data header. */
/** The process ID (PID). */
/** Optional flags (not used atm). */
/** Optional data buffer. */
void *pvData;
/** Size of optional data buffer. */
enum
{
/** Magic number for sanity checking the HOSTEXECCALLBACKDATA structure. */
HOSTEXECCALLBACKDATAMAGIC = 0x26011982,
/** Magic number for sanity checking the HOSTEXECOUTCALLBACKDATA structure. */
HOSTEXECOUTCALLBACKDATAMAGIC = 0x11061949
};
{
};
/**
* The service functions which are callable by host.
*/
enum eHostFn
{
/**
* The host wants to execute something in the guest. This can be a command line
* or starting a program.
*/
HOST_EXEC_CMD = 100,
/**
* Sends input data for stdin to a running process executed by HOST_EXEC_CMD.
*/
HOST_EXEC_SET_INPUT = 101,
/**
* Gets the current status of a running process, e.g.
*/
HOST_EXEC_GET_OUTPUT = 102
};
/**
* The service functions which are called by guest. The numbers may not change,
* so we hardcode them.
*/
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 asks the host to cancel all pending waits the guest waits on.
* This becomes necessary when the guest wants to quit but still waits for
* commands from the host.
*/
/**
* TODO
*/
GUEST_EXEC_SEND_OUTPUT = 100,
/**
* TODO
*/
GUEST_EXEC_SEND_STATUS = 101
};
/**
* Sub host commands. These commands are stored as first (=0) parameter in a GUEST_GET_HOST_MSG
* so that the guest can react dynamically to requests from the host.
*/
enum eGetHostMsgFn
{
/**
* Hosts wants the guest to stop waiting for new messages.
*/
/**
* The host wants to execute something in the guest. This can be a command line
* or starting a program.
*/
/**
* Sends input data for stdin to a running process executed by HOST_EXEC_CMD.
*/
GETHOSTMSG_EXEC_SEND_INPUT = 101,
/**
* from a running process executed by HOST_EXEC_CMD.
*/
};
/*
* HGCM parameter structures.
*/
#pragma pack (1)
typedef struct _VBoxGuestCtrlHGCMMsgType
{
/**
* The returned command the host wants to
* run on the guest.
*/
/** Number of parameters the message needs. */
typedef struct _VBoxGuestCtrlHGCMMsgCancelPendingWaits
{
typedef struct _VBoxGuestCtrlHGCMMsgExecCmd
{
/** Size (in bytes) of environment block, including terminating zeros. */
typedef struct _VBoxGuestCtrlHGCMMsgExecOut
{
/** Context ID. */
/** The process ID (PID). */
/** The pipe handle ID. */
/** Optional flags. */
/** Data buffer. */
typedef struct _VBoxGuestCtrlHGCMMsgExecStatus
{
/** Context ID. */
/** The process ID (PID). */
/** The process status. */
/** Optional flags (based on status). */
/** Optional data buffer (not used atm). */
#pragma pack ()
/* Structure for buffering execution requests in the host service. */
typedef struct _VBoxGuestCtrlParamBuffer
{
} /* namespace guestControl */
#endif /* ___VBox_HostService_GuestControlService_h defined */