types.h revision 21974606707d360439c47381c6ed866e18631feb
42576743851c3c956ad7e867e74df1084c30d434vboxsync/** @file
42576743851c3c956ad7e867e74df1084c30d434vboxsync * VirtualBox - Types.
42576743851c3c956ad7e867e74df1084c30d434vboxsync */
42576743851c3c956ad7e867e74df1084c30d434vboxsync
42576743851c3c956ad7e867e74df1084c30d434vboxsync/*
42576743851c3c956ad7e867e74df1084c30d434vboxsync * Copyright (C) 2006-2007 Oracle Corporation
42576743851c3c956ad7e867e74df1084c30d434vboxsync *
42576743851c3c956ad7e867e74df1084c30d434vboxsync * This file is part of VirtualBox Open Source Edition (OSE), as
42576743851c3c956ad7e867e74df1084c30d434vboxsync * available from http://www.virtualbox.org. This file is free software;
42576743851c3c956ad7e867e74df1084c30d434vboxsync * you can redistribute it and/or modify it under the terms of the GNU
42576743851c3c956ad7e867e74df1084c30d434vboxsync * General Public License (GPL) as published by the Free Software
42576743851c3c956ad7e867e74df1084c30d434vboxsync * Foundation, in version 2 as it comes in the "COPYING" file of the
42576743851c3c956ad7e867e74df1084c30d434vboxsync * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
42576743851c3c956ad7e867e74df1084c30d434vboxsync * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
42576743851c3c956ad7e867e74df1084c30d434vboxsync *
42576743851c3c956ad7e867e74df1084c30d434vboxsync * The contents of this file may alternatively be used under the terms
42576743851c3c956ad7e867e74df1084c30d434vboxsync * of the Common Development and Distribution License Version 1.0
42576743851c3c956ad7e867e74df1084c30d434vboxsync * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
42576743851c3c956ad7e867e74df1084c30d434vboxsync * VirtualBox OSE distribution, in which case the provisions of the
42576743851c3c956ad7e867e74df1084c30d434vboxsync * CDDL are applicable instead of those of the GPL.
42576743851c3c956ad7e867e74df1084c30d434vboxsync *
42576743851c3c956ad7e867e74df1084c30d434vboxsync * You may elect to license modified versions of this file under the
42576743851c3c956ad7e867e74df1084c30d434vboxsync * terms and conditions of either the GPL or the CDDL or both.
42576743851c3c956ad7e867e74df1084c30d434vboxsync */
42576743851c3c956ad7e867e74df1084c30d434vboxsync
42576743851c3c956ad7e867e74df1084c30d434vboxsync#ifndef ___VBox_types_h
42576743851c3c956ad7e867e74df1084c30d434vboxsync#define ___VBox_types_h
42576743851c3c956ad7e867e74df1084c30d434vboxsync
42576743851c3c956ad7e867e74df1084c30d434vboxsync#include <VBox/cdefs.h>
42576743851c3c956ad7e867e74df1084c30d434vboxsync#include <iprt/types.h>
42576743851c3c956ad7e867e74df1084c30d434vboxsync
42576743851c3c956ad7e867e74df1084c30d434vboxsync
42576743851c3c956ad7e867e74df1084c30d434vboxsync/** @defgroup grp_types Basic VBox Types
42576743851c3c956ad7e867e74df1084c30d434vboxsync * @{
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync */
42576743851c3c956ad7e867e74df1084c30d434vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** @defgroup grp_types_both Common Guest and Host Context Basic Types
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync * @ingroup grp_types
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync * @{
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** @defgroup grp_types_hc Host Context Basic Types
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync * @ingroup grp_types_both
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync * @{
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync */
42576743851c3c956ad7e867e74df1084c30d434vboxsync
42576743851c3c956ad7e867e74df1084c30d434vboxsync/** @} */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync/** @defgroup grp_types_gc Guest Context Basic Types
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync * @ingroup grp_types_both
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync * @{
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync/** @} */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync/** Pointer to per support driver session data.
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync * (The data is a R0 entity and private to the the R0 SUP part. All
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync * other should consider this a sort of handle.) */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsynctypedef R0PTRTYPE(struct SUPDRVSESSION *) PSUPDRVSESSION;
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync/** Pointer to a VM. */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsynctypedef struct VM *PVM;
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync/** Pointer to a VM - Ring-0 Ptr. */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsynctypedef R0PTRTYPE(struct VM *) PVMR0;
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync/** Pointer to a VM - Ring-3 Ptr. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef R3PTRTYPE(struct VM *) PVMR3;
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync/** Pointer to a VM - RC Ptr. */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsynctypedef RCPTRTYPE(struct VM *) PVMRC;
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to a virtual CPU structure. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef struct VMCPU * PVMCPU;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to a virtual CPU structure - Ring-3 Ptr. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef R3PTRTYPE(struct VMCPU *) PVMCPUR3;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to a virtual CPU structure - Ring-0 Ptr. */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsynctypedef R0PTRTYPE(struct VMCPU *) PVMCPUR0;
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync/** Pointer to a virtual CPU structure - RC Ptr. */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsynctypedef RCPTRTYPE(struct VMCPU *) PVMCPURC;
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to a ring-0 (global) VM structure. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef R0PTRTYPE(struct GVM *) PGVM;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to a ring-3 (user mode) VM structure. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef R3PTRTYPE(struct UVM *) PUVM;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to a ring-3 (user mode) VMCPU structure. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef R3PTRTYPE(struct UVMCPU *) PUVMCPU;
42576743851c3c956ad7e867e74df1084c30d434vboxsync
42576743851c3c956ad7e867e74df1084c30d434vboxsync/** Virtual CPU ID. */
42576743851c3c956ad7e867e74df1084c30d434vboxsynctypedef uint32_t VMCPUID;
42576743851c3c956ad7e867e74df1084c30d434vboxsync/** Pointer to a virtual CPU ID. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef VMCPUID *PVMCPUID;
42576743851c3c956ad7e867e74df1084c30d434vboxsync/** @name Special CPU ID values.
42576743851c3c956ad7e867e74df1084c30d434vboxsync * Most of these are for request scheduling.
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync *
42576743851c3c956ad7e867e74df1084c30d434vboxsync * @{ */
a5af4f8add719046631d3d68734b9b6d9ca9d046vboxsync/** All virtual CPUs. */
a5af4f8add719046631d3d68734b9b6d9ca9d046vboxsync#define VMCPUID_ALL UINT32_C(0xfffffff2)
42576743851c3c956ad7e867e74df1084c30d434vboxsync/** All virtual CPUs, descending order. */
42576743851c3c956ad7e867e74df1084c30d434vboxsync#define VMCPUID_ALL_REVERSE UINT32_C(0xfffffff3)
42576743851c3c956ad7e867e74df1084c30d434vboxsync/** Any virtual CPU.
42576743851c3c956ad7e867e74df1084c30d434vboxsync * Intended for scheduling a VM request or some other task. */
42576743851c3c956ad7e867e74df1084c30d434vboxsync#define VMCPUID_ANY UINT32_C(0xfffffff4)
42576743851c3c956ad7e867e74df1084c30d434vboxsync/** Any virtual CPU; always queue for future execution.
42576743851c3c956ad7e867e74df1084c30d434vboxsync * Intended for scheduling a VM request or some other task. */
42576743851c3c956ad7e867e74df1084c30d434vboxsync#define VMCPUID_ANY_QUEUE UINT32_C(0xfffffff5)
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync/** The NIL value. */
42576743851c3c956ad7e867e74df1084c30d434vboxsync#define NIL_VMCPUID UINT32_C(0xfffffffd)
42576743851c3c956ad7e867e74df1084c30d434vboxsync/** @} */
42576743851c3c956ad7e867e74df1084c30d434vboxsync
42576743851c3c956ad7e867e74df1084c30d434vboxsync/**
42576743851c3c956ad7e867e74df1084c30d434vboxsync * Virtual CPU set.
42576743851c3c956ad7e867e74df1084c30d434vboxsync */
42576743851c3c956ad7e867e74df1084c30d434vboxsynctypedef struct VMCPUSET
42576743851c3c956ad7e867e74df1084c30d434vboxsync{
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync /** The bitmap data. */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync uint32_t au32Bitmap[256/32];
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync} VMCPUSET;
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync/** Pointer to a Virtual CPU set. */
42576743851c3c956ad7e867e74df1084c30d434vboxsynctypedef VMCPUSET *PVMCPUSET;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to a const Virtual CPU set. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef VMCPUSET const *PCVMCPUSET;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
42576743851c3c956ad7e867e74df1084c30d434vboxsync/** Tests if a valid CPU ID is present in the set.. */
42576743851c3c956ad7e867e74df1084c30d434vboxsync#define VMCPUSET_IS_PRESENT(pSet, idCpu) ASMBitTest( &(pSet)->au32Bitmap, (idCpu))
42576743851c3c956ad7e867e74df1084c30d434vboxsync/** Adds a CPU to the set. */
42576743851c3c956ad7e867e74df1084c30d434vboxsync#define VMCPUSET_ADD(pSet, idCpu) ASMBitSet( &(pSet)->au32Bitmap, (idCpu))
a5af4f8add719046631d3d68734b9b6d9ca9d046vboxsync/** Deletes a CPU from the set. */
42576743851c3c956ad7e867e74df1084c30d434vboxsync#define VMCPUSET_DEL(pSet, idCpu) ASMBitClear(&(pSet)->au32Bitmap, (idCpu))
42576743851c3c956ad7e867e74df1084c30d434vboxsync/** Empties the set. */
42576743851c3c956ad7e867e74df1084c30d434vboxsync#define VMCPUSET_EMPTY(pSet) memset(&(pSet)->au32Bitmap[0], '\0', sizeof((pSet)->au32Bitmap))
42576743851c3c956ad7e867e74df1084c30d434vboxsync/** Filles the set. */
42576743851c3c956ad7e867e74df1084c30d434vboxsync#define VMCPUSET_FILL(pSet) memset(&(pSet)->au32Bitmap[0], 0xff, sizeof((pSet)->au32Bitmap))
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Filles the set. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync#define VMCPUSET_IS_EQUAL(pSet1, pSet2) (memcmp(&(pSet1)->au32Bitmap[0], &(pSet2)->au32Bitmap[0], sizeof((pSet1)->au32Bitmap)) == 0)
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/**
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync * VM State
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef enum VMSTATE
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync{
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** The VM is being created. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync VMSTATE_CREATING = 0,
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** The VM is created. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync VMSTATE_CREATED,
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** The VM state is being loaded from file. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync VMSTATE_LOADING,
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** The VM is being powered on */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync VMSTATE_POWERING_ON,
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** The VM is being resumed. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync VMSTATE_RESUMING,
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync /** The VM is runnning. */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync VMSTATE_RUNNING,
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync /** Live save: The VM is running and the state is being saved. */
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync VMSTATE_RUNNING_LS,
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync /** The VM is being reset. */
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync VMSTATE_RESETTING,
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync /** Live save: The VM is being reset and immediately suspended. */
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync VMSTATE_RESETTING_LS,
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync /** The VM is being suspended. */
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync VMSTATE_SUSPENDING,
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Live save: The VM is being suspended during a live save operation, either as
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync * part of the normal flow or VMR3Reset. */
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync VMSTATE_SUSPENDING_LS,
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync /** Live save: The VM is being suspended by VMR3Suspend during live save. */
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync VMSTATE_SUSPENDING_EXT_LS,
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync /** The VM is suspended. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync VMSTATE_SUSPENDED,
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync /** Live save: The VM has been suspended and is waiting for the live save
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync * operation to move on. */
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync VMSTATE_SUSPENDED_LS,
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync /** Live save: The VM has been suspended by VMR3Suspend during a live save. */
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync VMSTATE_SUSPENDED_EXT_LS,
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync /** The VM is suspended and its state is being saved by EMT(0). (See SSM) */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync VMSTATE_SAVING,
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync /** The VM is being debugged. (See DBGF.) */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync VMSTATE_DEBUGGING,
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync /** Live save: The VM is being debugged while the live phase is going on. */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync VMSTATE_DEBUGGING_LS,
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync /** The VM is being powered off. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync VMSTATE_POWERING_OFF,
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync /** Live save: The VM is being powered off and the save cancelled. */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync VMSTATE_POWERING_OFF_LS,
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync /** The VM is switched off, awaiting destruction. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync VMSTATE_OFF,
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync /** Live save: Waiting for cancellation and transition to VMSTATE_OFF. */
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync VMSTATE_OFF_LS,
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** The VM is powered off because of a fatal error. */
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync VMSTATE_FATAL_ERROR,
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync /** Live save: Waiting for cancellation and transition to FatalError. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync VMSTATE_FATAL_ERROR_LS,
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync /** The VM is in guru meditation over a fatal failure. */
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync VMSTATE_GURU_MEDITATION,
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync /** Live save: Waiting for cancellation and transition to GuruMeditation. */
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync VMSTATE_GURU_MEDITATION_LS,
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync /** The VM is screwed because of a failed state loading. */
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync VMSTATE_LOAD_FAILURE,
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync /** The VM is being destroyed. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync VMSTATE_DESTROYING,
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync /** Terminated. */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync VMSTATE_TERMINATED,
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync /** hack forcing the size of the enum to 32-bits. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync VMSTATE_MAKE_32BIT_HACK = 0x7fffffff
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync} VMSTATE;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync/** @def VBOXSTRICTRC_STRICT_ENABLED
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync * Indicates that VBOXSTRICTRC is in strict mode.
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync#if defined(__cplusplus) \
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync && ARCH_BITS == 64 /* cdecl requires classes and structs as hidden params. */ \
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync && !defined(_MSC_VER) /* trouble similar to 32-bit gcc. */ \
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync && ( defined(RT_STRICT) \
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync || defined(VBOX_STRICT) \
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync || defined(DEBUG) \
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync || defined(DOXYGEN_RUNNING) )
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync# define VBOXSTRICTRC_STRICT_ENABLED 1
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync# ifdef _MSC_VER
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync# pragma warning(disable:4190)
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync# endif
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync#endif
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync/** We need RTERR_STRICT_RC. */
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync#if defined(VBOXSTRICTRC_STRICT_ENABLED) && !defined(RTERR_STRICT_RC)
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync# define RTERR_STRICT_RC 1
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync#endif
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync/**
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync * Strict VirtualBox status code.
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync *
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync * This is normally an 32-bit integer and the only purpose of the type is to
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync * highlight the special handling that is required. But in strict build it is a
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync * class that causes compilation and runtime errors for some of the incorrect
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync * handling.
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync */
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync#ifdef VBOXSTRICTRC_STRICT_ENABLED
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsyncstruct VBOXSTRICTRC
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync{
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsyncprotected:
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync /** The status code. */
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync int32_t m_rc;
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsyncpublic:
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync /** Default constructor setting the status to VERR_IPE_UNINITIALIZED_STATUS. */
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync VBOXSTRICTRC()
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync#ifdef VERR_IPE_UNINITIALIZED_STATUS
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync : m_rc(VERR_IPE_UNINITIALIZED_STATUS)
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync#else
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync : m_rc(-233 /*VERR_IPE_UNINITIALIZED_STATUS*/)
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync#endif
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync {
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync }
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Constructor for normal integer status codes. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync VBOXSTRICTRC(int32_t const rc)
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync : m_rc(rc)
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync {
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync }
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Getter that VBOXSTRICTRC_VAL can use. */
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync int32_t getValue() const { return m_rc; }
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync /** @name Comparison operators
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync * @{ */
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync bool operator==(int32_t rc) const { return m_rc == rc; }
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync bool operator!=(int32_t rc) const { return m_rc != rc; }
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync bool operator<=(int32_t rc) const { return m_rc <= rc; }
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync bool operator>=(int32_t rc) const { return m_rc >= rc; }
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync bool operator<(int32_t rc) const { return m_rc < rc; }
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync bool operator>(int32_t rc) const { return m_rc > rc; }
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync /** @} */
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync /** Special automatic cast for RT_SUCCESS_NP. */
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync operator RTErrStrictType2() const { return RTErrStrictType2(m_rc); }
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsyncprivate:
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync /** @name Constructors that will prevent some of the bad types.
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync * @{ */
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync VBOXSTRICTRC(uint8_t rc) : m_rc(-999) { NOREF(rc); }
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync VBOXSTRICTRC(uint16_t rc) : m_rc(-999) { NOREF(rc); }
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync VBOXSTRICTRC(uint32_t rc) : m_rc(-999) { NOREF(rc); }
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync VBOXSTRICTRC(uint64_t rc) : m_rc(-999) { NOREF(rc); }
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync VBOXSTRICTRC(int8_t rc) : m_rc(-999) { NOREF(rc); }
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync VBOXSTRICTRC(int16_t rc) : m_rc(-999) { NOREF(rc); }
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync VBOXSTRICTRC(int64_t rc) : m_rc(-999) { NOREF(rc); }
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync /** @} */
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync};
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync#else
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsynctypedef int32_t VBOXSTRICTRC;
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync#endif
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** @def VBOXSTRICTRC_VAL
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync * Explicit getter.
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync * @param rcStrict The strict VirtualBox status code.
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync#ifdef VBOXSTRICTRC_STRICT_ENABLED
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync# define VBOXSTRICTRC_VAL(rcStrict) ( (rcStrict).getValue() )
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync#else
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync# define VBOXSTRICTRC_VAL(rcStrict) (rcStrict)
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync#endif
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** @def VBOXSTRICTRC_TODO
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync * Returns that needs dealing with.
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync * @param rcStrict The strict VirtualBox status code.
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync#define VBOXSTRICTRC_TODO(rcStrict) VBOXSTRICTRC_VAL(rcStrict)
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to a PDM Base Interface. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef struct PDMIBASE *PPDMIBASE;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to a pointer to a PDM Base Interface. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef PPDMIBASE *PPPDMIBASE;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to a PDM Device Instance. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef struct PDMDEVINS *PPDMDEVINS;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to a pointer to a PDM Device Instance. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef PPDMDEVINS *PPPDMDEVINS;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** R3 pointer to a PDM Device Instance. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef R3PTRTYPE(PPDMDEVINS) PPDMDEVINSR3;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** R0 pointer to a PDM Device Instance. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef R0PTRTYPE(PPDMDEVINS) PPDMDEVINSR0;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** RC pointer to a PDM Device Instance. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef RCPTRTYPE(PPDMDEVINS) PPDMDEVINSRC;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to a PDM USB Device Instance. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef struct PDMUSBINS *PPDMUSBINS;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to a pointer to a PDM USB Device Instance. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef PPDMUSBINS *PPPDMUSBINS;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to a PDM Driver Instance. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef struct PDMDRVINS *PPDMDRVINS;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to a pointer to a PDM Driver Instance. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef PPDMDRVINS *PPPDMDRVINS;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** R3 pointer to a PDM Driver Instance. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef R3PTRTYPE(PPDMDRVINS) PPDMDRVINSR3;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** R0 pointer to a PDM Driver Instance. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef R0PTRTYPE(PPDMDRVINS) PPDMDRVINSR0;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** RC pointer to a PDM Driver Instance. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef RCPTRTYPE(PPDMDRVINS) PPDMDRVINSRC;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to a PDM Service Instance. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef struct PDMSRVINS *PPDMSRVINS;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to a pointer to a PDM Service Instance. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef PPDMSRVINS *PPPDMSRVINS;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to a PDM critical section. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef union PDMCRITSECT *PPDMCRITSECT;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to a const PDM critical section. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef const union PDMCRITSECT *PCPDMCRITSECT;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** R3 pointer to a timer. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef R3PTRTYPE(struct TMTIMER *) PTMTIMERR3;
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync/** Pointer to a R3 pointer to a timer. */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsynctypedef PTMTIMERR3 *PPTMTIMERR3;
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync/** R0 pointer to a timer. */
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsynctypedef R0PTRTYPE(struct TMTIMER *) PTMTIMERR0;
2d0371c5f4b5bf0651da37a13cd3ae7479dd0432vboxsync/** Pointer to a R3 pointer to a timer. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef PTMTIMERR0 *PPTMTIMERR0;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** RC pointer to a timer. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef RCPTRTYPE(struct TMTIMER *) PTMTIMERRC;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to a RC pointer to a timer. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef PTMTIMERRC *PPTMTIMERRC;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to a timer. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef CTX_SUFF(PTMTIMER) PTMTIMER;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to a pointer to a timer. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef PTMTIMER *PPTMTIMER;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** SSM Operation handle. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef struct SSMHANDLE *PSSMHANDLE;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to a const SSM stream method table. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef struct SSMSTRMOPS const *PCSSMSTRMOPS;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to a CPUMCTX. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef struct CPUMCTX *PCPUMCTX;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to a const CPUMCTX. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef const struct CPUMCTX *PCCPUMCTX;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to a CPU context core. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef struct CPUMCTXCORE *PCPUMCTXCORE;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to a const CPU context core. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef const struct CPUMCTXCORE *PCCPUMCTXCORE;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync/** Pointer to selector hidden registers. */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsynctypedef struct CPUMSELREGHID *PCPUMSELREGHID;
42576743851c3c956ad7e867e74df1084c30d434vboxsync/** Pointer to const selector hidden registers. */
42576743851c3c956ad7e867e74df1084c30d434vboxsynctypedef const struct CPUMSELREGHID *PCCPUMSELREGHID;
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** @} */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** @defgroup grp_types_idt Interrupt Descriptor Table Entry.
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync * @ingroup grp_types
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync * @todo This all belongs in x86.h!
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync * @{ */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync/** @todo VBOXIDT -> VBOXDESCIDT, skip the complex variations. We'll never use them. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync/** IDT Entry, Task Gate view. */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync#pragma pack(1) /* paranoia */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef struct VBOXIDTE_TASKGATE
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync{
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Reserved. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u16Reserved1 : 16;
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync /** Task Segment Selector. */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync unsigned u16TSS : 16;
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync /** More reserved. */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync unsigned u8Reserved2 : 8;
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync /** Fixed value bit 0 - Set to 1. */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync unsigned u1Fixed0 : 1;
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync /** Busy bit. */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync unsigned u1Busy : 1;
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync /** Fixed value bit 2 - Set to 1. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u1Fixed1 : 1;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Fixed value bit 3 - Set to 0. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u1Fixed2: 1;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Fixed value bit 4 - Set to 0. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u1Fixed3 : 1;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Descriptor Privilege level. */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync unsigned u2DPL : 2;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Present flag. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u1Present : 1;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Reserved. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u16Reserved3 : 16;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync} VBOXIDTE_TASKGATE;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync#pragma pack()
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to IDT Entry, Task gate view. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef VBOXIDTE_TASKGATE *PVBOXIDTE_TASKGATE;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** IDT Entry, Intertupt gate view. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync#pragma pack(1) /* paranoia */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef struct VBOXIDTE_INTERRUPTGATE
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync{
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Low offset word. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u16OffsetLow : 16;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Segment Selector. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u16SegSel : 16;
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync /** Reserved. */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync unsigned u5Reserved2 : 5;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Fixed value bit 0 - Set to 0. */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync unsigned u1Fixed0 : 1;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Fixed value bit 1 - Set to 0. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u1Fixed1 : 1;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Fixed value bit 2 - Set to 0. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u1Fixed2 : 1;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Fixed value bit 3 - Set to 0. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u1Fixed3: 1;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Fixed value bit 4 - Set to 1. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u1Fixed4 : 1;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Fixed value bit 5 - Set to 1. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u1Fixed5 : 1;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Gate size, 1 = 32 bits, 0 = 16 bits. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u132BitGate : 1;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Fixed value bit 5 - Set to 0. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u1Fixed6 : 1;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Descriptor Privilege level. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u2DPL : 2;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Present flag. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u1Present : 1;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** High offset word. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u16OffsetHigh : 16;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync} VBOXIDTE_INTERRUPTGATE;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync#pragma pack()
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to IDT Entry, Interrupt gate view. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef VBOXIDTE_INTERRUPTGATE *PVBOXIDTE_INTERRUPTGATE;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** IDT Entry, Trap Gate view. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync#pragma pack(1) /* paranoia */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef struct VBOXIDTE_TRAPGATE
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync{
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Low offset word. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u16OffsetLow : 16;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Segment Selector. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u16SegSel : 16;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Reserved. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u5Reserved2 : 5;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Fixed value bit 0 - Set to 0. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u1Fixed0 : 1;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Fixed value bit 1 - Set to 0. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u1Fixed1 : 1;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Fixed value bit 2 - Set to 0. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u1Fixed2 : 1;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Fixed value bit 3 - Set to 1. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u1Fixed3: 1;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Fixed value bit 4 - Set to 1. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u1Fixed4 : 1;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Fixed value bit 5 - Set to 1. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u1Fixed5 : 1;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Gate size, 1 = 32 bits, 0 = 16 bits. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u132BitGate : 1;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Fixed value bit 5 - Set to 0. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u1Fixed6 : 1;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Descriptor Privilege level. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u2DPL : 2;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Present flag. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u1Present : 1;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** High offset word. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u16OffsetHigh : 16;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync} VBOXIDTE_TRAPGATE;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync#pragma pack()
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to IDT Entry, Trap Gate view. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef VBOXIDTE_TRAPGATE *PVBOXIDTE_TRAPGATE;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** IDT Entry Generic view. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync#pragma pack(1) /* paranoia */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef struct VBOXIDTE_GENERIC
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync{
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync /** Low offset word. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u16OffsetLow : 16;
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync /** Segment Selector. */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync unsigned u16SegSel : 16;
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync /** Reserved. */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync unsigned u5Reserved : 5;
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync /** IDT Type part one (not used for task gate). */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync unsigned u3Type1 : 3;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** IDT Type part two. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync unsigned u5Type2 : 5;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Descriptor Privilege level. */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync unsigned u2DPL : 2;
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync /** Present flag. */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync unsigned u1Present : 1;
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync /** High offset word. */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync unsigned u16OffsetHigh : 16;
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync} VBOXIDTE_GENERIC;
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync#pragma pack()
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync/** Pointer to IDT Entry Generic view. */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsynctypedef VBOXIDTE_GENERIC *PVBOXIDTE_GENERIC;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync/** IDT Type1 value. (Reserved for task gate!) */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync#define VBOX_IDTE_TYPE1 0
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync/** IDT Type2 value - Task gate. */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync#define VBOX_IDTE_TYPE2_TASK 0x5
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync/** IDT Type2 value - 16 bit interrupt gate. */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync#define VBOX_IDTE_TYPE2_INT_16 0x6
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** IDT Type2 value - 32 bit interrupt gate. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync#define VBOX_IDTE_TYPE2_INT_32 0xe
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync/** IDT Type2 value - 16 bit trap gate. */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync#define VBOX_IDTE_TYPE2_TRAP_16 0x7
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** IDT Type2 value - 32 bit trap gate. */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync#define VBOX_IDTE_TYPE2_TRAP_32 0xf
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** IDT Entry. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync#pragma pack(1) /* paranoia */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef union VBOXIDTE
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync{
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Task gate view. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync VBOXIDTE_TASKGATE Task;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Trap gate view. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync VBOXIDTE_TRAPGATE Trap;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Interrupt gate view. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync VBOXIDTE_INTERRUPTGATE Int;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Generic IDT view. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync VBOXIDTE_GENERIC Gen;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** 8 bit unsigned integer view. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync uint8_t au8[8];
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** 16 bit unsigned integer view. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync uint16_t au16[4];
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** 32 bit unsigned integer view. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync uint32_t au32[2];
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync /** 64 bit unsigned integer view. */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync uint64_t au64;
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync} VBOXIDTE;
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync#pragma pack()
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync/** Pointer to IDT Entry. */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsynctypedef VBOXIDTE *PVBOXIDTE;
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync/** Pointer to IDT Entry. */
42576743851c3c956ad7e867e74df1084c30d434vboxsynctypedef VBOXIDTE const *PCVBOXIDTE;
42576743851c3c956ad7e867e74df1084c30d434vboxsync
42576743851c3c956ad7e867e74df1084c30d434vboxsync#pragma pack(1)
42576743851c3c956ad7e867e74df1084c30d434vboxsync/** IDTR */
42576743851c3c956ad7e867e74df1084c30d434vboxsynctypedef struct VBOXIDTR
42576743851c3c956ad7e867e74df1084c30d434vboxsync{
42576743851c3c956ad7e867e74df1084c30d434vboxsync /** Size of the IDT. */
42576743851c3c956ad7e867e74df1084c30d434vboxsync uint16_t cbIdt;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Address of the IDT. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync uint64_t pIdt;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync} VBOXIDTR, *PVBOXIDTR;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync#pragma pack()
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync#pragma pack(1)
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** IDTR from version 1.6 */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef struct VBOXIDTR_VER1_6
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync{
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Size of the IDT. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync uint16_t cbIdt;
42576743851c3c956ad7e867e74df1084c30d434vboxsync /** Address of the IDT. */
42576743851c3c956ad7e867e74df1084c30d434vboxsync uint32_t pIdt;
42576743851c3c956ad7e867e74df1084c30d434vboxsync} VBOXIDTR_VER1_6, *PVBOXIDTR_VER1_6;
42576743851c3c956ad7e867e74df1084c30d434vboxsync#pragma pack()
42576743851c3c956ad7e867e74df1084c30d434vboxsync
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync/** @} */
42576743851c3c956ad7e867e74df1084c30d434vboxsync
42576743851c3c956ad7e867e74df1084c30d434vboxsync
42576743851c3c956ad7e867e74df1084c30d434vboxsync/** @def VBOXIDTE_OFFSET
42576743851c3c956ad7e867e74df1084c30d434vboxsync * Return the offset of an IDT entry.
42576743851c3c956ad7e867e74df1084c30d434vboxsync */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync#define VBOXIDTE_OFFSET(desc) \
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync ( ((uint32_t)((desc).Gen.u16OffsetHigh) << 16) \
42576743851c3c956ad7e867e74df1084c30d434vboxsync | ( (desc).Gen.u16OffsetLow ) )
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
42576743851c3c956ad7e867e74df1084c30d434vboxsync#pragma pack(1)
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** GDTR */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef struct VBOXGDTR
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync{
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Size of the GDT. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync uint16_t cbGdt;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Address of the GDT. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync uint64_t pGdt;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync} VBOXGDTR;
42576743851c3c956ad7e867e74df1084c30d434vboxsync#pragma pack()
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to GDTR. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef VBOXGDTR *PVBOXGDTR;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync#pragma pack(1)
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** GDTR from version 1.6 */
42576743851c3c956ad7e867e74df1084c30d434vboxsynctypedef struct VBOXGDTR_VER1_6
42576743851c3c956ad7e867e74df1084c30d434vboxsync{
42576743851c3c956ad7e867e74df1084c30d434vboxsync /** Size of the GDT. */
42576743851c3c956ad7e867e74df1084c30d434vboxsync uint16_t cbGdt;
42576743851c3c956ad7e867e74df1084c30d434vboxsync /** Address of the GDT. */
42576743851c3c956ad7e867e74df1084c30d434vboxsync uint32_t pGdt;
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync} VBOXGDTR_VER1_6;
42576743851c3c956ad7e867e74df1084c30d434vboxsync#pragma pack()
42576743851c3c956ad7e867e74df1084c30d434vboxsync
42576743851c3c956ad7e867e74df1084c30d434vboxsync/** @} */
42576743851c3c956ad7e867e74df1084c30d434vboxsync
42576743851c3c956ad7e867e74df1084c30d434vboxsync
42576743851c3c956ad7e867e74df1084c30d434vboxsync/**
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync * 32-bit Task Segment used in raw mode.
42576743851c3c956ad7e867e74df1084c30d434vboxsync * @todo Move this to SELM! Use X86TSS32 instead.
42576743851c3c956ad7e867e74df1084c30d434vboxsync */
42576743851c3c956ad7e867e74df1084c30d434vboxsync#pragma pack(1)
42576743851c3c956ad7e867e74df1084c30d434vboxsynctypedef struct VBOXTSS
42576743851c3c956ad7e867e74df1084c30d434vboxsync{
42576743851c3c956ad7e867e74df1084c30d434vboxsync /** 0x00 - Back link to previous task. (static) */
42576743851c3c956ad7e867e74df1084c30d434vboxsync RTSEL selPrev;
42576743851c3c956ad7e867e74df1084c30d434vboxsync uint16_t padding1;
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync /** 0x04 - Ring-0 stack pointer. (static) */
42576743851c3c956ad7e867e74df1084c30d434vboxsync uint32_t esp0;
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync /** 0x08 - Ring-0 stack segment. (static) */
42576743851c3c956ad7e867e74df1084c30d434vboxsync RTSEL ss0;
42576743851c3c956ad7e867e74df1084c30d434vboxsync uint16_t padding_ss0;
42576743851c3c956ad7e867e74df1084c30d434vboxsync /** 0x0c - Ring-1 stack pointer. (static) */
42576743851c3c956ad7e867e74df1084c30d434vboxsync uint32_t esp1;
42576743851c3c956ad7e867e74df1084c30d434vboxsync /** 0x10 - Ring-1 stack segment. (static) */
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync RTSEL ss1;
42576743851c3c956ad7e867e74df1084c30d434vboxsync uint16_t padding_ss1;
42576743851c3c956ad7e867e74df1084c30d434vboxsync /** 0x14 - Ring-2 stack pointer. (static) */
42576743851c3c956ad7e867e74df1084c30d434vboxsync uint32_t esp2;
42576743851c3c956ad7e867e74df1084c30d434vboxsync /** 0x18 - Ring-2 stack segment. (static) */
42576743851c3c956ad7e867e74df1084c30d434vboxsync RTSEL ss2;
42576743851c3c956ad7e867e74df1084c30d434vboxsync uint16_t padding_ss2;
42576743851c3c956ad7e867e74df1084c30d434vboxsync /** 0x1c - Page directory for the task. (static) */
42576743851c3c956ad7e867e74df1084c30d434vboxsync uint32_t cr3;
42576743851c3c956ad7e867e74df1084c30d434vboxsync /** 0x20 - EIP before task switch. */
42576743851c3c956ad7e867e74df1084c30d434vboxsync uint32_t eip;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** 0x24 - EFLAGS before task switch. */
42576743851c3c956ad7e867e74df1084c30d434vboxsync uint32_t eflags;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** 0x28 - EAX before task switch. */
42576743851c3c956ad7e867e74df1084c30d434vboxsync uint32_t eax;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** 0x2c - ECX before task switch. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync uint32_t ecx;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** 0x30 - EDX before task switch. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync uint32_t edx;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** 0x34 - EBX before task switch. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync uint32_t ebx;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** 0x38 - ESP before task switch. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync uint32_t esp;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** 0x3c - EBP before task switch. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync uint32_t ebp;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** 0x40 - ESI before task switch. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync uint32_t esi;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** 0x44 - EDI before task switch. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync uint32_t edi;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** 0x48 - ES before task switch. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync RTSEL es;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync uint16_t padding_es;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** 0x4c - CS before task switch. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync RTSEL cs;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync uint16_t padding_cs;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** 0x50 - SS before task switch. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync RTSEL ss;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync uint16_t padding_ss;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** 0x54 - DS before task switch. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync RTSEL ds;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync uint16_t padding_ds;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** 0x58 - FS before task switch. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync RTSEL fs;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync uint16_t padding_fs;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** 0x5c - GS before task switch. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync RTSEL gs;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync uint16_t padding_gs;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** 0x60 - LDTR before task switch. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync RTSEL selLdt;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync uint16_t padding_ldt;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** 0x64 - Debug trap flag */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync uint16_t fDebugTrap;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** 0x66 - Offset relative to the TSS of the start of the I/O Bitmap
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync * and the end of the interrupt redirection bitmap. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync uint16_t offIoBitmap;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** 0x68 - 32 bytes for the virtual interrupt redirection bitmap. (VME) */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync uint8_t IntRedirBitmap[32];
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync} VBOXTSS;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync#pragma pack()
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to task segment. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef VBOXTSS *PVBOXTSS;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to const task segment. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef const VBOXTSS *PCVBOXTSS;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/**
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync * Data transport buffer (scatter/gather)
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef struct PDMDATASEG
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync{
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Length of buffer in entry. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync size_t cbSeg;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Pointer to the start of the buffer. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync void *pvSeg;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync} PDMDATASEG;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to a data transport segment. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef PDMDATASEG *PPDMDATASEG;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to a const data transport segment. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef PDMDATASEG const *PCPDMDATASEG;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
42576743851c3c956ad7e867e74df1084c30d434vboxsync
42576743851c3c956ad7e867e74df1084c30d434vboxsync/**
42576743851c3c956ad7e867e74df1084c30d434vboxsync * Forms of generic segment offloading.
42576743851c3c956ad7e867e74df1084c30d434vboxsync */
42576743851c3c956ad7e867e74df1084c30d434vboxsynctypedef enum PDMNETWORKGSOTYPE
42576743851c3c956ad7e867e74df1084c30d434vboxsync{
42576743851c3c956ad7e867e74df1084c30d434vboxsync /** Invalid zero value. */
42576743851c3c956ad7e867e74df1084c30d434vboxsync PDMNETWORKGSOTYPE_INVALID = 0,
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** TCP/IPv4 - no CWR/ECE encoding. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync PDMNETWORKGSOTYPE_IPV4_TCP,
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** TCP/IPv6 - no CWR/ECE encoding. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync PDMNETWORKGSOTYPE_IPV6_TCP,
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** UDP/IPv4. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync PDMNETWORKGSOTYPE_IPV4_UDP,
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** UDP/IPv6. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync PDMNETWORKGSOTYPE_IPV6_UDP,
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** TCP/IPv6 over IPv4 tunneling - no CWR/ECE encoding.
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync * The header offsets and sizes relates to IPv4 and TCP, the IPv6 header is
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync * figured out as needed.
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync * @todo Needs checking against facts, this is just an outline of the idea. */
42576743851c3c956ad7e867e74df1084c30d434vboxsync PDMNETWORKGSOTYPE_IPV4_IPV6_TCP,
42576743851c3c956ad7e867e74df1084c30d434vboxsync /** UDP/IPv6 over IPv4 tunneling.
42576743851c3c956ad7e867e74df1084c30d434vboxsync * The header offsets and sizes relates to IPv4 and UDP, the IPv6 header is
42576743851c3c956ad7e867e74df1084c30d434vboxsync * figured out as needed.
42576743851c3c956ad7e867e74df1084c30d434vboxsync * @todo Needs checking against facts, this is just an outline of the idea. */
42576743851c3c956ad7e867e74df1084c30d434vboxsync PDMNETWORKGSOTYPE_IPV4_IPV6_UDP,
42576743851c3c956ad7e867e74df1084c30d434vboxsync /** The end of valid GSO types. */
42576743851c3c956ad7e867e74df1084c30d434vboxsync PDMNETWORKGSOTYPE_END
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync} PDMNETWORKGSOTYPE;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/**
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync * Generic segment offloading context.
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync *
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync * We generally follow the E1000 specs wrt to which header fields we change.
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync * However the GSO type implies where the checksum fields are and that they are
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync * always updated from scratch (no half done pseudo checksums).
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync *
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync * @remarks This is part of the internal network GSO packets. Take great care
42576743851c3c956ad7e867e74df1084c30d434vboxsync * when making changes. The size is expected to be exactly 8 bytes.
42576743851c3c956ad7e867e74df1084c30d434vboxsync */
42576743851c3c956ad7e867e74df1084c30d434vboxsynctypedef struct PDMNETWORKGSO
42576743851c3c956ad7e867e74df1084c30d434vboxsync{
42576743851c3c956ad7e867e74df1084c30d434vboxsync /** The type of segmentation offloading we're performing (PDMNETWORKGSOTYPE). */
42576743851c3c956ad7e867e74df1084c30d434vboxsync uint8_t u8Type;
02f73b88a6e96b7f1b8ab0bbb98cfb798b566fbdvboxsync /** The total header size. */
42576743851c3c956ad7e867e74df1084c30d434vboxsync uint8_t cbHdrs;
42576743851c3c956ad7e867e74df1084c30d434vboxsync /** The max segment size (MSS) to apply. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync uint16_t cbMaxSeg;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Offset of the first header (IPv4 / IPv6). 0 if not not needed. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync uint8_t offHdr1;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Offset of the second header (TCP / UDP). 0 if not not needed. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync uint8_t offHdr2;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync /** Unused. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync uint8_t au8Unused[2];
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync} PDMNETWORKGSO;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to a GSO context. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef PDMNETWORKGSO *PPDMNETWORKGSO;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/** Pointer to a const GSO context. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsynctypedef PDMNETWORKGSO const *PCPDMNETWORKGSO;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/**
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync * The current ROM page protection.
42576743851c3c956ad7e867e74df1084c30d434vboxsync *
42576743851c3c956ad7e867e74df1084c30d434vboxsync * @remarks This is part of the saved state.
42576743851c3c956ad7e867e74df1084c30d434vboxsync */
a5af4f8add719046631d3d68734b9b6d9ca9d046vboxsynctypedef enum PGMROMPROT
42576743851c3c956ad7e867e74df1084c30d434vboxsync{
42576743851c3c956ad7e867e74df1084c30d434vboxsync /** The customary invalid value. */
42576743851c3c956ad7e867e74df1084c30d434vboxsync PGMROMPROT_INVALID = 0,
42576743851c3c956ad7e867e74df1084c30d434vboxsync /** Read from the virgin ROM page, ignore writes.
42576743851c3c956ad7e867e74df1084c30d434vboxsync * Map the virgin page, use write access handler to ignore writes. */
42576743851c3c956ad7e867e74df1084c30d434vboxsync PGMROMPROT_READ_ROM_WRITE_IGNORE,
42576743851c3c956ad7e867e74df1084c30d434vboxsync /** Read from the virgin ROM page, write to the shadow RAM.
42576743851c3c956ad7e867e74df1084c30d434vboxsync * Map the virgin page, use write access handler change the RAM. */
a5af4f8add719046631d3d68734b9b6d9ca9d046vboxsync PGMROMPROT_READ_ROM_WRITE_RAM,
42576743851c3c956ad7e867e74df1084c30d434vboxsync /** Read from the shadow ROM page, ignore writes.
42576743851c3c956ad7e867e74df1084c30d434vboxsync * Map the shadow page read-only, use write access handler to ignore writes. */
42576743851c3c956ad7e867e74df1084c30d434vboxsync PGMROMPROT_READ_RAM_WRITE_IGNORE,
42576743851c3c956ad7e867e74df1084c30d434vboxsync /** Read from the shadow ROM page, ignore writes.
42576743851c3c956ad7e867e74df1084c30d434vboxsync * Map the shadow page read-write, disabled write access handler. */
42576743851c3c956ad7e867e74df1084c30d434vboxsync PGMROMPROT_READ_RAM_WRITE_RAM,
42576743851c3c956ad7e867e74df1084c30d434vboxsync /** The end of valid values. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync PGMROMPROT_END,
42576743851c3c956ad7e867e74df1084c30d434vboxsync /** The usual 32-bit type size hack. */
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync PGMROMPROT_32BIT_HACK = 0x7fffffff
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync} PGMROMPROT;
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync/**
cdcfac625bb49f1d4b67aaf8fb8b1cdb69fe49c2vboxsync * Page mapping lock.
42576743851c3c956ad7e867e74df1084c30d434vboxsync *
*/
typedef struct PGMPAGEMAPLOCK
{
/** @todo see PGMPhysIsPageMappingLockValid for possibly incorrect assumptions */
#if defined(IN_RC) || defined(VBOX_WITH_2X_4GB_ADDR_SPACE_IN_R0)
/** Just a dummy for the time being. */
uint32_t u32Dummy;
uint32_t u32Dummy1;
# if HC_ARCH_BITS == 64
uint32_t u32Align[2];
# endif
#else
/** Pointer to the PGMPAGE and lock type.
* bit-0 abuse: set=write, clear=read. */
uintptr_t uPageAndType;
/** Read lock type value. */
# define PGMPAGEMAPLOCK_TYPE_READ ((uintptr_t)0)
/** Write lock type value. */
# define PGMPAGEMAPLOCK_TYPE_WRITE ((uintptr_t)1)
/** Lock type mask. */
# define PGMPAGEMAPLOCK_TYPE_MASK ((uintptr_t)1)
/** Pointer to the PGMCHUNKR3MAP. */
void *pvMap;
#endif
} PGMPAGEMAPLOCK;
/** Pointer to a page mapping lock. */
typedef PGMPAGEMAPLOCK *PPGMPAGEMAPLOCK;
/** Configuration manager tree node - A key. */
typedef struct CFGMNODE *PCFGMNODE;
/** Configuration manager tree leaf - A value. */
typedef struct CFGMLEAF *PCFGMLEAF;
/**
* CPU modes.
*/
typedef enum CPUMMODE
{
/** The usual invalid zero entry. */
CPUMMODE_INVALID = 0,
/** Real mode. */
CPUMMODE_REAL,
/** Protected mode (32-bit). */
CPUMMODE_PROTECTED,
/** Long mode (64-bit). */
CPUMMODE_LONG
} CPUMMODE;
/** @} */
#endif