VirtualBox

source: vbox/trunk/src/VBox/VMM/VMMR0/HWSVMR0.h@ 12756

Last change on this file since 12756 was 12756, checked in by vboxsync, 16 years ago

Attempt to correct hidden selector attributes when switching from real to protected mode. (VT-x weirdness again)

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id
File size: 4.5 KB
Line 
1/* $Id: HWSVMR0.h 12756 2008-09-26 08:25:57Z vboxsync $ */
2/** @file
3 * HWACCM AMD-V - Internal header file.
4 */
5
6/*
7 * Copyright (C) 2006-2007 Sun Microsystems, Inc.
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 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
18 * Clara, CA 95054 USA or visit http://www.sun.com if you need
19 * additional information or have any questions.
20 */
21
22#ifndef ___VMMR0_HWSVMR0_h
23#define ___VMMR0_HWSVMR0_h
24
25#include <VBox/cdefs.h>
26#include <VBox/types.h>
27#include <VBox/em.h>
28#include <VBox/stam.h>
29#include <VBox/dis.h>
30#include <VBox/hwaccm.h>
31#include <VBox/pgm.h>
32#include <VBox/hwacc_svm.h>
33
34__BEGIN_DECLS
35
36/** @defgroup grp_svm_int Internal
37 * @ingroup grp_svm
38 * @internal
39 * @{
40 */
41
42#ifdef IN_RING0
43
44/**
45 * Enters the AMD-V session
46 *
47 * @returns VBox status code.
48 * @param pVM The VM to operate on.
49 * @param pCpu CPU info struct
50 */
51HWACCMR0DECL(int) SVMR0Enter(PVM pVM, PHWACCM_CPUINFO pCpu);
52
53/**
54 * Leaves the AMD-V session
55 *
56 * @returns VBox status code.
57 * @param pVM The VM to operate on.
58 * @param pCtx CPU context
59 */
60HWACCMR0DECL(int) SVMR0Leave(PVM pVM, PCPUMCTX pCtx);
61
62/**
63 * Sets up and activates AMD-V on the current CPU
64 *
65 * @returns VBox status code.
66 * @param pCpu CPU info struct
67 * @param pVM The VM to operate on.
68 * @param pvPageCpu Pointer to the global cpu page
69 * @param pPageCpuPhys Physical address of the global cpu page
70 */
71HWACCMR0DECL(int) SVMR0EnableCpu(PHWACCM_CPUINFO pCpu, PVM pVM, void *pvPageCpu, RTHCPHYS pPageCpuPhys);
72
73/**
74 * Deactivates AMD-V on the current CPU
75 *
76 * @returns VBox status code.
77 * @param pCpu CPU info struct
78 * @param pvPageCpu Pointer to the global cpu page
79 * @param pPageCpuPhys Physical address of the global cpu page
80 */
81HWACCMR0DECL(int) SVMR0DisableCpu(PHWACCM_CPUINFO pCpu, void *pvPageCpu, RTHCPHYS pPageCpuPhys);
82
83/**
84 * Does Ring-0 per VM AMD-V init.
85 *
86 * @returns VBox status code.
87 * @param pVM The VM to operate on.
88 */
89HWACCMR0DECL(int) SVMR0InitVM(PVM pVM);
90
91/**
92 * Does Ring-0 per VM AMD-V termination.
93 *
94 * @returns VBox status code.
95 * @param pVM The VM to operate on.
96 */
97HWACCMR0DECL(int) SVMR0TermVM(PVM pVM);
98
99/**
100 * Sets up AMD-V for the specified VM
101 *
102 * @returns VBox status code.
103 * @param pVM The VM to operate on.
104 */
105HWACCMR0DECL(int) SVMR0SetupVM(PVM pVM);
106
107
108/**
109 * Runs guest code in an AMD-V VM.
110 *
111 * @returns VBox status code.
112 * @param pVM The VM to operate on.
113 * @param pCtx Guest context
114 */
115HWACCMR0DECL(int) SVMR0RunGuestCode(PVM pVM, CPUMCTX *pCtx);
116
117
118/**
119 * Save the host state
120 *
121 * @returns VBox status code.
122 * @param pVM The VM to operate on.
123 */
124HWACCMR0DECL(int) SVMR0SaveHostState(PVM pVM);
125
126/**
127 * Loads the guest state
128 *
129 * @returns VBox status code.
130 * @param pVM The VM to operate on.
131 * @param pCtx Guest context
132 */
133HWACCMR0DECL(int) SVMR0LoadGuestState(PVM pVM, CPUMCTX *pCtx);
134
135
136/** Convert hidden selector attribute word between VMX and SVM formats. */
137#define SVM_HIDSEGATTR_VMX2SVM(a) (a & 0xFF) | ((a & 0xF000) >> 4)
138#define SVM_HIDSEGATTR_SVM2VMX(a) (a & 0xFF) | ((a & 0x0F00) << 4)
139
140#define SVM_WRITE_SELREG(REG, reg) \
141{ \
142 pVMCB->guest.REG.u16Sel = pCtx->reg; \
143 pVMCB->guest.REG.u32Limit = pCtx->reg##Hid.u32Limit; \
144 pVMCB->guest.REG.u64Base = pCtx->reg##Hid.u64Base; \
145 pVMCB->guest.REG.u16Attr = SVM_HIDSEGATTR_VMX2SVM(pCtx->reg##Hid.Attr.u); \
146}
147
148#define SVM_READ_SELREG(REG, reg) \
149{ \
150 pCtx->reg = pVMCB->guest.REG.u16Sel; \
151 pCtx->reg##Hid.u32Limit = pVMCB->guest.REG.u32Limit; \
152 pCtx->reg##Hid.u64Base = pVMCB->guest.REG.u64Base; \
153 pCtx->reg##Hid.Attr.u = SVM_HIDSEGATTR_SVM2VMX(pVMCB->guest.REG.u16Attr); \
154}
155
156#endif /* IN_RING0 */
157
158/** @} */
159
160__END_DECLS
161
162#endif
163
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