Logo Search packages:      
Sourcecode: virtualbox-ose version File versions

cdefs.h

Go to the documentation of this file.
/** @file
 * VirtualBox - Common C and C++ definition.
 */

/*
 * Copyright (C) 2006-2007 Sun Microsystems, Inc.
 *
 * This file is part of VirtualBox Open Source Edition (OSE), as
 * available from http://www.virtualbox.org. This file is free software;
 * you can redistribute it and/or modify it under the terms of the GNU
 * 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.
 *
 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
 * Clara, CA 95054 USA or visit http://www.sun.com if you need
 * additional information or have any questions.
 */

#ifndef ___VBox_cdefs_h
#define ___VBox_cdefs_h

#include <iprt/cdefs.h>


/** @def VBOX_WITH_STATISTICS
 * When defined all statistics will be included in the build.
 * This is enabled by default in all debug builds.
 */
#ifndef VBOX_WITH_STATISTICS
# ifdef DEBUG
#  define VBOX_WITH_STATISTICS
# endif
#endif

/** @def VBOX_STRICT
 * Alias for RT_STRICT.
 */
#ifdef RT_STRICT
# ifndef VBOX_STRICT
#  define VBOX_STRICT
# endif
#endif


/*
 * Shut up DOXYGEN warnings and guide it properly thru the code.
 */
#ifdef  __DOXYGEN__
#define VBOX_WITH_STATISTICS
#ifndef VBOX_STRICT
# define VBOX_STRICT
#endif
#define IN_CFGM_GC
#define IN_CFGM_R3
#define IN_CPUM_GC
#define IN_CPUM_R0
#define IN_CPUM_R3
#define IN_CSAM_R0
#define IN_CSAM_R3
#define IN_CSAM_GC
#define IN_DBGF_R0
#define IN_DBGF_R3
#define IN_DBGF_GC
#define IN_DIS_GC
#define IN_DIS_R0
#define IN_DIS_R3
#define IN_EM_GC
#define IN_EM_R3
#define IN_EM_R0
#define IN_HWACCM_R0
#define IN_HWACCM_R3
#define IN_HWACCM_GC
#define IN_IDE_R3
#define IN_INTNET_R0
#define IN_INTNET_R3
#define IN_IOM_GC
#define IN_IOM_R3
#define IN_IOM_R0
#define IN_MM_GC
#define IN_MM_R0
#define IN_MM_R3
#define IN_PATM_R0
#define IN_PATM_R3
#define IN_PATM_GC
#define IN_PDM_GC
#define IN_PDM_R3
#define IN_PGM_GC
#define IN_PGM_R0
#define IN_PGM_R3
#define IN_REM_GC
#define IN_REM_R0
#define IN_REM_R3
#define IN_SELM_GC
#define IN_SELM_R0
#define IN_SELM_R3
#define IN_SSM_R3
#define IN_STAM_GC
#define IN_STAM_R0
#define IN_STAM_R3
#define IN_SUP_R0
#define IN_SUP_R3
#define IN_SUP_GC
#define IN_TM_GC
#define IN_TM_R0
#define IN_TM_R3
#define IN_TRPM_GC
#define IN_TRPM_R0
#define IN_TRPM_R3
#define IN_USB_GC
#define IN_USB_R0
#define IN_USB_R3
#define IN_USBLIB
#define IN_VGADEVICE_GC
#define IN_VGADEVICE_R3
#define IN_VHHD_R3
#define IN_VM_GC
#define IN_VM_R0
#define IN_VM_R3
#define IN_VMM_GC
#define IN_VMM_R0
#define IN_VMM_R3
/** @todo fixme */
#endif




/** @def VBOXCALL
 * The standard calling convention for VBOX interfaces.
 */
00142 #define VBOXCALL   RTCALL



/** @def IN_VM_R3
 * Used to indicate whether we're inside the same link module as the ring 3 part of the
 * virtual machine (the module) or not.
 */
/** @def VMR3DECL
 * Ring 3 VM export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_VM_R3
# define VMR3DECL(type)     DECLEXPORT(type) VBOXCALL
#else
00157 # define VMR3DECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_VM_R0
 * Used to indicate whether we're inside the same link module as the ring 0
 * part of the virtual machine (the module) or not.
 */
/** @def VMR0DECL
 * Ring 0 VM export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_VM_R0
# define VMR0DECL(type)     DECLEXPORT(type) VBOXCALL
#else
00171 # define VMR0DECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_VM_GC
 * Used to indicate whether we're inside the same link module as the guest context
 * part of the virtual machine (the module) or not.
 */
/** @def VMGCDECL
 * Guest context VM export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_VM_GC
# define VMGCDECL(type)     DECLEXPORT(type) VBOXCALL
#else
00185 # define VMGCDECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def VMDECL
 * VM export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#if defined(IN_VM_R3) || defined(IN_VM_R0) || defined(IN_VM_GC)
# define VMDECL(type)       DECLEXPORT(type) VBOXCALL
#else
00195 # define VMDECL(type)       DECLIMPORT(type) VBOXCALL
#endif


/** @def IN_VMM_R3
 * Used to indicate whether we're inside the same link module as the ring 3 part of the
 * virtual machine monitor or not.
 */
/** @def VMMR3DECL
 * Ring 3 VMM export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_VMM_R3
# define VMMR3DECL(type)    DECLEXPORT(type) VBOXCALL
#else
00210 # define VMMR3DECL(type)    DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_VMM_R0
 * Used to indicate whether we're inside the same link module as the ring 0 part of the
 * virtual machine monitor or not.
 */
/** @def VMMR0DECL
 * Ring 0 VMM export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_VMM_R0
# define VMMR0DECL(type)    DECLEXPORT(type) VBOXCALL
#else
00224 # define VMMR0DECL(type)    DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_VMM_GC
 * Used to indicate whether we're inside the same link module as the guest context
 * part of the virtual machine monitor or not.
 */
/** @def VMMGCDECL
 * Guest context VMM export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_VMM_GC
# define VMMGCDECL(type)    DECLEXPORT(type) VBOXCALL
#else
00238 # define VMMGCDECL(type)    DECLIMPORT(type) VBOXCALL
#endif

/** @def VMMDECL
 * VMM export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#if defined(IN_VMM_R3) || defined(IN_VMM_R0) || defined(IN_VMM_GC)
# define VMMDECL(type)      DECLEXPORT(type) VBOXCALL
#else
00248 # define VMMDECL(type)      DECLIMPORT(type) VBOXCALL
#endif


/** @def IN_DIS_R3
 * Used to indicate whether we're inside the same link module as the
 * Ring-3 disassembler or not.
 */
/** @def DISR3DECL(type)
 * Disassembly export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_DIS_R3
# define DISR3DECL(type)    DECLEXPORT(type) VBOXCALL
#else
00263 # define DISR3DECL(type)    DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_DIS_R0
 * Used to indicate whether we're inside the same link module as the
 * Ring-0 disassembler or not.
 */
/** @def DISR0DECL(type)
 * Disassembly export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_DIS_R0
# define DISR0DECL(type)    DECLEXPORT(type) VBOXCALL
#else
00277 # define DISR0DECL(type)    DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_DIS_GC
 * Used to indicate whether we're inside the same link module as the
 * GC disassembler or not.
 */
/** @def DISGCDECL(type)
 * Disassembly export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_DIS_GC
# define DISGCDECL(type)    DECLEXPORT(type) VBOXCALL
#else
00291 # define DISGCDECL(type)    DECLIMPORT(type) VBOXCALL
#endif

/** @def DISDECL(type)
 * Disassembly export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#if defined(IN_DIS_R3) ||defined(IN_DIS_R0) || defined(IN_DIS_GC)
# define DISDECL(type)      DECLEXPORT(type) VBOXCALL
#else
00301 # define DISDECL(type)      DECLIMPORT(type) VBOXCALL
#endif


/** @def IN_SUP_R3
 * Used to indicate whether we're inside the same link module as the Ring 3 Support Library or not.
 */
/** @def SUPR3DECL(type)
 * Support library export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_SUP_R3
# define SUPR3DECL(type)    DECLEXPORT(type) VBOXCALL
#else
00315 # define SUPR3DECL(type)    DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_SUP_R0
 * Used to indicate whether we're inside the same link module as the Ring 0 Support Library or not.
 */
/** @def SUPR0DECL(type)
 * Support library export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_SUP_R0
# define SUPR0DECL(type)    DECLEXPORT(type) VBOXCALL
#else
# define SUPR0DECL(type)    DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_SUP_GC
 * Used to indicate whether we're inside the same link module as the GC Support Library or not.
 */
/** @def SUPGCDECL(type)
 * Support library export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_SUP_GC
# define SUPGCDECL(type)    DECLEXPORT(type) VBOXCALL
#else
00341 # define SUPGCDECL(type)    DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_SUP_R0
 * Used to indicate whether we're inside the same link module as the Ring 0 Support Library or not.
 */
/** @def SUPR0DECL(type)
 * Support library export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#if defined(IN_SUP_R0) || defined(IN_SUP_R3) || defined(IN_SUP_GC)
# define SUPDECL(type)    DECLEXPORT(type) VBOXCALL
#else
# define SUPDECL(type)    DECLIMPORT(type) VBOXCALL
#endif




/** @def IN_PDM_R3
 * Used to indicate whether we're inside the same link module as the Ring 3
 * Pluggable Device Manager.
 */
/** @def PDMR3DECL(type)
 * Pluggable Device Manager export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_PDM_R3
# define PDMR3DECL(type)    DECLEXPORT(type) VBOXCALL
#else
00371 # define PDMR3DECL(type)    DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_PDM_GC
 * Used to indicate whether we're inside the same link module as the GC
 * Pluggable Device Manager.
 */
