VirtualBox

source: vbox/trunk/include/VBox/vmm/gvm.h@ 61649

Last change on this file since 61649 was 58110, checked in by vboxsync, 9 years ago

include,misc: Doxygen grouping adjustments, collecting all the VMM bits under one parent group, ditto for the COM library.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id
File size: 3.1 KB
Line 
1/* $Id: gvm.h 58110 2015-10-07 18:36:49Z vboxsync $ */
2/** @file
3 * GVM - The Global VM Data.
4 */
5
6/*
7 * Copyright (C) 2007-2015 Oracle Corporation
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 *
17 * The contents of this file may alternatively be used under the terms
18 * of the Common Development and Distribution License Version 1.0
19 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
20 * VirtualBox OSE distribution, in which case the provisions of the
21 * CDDL are applicable instead of those of the GPL.
22 *
23 * You may elect to license modified versions of this file under the
24 * terms and conditions of either the GPL or the CDDL or both.
25 */
26
27
28#ifndef ___VBox_vmm_gvm_h
29#define ___VBox_vmm_gvm_h
30
31#include <VBox/types.h>
32#include <iprt/thread.h>
33
34
35/** @defgroup grp_gvmcpu GVMCPU - The Global VMCPU Data
36 * @ingroup grp_vmm
37 * @{
38 */
39
40typedef struct GVMCPU
41{
42 /** VCPU id (0 - (pVM->cCpus - 1). */
43 VMCPUID idCpu;
44
45 /** Handle to the EMT thread. */
46 RTNATIVETHREAD hEMT;
47
48 /** The GVMM per vcpu data. */
49 union
50 {
51#ifdef ___GVMMR0Internal_h
52 struct GVMMPERVCPU s;
53#endif
54 uint8_t padding[64];
55 } gvmm;
56} GVMCPU;
57/** Pointer to the GVMCPU data. */
58typedef GVMCPU *PGVMCPU;
59
60/** @} */
61
62/** @defgroup grp_gvm GVM - The Global VM Data
63 * @ingroup grp_vmm
64 * @{
65 */
66
67/**
68 * The Global VM Data.
69 *
70 * This is a ring-0 only structure where we put items we don't need to
71 * share with ring-3 or GC, like for instance various RTR0MEMOBJ handles.
72 *
73 * Unlike VM, there are no special alignment restrictions here. The
74 * paddings are checked by compile time assertions.
75 */
76typedef struct GVM
77{
78 /** Magic / eye-catcher (GVM_MAGIC). */
79 uint32_t u32Magic;
80 /** The global VM handle for this VM. */
81 uint32_t hSelf;
82 /** The ring-0 mapping of the VM structure. */
83 PVM pVM;
84 /** Number of Virtual CPUs, i.e. how many entries there are in aCpus.
85 * Same same as VM::cCpus. */
86 uint32_t cCpus;
87 uint32_t padding;
88
89 /** The GVMM per vm data. */
90 union
91 {
92#ifdef ___GVMMR0Internal_h
93 struct GVMMPERVM s;
94#endif
95 uint8_t padding[256];
96 } gvmm;
97
98 /** The GMM per vm data. */
99 union
100 {
101#ifdef ___GMMR0Internal_h
102 struct GMMPERVM s;
103#endif
104 uint8_t padding[512];
105 } gmm;
106
107 /** The RAWPCIVM per vm data. */
108 union
109 {
110#ifdef ___VBox_rawpci_h
111 struct RAWPCIPERVM s;
112#endif
113 uint8_t padding[64];
114 } rawpci;
115
116
117 /** GVMCPU array for the configured number of virtual CPUs. */
118 GVMCPU aCpus[1];
119} GVM;
120
121/** The GVM::u32Magic value (Wayne Shorter). */
122#define GVM_MAGIC 0x19330825
123
124/** @} */
125
126#endif
127
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette