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

types.h

Go to the documentation of this file.
/** @file
 * VirtualBox - Types.
 */

/*
 * Copyright (C) 2006-2007 innotek GmbH
 *
 * 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 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.
 */

#ifndef ___VBox_types_h
#define ___VBox_types_h

#include <VBox/cdefs.h>
#include <iprt/types.h>


/** @defgroup grp_types     Basic VBox Types
 * @{
 */


/** @defgroup grp_types_both  Common Guest and Host Context Basic Types
 * @ingroup grp_types
 * @{
 */


/** @defgroup grp_types_hc  Host Context Basic Types
 * @ingroup grp_types_both
 * @{
 */

/** @deprecated
 * @{ */
00042 typedef RTHCPHYS    VBOXHCPHYS;
typedef VBOXHCPHYS *PVBOXHCPHYS;
#define NILVBOXHCPHYS NIL_RTHCPHYS
typedef RTHCPTR     VBOXHCPTR;
typedef VBOXHCPTR  *PVBOXHCPTR;
/** @} */

/** @} */


/** @defgroup grp_types_gc  Guest Context Basic Types
 * @ingroup grp_types_both
 * @{
 */

/** @deprecated
 * @{ */
00059 typedef RTGCPHYS    VBOXGCPHYS;
typedef VBOXGCPHYS *PVBOXGCPHYS;
#define NILVBOXGCPHYS NIL_RTGCPHYS
typedef RTGCPTR     VBOXGCPTR;
typedef VBOXGCPTR  *PVBOXGCPTR;
/** @} */

/** @} */


/** Pointer to per support driver session data.
 * (The data is a R0 entity and private to the the R0 SUP part. All
 * other should consider this a sort of handle.) */
typedef R0PTRTYPE(struct SUPDRVSESSION *) PSUPDRVSESSION;

/** Pointer to a VM. */
00075 typedef struct VM              *PVM;
/** Pointer to a VM - Ring-0 Ptr. */
typedef R0PTRTYPE(struct VM *)  PVMR0;
/** Pointer to a VM - Ring-3 Ptr. */
typedef R3PTRTYPE(struct VM *)  PVMR3;
/** Pointer to a VM - GC Ptr. */
typedef GCPTRTYPE(struct VM *)  PVMGC;


/** VM State
 */
00086 typedef enum VMSTATE
{
    /** The VM is being created. */
00089     VMSTATE_CREATING = 0,
    /** The VM is created. */
00091     VMSTATE_CREATED,
    /** The VM is runnning. */
00093     VMSTATE_RUNNING,
    /** The VM state is being loaded from file. */
00095     VMSTATE_LOADING,
    /** The VM is screwed because of a failed state loading. */
00097     VMSTATE_LOAD_FAILURE,
    /** The VM state is being saved to file. */
00099     VMSTATE_SAVING,
    /** The VM is suspended. */
00101     VMSTATE_SUSPENDED,
    /** The VM is being reset. */
00103     VMSTATE_RESETTING,
    /** The VM is in guru meditation over a fatal failure. */
00105     VMSTATE_GURU_MEDITATION,
    /** The VM is switched off, awaiting destruction. */
00107     VMSTATE_OFF,
    /** The VM is being destroyed. */
00109     VMSTATE_DESTROYING,
    /** Terminated. */
00111     VMSTATE_TERMINATED,
    /** hack forcing the size of the enum to 32-bits. */
00113     VMSTATE_MAKE_32BIT_HACK = 0x7fffffff
} VMSTATE;


/** Pointer to a PDM Driver Base Interface. */
00118 typedef struct PDMIBASE *PPDMIBASE;
/** Pointer to a pointer to a PDM Driver Base Interface. */
00120 typedef PPDMIBASE *PPPDMIBASE;

/** Pointer to a PDM Device Instance. */
00123 typedef struct PDMDEVINS *PPDMDEVINS;
/** Pointer to a pointer to a PDM Device Instance. */
00125 typedef PPDMDEVINS *PPPDMDEVINS;
/** HC pointer to a PDM Device Instance.
 * @deprecated */