/** @def PDMGCDECL(type)
 * Pluggable Device Manager export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_PDM_GC
# define PDMGCDECL(type)    DECLEXPORT(type) VBOXCALL
#else
00385 # define PDMGCDECL(type)    DECLIMPORT(type) VBOXCALL
#endif

/** @def PDMDECL(type)
 * Pluggable Device Manager export or import declaration.
 * Functions declared using this macro exists in all contexts.
 * @param   type    The return type of the function declaration.
 */
#if defined(IN_PDM_R3) || defined(IN_PDM_GC) || defined(IN_PDM_R0)
# define PDMDECL(type)      DECLEXPORT(type) VBOXCALL
#else
00396 # define PDMDECL(type)      DECLIMPORT(type) VBOXCALL
#endif




/** @def IN_CFGM_R3
 * Used to indicate whether we're inside the same link module as the Ring 3
 * Configuration Manager.
 */
/** @def CFGMR3DECL(type)
 * Configuration Manager export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_CFGM_R3
# define CFGMR3DECL(type)   DECLEXPORT(type) VBOXCALL
#else
00413 # define CFGMR3DECL(type)   DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_CFGM_GC
 * Used to indicate whether we're inside the same link module as the GC
 * Configuration Manager.
 */
/** @def CFGMGCDECL(type)
 * Configuration Manager export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_CFGM_GC
# define CFGMGCDECL(type)   DECLEXPORT(type) VBOXCALL
#else
00427 # define CFGMGCDECL(type)   DECLIMPORT(type) VBOXCALL
#endif


/** @def IN_CPUM_R0
 * Used to indicate whether we're inside the same link module as
 * the HC Ring-0 CPU Monitor(/Manager).
 */
/** @def CPUMR0DECL(type)
 * CPU Monitor(/Manager) HC Ring-0 export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_CPUM_R0
# define CPUMR0DECL(type)     DECLEXPORT(type) VBOXCALL
#else
00442 # define CPUMR0DECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_CPUM_R3
 * Used to indicate whether we're inside the same link module as
 * the HC Ring-3 CPU Monitor(/Manager).
 */
/** @def CPUMR3DECL(type)
 * CPU Monitor(/Manager) HC Ring-3 export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_CPUM_R3
# define CPUMR3DECL(type)     DECLEXPORT(type) VBOXCALL
#else
00456 # define CPUMR3DECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_CPUM_GC
 * Used to indicate whether we're inside the same link module as
 * the GC CPU Monitor(/Manager).
 */
/** @def CPUMGCDECL(type)
 * CPU Monitor(/Manager) HC Ring-3 export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_CPUM_GC
# define CPUMGCDECL(type)     DECLEXPORT(type) VBOXCALL
#else
00470 # define CPUMGCDECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def CPUMDECL(type)
 * CPU Monitor(/Manager) export or import declaration.
 * Functions declared using this macro exists in all contexts.
 * @param   type    The return type of the function declaration.
 */
#if defined(IN_CPUM_R3) || defined(IN_CPUM_GC) || defined(IN_CPUM_R0)
# define CPUMDECL(type)       DECLEXPORT(type) VBOXCALL
#else
00481 # define CPUMDECL(type)       DECLIMPORT(type) VBOXCALL
#endif



/** @def IN_PATM_R0
 * Used to indicate whether we're inside the same link module as
 * the HC Ring-0 CPU Monitor(/Manager).
 */
/** @def PATMR0DECL(type)
 * Patch Manager HC Ring-0 export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_PATM_R0
# define PATMR0DECL(type)     DECLEXPORT(type) VBOXCALL
#else
00497 # define PATMR0DECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_PATM_R3
 * Used to indicate whether we're inside the same link module as
 * the HC Ring-3 CPU Monitor(/Manager).
 */
/** @def PATMR3DECL(type)
 * Patch Manager HC Ring-3 export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_PATM_R3
# define PATMR3DECL(type)     DECLEXPORT(type) VBOXCALL
#else
00511 # define PATMR3DECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_PATM_GC
 * Used to indicate whether we're inside the same link module as
 * the GC Patch Manager.
 */
/** @def PATMGCDECL(type)
 * Patch Manager HC Ring-3 export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_PATM_GC
# define PATMGCDECL(type)     DECLEXPORT(type) VBOXCALL
#else
00525 # define PATMGCDECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def PATMDECL(type)
 * Patch Manager all contexts export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#if defined(IN_PATM_R3) || defined(IN_PATM_R0) || defined(IN_PATM_GC)
# define PATMDECL(type)     DECLEXPORT(type) VBOXCALL
#else
00535 # define PATMDECL(type)     DECLIMPORT(type) VBOXCALL
#endif



/** @def IN_CSAM_R0
 * Used to indicate whether we're inside the same link module as
 * the HC Ring-0 CPU Monitor(/Manager).
 */
