VBoxGuestR3LibGuestCtrl.cpp revision 462e60a19d02a99b2b1a5c08dff74bb0808d707c
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync * VBoxGuestR3Lib - Ring-3 Support Library for VirtualBox guest additions, guest control.
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync * Copyright (C) 2010-2013 Oracle Corporation
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync * This file is part of VirtualBox Open Source Edition (OSE), as
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync * available from http://www.virtualbox.org. This file is free software;
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync * you can redistribute it and/or modify it under the terms of the GNU
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync * General Public License (GPL) as published by the Free Software
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync * Foundation, in version 2 as it comes in the "COPYING" file of the
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync * The contents of this file may alternatively be used under the terms
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync * of the Common Development and Distribution License Version 1.0
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync * VirtualBox OSE distribution, in which case the provisions of the
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync * CDDL are applicable instead of those of the GPL.
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync * You may elect to license modified versions of this file under the
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync * terms and conditions of either the GPL or the CDDL or both.
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync/*******************************************************************************
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync* Header Files *
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync*******************************************************************************/
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync/*******************************************************************************
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync* Structures and Typedefs *
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync*******************************************************************************/
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsyncusing namespace guestControl;
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync * Connects to the guest control service.
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync * @returns VBox status code
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync * @param puClientId Where to put the client id on success. The client id
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync * must be passed to all the other calls to the service.
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncVBGLR3DECL(int) VbglR3GuestCtrlConnect(uint32_t *puClientId)
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync strcpy(Info.Loc.u.host.achName, "VBoxGuestControlSvc");
ad27e1d5e48ca41245120c331cc88b50464813cevboxsync Info.u32ClientID = UINT32_MAX; /* try make valgrind shut up. */
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync int rc = vbglR3DoIOCtl(VBOXGUEST_IOCTL_HGCM_CONNECT, &Info, sizeof(Info));
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync * Disconnect from the guest control service.
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync * @returns VBox status code.
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync * @param uClientId The client id returned by VbglR3GuestCtrlConnect().
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncVBGLR3DECL(int) VbglR3GuestCtrlDisconnect(uint32_t uClientId)
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync int rc = vbglR3DoIOCtl(VBOXGUEST_IOCTL_HGCM_DISCONNECT, &Info, sizeof(Info));
9d4498106267e3834edc3a37bca5ca660153525cvboxsync * Waits until a new host message arrives.
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync * This will block until a message becomes available.
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync * @returns VBox status code.
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync * @param uClientId The client id returned by VbglR3GuestCtrlConnect().
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync * @param puMsg Where to store the message id.
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync * @param puNumParms Where to store the number of parameters which will be received
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync * in a second call to the host.
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncVBGLR3DECL(int) VbglR3GuestCtrlMsgWaitFor(uint32_t uClientId, uint32_t *puMsg, uint32_t *puNumParms)
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync Msg.hdr.u32Function = GUEST_MSG_WAIT; /* Tell the host we want our next command. */
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync Msg.hdr.cParms = 2; /* Just peek for the next message! */
ed24120b1d8a2eddf4291a9654cf45b2372135abvboxsync int rc = vbglR3DoIOCtl(VBOXGUEST_IOCTL_HGCM_CALL(sizeof(Msg)), &Msg, sizeof(Msg));
5d69af51557e9e9db029ecd243e820383af49b18vboxsync rc = VbglHGCMParmUInt32Get(&Msg.num_parms, puNumParms);
5d69af51557e9e9db029ecd243e820383af49b18vboxsync /* Ok, so now we know what message type and how much parameters there are. */
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync * Asks the host guest control service to set a command filter to this
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync * client so that it only will receive certain commands in the future.
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync * @return IPRT status code.
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync * @param uClientId The client id returned by VbglR3GuestCtrlConnect().
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync * @param uFilterAdd Filter mask to add.
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync * @param uFilterRemove Filter mask to remove.
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncVBGLR3DECL(int) VbglR3GuestCtrlMsgSetFilter(uint32_t uClientId,
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync Msg.hdr.u32Function = GUEST_MSG_FILTER; /* Tell the host we want to set a filter. */
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync int rc = vbglR3DoIOCtl(VBOXGUEST_IOCTL_HGCM_CALL(sizeof(Msg)), &Msg, sizeof(Msg));
4d8251400411b4dcf2c86b5b0376a326ff45938cvboxsync * Asks the host to cancel (release) all pending waits which were deferred.
4d8251400411b4dcf2c86b5b0376a326ff45938cvboxsync * @returns VBox status code.
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync * @param uClientId The client id returned by VbglR3GuestCtrlConnect().
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncVBGLR3DECL(int) VbglR3GuestCtrlCancelPendingWaits(uint32_t uClientId)
4d8251400411b4dcf2c86b5b0376a326ff45938cvboxsync int rc = vbglR3DoIOCtl(VBOXGUEST_IOCTL_HGCM_CALL(sizeof(Msg)), &Msg, sizeof(Msg));
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncVBGLR3DECL(int) VbglR3GuestCtrlSessionNotify(uint32_t uClientId, uint32_t uContext,
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync int rc = vbglR3DoIOCtl(VBOXGUEST_IOCTL_HGCM_CALL(sizeof(Msg)), &Msg, sizeof(Msg));
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync * Retrieves the request to create a new guest session.
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync * @return IPRT status code.
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync * @param pHostCtx Host context.
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync ** @todo Docs!
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncVBGLR3DECL(int) VbglR3GuestCtrlSessionGetOpen(PVBGLR3GUESTCTRLHOSTCTX pHostCtx,
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AssertReturn(pHostCtx->uNumParms == 6, VERR_INVALID_PARAMETER);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AssertPtrReturn(pszPassword, VERR_INVALID_POINTER);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync VbglHGCMParmPtrSet(&Msg.username, pszUser, cbUser);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync VbglHGCMParmPtrSet(&Msg.password, pszPassword, cbPassword);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync VbglHGCMParmPtrSet(&Msg.domain, pszDomain, cbDomain);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync int rc = vbglR3DoIOCtl(VBOXGUEST_IOCTL_HGCM_CALL(sizeof(Msg)), &Msg, sizeof(Msg));
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync *puSessionID = VBOX_GUESTCTRL_CONTEXTID_GET_SESSION(pHostCtx->uContextID);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync * Retrieves the request to terminate an existing guest session.
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync * @return IPRT status code.
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync * @param pHostCtx Host context.
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync ** @todo Docs!
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncVBGLR3DECL(int) VbglR3GuestCtrlSessionGetClose(PVBGLR3GUESTCTRLHOSTCTX pHostCtx, uint32_t *puFlags, uint32_t *puSessionID)
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AssertReturn(pHostCtx->uNumParms == 2, VERR_INVALID_PARAMETER);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync int rc = vbglR3DoIOCtl(VBOXGUEST_IOCTL_HGCM_CALL(sizeof(Msg)), &Msg, sizeof(Msg));
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync *puSessionID = VBOX_GUESTCTRL_CONTEXTID_GET_SESSION(pHostCtx->uContextID);
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync * Allocates and gets host data, based on the message id.
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync * This will block until data becomes available.
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync * @returns VBox status code.
de210ca38246009981a22de928a52566c8c53970vboxsync ** @todo Docs!
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync ** @todo Move the parameters in an own struct!
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncVBGLR3DECL(int) VbglR3GuestCtrlProcGetStart(PVBGLR3GUESTCTRLHOSTCTX pHostCtx,
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync char *pszEnv, uint32_t *pcbEnv, uint32_t *pcEnvVars,
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync uint64_t *puAffinity, uint32_t cbAffinity, uint32_t *pcAffinity)
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AssertPtrReturn(puTimeoutMS, VERR_INVALID_POINTER);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AssertPtrReturn(pszPassword, VERR_INVALID_POINTER);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync VbglHGCMParmPtrSet(&Msg.u.v1.username, pszUser, cbUser);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync VbglHGCMParmPtrSet(&Msg.u.v1.password, pszPassword, cbPassword);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync VbglHGCMParmPtrSet(&Msg.u.v2.affinity, puAffinity, cbAffinity);
ba8183e1a0c699f5b5131a03e157fc7e39ed3009vboxsync int rc = vbglR3DoIOCtl(VBOXGUEST_IOCTL_HGCM_CALL(sizeof(Msg)), &Msg, sizeof(Msg));
817d003403ed9395143bd4ba88fbd9cb60e5eeebvboxsync * Allocates and gets host data, based on the message id.
817d003403ed9395143bd4ba88fbd9cb60e5eeebvboxsync * This will block until data becomes available.
817d003403ed9395143bd4ba88fbd9cb60e5eeebvboxsync * @returns VBox status code.
817d003403ed9395143bd4ba88fbd9cb60e5eeebvboxsync ** @todo Docs!
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncVBGLR3DECL(int) VbglR3GuestCtrlProcGetOutput(PVBGLR3GUESTCTRLHOSTCTX pHostCtx,
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync uint32_t *puPID, uint32_t *puHandle, uint32_t *puFlags)
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AssertReturn(pHostCtx->uNumParms == 4, VERR_INVALID_PARAMETER);
817d003403ed9395143bd4ba88fbd9cb60e5eeebvboxsync int rc = vbglR3DoIOCtl(VBOXGUEST_IOCTL_HGCM_CALL(sizeof(Msg)), &Msg, sizeof(Msg));
9eea21d61089fe62b80ef3f4549600091c2b1967vboxsync * Retrieves the input data from host which then gets sent to the
9eea21d61089fe62b80ef3f4549600091c2b1967vboxsync * started process.
9eea21d61089fe62b80ef3f4549600091c2b1967vboxsync * This will block until data becomes available.
9eea21d61089fe62b80ef3f4549600091c2b1967vboxsync * @returns VBox status code.
9eea21d61089fe62b80ef3f4549600091c2b1967vboxsync ** @todo Docs!
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncVBGLR3DECL(int) VbglR3GuestCtrlProcGetInput(PVBGLR3GUESTCTRLHOSTCTX pHostCtx,
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AssertReturn(pHostCtx->uNumParms == 5, VERR_INVALID_PARAMETER);
9eea21d61089fe62b80ef3f4549600091c2b1967vboxsync int rc = vbglR3DoIOCtl(VBOXGUEST_IOCTL_HGCM_CALL(sizeof(Msg)), &Msg, sizeof(Msg));
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncVBGLR3DECL(int) VbglR3GuestCtrlFileGetOpen(PVBGLR3GUESTCTRLHOSTCTX pHostCtx,
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AssertReturn(pHostCtx->uNumParms == 6, VERR_INVALID_PARAMETER);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AssertPtrReturn(pszFileName, VERR_INVALID_POINTER);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AssertPtrReturn(pszOpenMode, VERR_INVALID_POINTER);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AssertPtrReturn(pszDisposition, VERR_INVALID_POINTER);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AssertReturn(cbDisposition, VERR_INVALID_PARAMETER);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AssertPtrReturn(puCreationMode, VERR_INVALID_POINTER);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync VbglHGCMParmPtrSet(&Msg.filename, pszFileName, cbFileName);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync VbglHGCMParmPtrSet(&Msg.openmode, pszOpenMode, cbOpenMode);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync VbglHGCMParmPtrSet(&Msg.disposition, pszDisposition, cbDisposition);
817d003403ed9395143bd4ba88fbd9cb60e5eeebvboxsync int rc = vbglR3DoIOCtl(VBOXGUEST_IOCTL_HGCM_CALL(sizeof(Msg)), &Msg, sizeof(Msg));
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncVBGLR3DECL(int) VbglR3GuestCtrlFileGetClose(PVBGLR3GUESTCTRLHOSTCTX pHostCtx, uint32_t *puHandle)
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AssertReturn(pHostCtx->uNumParms == 2, VERR_INVALID_PARAMETER);
9eea21d61089fe62b80ef3f4549600091c2b1967vboxsync int rc = vbglR3DoIOCtl(VBOXGUEST_IOCTL_HGCM_CALL(sizeof(Msg)), &Msg, sizeof(Msg));
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncVBGLR3DECL(int) VbglR3GuestCtrlFileGetRead(PVBGLR3GUESTCTRLHOSTCTX pHostCtx,
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AssertReturn(pHostCtx->uNumParms == 4, VERR_INVALID_PARAMETER);
3ff8aa7d3c74cfbe8da5f77b8ea6c748cc79213avboxsync int rc = vbglR3DoIOCtl(VBOXGUEST_IOCTL_HGCM_CALL(sizeof(Msg)), &Msg, sizeof(Msg));
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncVBGLR3DECL(int) VbglR3GuestCtrlFileGetReadAt(PVBGLR3GUESTCTRLHOSTCTX pHostCtx,
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync uint32_t *puHandle, uint32_t *puToRead, uint64_t *puOffset)
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AssertReturn(pHostCtx->uNumParms == 5, VERR_INVALID_PARAMETER);
3ff8aa7d3c74cfbe8da5f77b8ea6c748cc79213avboxsync int rc = vbglR3DoIOCtl(VBOXGUEST_IOCTL_HGCM_CALL(sizeof(Msg)), &Msg, sizeof(Msg));
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncVBGLR3DECL(int) VbglR3GuestCtrlFileGetWrite(PVBGLR3GUESTCTRLHOSTCTX pHostCtx, uint32_t *puHandle,
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AssertReturn(pHostCtx->uNumParms == 4, VERR_INVALID_PARAMETER);
3ff8aa7d3c74cfbe8da5f77b8ea6c748cc79213avboxsync int rc = vbglR3DoIOCtl(VBOXGUEST_IOCTL_HGCM_CALL(sizeof(Msg)), &Msg, sizeof(Msg));
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncVBGLR3DECL(int) VbglR3GuestCtrlFileGetWriteAt(PVBGLR3GUESTCTRLHOSTCTX pHostCtx, uint32_t *puHandle,
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync void *pvData, uint32_t cbData, uint32_t *pcbSize, uint64_t *puOffset)
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AssertReturn(pHostCtx->uNumParms == 5, VERR_INVALID_PARAMETER);
3ff8aa7d3c74cfbe8da5f77b8ea6c748cc79213avboxsync int rc = vbglR3DoIOCtl(VBOXGUEST_IOCTL_HGCM_CALL(sizeof(Msg)), &Msg, sizeof(Msg));
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncVBGLR3DECL(int) VbglR3GuestCtrlFileGetSeek(PVBGLR3GUESTCTRLHOSTCTX pHostCtx,
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync uint32_t *puHandle, uint32_t *puSeekMethod, uint64_t *puOffset)
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AssertReturn(pHostCtx->uNumParms == 4, VERR_INVALID_PARAMETER);
3ff8aa7d3c74cfbe8da5f77b8ea6c748cc79213avboxsync AssertPtrReturn(puSeekMethod, VERR_INVALID_POINTER);
3ff8aa7d3c74cfbe8da5f77b8ea6c748cc79213avboxsync int rc = vbglR3DoIOCtl(VBOXGUEST_IOCTL_HGCM_CALL(sizeof(Msg)), &Msg, sizeof(Msg));
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncVBGLR3DECL(int) VbglR3GuestCtrlFileGetTell(PVBGLR3GUESTCTRLHOSTCTX pHostCtx, uint32_t *puHandle)
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AssertReturn(pHostCtx->uNumParms == 2, VERR_INVALID_PARAMETER);
3ff8aa7d3c74cfbe8da5f77b8ea6c748cc79213avboxsync int rc = vbglR3DoIOCtl(VBOXGUEST_IOCTL_HGCM_CALL(sizeof(Msg)), &Msg, sizeof(Msg));
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncVBGLR3DECL(int) VbglR3GuestCtrlProcGetTerminate(PVBGLR3GUESTCTRLHOSTCTX pHostCtx, uint32_t *puPID)
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AssertReturn(pHostCtx->uNumParms == 2, VERR_INVALID_PARAMETER);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync int rc = vbglR3DoIOCtl(VBOXGUEST_IOCTL_HGCM_CALL(sizeof(Msg)), &Msg, sizeof(Msg));
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncVBGLR3DECL(int) VbglR3GuestCtrlProcGetWaitFor(PVBGLR3GUESTCTRLHOSTCTX pHostCtx, uint32_t *puPID, uint32_t *puWaitFlags, uint32_t *puTimeoutMS)
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AssertReturn(pHostCtx->uNumParms == 5, VERR_INVALID_PARAMETER);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync int rc = vbglR3DoIOCtl(VBOXGUEST_IOCTL_HGCM_CALL(sizeof(Msg)), &Msg, sizeof(Msg));
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncVBGLR3DECL(int) VbglR3GuestCtrlFileNotify(uint32_t uClientId, uint32_t uContext,
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync //Msg.hdr.u32Function = GUEST_FILE_NOTIFY;
3ff8aa7d3c74cfbe8da5f77b8ea6c748cc79213avboxsync VbglHGCMParmPtrSet(&Msg.payload, pvPayload, cbPayload);
3ff8aa7d3c74cfbe8da5f77b8ea6c748cc79213avboxsync int rc = vbglR3DoIOCtl(VBOXGUEST_IOCTL_HGCM_CALL(sizeof(Msg)), &Msg, sizeof(Msg));
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync * Callback for reporting a guest process status (along with some other stuff) to the host.
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync * @returns VBox status code.
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync ** @todo Docs!
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncVBGLR3DECL(int) VbglR3GuestCtrlProcCbStatus(uint32_t u32ClientID,
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync int rc = vbglR3DoIOCtl(VBOXGUEST_IOCTL_HGCM_CALL(sizeof(Msg)), &Msg, sizeof(Msg));
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync * Sends output (from stdout/stderr) from a running process.
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync * @returns VBox status code.
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync ** @todo Docs!
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncVBGLR3DECL(int) VbglR3GuestCtrlProcCbOutput(uint32_t u32ClientID,
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync int rc = vbglR3DoIOCtl(VBOXGUEST_IOCTL_HGCM_CALL(sizeof(Msg)), &Msg, sizeof(Msg));
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync * Callback for reporting back the input status of a guest process to the host.
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync * @returns VBox status code.
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync ** @todo Docs!
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncVBGLR3DECL(int) VbglR3GuestCtrlProcCbStatusInput(uint32_t u32ClientID,
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync int rc = vbglR3DoIOCtl(VBOXGUEST_IOCTL_HGCM_CALL(sizeof(Msg)), &Msg, sizeof(Msg));