typedef HCPTRTYPE(PPDMDEVINS) PPDMDEVINSHC;
/** R3 pointer to a PDM Device Instance. */
typedef R3PTRTYPE(PPDMDEVINS) PPDMDEVINSR3;
/** R0 pointer to a PDM Device Instance. */
typedef R0PTRTYPE(PPDMDEVINS) PPDMDEVINSR0;
/** GC pointer to a PDM Device Instance. */
typedef GCPTRTYPE(PPDMDEVINS) PPDMDEVINSGC;

/** Pointer to a PDM USB Device Instance. */
00137 typedef struct PDMUSBINS *PPDMUSBINS;
/** Pointer to a pointer to a PDM USB Device Instance. */
00139 typedef PPDMUSBINS *PPPDMUSBINS;

/** Pointer to a PDM Driver Instance. */
00142 typedef struct PDMDRVINS *PPDMDRVINS;
/** Pointer to a pointer to a PDM Driver Instance. */
00144 typedef PPDMDRVINS *PPPDMDRVINS;

/** Pointer to a PDM Service Instance. */
00147 typedef struct PDMSRVINS *PPDMSRVINS;
/** Pointer to a pointer to a PDM Service Instance. */
00149 typedef PPDMSRVINS *PPPDMSRVINS;

/** HC pointer to a timer.
 * @deprecated */
typedef HCPTRTYPE(struct TMTIMER *) PTMTIMERHC;
/** Pointer to a HC pointer to a timer.
 * @deprecated */
00156 typedef PTMTIMERHC *PPTMTIMERHC;

/** R3 pointer to a timer. */
typedef R3PTRTYPE(struct TMTIMER *) PTMTIMERR3;
/** Pointer to a R3 pointer to a timer. */
00161 typedef PTMTIMERR3 *PPTMTIMERR3;

/** R0 pointer to a timer. */
typedef R0PTRTYPE(struct TMTIMER *) PTMTIMERR0;
/** Pointer to a R3 pointer to a timer. */
00166 typedef PTMTIMERR0 *PPTMTIMERR0;

/** GC pointer to a timer. */
typedef GCPTRTYPE(struct TMTIMER *) PTMTIMERGC;
/** Pointer to a GC pointer to a timer. */
00171 typedef PTMTIMERGC *PPTMTIMERGC;

/** Pointer to a timer. */
typedef CTXSUFF(PTMTIMER)   PTMTIMER;
/** Pointer to a pointer to a timer. */
typedef CTXSUFF(PPTMTIMER)  PPTMTIMER;

/** SSM Operation handle. */
00179 typedef struct SSMHANDLE *PSSMHANDLE;

/** @} */


/** @defgroup grp_types_idt     Interrupt Descriptor Table Entry.
 * @ingroup grp_types
 * @todo This all belongs in x86.h!
 * @{ */

/** @todo VBOXIDT -> VBOXDESCIDT, skip the complex variations. We'll never use them. */

/** IDT Entry, Task Gate view. */
#pragma pack(1)                         /* paranoia */
00193 typedef struct VBOXIDTE_TASKGATE
{
    /** Reserved. */
00196     unsigned    u16Reserved1 : 16;
    /** Task Segment Selector. */
00198     unsigned    u16TSS : 16;
    /** More reserved. */
00200     unsigned    u8Reserved2 : 8;
    /** Fixed value bit 0 - Set to 1. */
00202     unsigned    u1Fixed0 : 1;
    /** Busy bit. */
00204     unsigned    u1Busy : 1;
    /** Fixed value bit 2 - Set to 1. */
00206     unsigned    u1Fixed1 : 1;
    /** Fixed value bit 3 - Set to 0. */
00208     unsigned    u1Fixed2: 1;
    /** Fixed value bit 4 - Set to 0. */
00210     unsigned    u1Fixed3 : 1;
    /** Descriptor Privilege level. */
00212     unsigned    u2DPL : 2;
    /** Present flag. */
00214     unsigned    u1Present : 1;
    /** Reserved. */
00216     unsigned    u16Reserved3 : 16;
} VBOXIDTE_TASKGATE;
#pragma pack()
/** Pointer to IDT Entry, Task gate view. */
00220 typedef VBOXIDTE_TASKGATE *PVBOXIDTE_TASKGATE;