/** @def CSAMR0DECL(type)
 * Code Scanning and Analysis Manager HC Ring-0 export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_CSAM_R0
# define CSAMR0DECL(type)     DECLEXPORT(type) VBOXCALL
#else
00551 # define CSAMR0DECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_CSAM_R3
 * Used to indicate whether we're inside the same link module as
 * the HC Ring-3 CPU Monitor(/Manager).
 */
/** @def CSAMR3DECL(type)
 * Code Scanning and Analysis Manager HC Ring-3 export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_CSAM_R3
# define CSAMR3DECL(type)     DECLEXPORT(type) VBOXCALL
#else
00565 # define CSAMR3DECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_CSAM_GC
 * Used to indicate whether we're inside the same link module as
 * the GC Code Scanning and Analysis Manager.
 */
/** @def CSAMGCDECL(type)
 * Code Scanning and Analysis Manager HC Ring-3 export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_CSAM_GC
# define CSAMGCDECL(type)     DECLEXPORT(type) VBOXCALL
#else
00579 # define CSAMGCDECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def CSAMDECL(type)
 * Code Scanning and Analysis Manager export or import declaration.
 * Functions declared using this macro exists in all contexts.
 * @param   type    The return type of the function declaration.
 */
#if defined(IN_CSAM_R3) || defined(IN_CSAM_GC) || defined(IN_CSAM_R0)
# define CSAMDECL(type)       DECLEXPORT(type) VBOXCALL
#else
00590 # define CSAMDECL(type)       DECLIMPORT(type) VBOXCALL
#endif



/** @def IN_MM_R0
 * Used to indicate whether we're inside the same link module as
 * the HC Ring-0 Memory Monitor(/Manager).
 */
/** @def MMR0DECL(type)
 * Memory Monitor(/Manager) HC Ring-0 export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_MM_R0
# define MMR0DECL(type)     DECLEXPORT(type) VBOXCALL
#else
00606 # define MMR0DECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_MM_R3
 * Used to indicate whether we're inside the same link module as
 * the HC Ring-3 Memory Monitor(/Manager).
 */
/** @def MMR3DECL(type)
 * Memory Monitor(/Manager) HC Ring-3 export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_MM_R3
# define MMR3DECL(type)     DECLEXPORT(type) VBOXCALL
#else
00620 # define MMR3DECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_MM_GC
 * Used to indicate whether we're inside the same link module as
 * the GC Memory Monitor(/Manager).
 */
/** @def MMGCDECL(type)
 * Memory Monitor(/Manager) HC Ring-3 export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_MM_GC
# define MMGCDECL(type)     DECLEXPORT(type) VBOXCALL
#else
00634 # define MMGCDECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def MMDECL(type)
 * Memory Monitor(/Manager) export or import declaration.
 * Functions declared using this macro exists in all contexts.
 * @param   type    The return type of the function declaration.
 */
#if defined(IN_MM_R3) || defined(IN_MM_GC) || defined(IN_MM_R0)
# define MMDECL(type)       DECLEXPORT(type) VBOXCALL
#else
00645 # define MMDECL(type)       DECLIMPORT(type) VBOXCALL
#endif




/** @def IN_SELM_R0
 * Used to indicate whether we're inside the same link module as
 * the HC Ring-0 Selector Monitor(/Manager).
 */
/** @def SELMR0DECL(type)
 * Selector Monitor(/Manager) HC Ring-0 export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_SELM_R0
# define SELMR0DECL(type)     DECLEXPORT(type) VBOXCALL
#else
00662 # define SELMR0DECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_SELM_R3
 * Used to indicate whether we're inside the same link module as
 * the HC Ring-3 Selector Monitor(/Manager).
 */
/** @def SELMR3DECL(type)
 * Selector Monitor(/Manager) HC Ring-3 export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_SELM_R3
# define SELMR3DECL(type)     DECLEXPORT(type) VBOXCALL
#else
00676 # define SELMR3DECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_SELM_GC
 * Used to indicate whether we're inside the same link module as
 * the GC Selector Monitor(/Manager).
 */
/** @def SELMGCDECL(type)
 * Selector Monitor(/Manager) HC Ring-3 export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_SELM_GC
# define SELMGCDECL(type)     DECLEXPORT(type) VBOXCALL
#else
00690 # define SELMGCDECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def SELMDECL(type)
 * Selector Monitor(/Manager) export or import declaration.
 * Functions declared using this macro exists in all contexts.
 * @param   type    The return type of the function declaration.
 */
#if defined(IN_SELM_R3) || defined(IN_SELM_GC) || defined(IN_SELM_R0)
# define SELMDECL(type)       DECLEXPORT(type) VBOXCALL
#else
00701 # define SELMDECL(type)       DECLIMPORT(type) VBOXCALL
#endif



/** @def IN_HWACCM_R0
 * Used to indicate whether we're inside the same link module as
 * the HC Ring-0 VMX Monitor(/Manager).
 */
