pdmthread.h revision 7b067f3f07310bff46d1d6a4ac94d8b9bb7ccccd
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync * PDM - Pluggable Device Manager, Threads. (VMM)
cec22f4b94382f5ebee9d2f6b6df672689681e07vboxsync * Copyright (C) 2006-2007 Sun Microsystems, Inc.
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync * This file is part of VirtualBox Open Source Edition (OSE), as
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync * available from http://www.virtualbox.org. This file is free software;
cec22f4b94382f5ebee9d2f6b6df672689681e07vboxsync * you can redistribute it and/or modify it under the terms of the GNU
cec22f4b94382f5ebee9d2f6b6df672689681e07vboxsync * General Public License (GPL) as published by the Free Software
cec22f4b94382f5ebee9d2f6b6df672689681e07vboxsync * Foundation, in version 2 as it comes in the "COPYING" file of the
cec22f4b94382f5ebee9d2f6b6df672689681e07vboxsync * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
cec22f4b94382f5ebee9d2f6b6df672689681e07vboxsync * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
cec22f4b94382f5ebee9d2f6b6df672689681e07vboxsync * The contents of this file may alternatively be used under the terms
cec22f4b94382f5ebee9d2f6b6df672689681e07vboxsync * of the Common Development and Distribution License Version 1.0
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
cec22f4b94382f5ebee9d2f6b6df672689681e07vboxsync * VirtualBox OSE distribution, in which case the provisions of the
cec22f4b94382f5ebee9d2f6b6df672689681e07vboxsync * CDDL are applicable instead of those of the GPL.
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync * You may elect to license modified versions of this file under the
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync * terms and conditions of either the GPL or the CDDL or both.
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync * Clara, CA 95054 USA or visit http://www.sun.com if you need
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync * additional information or have any questions.
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync/** @defgroup grp_pdm_thread The PDM Threads API
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync * @ingroup grp_pdm
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync * The thread state
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync /** The usual invalid 0 entry. */
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync /** The thread is initializing.
81db31727ed27322c3f5e3bc40e71fe7fc54bf91vboxsync * Prev state: none
81db31727ed27322c3f5e3bc40e71fe7fc54bf91vboxsync * Next state: suspended, terminating (error) */
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync /** The thread has been asked to suspend.
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync * Prev state: running
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync * Next state: suspended */
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync /** The thread is supended.
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync * Prev state: suspending, initializing
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync * Next state: resuming, terminated. */
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync /** The thread is active.
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync * Prev state: suspended
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync * Next state: running, terminating. */
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync /** The thread is active.
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync * Prev state: resuming
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync * Next state: suspending, terminating. */
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync /** The thread has been asked to terminate.
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync * Prev state: initializing, suspended, resuming, running
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync * Next state: terminated. */
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync /** The thread is terminating / has terminated.
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync * Prev state: terminating
cec22f4b94382f5ebee9d2f6b6df672689681e07vboxsync * Next state: none */
cec22f4b94382f5ebee9d2f6b6df672689681e07vboxsync /** The usual 32-bit hack. */
cec22f4b94382f5ebee9d2f6b6df672689681e07vboxsync/** A pointer to a PDM thread. */
cec22f4b94382f5ebee9d2f6b6df672689681e07vboxsync/** A pointer to a pointer to a PDM thread. */
cec22f4b94382f5ebee9d2f6b6df672689681e07vboxsync * PDM thread, device variation.
cec22f4b94382f5ebee9d2f6b6df672689681e07vboxsync * @returns VBox status code.
cec22f4b94382f5ebee9d2f6b6df672689681e07vboxsync * @param pDevIns The device instance.
cec22f4b94382f5ebee9d2f6b6df672689681e07vboxsync * @param pThread The PDM thread data.
cec22f4b94382f5ebee9d2f6b6df672689681e07vboxsynctypedef int FNPDMTHREADDEV(PPDMDEVINS pDevIns, PPDMTHREAD pThread);
cec22f4b94382f5ebee9d2f6b6df672689681e07vboxsync/** Pointer to a FNPDMTHREADDEV(). */
cec22f4b94382f5ebee9d2f6b6df672689681e07vboxsync * PDM thread, USB device variation.
cec22f4b94382f5ebee9d2f6b6df672689681e07vboxsync * @returns VBox status code.
cec22f4b94382f5ebee9d2f6b6df672689681e07vboxsync * @param pUsbIns The USB device instance.
cec22f4b94382f5ebee9d2f6b6df672689681e07vboxsync * @param pThread The PDM thread data.
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsynctypedef int FNPDMTHREADUSB(PPDMUSBINS pUsbIns, PPDMTHREAD pThread);
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync/** Pointer to a FNPDMTHREADUSB(). */
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync * PDM thread, driver variation.
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync * @returns VBox status code.
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync * @param pDrvIns The driver instance.
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync * @param pThread The PDM thread data.
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsynctypedef int FNPDMTHREADDRV(PPDMDRVINS pDrvIns, PPDMTHREAD pThread);
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync/** Pointer to a FNPDMTHREADDRV(). */
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync * PDM thread, driver variation.
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync * @returns VBox status code.
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync * @param pVM The VM handle.
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync * @param pThread The PDM thread data.
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsynctypedef int FNPDMTHREADINT(PVM pVM, PPDMTHREAD pThread);
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync/** Pointer to a FNPDMTHREADINT(). */
4c37c32b924cb13b821f9d2e01f42cabbd3d9cf9vboxsync * PDM thread, driver variation.
typedef struct PDMTHREAD
} Dev;
} Usb;
} Drv;
} Int;
} Ext;
#ifdef PDMTHREADINT_DECLARED
PDMTHREADINT s;
} Internal;
} PDMTHREAD;
#ifdef IN_RING3
VMMR3DECL(int) PDMR3ThreadCreate(PVM pVM, PPPDMTHREAD ppThread, void *pvUser, PFNPDMTHREADINT pfnThread,
VMMR3DECL(int) PDMR3ThreadCreateExternal(PVM pVM, PPPDMTHREAD ppThread, void *pvUser, PFNPDMTHREADEXT pfnThread,