/** IDT Entry, Intertupt gate view. */
#pragma pack(1)                         /* paranoia */
00225 typedef struct VBOXIDTE_INTERRUPTGATE
{
    /** Low offset word. */
00228     unsigned    u16OffsetLow : 16;
    /** Segment Selector. */
00230     unsigned    u16SegSel : 16;
    /** Reserved. */
00232     unsigned    u5Reserved2 : 5;
    /** Fixed value bit 0 - Set to 0. */
00234     unsigned    u1Fixed0 : 1;
    /** Fixed value bit 1 - Set to 0. */
00236     unsigned    u1Fixed1 : 1;
    /** Fixed value bit 2 - Set to 0. */
00238     unsigned    u1Fixed2 : 1;
    /** Fixed value bit 3 - Set to 0. */
00240     unsigned    u1Fixed3: 1;
    /** Fixed value bit 4 - Set to 1. */
00242     unsigned    u1Fixed4 : 1;
    /** Fixed value bit 5 - Set to 1. */
00244     unsigned    u1Fixed5 : 1;
    /** Gate size, 1 = 32 bits, 0 = 16 bits. */
00246     unsigned    u132BitGate : 1;
    /** Fixed value bit 5 - Set to 0. */
00248     unsigned    u1Fixed6 : 1;
    /** Descriptor Privilege level. */
00250     unsigned    u2DPL : 2;
    /** Present flag. */
00252     unsigned    u1Present : 1;
    /** High offset word. */
00254     unsigned    u16OffsetHigh : 16;
} VBOXIDTE_INTERRUPTGATE;
#pragma pack()
/** Pointer to IDT Entry, Interrupt gate view. */
00258 typedef  VBOXIDTE_INTERRUPTGATE *PVBOXIDTE_INTERRUPTGATE;

/** IDT Entry, Trap Gate view. */
#pragma pack(1)                         /* paranoia */
00262 typedef struct VBOXIDTE_TRAPGATE
{
    /** Low offset word. */
00265     unsigned    u16OffsetLow : 16;
    /** Segment Selector. */
00267     unsigned    u16SegSel : 16;
    /** Reserved. */
00269     unsigned    u5Reserved2 : 5;
    /** Fixed value bit 0 - Set to 0. */
00271     unsigned    u1Fixed0 : 1;
    /** Fixed value bit 1 - Set to 0. */
00273     unsigned    u1Fixed1 : 1;
    /** Fixed value bit 2 - Set to 0. */
00275     unsigned    u1Fixed2 : 1;
    /** Fixed value bit 3 - Set to 1. */
00277     unsigned    u1Fixed3: 1;
    /** Fixed value bit 4 - Set to 1. */
00279     unsigned    u1Fixed4 : 1;
    /** Fixed value bit 5 - Set to 1. */
00281     unsigned    u1Fixed5 : 1;
    /** Gate size, 1 = 32 bits, 0 = 16 bits. */
00283     unsigned    u132BitGate : 1;
    /** Fixed value bit 5 - Set to 0. */
00285     unsigned    u1Fixed6 : 1;
    /** Descriptor Privilege level. */
00287     unsigned    u2DPL : 2;
    /** Present flag. */
00289     unsigned    u1Present : 1;
    /** High offset word. */
00291     unsigned    u16OffsetHigh : 16;
} VBOXIDTE_TRAPGATE;
#pragma pack()
/** Pointer to IDT Entry, Trap Gate view. */
00295 typedef VBOXIDTE_TRAPGATE *PVBOXIDTE_TRAPGATE;

/** IDT Entry Generic view. */
#pragma pack(1)                         /* paranoia */
00299 typedef struct VBOXIDTE_GENERIC
{
    /** Low offset word. */
00302     unsigned    u16OffsetLow : 16;
    /** Segment Selector. */
00304     unsigned    u16SegSel : 16;
    /** Reserved. */
00306     unsigned    u5Reserved : 5;
    /** IDT Type part one (not used for task gate). */
00308     unsigned    u3Type1 : 3;
    /** IDT Type part two. */
00310     unsigned    u5Type2 : 5;
    /** Descriptor Privilege level. */
00312     unsigned    u2DPL : 2;
    /** Present flag. */
00314     unsigned    u1Present : 1;
    /** High offset word. */
00316     unsigned    u16OffsetHigh : 16;
} VBOXIDTE_GENERIC;
#pragma pack()
/** Pointer to IDT Entry Generic view. */
00320 typedef VBOXIDTE_GENERIC *PVBOXIDTE_GENERIC;