/** @def HWACCMR0DECL(type)
 * Selector Monitor(/Manager) HC Ring-0 export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_HWACCM_R0
# define HWACCMR0DECL(type)     DECLEXPORT(type) VBOXCALL
#else
00717 # define HWACCMR0DECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_HWACCM_R3
 * Used to indicate whether we're inside the same link module as
 * the HC Ring-3 VMX Monitor(/Manager).
 */
/** @def HWACCMR3DECL(type)
 * Selector Monitor(/Manager) HC Ring-3 export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_HWACCM_R3
# define HWACCMR3DECL(type)     DECLEXPORT(type) VBOXCALL
#else
00731 # define HWACCMR3DECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_HWACCM_GC
 * Used to indicate whether we're inside the same link module as
 * the GC VMX Monitor(/Manager).
 */
/** @def HWACCMGCDECL(type)
 * Selector Monitor(/Manager) HC Ring-3 export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_HWACCM_GC
# define HWACCMGCDECL(type)     DECLEXPORT(type) VBOXCALL
#else
00745 # define HWACCMGCDECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def HWACCMDECL(type)
 * VMX Monitor(/Manager) export or import declaration.
 * Functions declared using this macro exists in all contexts.
 * @param   type    The return type of the function declaration.
 */
#if defined(IN_HWACCM_R3) || defined(IN_HWACCM_GC) || defined(IN_HWACCM_R0)
# define HWACCMDECL(type)       DECLEXPORT(type) VBOXCALL
#else
00756 # define HWACCMDECL(type)       DECLIMPORT(type) VBOXCALL
#endif



/** @def IN_TM_R0
 * Used to indicate whether we're inside the same link module as
 * the HC Ring-0 Time Manager.
 */
/** @def TMR0DECL(type)
 * Time Manager HC Ring-0 export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_TM_R0
# define TMR0DECL(type)     DECLEXPORT(type) VBOXCALL
#else
00772 # define TMR0DECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_TM_R3
 * Used to indicate whether we're inside the same link module as
 * the HC Ring-3 Time Manager.
 */
/** @def TMR3DECL(type)
 * Time Manager HC Ring-3 export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_TM_R3
# define TMR3DECL(type)     DECLEXPORT(type) VBOXCALL
#else
00786 # define TMR3DECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_TM_GC
 * Used to indicate whether we're inside the same link module as
 * the GC Time Manager.
 */
/** @def TMGCDECL(type)
 * Time Manager HC Ring-3 export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_TM_GC
# define TMGCDECL(type)     DECLEXPORT(type) VBOXCALL
#else
00800 # define TMGCDECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def TMDECL(type)
 * Time Manager export or import declaration.
 * Functions declared using this macro exists in all contexts.
 * @param   type    The return type of the function declaration.
 */
#if defined(IN_TM_R3) || defined(IN_TM_GC) || defined(IN_TM_R0)
# define TMDECL(type)       DECLEXPORT(type) VBOXCALL
#else
00811 # define TMDECL(type)       DECLIMPORT(type) VBOXCALL
#endif




/** @def IN_TRPM_R0
 * Used to indicate whether we're inside the same link module as
 * the HC Ring-0 Trap Monitor.
 */
/** @def TRPMR0DECL(type)
 * Trap Monitor HC Ring-0 export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_TRPM_R0
# define TRPMR0DECL(type)     DECLEXPORT(type) VBOXCALL
#else
00828 # define TRPMR0DECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_TRPM_R3
 * Used to indicate whether we're inside the same link module as
 * the HC Ring-3 Trap Monitor.
 */
/** @def TRPMR3DECL(type)
 * Trap Monitor HC Ring-3 export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_TRPM_R3
# define TRPMR3DECL(type)     DECLEXPORT(type) VBOXCALL
#else
00842 # define TRPMR3DECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_TRPM_GC
 * Used to indicate whether we're inside the same link module as
 * the GC Trap Monitor.
 */
/** @def TRPMGCDECL(type)
 * Trap Monitor GC export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_TRPM_GC
# define TRPMGCDECL(type)     DECLEXPORT(type) VBOXCALL
#else
00856 # define TRPMGCDECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def TRPMDECL(type)
 * Trap Monitor export or import declaration.
 * Functions declared using this macro exists in all contexts.
 * @param   type    The return type of the function declaration.
 */
#if defined(IN_TRPM_R3) || defined(IN_TRPM_GC) || defined(IN_TRPM_R0)
# define TRPMDECL(type)       DECLEXPORT(type) VBOXCALL
#else
00867 # define TRPMDECL(type)       DECLIMPORT(type) VBOXCALL
#endif




/** @def IN_USB_R0
 * Used to indicate whether we're inside the same link module as
 * the HC Ring-0 USB device / service.
 */
/** @def USBR0DECL(type)
 * USB device / service HC Ring-0 export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_USB_R0
# define USBR0DECL(type)     DECLEXPORT(type) VBOXCALL
#else
00884 # define USBR0DECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_USB_R3
 * Used to indicate whether we're inside the same link module as
 * the HC Ring-3 USB device / service.
 */
/** @def USBR3DECL(type)
 * USB device / services HC Ring-3 export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_USB_R3
# define USBR3DECL(type)     DECLEXPORT(type) VBOXCALL
#else
00898 # define USBR3DECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_USB_GC
 * Used to indicate whether we're inside the same link module as
 * the GC USB device.
 */
/** @def USBGCDECL(type)
 * USB device GC export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_USB_GC
# define USBGCDECL(type)     DECLEXPORT(type) VBOXCALL
#else
00912 # define USBGCDECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def USBDECL(type)
 * Trap Monitor export or import declaration.
 * Functions declared using this macro exists in all contexts.
 * @param   type    The return type of the function declaration.
 */
#if defined(IN_USB_R3) || defined(IN_USB_GC) || defined(IN_USB_R0)
# define USBDECL(type)       DECLEXPORT(type) VBOXCALL
#else
00923 # define USBDECL(type)       DECLIMPORT(type) VBOXCALL
#endif



/** @def IN_USBLIB
 * Used to indicate whether we're inside the same link module as the USBLib.
 */
/** @def USBLIB_DECL
 * USBLIB export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_RING0
# define USBLIB_DECL(type)   type VBOXCALL
#elif defined(IN_USBLIB)
# define USBLIB_DECL(type)   DECLEXPORT(type) VBOXCALL
#else
00940 # define USBLIB_DECL(type)   DECLIMPORT(type) VBOXCALL
#endif



/** @def IN_INTNET_R3
 * Used to indicate whether we're inside the same link module as the Ring 3
 * Internal Networking Service.
 */
/** @def INTNETR3DECL(type)
 * Internal Networking Service export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_INTNET_R3
# define INTNETR3DECL(type)    DECLEXPORT(type) VBOXCALL
#else
00956 # define INTNETR3DECL(type)    DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_INTNET_R0
 * Used to indicate whether we're inside the same link module as the R0
 * Internal Network Service.
 */
/** @def INTNETR0DECL(type)
 * Internal Networking Service export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_INTNET_R0
# define INTNETR0DECL(type)    DECLEXPORT(type) VBOXCALL
#else
00970 # define INTNETR0DECL(type)    DECLIMPORT(type) VBOXCALL
#endif



/** @def IN_IOM_R3
 * Used to indicate whether we're inside the same link module as the Ring 3
 * Input/Output Monitor.
 */
/** @def IOMR3DECL(type)
 * Input/Output Monitor export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_IOM_R3
# define IOMR3DECL(type)    DECLEXPORT(type) VBOXCALL
#else
00986 # define IOMR3DECL(type)    DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_IOM_GC
 * Used to indicate whether we're inside the same link module as the GC
 * Input/Output Monitor.
 */
/** @def IOMGCDECL(type)
 * Input/Output Monitor export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_IOM_GC
# define IOMGCDECL(type)    DECLEXPORT(type) VBOXCALL
#else
01000 # define IOMGCDECL(type)    DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_IOM_R0
 * Used to indicate whether we're inside the same link module as the R0
 * Input/Output Monitor.
 */
/** @def IOMR0DECL(type)
 * Input/Output Monitor export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_IOM_R0
# define IOMR0DECL(type)    DECLEXPORT(type) VBOXCALL
#else
01014 # define IOMR0DECL(type)    DECLIMPORT(type) VBOXCALL
#endif

/** @def IOMDECL(type)
 * Input/Output Monitor export or import declaration.
 * Functions declared using this macro exists in all contexts.
 * @param   type    The return type of the function declaration.
 */
#if defined(IN_IOM_R3) || defined(IN_IOM_GC) || defined(IN_IOM_R0)
# define IOMDECL(type)      DECLEXPORT(type) VBOXCALL
#else
01025 # define IOMDECL(type)      DECLIMPORT(type) VBOXCALL
#endif


/** @def IN_VGADEVICE_R3
 * Used to indicate whether we're inside the same link module as
 * the HC Ring-3 VGA Monitor(/Manager).
 */
/** @def VGAR3DECL(type)
 * VGA Monitor(/Manager) HC Ring-3 export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_VGADEVICE_R3
# define VGAR3DECL(type)     DECLEXPORT(type) VBOXCALL
#else
01040 # define VGAR3DECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_VGADEVICE_GC
 * Used to indicate whether we're inside the same link module as
 * the GC VGA Monitor(/Manager).
 */
/** @def VGAGCDECL(type)
 * VGA Monitor(/Manager) HC Ring-3 export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_VGADEVICE_GC
# define VGAGCDECL(type)     DECLEXPORT(type) VBOXCALL
#else
01054 # define VGAGCDECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def VGADECL(type)
 * VGA Monitor(/Manager) export or import declaration.
 * Functions declared using this macro exists in all contexts.
 * @param   type    The return type of the function declaration.
 */