/** IDT Type1 value. (Reserved for task gate!) */
00323 #define VBOX_IDTE_TYPE1             0
/** IDT Type2 value - Task gate. */
00325 #define VBOX_IDTE_TYPE2_TASK        0x5
/** IDT Type2 value - 16 bit interrupt gate. */
00327 #define VBOX_IDTE_TYPE2_INT_16      0x6
/** IDT Type2 value - 32 bit interrupt gate. */
00329 #define VBOX_IDTE_TYPE2_INT_32      0xe
/** IDT Type2 value - 16 bit trap gate. */
00331 #define VBOX_IDTE_TYPE2_TRAP_16     0x7
/** IDT Type2 value - 32 bit trap gate. */
00333 #define VBOX_IDTE_TYPE2_TRAP_32     0xf

/** IDT Entry. */
#pragma pack(1)                         /* paranoia */
00337 typedef union VBOXIDTE
{
    /** Task gate view. */
00340     VBOXIDTE_TASKGATE       Task;
    /** Trap gate view. */
00342     VBOXIDTE_TRAPGATE       Trap;
    /** Interrupt gate view. */
00344     VBOXIDTE_INTERRUPTGATE  Int;
    /** Generic IDT view. */
00346     VBOXIDTE_GENERIC        Gen;

    /** 8 bit unsigned integer view. */
00349     uint8_t     au8[8];
    /** 16 bit unsigned integer view. */
00351     uint16_t    au16[4];
    /** 32 bit unsigned integer view. */
00353     uint32_t    au32[2];
    /** 64 bit unsigned integer view. */
00355     uint64_t    au64;
} VBOXIDTE;
#pragma pack()
/** Pointer to IDT Entry. */
00359 typedef VBOXIDTE *PVBOXIDTE;

#pragma pack(1)
/** IDTR */
00363 typedef struct VBOXIDTR
{
    /** Size of the IDT. */
00366     uint16_t    cbIdt;
    /** Address of the IDT. */
00368     uint32_t    pIdt;
} VBOXIDTR, *PVBOXIDTR;
#pragma pack()
/** @} */


/** @defgroup grp_types_desc    Descriptor Table Entry.
 * @ingroup grp_types
 * @{ */

#pragma pack(1)
/**
 * Memory descriptor.
 */
00382 typedef struct VBOXDESCGENERIC
{
    /**  0-15 - Limit - Low word. */
00385     unsigned    u16LimitLow : 16;
    /** 16-31 - Base address - lowe word.
     * Don't try set this to 24 because MSC is doing studing things then. */
00388     unsigned    u16BaseLow : 16;
    /** 32-39 - Base address - first 8 bits of high word. */
00390     unsigned    u8BaseHigh1 : 8;
    /** 40-43 - Segment Type. */
00392     unsigned    u4Type : 4;
    /** 44    - Descriptor Type. System(=0) or code/data selector */
00394     unsigned    u1DescType : 1;
    /** 45-46 - Descriptor Privelege level. */
00396     unsigned    u2Dpl : 2;
    /** 47    - Flags selector present(=1) or not. */
00398     unsigned    u1Present : 1;
    /** 48-51 - Segment limit 16-19. */
00400     unsigned    u4LimitHigh : 4;
    /** 52    - Available for system software. */
00402     unsigned    u1Available : 1;
    /** 53    - Reserved - 0. In long mode this is the 'Long' (L) attribute bit. */
00404     unsigned    u1Reserved : 1;
    /** 54    - This flags meaning depends on the segment type. Try make sense out
     * of the intel manual yourself.  */
00407     unsigned    u1DefBig : 1;
    /** 55    - Granularity of the limit. If set 4KB granularity is used, if
     * clear byte. */
00410     unsigned    u1Granularity : 1;
    /** 56-63 - Base address - highest 8 bits. */
00412     unsigned    u8BaseHigh2 : 8;
} VBOXDESCGENERIC;
#pragma pack()
/** Pointer to a generic descriptor entry. */
00416 typedef VBOXDESCGENERIC *PVBOXDESCGENERIC;

#pragma pack(1)
/**
 * Descriptor table entry.
 */