#if defined(IN_VGADEVICE_R3) || defined(IN_VGADEVICE_GC)
# define VGADECL(type)       DECLEXPORT(type) VBOXCALL
#else
01065 # define VGADECL(type)       DECLIMPORT(type) VBOXCALL
#endif


/** @def IN_PGM_R3
 * Used to indicate whether we're inside the same link module as the Ring 3
 * Page Monitor and Manager.
 */
/** @def PGMR3DECL(type)
 * Page Monitor and Manager export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_PGM_R3
# define PGMR3DECL(type)    DECLEXPORT(type) VBOXCALL
#else
01080 # define PGMR3DECL(type)    DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_PGM_GC
 * Used to indicate whether we're inside the same link module as the GC
 * Page Monitor and Manager.
 */
/** @def PGMGCDECL(type)
 * Page Monitor and Manager export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_PGM_GC
# define PGMGCDECL(type)    DECLEXPORT(type) VBOXCALL
#else
01094 # define PGMGCDECL(type)    DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_PGM_R0
 * Used to indicate whether we're inside the same link module as the R0
 * Page Monitor and Manager.
 */
/** @def PGMR0DECL(type)
 * Page Monitor and Manager export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_PGM_R0
# define PGMR0DECL(type)    DECLEXPORT(type) VBOXCALL
#else
01108 # define PGMR0DECL(type)    DECLIMPORT(type) VBOXCALL
#endif

/** @def PGMDECL(type)
 * Page Monitor and Manager export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#if defined(IN_PGM_R3) || defined(IN_PGM_R0) || defined(IN_PGM_GC)
# define PGMDECL(type)      DECLEXPORT(type) VBOXCALL
#else
01118 # define PGMDECL(type)      DECLIMPORT(type) VBOXCALL
#endif


/** @def IN_DBGF_R3
 * Used to indicate whether we're inside the same link module as the Ring 3
 * Debugging Facility.
 */
/** @def DBGFR3DECL(type)
 * R3 Debugging Facility export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_DBGF_R3
# define DBGFR3DECL(type)   DECLEXPORT(type) VBOXCALL
#else
01133 # define DBGFR3DECL(type)   DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_DBGF_R0
 * Used to indicate whether we're inside the same link module as the Ring 0
 * Debugging Facility.
 */
/** @def DBGFR0DECL(type)
 * R0 Debugging Facility export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_DBGF_R0
# define DBGFR0DECL(type)   DECLEXPORT(type) VBOXCALL
#else
01147 # define DBGFR0DECL(type)   DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_DBGF_GC
 * Used to indicate whether we're inside the same link module as the GC
 * Debugging Facility.
 */
/** @def DBGFGCDECL(type)
 * GC Debugging Facility export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_DBGF_GC
# define DBGFGCDECL(type)   DECLEXPORT(type) VBOXCALL
#else
# define DBGFGCDECL(type)   DECLIMPORT(type) VBOXCALL
#endif

/** @def DBGFGCDECL(type)
 * Debugging Facility export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#if defined(IN_DBGF_R3) || defined(IN_DBGF_R0) || defined(IN_DBGF_GC)
# define DBGFDECL(type)     DECLEXPORT(type) VBOXCALL
#else
# define DBGFDECL(type)     DECLIMPORT(type) VBOXCALL
#endif



/** @def IN_SSM_R3
 * Used to indicate whether we're inside the same link module as the Ring 3
 * Saved State Manager.
 */
/** @def SSMR3DECL(type)
 * R3 Saved State export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_SSM_R3
# define SSMR3DECL(type)    DECLEXPORT(type) VBOXCALL
#else
01187 # define SSMR3DECL(type)    DECLIMPORT(type) VBOXCALL
#endif



/** @def IN_STAM_R3
 * Used to indicate whether we're inside the same link module as the Ring 3
 * Statistics Manager.
 */
/** @def STAMR3DECL(type)
 * R3 Statistics Manager export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_STAM_R3
# define STAMR3DECL(type)   DECLEXPORT(type) VBOXCALL
#else
01203 # define STAMR3DECL(type)   DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_STAM_R0
 * Used to indicate whether we're inside the same link module as the Ring 0
 * Statistics Manager.
 */
/** @def STAMR0DECL(type)
 * R0 Statistics Manager export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_STAM_R0
# define STAMR0DECL(type)   DECLEXPORT(type) VBOXCALL
#else
01217 # define STAMR0DECL(type)   DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_STAM_GC
 * Used to indicate whether we're inside the same link module as the GC
 * Statistics Manager.
 */
/** @def STAMGCDECL(type)
 * GC Statistics Manager export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_STAM_GC
# define STAMGCDECL(type)   DECLEXPORT(type) VBOXCALL
#else
# define STAMGCDECL(type)   DECLIMPORT(type) VBOXCALL
#endif

/** @def STAMGCDECL(type)
 * Debugging Facility export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#if defined(IN_STAM_R3) || defined(IN_STAM_R0) || defined(IN_STAM_GC)
# define STAMDECL(type)     DECLEXPORT(type) VBOXCALL
#else
# define STAMDECL(type)     DECLIMPORT(type) VBOXCALL
#endif



/** @def IN_EM_R3
 * Used to indicate whether we're inside the same link module as the Ring 3
 * Execution Monitor.
 */
/** @def EMR3DECL(type)
 * Execution Monitor export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_EM_R3
# define EMR3DECL(type)     DECLEXPORT(type) VBOXCALL
#else
01257 # define EMR3DECL(type)     DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_EM_GC
 * Used to indicate whether we're inside the same link module as the GC
 * Execution Monitor.
 */
/** @def EMGCDECL(type)
 * Execution Monitor export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_EM_GC
# define EMGCDECL(type)     DECLEXPORT(type) VBOXCALL
#else
01271 # define EMGCDECL(type)     DECLIMPORT(type) VBOXCALL
#endif


/** @def EMDECL(type)
 * Execution Monitor export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#if defined(IN_EM_R3) || defined(IN_EM_GC) || defined(IN_EM_R0)
# define EMDECL(type)       DECLEXPORT(type) VBOXCALL
#else
01282 # define EMDECL(type)       DECLIMPORT(type) VBOXCALL
#endif


/** @def IN_IDE_R3
 * Used to indicate whether we're inside the same link module as the Ring 3
 * IDE device.
 */
/** @def IDER3DECL(type)
 * Ring-3 IDE device export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_IDE_R3
# define IDER3DECL(type)    DECLEXPORT(type) VBOXCALL
#else
01297 # define IDER3DECL(type)    DECLIMPORT(type) VBOXCALL
#endif


/** @def IN_VBOXDDU
 * Used to indicate whether we're inside the VBoxDDU shared object.
 */
/** @def VBOXDDU_DECL(type)
 * VBoxDDU export or import (ring-3).
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_VBOXDDU
# define VBOXDDU_DECL(type) DECLEXPORT(type) VBOXCALL
#else
01311 # define VBOXDDU_DECL(type) DECLIMPORT(type) VBOXCALL
#endif



/** @def IN_REM_R0
 * Used to indicate whether we're inside the same link module as
 * the HC Ring-0 Recompiled Execution Manager.
 */
/** @def REMR0DECL(type)
 * Recompiled Execution Manager HC Ring-0 export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_REM_R0
# define REMR0DECL(type)    DECLEXPORT(type) VBOXCALL
#else
01327 # define REMR0DECL(type)    DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_RT_R3
 * Used to indicate whether we're inside the same link module as
 * the HC Ring-3 Recompiled Execution Manager.
 */
/** @def RTR3DECL(type)
 * Recompiled Execution Manager HC Ring-3 export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_REM_R3
# define REMR3DECL(type)    DECLEXPORT(type) VBOXCALL
#else
# define REMR3DECL(type)    DECLIMPORT(type) VBOXCALL
#endif

/** @def IN_REM_GC
 * Used to indicate whether we're inside the same link module as
 * the GC Recompiled Execution Manager.
 */
/** @def REMGCDECL(type)
 * Recompiled Execution Manager HC Ring-3 export or import declaration.
 * @param   type    The return type of the function declaration.
 */
#ifdef IN_REM_GC
# define REMGCDECL(type)    DECLEXPORT(type) VBOXCALL
#else
01355 # define REMGCDECL(type)    DECLIMPORT(type) VBOXCALL
#endif

/** @def REMDECL(type)
 * Recompiled Execution Manager export or import declaration.
 * Functions declared using this macro exists in all contexts.
 * @param   type    The return type of the function declaration.
 */
#if defined(IN_REM_R3) || defined(IN_REM_GC) || defined(IN_REM_R0)
# define REMDECL(type)      DECLEXPORT(type) VBOXCALL
#else
01366 # define REMDECL(type)      DECLIMPORT(type) VBOXCALL
#endif




/** @def DBGDECL(type)
 * Debugger module export or import declaration.
 * Functions declared using this exists only in R3 since the
 * debugger modules is R3 only.
 * @param   type    The return type of the function declaration.
 */
#if defined(IN_DBG_R3) || defined(IN_DBG)
# define DBGDECL(type)       DECLEXPORT(type) VBOXCALL
#else
01381 # define DBGDECL(type)       DECLIMPORT(type) VBOXCALL
#endif


/** @def NoDmik(expr)
 * Turns the given expression into NOOP when DEBUG_dmik is defined. Evaluates
 * the expression normally otherwise.
 * @param expr  Expression to guard.
 */
#if defined(DEBUG_dmik)
# define NOT_DMIK(expr)     do { } while (0)
#else
# define NOT_DMIK(expr)     expr
#endif


#endif


Generated by  Doxygen 1.6.0   Back to index