00422 typedef union VBOXDESC
{
    /** Generic descriptor view. */
00425     VBOXDESCGENERIC Gen;
    /** IDT view. */
00427     VBOXIDTE        Idt;

    /** 8 bit unsigned interger view. */
00430     uint8_t         au8[8];
    /** 16 bit unsigned interger view. */
00432     uint16_t        au16[4];
    /** 32 bit unsigned interger view. */
00434     uint32_t        au32[2];
} VBOXDESC;
#pragma pack()
/** Pointer to descriptor table entry. */
00438 typedef VBOXDESC *PVBOXDESC;
/** Pointer to const descriptor table entry. */
00440 typedef VBOXDESC const *PCVBOXDESC;


#pragma pack(1)
/** GDTR */
00445 typedef struct VBOXGDTR
{
    /** Size of the GDT. */
00448     uint16_t    cbGdt;
    /** Address of the GDT. */
00450     uint32_t    pGdt;
} VBOXGDTR;
#pragma pack()
/** Pointer to GDTR. */
00454 typedef VBOXGDTR *PVBOXGDTR;

/** @} */


/** @defgroup grp_types_pg  Page Structures
 * @ingroup grp_types
 * @{
 */

/** These absolete / belong to PGM. Use VBox/x86.h structs everywhere else. */
00465 #define VBOXPTE     X86PTE
#define PVBOXPTE    PX86PTE
#define VBOXPT      X86PT
#define PVBOXPT     PX86PT
#define VBOXPDE     X86PDE
#define PVBOXPDE    PX86PDE
#define VBOXPD      X86PD
#define PVBOXPD     PX86PD

/** @} */



/**
 * Task Segment
 */
#pragma pack(1)
00482 typedef struct VBOXTSS
{
    /** Back link to previous task. (static) */
00485     RTSEL       selPrev;
    uint16_t    padding1;
    /** Ring-0 stack pointer. (static) */
00488     uint32_t    esp0;
    /** Ring-0 stack segment. (static) */
00490     RTSEL       ss0;
    uint16_t    padding_ss0;
    /** Ring-1 stack pointer. (static) */
00493     uint32_t    esp1;
    /** Ring-1 stack segment. (static) */
00495     RTSEL       ss1;
    uint16_t    padding_ss1;
    /** Ring-2 stack pointer. (static) */
00498     uint32_t    esp2;
    /** Ring-2 stack segment. (static) */
00500     RTSEL       ss2;
    uint16_t    padding_ss2;
    /** Page directory for the task. (static) */
00503     uint32_t    cr3;
    /** EIP before task switch. */
00505     uint32_t    eip;
    /** EFLAGS before task switch. */
00507     uint32_t    eflags;
    /** EAX before task switch. */
00509     uint32_t    eax;
    /** ECX before task switch. */
00511     uint32_t    ecx;
    /** EDX before task switch. */
00513     uint32_t    edx;
    /** EBX before task switch. */
00515     uint32_t    ebx;
    /** ESP before task switch. */
00517     uint32_t    esp;
    /** EBP before task switch. */
00519     uint32_t    ebp;
    /** ESI before task switch. */
00521     uint32_t    esi;
    /** EDI before task switch. */
00523     uint32_t    edi;
    /** ES before task switch. */
00525     RTSEL       es;
    uint16_t    padding_es;
    /** CS before task switch. */
00528     RTSEL       cs;
    uint16_t    padding_cs;
    /** SS before task switch. */
00531     RTSEL       ss;
    uint16_t    padding_ss;
    /** DS before task switch. */
00534     RTSEL       ds;
    uint16_t    padding_ds;
    /** FS before task switch. */
00537     RTSEL       fs;
    uint16_t    padding_fs;
    /** GS before task switch. */
00540     RTSEL       gs;
    uint16_t    padding_gs;
    /** LDTR before task switch. */
00543     RTSEL       selLdt;
    uint16_t    padding_ldt;
    /** Debug trap flag */
00546     uint16_t    fDebugTrap;
    /** Offset relative to the TSS of the start of the I/O Bitmap
     * and the end of the interrupt redirection bitmap. */
00549     uint16_t    offIoBitmap;
    /** 32 bytes for the virtual interrupt redirection bitmap. (VME) */
00551     uint8_t     IntRedirBitmap[32];
} VBOXTSS;
#pragma pack()
/** Pointer to task segment. */
00555 typedef VBOXTSS *PVBOXTSS;
/** Pointer to const task segment. */
00557 typedef const VBOXTSS *PCVBOXTSS;


/** @} */

#endif

Generated by  Doxygen 1.6.0   Back to index