VirtualBox

source: vbox/trunk/src/VBox/VMM/VMMAll/CPUMAllMsrs.cpp@ 69111

Last change on this file since 69111 was 69111, checked in by vboxsync, 7 years ago

(C) year

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 229.0 KB
Line 
1/* $Id: CPUMAllMsrs.cpp 69111 2017-10-17 14:26:02Z vboxsync $ */
2/** @file
3 * CPUM - CPU MSR Registers.
4 */
5
6/*
7 * Copyright (C) 2013-2017 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
18
19/*********************************************************************************************************************************
20* Header Files *
21*********************************************************************************************************************************/
22#define LOG_GROUP LOG_GROUP_CPUM
23#include <VBox/vmm/cpum.h>
24#include <VBox/vmm/apic.h>
25#include <VBox/vmm/hm.h>
26#include <VBox/vmm/tm.h>
27#include <VBox/vmm/gim.h>
28#include "CPUMInternal.h"
29#include <VBox/vmm/vm.h>
30#include <VBox/err.h>
31
32
33/*********************************************************************************************************************************
34* Defined Constants And Macros *
35*********************************************************************************************************************************/
36/**
37 * Validates the CPUMMSRRANGE::offCpumCpu value and declares a local variable
38 * pointing to it.
39 *
40 * ASSUMES sizeof(a_Type) is a power of two and that the member is aligned
41 * correctly.
42 */
43#define CPUM_MSR_ASSERT_CPUMCPU_OFFSET_RETURN(a_pVCpu, a_pRange, a_Type, a_VarName) \
44 AssertMsgReturn( (a_pRange)->offCpumCpu >= 8 \
45 && (a_pRange)->offCpumCpu < sizeof(CPUMCPU) \
46 && !((a_pRange)->offCpumCpu & (RT_MIN(sizeof(a_Type), 8) - 1)) \
47 , ("offCpumCpu=%#x %s\n", (a_pRange)->offCpumCpu, (a_pRange)->szName), \
48 VERR_CPUM_MSR_BAD_CPUMCPU_OFFSET); \
49 a_Type *a_VarName = (a_Type *)((uintptr_t)&(a_pVCpu)->cpum.s + (a_pRange)->offCpumCpu)
50
51
52/*********************************************************************************************************************************
53* Structures and Typedefs *
54*********************************************************************************************************************************/
55
56/**
57 * Implements reading one or more MSRs.
58 *
59 * @returns VBox status code.
60 * @retval VINF_SUCCESS on success.
61 * @retval VINF_CPUM_R3_MSR_READ if the MSR read could not be serviced in the
62 * current context (raw-mode or ring-0).
63 * @retval VERR_CPUM_RAISE_GP_0 on failure (invalid MSR).
64 *
65 * @param pVCpu The cross context virtual CPU structure.
66 * @param idMsr The MSR we're reading.
67 * @param pRange The MSR range descriptor.
68 * @param puValue Where to return the value.
69 */
70typedef DECLCALLBACK(VBOXSTRICTRC) FNCPUMRDMSR(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue);
71/** Pointer to a RDMSR worker for a specific MSR or range of MSRs. */
72typedef FNCPUMRDMSR *PFNCPUMRDMSR;
73
74
75/**
76 * Implements writing one or more MSRs.
77 *
78 * @retval VINF_SUCCESS on success.
79 * @retval VINF_CPUM_R3_MSR_WRITE if the MSR write could not be serviced in the
80 * current context (raw-mode or ring-0).
81 * @retval VERR_CPUM_RAISE_GP_0 on failure.
82 *
83 * @param pVCpu The cross context virtual CPU structure.
84 * @param idMsr The MSR we're writing.
85 * @param pRange The MSR range descriptor.
86 * @param uValue The value to set, ignored bits masked.
87 * @param uRawValue The raw value with the ignored bits not masked.
88 */
89typedef DECLCALLBACK(VBOXSTRICTRC) FNCPUMWRMSR(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue);
90/** Pointer to a WRMSR worker for a specific MSR or range of MSRs. */
91typedef FNCPUMWRMSR *PFNCPUMWRMSR;
92
93
94
95/*
96 * Generic functions.
97 * Generic functions.
98 * Generic functions.
99 */
100
101
102/** @callback_method_impl{FNCPUMRDMSR} */
103static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_FixedValue(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
104{
105 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr);
106 *puValue = pRange->uValue;
107 return VINF_SUCCESS;
108}
109
110
111/** @callback_method_impl{FNCPUMWRMSR} */
112static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IgnoreWrite(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
113{
114 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
115 Log(("CPUM: Ignoring WRMSR %#x (%s), %#llx\n", idMsr, pRange->szName, uValue));
116 return VINF_SUCCESS;
117}
118
119
120/** @callback_method_impl{FNCPUMRDMSR} */
121static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_WriteOnly(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
122{
123 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(puValue);
124 return VERR_CPUM_RAISE_GP_0;
125}
126
127
128/** @callback_method_impl{FNCPUMWRMSR} */
129static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_ReadOnly(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
130{
131 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
132 Assert(pRange->fWrGpMask == UINT64_MAX);
133 return VERR_CPUM_RAISE_GP_0;
134}
135
136
137
138
139/*
140 * IA32
141 * IA32
142 * IA32
143 */
144
145/** @callback_method_impl{FNCPUMRDMSR} */
146static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32P5McAddr(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
147{
148 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
149 *puValue = 0; /** @todo implement machine check injection. */
150 return VINF_SUCCESS;
151}
152
153
154/** @callback_method_impl{FNCPUMWRMSR} */
155static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32P5McAddr(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
156{
157 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
158 /** @todo implement machine check injection. */
159 return VINF_SUCCESS;
160}
161
162
163/** @callback_method_impl{FNCPUMRDMSR} */
164static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32P5McType(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
165{
166 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
167 *puValue = 0; /** @todo implement machine check injection. */
168 return VINF_SUCCESS;
169}
170
171
172/** @callback_method_impl{FNCPUMWRMSR} */
173static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32P5McType(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
174{
175 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
176 /** @todo implement machine check injection. */
177 return VINF_SUCCESS;
178}
179
180
181/** @callback_method_impl{FNCPUMRDMSR} */
182static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32TimestampCounter(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
183{
184 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
185 *puValue = TMCpuTickGet(pVCpu);
186 return VINF_SUCCESS;
187}
188
189
190/** @callback_method_impl{FNCPUMWRMSR} */
191static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32TimestampCounter(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
192{
193 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
194 TMCpuTickSet(pVCpu->CTX_SUFF(pVM), pVCpu, uValue);
195 return VINF_SUCCESS;
196}
197
198
199/** @callback_method_impl{FNCPUMRDMSR} */
200static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32PlatformId(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
201{
202 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr);
203 uint64_t uValue = pRange->uValue;
204 if (uValue & 0x1f00)
205 {
206 /* Max allowed bus ratio present. */
207 /** @todo Implement scaled BUS frequency. */
208 }
209
210 *puValue = uValue;
211 return VINF_SUCCESS;
212}
213
214
215/** @callback_method_impl{FNCPUMRDMSR} */
216static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32ApicBase(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
217{
218 RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
219 return APICGetBaseMsr(pVCpu, puValue);
220}
221
222
223/** @callback_method_impl{FNCPUMWRMSR} */
224static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32ApicBase(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
225{
226 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
227 return APICSetBaseMsr(pVCpu, uValue);
228}
229
230
231/** @callback_method_impl{FNCPUMRDMSR} */
232static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32FeatureControl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
233{
234 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
235 *puValue = 1; /* Locked, no VT-X, no SYSENTER micromanagement. */
236 return VINF_SUCCESS;
237}
238
239
240/** @callback_method_impl{FNCPUMWRMSR} */
241static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32FeatureControl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
242{
243 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
244 return VERR_CPUM_RAISE_GP_0;
245}
246
247
248/** @callback_method_impl{FNCPUMRDMSR} */
249static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32BiosSignId(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
250{
251 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
252 /** @todo fake microcode update. */
253 *puValue = pRange->uValue;
254 return VINF_SUCCESS;
255}
256
257
258/** @callback_method_impl{FNCPUMWRMSR} */
259static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32BiosSignId(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
260{
261 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
262 /* Normally, zero is written to Ia32BiosSignId before reading it in order
263 to select the signature instead of the BBL_CR_D3 behaviour. The GP mask
264 of the database entry should take care of most illegal writes for now, so
265 just ignore all writes atm. */
266 return VINF_SUCCESS;
267}
268
269
270/** @callback_method_impl{FNCPUMWRMSR} */
271static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32BiosUpdateTrigger(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
272{
273 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
274 /** @todo Fake bios update trigger better. The value is the address to an
275 * update package, I think. We should probably GP if it's invalid. */
276 return VINF_SUCCESS;
277}
278
279
280/** @callback_method_impl{FNCPUMRDMSR} */
281static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32SmmMonitorCtl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
282{
283 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
284 /** @todo SMM. */
285 *puValue = 0;
286 return VINF_SUCCESS;
287}
288
289
290/** @callback_method_impl{FNCPUMWRMSR} */
291static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32SmmMonitorCtl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
292{
293 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
294 /** @todo SMM. */
295 return VINF_SUCCESS;
296}
297
298
299/** @callback_method_impl{FNCPUMRDMSR} */
300static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32PmcN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
301{
302 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
303 /** @todo check CPUID leaf 0ah. */
304 *puValue = 0;
305 return VINF_SUCCESS;
306}
307
308
309/** @callback_method_impl{FNCPUMWRMSR} */
310static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32PmcN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
311{
312 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
313 /** @todo check CPUID leaf 0ah. */
314 return VINF_SUCCESS;
315}
316
317
318/** @callback_method_impl{FNCPUMRDMSR} */
319static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32MonitorFilterLineSize(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
320{
321 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
322 /** @todo return 0x1000 if we try emulate mwait 100% correctly. */
323 *puValue = 0x40; /** @todo Change to CPU cache line size. */
324 return VINF_SUCCESS;
325}
326
327
328/** @callback_method_impl{FNCPUMWRMSR} */
329static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32MonitorFilterLineSize(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
330{
331 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
332 /** @todo should remember writes, though it's supposedly something only a BIOS
333 * would write so, it's not extremely important. */
334 return VINF_SUCCESS;
335}
336
337/** @callback_method_impl{FNCPUMRDMSR} */
338static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32MPerf(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
339{
340 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
341 /** @todo Read MPERF: Adjust against previously written MPERF value. Is TSC
342 * what we want? */
343 *puValue = TMCpuTickGet(pVCpu);
344 return VINF_SUCCESS;
345}
346
347
348/** @callback_method_impl{FNCPUMWRMSR} */
349static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32MPerf(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
350{
351 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
352 /** @todo Write MPERF: Calc adjustment. */
353 return VINF_SUCCESS;
354}
355
356
357/** @callback_method_impl{FNCPUMRDMSR} */
358static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32APerf(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
359{
360 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
361 /** @todo Read APERF: Adjust against previously written MPERF value. Is TSC
362 * what we want? */
363 *puValue = TMCpuTickGet(pVCpu);
364 return VINF_SUCCESS;
365}
366
367
368/** @callback_method_impl{FNCPUMWRMSR} */
369static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32APerf(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
370{
371 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
372 /** @todo Write APERF: Calc adjustment. */
373 return VINF_SUCCESS;
374}
375
376
377/** @callback_method_impl{FNCPUMRDMSR} */
378static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32MtrrCap(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
379{
380 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
381
382 /* This is currently a bit weird. :-) */
383 uint8_t const cVariableRangeRegs = 0;
384 bool const fSystemManagementRangeRegisters = false;
385 bool const fFixedRangeRegisters = false;
386 bool const fWriteCombiningType = false;
387 *puValue = cVariableRangeRegs
388 | (fFixedRangeRegisters ? RT_BIT_64(8) : 0)
389 | (fWriteCombiningType ? RT_BIT_64(10) : 0)
390 | (fSystemManagementRangeRegisters ? RT_BIT_64(11) : 0);
391 return VINF_SUCCESS;
392}
393
394
395/** @callback_method_impl{FNCPUMRDMSR} */
396static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32MtrrPhysBaseN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
397{
398 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
399 /** @todo Implement variable MTRR storage. */
400 Assert(pRange->uValue == (idMsr - 0x200) / 2);
401 *puValue = 0;
402 return VINF_SUCCESS;
403}
404
405
406/** @callback_method_impl{FNCPUMWRMSR} */
407static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32MtrrPhysBaseN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
408{
409 /*
410 * Validate the value.
411 */
412 Assert(pRange->uValue == (idMsr - 0x200) / 2);
413 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(uRawValue); RT_NOREF_PV(pRange);
414
415 if ((uValue & 0xff) >= 7)
416 {
417 Log(("CPUM: Invalid type set writing MTRR PhysBase MSR %#x: %#llx (%#llx)\n", idMsr, uValue, uValue & 0xff));
418 return VERR_CPUM_RAISE_GP_0;
419 }
420
421 uint64_t fInvPhysMask = ~(RT_BIT_64(pVCpu->CTX_SUFF(pVM)->cpum.s.GuestFeatures.cMaxPhysAddrWidth) - 1U);
422 if (fInvPhysMask & uValue)
423 {
424 Log(("CPUM: Invalid physical address bits set writing MTRR PhysBase MSR %#x: %#llx (%#llx)\n",
425 idMsr, uValue, uValue & fInvPhysMask));
426 return VERR_CPUM_RAISE_GP_0;
427 }
428
429 /*
430 * Store it.
431 */
432 /** @todo Implement variable MTRR storage. */
433 return VINF_SUCCESS;
434}
435
436
437/** @callback_method_impl{FNCPUMRDMSR} */
438static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32MtrrPhysMaskN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
439{
440 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
441 /** @todo Implement variable MTRR storage. */
442 Assert(pRange->uValue == (idMsr - 0x200) / 2);
443 *puValue = 0;
444 return VINF_SUCCESS;
445}
446
447
448/** @callback_method_impl{FNCPUMWRMSR} */
449static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32MtrrPhysMaskN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
450{
451 /*
452 * Validate the value.
453 */
454 Assert(pRange->uValue == (idMsr - 0x200) / 2);
455 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(uRawValue); RT_NOREF_PV(pRange);
456
457 uint64_t fInvPhysMask = ~(RT_BIT_64(pVCpu->CTX_SUFF(pVM)->cpum.s.GuestFeatures.cMaxPhysAddrWidth) - 1U);
458 if (fInvPhysMask & uValue)
459 {
460 Log(("CPUM: Invalid physical address bits set writing MTRR PhysMask MSR %#x: %#llx (%#llx)\n",
461 idMsr, uValue, uValue & fInvPhysMask));
462 return VERR_CPUM_RAISE_GP_0;
463 }
464
465 /*
466 * Store it.
467 */
468 /** @todo Implement variable MTRR storage. */
469 return VINF_SUCCESS;
470}
471
472
473/** @callback_method_impl{FNCPUMRDMSR} */
474static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32MtrrFixed(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
475{
476 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
477 CPUM_MSR_ASSERT_CPUMCPU_OFFSET_RETURN(pVCpu, pRange, uint64_t, puFixedMtrr);
478 *puValue = *puFixedMtrr;
479 return VINF_SUCCESS;
480}
481
482
483/** @callback_method_impl{FNCPUMWRMSR} */
484static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32MtrrFixed(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
485{
486 CPUM_MSR_ASSERT_CPUMCPU_OFFSET_RETURN(pVCpu, pRange, uint64_t, puFixedMtrr);
487 RT_NOREF_PV(idMsr); RT_NOREF_PV(uRawValue);
488
489 for (uint32_t cShift = 0; cShift < 63; cShift += 8)
490 {
491 uint8_t uType = (uint8_t)(uValue >> cShift);
492 if (uType >= 7)
493 {
494 Log(("CPUM: Invalid MTRR type at %u:%u in fixed range (%#x/%s): %#llx (%#llx)\n",
495 cShift + 7, cShift, idMsr, pRange->szName, uValue, uType));
496 return VERR_CPUM_RAISE_GP_0;
497 }
498 }
499 *puFixedMtrr = uValue;
500 return VINF_SUCCESS;
501}
502
503
504/** @callback_method_impl{FNCPUMRDMSR} */
505static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32MtrrDefType(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
506{
507 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
508 *puValue = pVCpu->cpum.s.GuestMsrs.msr.MtrrDefType;
509 return VINF_SUCCESS;
510}
511
512
513/** @callback_method_impl{FNCPUMWRMSR} */
514static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32MtrrDefType(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
515{
516 RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uRawValue);
517
518 if ((uValue & 0xff) >= 7)
519 {
520 Log(("CPUM: Invalid MTRR default type value on %s: %#llx (%#llx)\n", pRange->szName, uValue, uValue & 0xff));
521 return VERR_CPUM_RAISE_GP_0;
522 }
523
524 pVCpu->cpum.s.GuestMsrs.msr.MtrrDefType = uValue;
525 return VINF_SUCCESS;
526}
527
528
529/** @callback_method_impl{FNCPUMRDMSR} */
530static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32Pat(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
531{
532 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
533 *puValue = pVCpu->cpum.s.Guest.msrPAT;
534 return VINF_SUCCESS;
535}
536
537
538/** @callback_method_impl{FNCPUMWRMSR} */
539static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32Pat(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
540{
541 RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uRawValue);
542 pVCpu->cpum.s.Guest.msrPAT = uValue;
543 return VINF_SUCCESS;
544}
545
546
547/** @callback_method_impl{FNCPUMRDMSR} */
548static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32SysEnterCs(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
549{
550 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
551 *puValue = pVCpu->cpum.s.Guest.SysEnter.cs;
552 return VINF_SUCCESS;
553}
554
555
556/** @callback_method_impl{FNCPUMWRMSR} */
557static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32SysEnterCs(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
558{
559 RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uRawValue);
560
561 /* Note! We used to mask this by 0xffff, but turns out real HW doesn't and
562 there are generally 32-bit working bits backing this register. */
563 pVCpu->cpum.s.Guest.SysEnter.cs = uValue;
564 return VINF_SUCCESS;
565}
566
567
568/** @callback_method_impl{FNCPUMRDMSR} */
569static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32SysEnterEsp(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
570{
571 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
572 *puValue = pVCpu->cpum.s.Guest.SysEnter.esp;
573 return VINF_SUCCESS;
574}
575
576
577/** @callback_method_impl{FNCPUMWRMSR} */
578static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32SysEnterEsp(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
579{
580 if (X86_IS_CANONICAL(uValue))
581 {
582 pVCpu->cpum.s.Guest.SysEnter.esp = uValue;
583 return VINF_SUCCESS;
584 }
585 Log(("CPUM: IA32_SYSENTER_ESP not canonical! %#llx\n", uValue));
586 RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uRawValue);
587 return VERR_CPUM_RAISE_GP_0;
588}
589
590
591/** @callback_method_impl{FNCPUMRDMSR} */
592static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32SysEnterEip(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
593{
594 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
595 *puValue = pVCpu->cpum.s.Guest.SysEnter.eip;
596 return VINF_SUCCESS;
597}
598
599
600/** @callback_method_impl{FNCPUMWRMSR} */
601static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32SysEnterEip(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
602{
603 if (X86_IS_CANONICAL(uValue))
604 {
605 pVCpu->cpum.s.Guest.SysEnter.eip = uValue;
606 return VINF_SUCCESS;
607 }
608#ifdef IN_RING3
609 LogRel(("CPUM: IA32_SYSENTER_EIP not canonical! %#llx\n", uValue));
610#else
611 Log(("CPUM: IA32_SYSENTER_EIP not canonical! %#llx\n", uValue));
612#endif
613 RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uRawValue);
614 return VERR_CPUM_RAISE_GP_0;
615}
616
617
618/** @callback_method_impl{FNCPUMRDMSR} */
619static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32McgCap(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
620{
621#if 0 /** @todo implement machine checks. */
622 *puValue = pRange->uValue & (RT_BIT_64(8) | 0);
623#else
624 *puValue = 0;
625#endif
626 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
627 return VINF_SUCCESS;
628}
629
630
631/** @callback_method_impl{FNCPUMRDMSR} */
632static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32McgStatus(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
633{
634 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
635 /** @todo implement machine checks. */
636 *puValue = 0;
637 return VINF_SUCCESS;
638}
639
640
641/** @callback_method_impl{FNCPUMWRMSR} */
642static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32McgStatus(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
643{
644 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
645 /** @todo implement machine checks. */
646 return VINF_SUCCESS;
647}
648
649
650/** @callback_method_impl{FNCPUMRDMSR} */
651static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32McgCtl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
652{
653 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
654 /** @todo implement machine checks. */
655 *puValue = 0;
656 return VINF_SUCCESS;
657}
658
659
660/** @callback_method_impl{FNCPUMWRMSR} */
661static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32McgCtl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
662{
663 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
664 /** @todo implement machine checks. */
665 return VINF_SUCCESS;
666}
667
668
669/** @callback_method_impl{FNCPUMRDMSR} */
670static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32DebugCtl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
671{
672 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
673 /** @todo implement IA32_DEBUGCTL. */
674 *puValue = 0;
675 return VINF_SUCCESS;
676}
677
678
679/** @callback_method_impl{FNCPUMWRMSR} */
680static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32DebugCtl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
681{
682 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
683 /** @todo implement IA32_DEBUGCTL. */
684 return VINF_SUCCESS;
685}
686
687
688/** @callback_method_impl{FNCPUMRDMSR} */
689static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32SmrrPhysBase(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
690{
691 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
692 /** @todo implement intel SMM. */
693 *puValue = 0;
694 return VINF_SUCCESS;
695}
696
697
698/** @callback_method_impl{FNCPUMWRMSR} */
699static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32SmrrPhysBase(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
700{
701 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
702 /** @todo implement intel SMM. */
703 return VERR_CPUM_RAISE_GP_0;
704}
705
706
707/** @callback_method_impl{FNCPUMRDMSR} */
708static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32SmrrPhysMask(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
709{
710 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
711 /** @todo implement intel SMM. */
712 *puValue = 0;
713 return VINF_SUCCESS;
714}
715
716
717/** @callback_method_impl{FNCPUMWRMSR} */
718static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32SmrrPhysMask(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
719{
720 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
721 /** @todo implement intel SMM. */
722 return VERR_CPUM_RAISE_GP_0;
723}
724
725
726/** @callback_method_impl{FNCPUMRDMSR} */
727static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32PlatformDcaCap(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
728{
729 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
730 /** @todo implement intel direct cache access (DCA)?? */
731 *puValue = 0;
732 return VINF_SUCCESS;
733}
734
735
736/** @callback_method_impl{FNCPUMWRMSR} */
737static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32PlatformDcaCap(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
738{
739 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
740 /** @todo implement intel direct cache access (DCA)?? */
741 return VINF_SUCCESS;
742}
743
744
745/** @callback_method_impl{FNCPUMRDMSR} */
746static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32CpuDcaCap(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
747{
748 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
749 /** @todo implement intel direct cache access (DCA)?? */
750 *puValue = 0;
751 return VINF_SUCCESS;
752}
753
754
755/** @callback_method_impl{FNCPUMRDMSR} */
756static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32Dca0Cap(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
757{
758 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
759 /** @todo implement intel direct cache access (DCA)?? */
760 *puValue = 0;
761 return VINF_SUCCESS;
762}
763
764
765/** @callback_method_impl{FNCPUMWRMSR} */
766static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32Dca0Cap(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
767{
768 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
769 /** @todo implement intel direct cache access (DCA)?? */
770 return VINF_SUCCESS;
771}
772
773
774/** @callback_method_impl{FNCPUMRDMSR} */
775static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32PerfEvtSelN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
776{
777 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
778 /** @todo implement IA32_PERFEVTSEL0+. */
779 *puValue = 0;
780 return VINF_SUCCESS;
781}
782
783
784/** @callback_method_impl{FNCPUMWRMSR} */
785static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32PerfEvtSelN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
786{
787 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
788 /** @todo implement IA32_PERFEVTSEL0+. */
789 return VINF_SUCCESS;
790}
791
792
793/** @callback_method_impl{FNCPUMRDMSR} */
794static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32PerfStatus(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
795{
796 RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
797 uint64_t uValue = pRange->uValue;
798
799 /* Always provide the max bus ratio for now. XNU expects it. */
800 uValue &= ~((UINT64_C(0x1f) << 40) | RT_BIT_64(46));
801
802 PVM pVM = pVCpu->CTX_SUFF(pVM);
803 uint64_t uScalableBusHz = CPUMGetGuestScalableBusFrequency(pVM);
804 uint64_t uTscHz = TMCpuTicksPerSecond(pVM);
805 uint8_t uTscRatio = (uint8_t)((uTscHz + uScalableBusHz / 2) / uScalableBusHz);
806 if (uTscRatio > 0x1f)
807 uTscRatio = 0x1f;
808 uValue |= (uint64_t)uTscRatio << 40;
809
810 *puValue = uValue;
811 return VINF_SUCCESS;
812}
813
814
815/** @callback_method_impl{FNCPUMWRMSR} */
816static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32PerfStatus(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
817{
818 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
819 /* Pentium4 allows writing, but all bits are ignored. */
820 return VINF_SUCCESS;
821}
822
823
824/** @callback_method_impl{FNCPUMRDMSR} */
825static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32PerfCtl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
826{
827 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
828 /** @todo implement IA32_PERFCTL. */
829 *puValue = 0;
830 return VINF_SUCCESS;
831}
832
833
834/** @callback_method_impl{FNCPUMWRMSR} */
835static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32PerfCtl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
836{
837 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
838 /** @todo implement IA32_PERFCTL. */
839 return VINF_SUCCESS;
840}
841
842
843/** @callback_method_impl{FNCPUMRDMSR} */
844static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32FixedCtrN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
845{
846 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
847 /** @todo implement IA32_FIXED_CTRn (fixed performance counters). */
848 *puValue = 0;
849 return VINF_SUCCESS;
850}
851
852
853/** @callback_method_impl{FNCPUMWRMSR} */
854static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32FixedCtrN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
855{
856 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
857 /** @todo implement IA32_FIXED_CTRn (fixed performance counters). */
858 return VINF_SUCCESS;
859}
860
861
862/** @callback_method_impl{FNCPUMRDMSR} */
863static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32PerfCapabilities(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
864{
865 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
866 /** @todo implement performance counters. */
867 *puValue = 0;
868 return VINF_SUCCESS;
869}
870
871
872/** @callback_method_impl{FNCPUMWRMSR} */
873static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32PerfCapabilities(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
874{
875 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
876 /** @todo implement performance counters. */
877 return VINF_SUCCESS;
878}
879
880
881/** @callback_method_impl{FNCPUMRDMSR} */
882static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32FixedCtrCtrl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
883{
884 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
885 /** @todo implement performance counters. */
886 *puValue = 0;
887 return VINF_SUCCESS;
888}
889
890
891/** @callback_method_impl{FNCPUMWRMSR} */
892static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32FixedCtrCtrl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
893{
894 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
895 /** @todo implement performance counters. */
896 return VINF_SUCCESS;
897}
898
899
900/** @callback_method_impl{FNCPUMRDMSR} */
901static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32PerfGlobalStatus(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
902{
903 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
904 /** @todo implement performance counters. */
905 *puValue = 0;
906 return VINF_SUCCESS;
907}
908
909
910/** @callback_method_impl{FNCPUMWRMSR} */
911static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32PerfGlobalStatus(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
912{
913 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
914 /** @todo implement performance counters. */
915 return VINF_SUCCESS;
916}
917
918
919/** @callback_method_impl{FNCPUMRDMSR} */
920static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32PerfGlobalCtrl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
921{
922 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
923 /** @todo implement performance counters. */
924 *puValue = 0;
925 return VINF_SUCCESS;
926}
927
928
929/** @callback_method_impl{FNCPUMWRMSR} */
930static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32PerfGlobalCtrl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
931{
932 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
933 /** @todo implement performance counters. */
934 return VINF_SUCCESS;
935}
936
937
938/** @callback_method_impl{FNCPUMRDMSR} */
939static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32PerfGlobalOvfCtrl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
940{
941 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
942 /** @todo implement performance counters. */
943 *puValue = 0;
944 return VINF_SUCCESS;
945}
946
947
948/** @callback_method_impl{FNCPUMWRMSR} */
949static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32PerfGlobalOvfCtrl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
950{
951 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
952 /** @todo implement performance counters. */
953 return VINF_SUCCESS;
954}
955
956
957/** @callback_method_impl{FNCPUMRDMSR} */
958static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32PebsEnable(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
959{
960 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
961 /** @todo implement performance counters. */
962 *puValue = 0;
963 return VINF_SUCCESS;
964}
965
966
967/** @callback_method_impl{FNCPUMWRMSR} */
968static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32PebsEnable(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
969{
970 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
971 /** @todo implement performance counters. */
972 return VINF_SUCCESS;
973}
974
975
976/** @callback_method_impl{FNCPUMRDMSR} */
977static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32ClockModulation(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
978{
979 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
980 /** @todo implement IA32_CLOCK_MODULATION. */
981 *puValue = 0;
982 return VINF_SUCCESS;
983}
984
985
986/** @callback_method_impl{FNCPUMWRMSR} */
987static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32ClockModulation(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
988{
989 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
990 /** @todo implement IA32_CLOCK_MODULATION. */
991 return VINF_SUCCESS;
992}
993
994
995/** @callback_method_impl{FNCPUMRDMSR} */
996static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32ThermInterrupt(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
997{
998 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
999 /** @todo implement IA32_THERM_INTERRUPT. */
1000 *puValue = 0;
1001 return VINF_SUCCESS;
1002}
1003
1004
1005/** @callback_method_impl{FNCPUMWRMSR} */
1006static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32ThermInterrupt(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
1007{
1008 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
1009 /** @todo implement IA32_THERM_STATUS. */
1010 return VINF_SUCCESS;
1011}
1012
1013
1014/** @callback_method_impl{FNCPUMRDMSR} */
1015static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32ThermStatus(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1016{
1017 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1018 /** @todo implement IA32_THERM_STATUS. */
1019 *puValue = 0;
1020 return VINF_SUCCESS;
1021}
1022
1023
1024/** @callback_method_impl{FNCPUMWRMSR} */
1025static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32ThermStatus(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
1026{
1027 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
1028 /** @todo implement IA32_THERM_INTERRUPT. */
1029 return VINF_SUCCESS;
1030}
1031
1032
1033/** @callback_method_impl{FNCPUMRDMSR} */
1034static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32Therm2Ctl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1035{
1036 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1037 /** @todo implement IA32_THERM2_CTL. */
1038 *puValue = 0;
1039 return VINF_SUCCESS;
1040}
1041
1042
1043/** @callback_method_impl{FNCPUMWRMSR} */
1044static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32Therm2Ctl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
1045{
1046 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
1047 /** @todo implement IA32_THERM2_CTL. */
1048 return VINF_SUCCESS;
1049}
1050
1051
1052/** @callback_method_impl{FNCPUMRDMSR} */
1053static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32MiscEnable(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1054{
1055 RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1056 *puValue = pVCpu->cpum.s.GuestMsrs.msr.MiscEnable;
1057 return VINF_SUCCESS;
1058}
1059
1060
1061/** @callback_method_impl{FNCPUMWRMSR} */
1062static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32MiscEnable(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
1063{
1064 RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
1065#ifdef LOG_ENABLED
1066 uint64_t const uOld = pVCpu->cpum.s.GuestMsrs.msr.MiscEnable;
1067#endif
1068
1069 /* Unsupported bits are generally ignored and stripped by the MSR range
1070 entry that got us here. So, we just need to preserve fixed bits. */
1071 pVCpu->cpum.s.GuestMsrs.msr.MiscEnable = uValue
1072 | MSR_IA32_MISC_ENABLE_PEBS_UNAVAIL
1073 | MSR_IA32_MISC_ENABLE_BTS_UNAVAIL;
1074
1075 Log(("CPUM: IA32_MISC_ENABLE; old=%#llx written=%#llx => %#llx\n",
1076 uOld, uValue, pVCpu->cpum.s.GuestMsrs.msr.MiscEnable));
1077
1078 /** @todo Wire IA32_MISC_ENABLE bit 22 to our NT 4 CPUID trick. */
1079 /** @todo Wire up MSR_IA32_MISC_ENABLE_XD_DISABLE. */
1080 return VINF_SUCCESS;
1081}
1082
1083
1084/** @callback_method_impl{FNCPUMRDMSR} */
1085static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32McCtlStatusAddrMiscN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1086{
1087 RT_NOREF_PV(pVCpu); RT_NOREF_PV(pRange);
1088
1089 /** @todo Implement machine check exception injection. */
1090 switch (idMsr & 3)
1091 {
1092 case 0:
1093 case 1:
1094 *puValue = 0;
1095 break;
1096
1097 /* The ADDR and MISC registers aren't accessible since the
1098 corresponding STATUS bits are zero. */
1099 case 2:
1100 Log(("CPUM: Reading IA32_MCi_ADDR %#x -> #GP\n", idMsr));
1101 return VERR_CPUM_RAISE_GP_0;
1102 case 3:
1103 Log(("CPUM: Reading IA32_MCi_MISC %#x -> #GP\n", idMsr));
1104 return VERR_CPUM_RAISE_GP_0;
1105 }
1106 return VINF_SUCCESS;
1107}
1108
1109
1110/** @callback_method_impl{FNCPUMWRMSR} */
1111static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32McCtlStatusAddrMiscN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
1112{
1113 RT_NOREF_PV(pVCpu); RT_NOREF_PV(pRange); RT_NOREF_PV(uRawValue);
1114 switch (idMsr & 3)
1115 {
1116 case 0:
1117 /* Ignore writes to the CTL register. */
1118 break;
1119
1120 case 1:
1121 /* According to specs, the STATUS register can only be written to
1122 with the value 0. VBoxCpuReport thinks different for a
1123 Pentium M Dothan, but implementing according to specs now. */
1124 if (uValue != 0)
1125 {
1126 Log(("CPUM: Writing non-zero value (%#llx) to IA32_MCi_STATUS %#x -> #GP\n", uValue, idMsr));
1127 return VERR_CPUM_RAISE_GP_0;
1128 }
1129 break;
1130
1131 /* Specs states that ADDR and MISC can be cleared by writing zeros.
1132 Writing 1s will GP. Need to figure out how this relates to the
1133 ADDRV and MISCV status flags. If writing is independent of those
1134 bits, we need to know whether the CPU really implements them since
1135 that is exposed by writing 0 to them.
1136 Implementing the solution with the fewer GPs for now. */
1137 case 2:
1138 if (uValue != 0)
1139 {
1140 Log(("CPUM: Writing non-zero value (%#llx) to IA32_MCi_ADDR %#x -> #GP\n", uValue, idMsr));
1141 return VERR_CPUM_RAISE_GP_0;
1142 }
1143 break;
1144 case 3:
1145 if (uValue != 0)
1146 {
1147 Log(("CPUM: Writing non-zero value (%#llx) to IA32_MCi_MISC %#x -> #GP\n", uValue, idMsr));
1148 return VERR_CPUM_RAISE_GP_0;
1149 }
1150 break;
1151 }
1152 return VINF_SUCCESS;
1153}
1154
1155
1156/** @callback_method_impl{FNCPUMRDMSR} */
1157static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32McNCtl2(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1158{
1159 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1160 /** @todo Implement machine check exception injection. */
1161 *puValue = 0;
1162 return VINF_SUCCESS;
1163}
1164
1165
1166/** @callback_method_impl{FNCPUMWRMSR} */
1167static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32McNCtl2(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
1168{
1169 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
1170 /** @todo Implement machine check exception injection. */
1171 return VINF_SUCCESS;
1172}
1173
1174
1175/** @callback_method_impl{FNCPUMRDMSR} */
1176static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32DsArea(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1177{
1178 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1179 /** @todo implement IA32_DS_AREA. */
1180 *puValue = 0;
1181 return VINF_SUCCESS;
1182}
1183
1184
1185/** @callback_method_impl{FNCPUMWRMSR} */
1186static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32DsArea(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
1187{
1188 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
1189 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
1190 return VINF_SUCCESS;
1191}
1192
1193
1194/** @callback_method_impl{FNCPUMRDMSR} */
1195static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32TscDeadline(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1196{
1197 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1198 /** @todo implement TSC deadline timer. */
1199 *puValue = 0;
1200 return VINF_SUCCESS;
1201}
1202
1203
1204/** @callback_method_impl{FNCPUMWRMSR} */
1205static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32TscDeadline(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
1206{
1207 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
1208 /** @todo implement TSC deadline timer. */
1209 return VINF_SUCCESS;
1210}
1211
1212
1213/** @callback_method_impl{FNCPUMRDMSR} */
1214static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32X2ApicN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1215{
1216 RT_NOREF_PV(pRange);
1217 return APICReadMsr(pVCpu, idMsr, puValue);
1218}
1219
1220
1221/** @callback_method_impl{FNCPUMWRMSR} */
1222static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32X2ApicN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
1223{
1224 RT_NOREF_PV(pRange); RT_NOREF_PV(uRawValue);
1225 return APICWriteMsr(pVCpu, idMsr, uValue);
1226}
1227
1228
1229/** @callback_method_impl{FNCPUMRDMSR} */
1230static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32DebugInterface(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1231{
1232 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1233 /** @todo IA32_DEBUG_INTERFACE (no docs) */
1234 *puValue = 0;
1235 return VINF_SUCCESS;
1236}
1237
1238
1239/** @callback_method_impl{FNCPUMWRMSR} */
1240static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Ia32DebugInterface(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
1241{
1242 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
1243 /** @todo IA32_DEBUG_INTERFACE (no docs) */
1244 return VINF_SUCCESS;
1245}
1246
1247
1248/** @callback_method_impl{FNCPUMRDMSR} */
1249static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32VmxBase(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1250{
1251 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1252 *puValue = 0;
1253 return VINF_SUCCESS;
1254}
1255
1256
1257/** @callback_method_impl{FNCPUMRDMSR} */
1258static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32VmxPinbasedCtls(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1259{
1260 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1261 *puValue = 0;
1262 return VINF_SUCCESS;
1263}
1264
1265
1266/** @callback_method_impl{FNCPUMRDMSR} */
1267static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32VmxProcbasedCtls(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1268{
1269 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1270 *puValue = 0;
1271 return VINF_SUCCESS;
1272}
1273
1274
1275/** @callback_method_impl{FNCPUMRDMSR} */
1276static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32VmxExitCtls(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1277{
1278 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1279 *puValue = 0;
1280 return VINF_SUCCESS;
1281}
1282
1283
1284/** @callback_method_impl{FNCPUMRDMSR} */
1285static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32VmxEntryCtls(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1286{
1287 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1288 *puValue = 0;
1289 return VINF_SUCCESS;
1290}
1291
1292
1293/** @callback_method_impl{FNCPUMRDMSR} */
1294static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32VmxMisc(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1295{
1296 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1297 *puValue = 0;
1298 return VINF_SUCCESS;
1299}
1300
1301
1302/** @callback_method_impl{FNCPUMRDMSR} */
1303static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32VmxCr0Fixed0(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1304{
1305 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1306 *puValue = 0;
1307 return VINF_SUCCESS;
1308}
1309
1310
1311/** @callback_method_impl{FNCPUMRDMSR} */
1312static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32VmxCr0Fixed1(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1313{
1314 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1315 *puValue = 0;
1316 return VINF_SUCCESS;
1317}
1318
1319
1320/** @callback_method_impl{FNCPUMRDMSR} */
1321static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32VmxCr4Fixed0(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1322{
1323 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1324 *puValue = 0;
1325 return VINF_SUCCESS;
1326}
1327
1328
1329/** @callback_method_impl{FNCPUMRDMSR} */
1330static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32VmxCr4Fixed1(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1331{
1332 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1333 *puValue = 0;
1334 return VINF_SUCCESS;
1335}
1336
1337
1338/** @callback_method_impl{FNCPUMRDMSR} */
1339static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32VmxVmcsEnum(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1340{
1341 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1342 *puValue = 0;
1343 return VINF_SUCCESS;
1344}
1345
1346
1347/** @callback_method_impl{FNCPUMRDMSR} */
1348static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32VmxProcBasedCtls2(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1349{
1350 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1351 *puValue = 0;
1352 return VINF_SUCCESS;
1353}
1354
1355
1356/** @callback_method_impl{FNCPUMRDMSR} */
1357static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32VmxEptVpidCap(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1358{
1359 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1360 *puValue = 0;
1361 return VINF_SUCCESS;
1362}
1363
1364
1365/** @callback_method_impl{FNCPUMRDMSR} */
1366static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32VmxTruePinbasedCtls(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1367{
1368 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1369 *puValue = 0;
1370 return VINF_SUCCESS;
1371}
1372
1373
1374/** @callback_method_impl{FNCPUMRDMSR} */
1375static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32VmxTrueProcbasedCtls(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1376{
1377 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1378 *puValue = 0;
1379 return VINF_SUCCESS;
1380}
1381
1382
1383/** @callback_method_impl{FNCPUMRDMSR} */
1384static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32VmxTrueExitCtls(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1385{
1386 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1387 *puValue = 0;
1388 return VINF_SUCCESS;
1389}
1390
1391
1392/** @callback_method_impl{FNCPUMRDMSR} */
1393static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32VmxTrueEntryCtls(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1394{
1395 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1396 *puValue = 0;
1397 return VINF_SUCCESS;
1398}
1399
1400
1401/** @callback_method_impl{FNCPUMRDMSR} */
1402static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Ia32VmxVmFunc(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1403{
1404 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1405 *puValue = 0;
1406 return VINF_SUCCESS;
1407}
1408
1409
1410
1411
1412
1413
1414
1415
1416
1417
1418/*
1419 * AMD64
1420 * AMD64
1421 * AMD64
1422 */
1423
1424
1425/** @callback_method_impl{FNCPUMRDMSR} */
1426static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Amd64Efer(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1427{
1428 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1429 *puValue = pVCpu->cpum.s.Guest.msrEFER;
1430 return VINF_SUCCESS;
1431}
1432
1433
1434/** @callback_method_impl{FNCPUMWRMSR} */
1435static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Amd64Efer(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
1436{
1437 RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uRawValue);
1438 uint64_t uValidatedEfer;
1439 uint64_t const uOldEfer = pVCpu->cpum.s.Guest.msrEFER;
1440 int rc = CPUMQueryValidatedGuestEfer(pVCpu->CTX_SUFF(pVM), pVCpu->cpum.s.Guest.cr0, uOldEfer, uValue, &uValidatedEfer);
1441 if (RT_FAILURE(rc))
1442 return VERR_CPUM_RAISE_GP_0;
1443
1444 pVCpu->cpum.s.Guest.msrEFER = uValidatedEfer;
1445
1446 /* AMD64 Architecture Programmer's Manual: 15.15 TLB Control; flush the TLB
1447 if MSR_K6_EFER_NXE, MSR_K6_EFER_LME or MSR_K6_EFER_LMA are changed. */
1448 if ( (uOldEfer & (MSR_K6_EFER_NXE | MSR_K6_EFER_LME | MSR_K6_EFER_LMA))
1449 != (pVCpu->cpum.s.Guest.msrEFER & (MSR_K6_EFER_NXE | MSR_K6_EFER_LME | MSR_K6_EFER_LMA)))
1450 {
1451 /// @todo PGMFlushTLB(pVCpu, cr3, true /*fGlobal*/);
1452 HMFlushTLB(pVCpu);
1453
1454 /* Notify PGM about NXE changes. */
1455 if ( (uOldEfer & MSR_K6_EFER_NXE)
1456 != (pVCpu->cpum.s.Guest.msrEFER & MSR_K6_EFER_NXE))
1457 PGMNotifyNxeChanged(pVCpu, !(uOldEfer & MSR_K6_EFER_NXE));
1458 }
1459 return VINF_SUCCESS;
1460}
1461
1462
1463/** @callback_method_impl{FNCPUMRDMSR} */
1464static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Amd64SyscallTarget(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1465{
1466 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1467 *puValue = pVCpu->cpum.s.Guest.msrSTAR;
1468 return VINF_SUCCESS;
1469}
1470
1471
1472/** @callback_method_impl{FNCPUMWRMSR} */
1473static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Amd64SyscallTarget(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
1474{
1475 RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uRawValue);
1476 pVCpu->cpum.s.Guest.msrSTAR = uValue;
1477 return VINF_SUCCESS;
1478}
1479
1480
1481/** @callback_method_impl{FNCPUMRDMSR} */
1482static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Amd64LongSyscallTarget(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1483{
1484 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1485 *puValue = pVCpu->cpum.s.Guest.msrLSTAR;
1486 return VINF_SUCCESS;
1487}
1488
1489
1490/** @callback_method_impl{FNCPUMWRMSR} */
1491static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Amd64LongSyscallTarget(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
1492{
1493 RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uRawValue);
1494 if (!X86_IS_CANONICAL(uValue))
1495 {
1496 Log(("CPUM: wrmsr %s(%#x), %#llx -> #GP - not canonical\n", pRange->szName, idMsr, uValue));
1497 return VERR_CPUM_RAISE_GP_0;
1498 }
1499 pVCpu->cpum.s.Guest.msrLSTAR = uValue;
1500 return VINF_SUCCESS;
1501}
1502
1503
1504/** @callback_method_impl{FNCPUMRDMSR} */
1505static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Amd64CompSyscallTarget(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1506{
1507 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1508 *puValue = pVCpu->cpum.s.Guest.msrCSTAR;
1509 return VINF_SUCCESS;
1510}
1511
1512
1513/** @callback_method_impl{FNCPUMWRMSR} */
1514static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Amd64CompSyscallTarget(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
1515{
1516 RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uRawValue);
1517 if (!X86_IS_CANONICAL(uValue))
1518 {
1519 Log(("CPUM: wrmsr %s(%#x), %#llx -> #GP - not canonical\n", pRange->szName, idMsr, uValue));
1520 return VERR_CPUM_RAISE_GP_0;
1521 }
1522 pVCpu->cpum.s.Guest.msrCSTAR = uValue;
1523 return VINF_SUCCESS;
1524}
1525
1526
1527/** @callback_method_impl{FNCPUMRDMSR} */
1528static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Amd64SyscallFlagMask(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1529{
1530 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1531 *puValue = pVCpu->cpum.s.Guest.msrSFMASK;
1532 return VINF_SUCCESS;
1533}
1534
1535
1536/** @callback_method_impl{FNCPUMWRMSR} */
1537static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Amd64SyscallFlagMask(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
1538{
1539 RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uRawValue);
1540 pVCpu->cpum.s.Guest.msrSFMASK = uValue;
1541 return VINF_SUCCESS;
1542}
1543
1544
1545/** @callback_method_impl{FNCPUMRDMSR} */
1546static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Amd64FsBase(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1547{
1548 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1549 *puValue = pVCpu->cpum.s.Guest.fs.u64Base;
1550 return VINF_SUCCESS;
1551}
1552
1553
1554/** @callback_method_impl{FNCPUMWRMSR} */
1555static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Amd64FsBase(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
1556{
1557 RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uRawValue);
1558 pVCpu->cpum.s.Guest.fs.u64Base = uValue;
1559 return VINF_SUCCESS;
1560}
1561
1562
1563/** @callback_method_impl{FNCPUMRDMSR} */
1564static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Amd64GsBase(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1565{
1566 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1567 *puValue = pVCpu->cpum.s.Guest.gs.u64Base;
1568 return VINF_SUCCESS;
1569}
1570
1571/** @callback_method_impl{FNCPUMWRMSR} */
1572static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Amd64GsBase(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
1573{
1574 RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uRawValue);
1575 pVCpu->cpum.s.Guest.gs.u64Base = uValue;
1576 return VINF_SUCCESS;
1577}
1578
1579
1580
1581/** @callback_method_impl{FNCPUMRDMSR} */
1582static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Amd64KernelGsBase(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1583{
1584 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1585 *puValue = pVCpu->cpum.s.Guest.msrKERNELGSBASE;
1586 return VINF_SUCCESS;
1587}
1588
1589/** @callback_method_impl{FNCPUMWRMSR} */
1590static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Amd64KernelGsBase(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
1591{
1592 RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uRawValue);
1593 pVCpu->cpum.s.Guest.msrKERNELGSBASE = uValue;
1594 return VINF_SUCCESS;
1595}
1596
1597
1598/** @callback_method_impl{FNCPUMRDMSR} */
1599static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Amd64TscAux(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1600{
1601 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1602 *puValue = pVCpu->cpum.s.GuestMsrs.msr.TscAux;
1603 return VINF_SUCCESS;
1604}
1605
1606/** @callback_method_impl{FNCPUMWRMSR} */
1607static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Amd64TscAux(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
1608{
1609 RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uRawValue);
1610 pVCpu->cpum.s.GuestMsrs.msr.TscAux = uValue;
1611 return VINF_SUCCESS;
1612}
1613
1614
1615/*
1616 * Intel specific
1617 * Intel specific
1618 * Intel specific
1619 */
1620
1621/** @callback_method_impl{FNCPUMRDMSR} */
1622static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelEblCrPowerOn(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1623{
1624 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1625 /** @todo recalc clock frequency ratio? */
1626 *puValue = pRange->uValue;
1627 return VINF_SUCCESS;
1628}
1629
1630
1631/** @callback_method_impl{FNCPUMWRMSR} */
1632static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelEblCrPowerOn(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
1633{
1634 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
1635 /** @todo Write EBL_CR_POWERON: Remember written bits. */
1636 return VINF_SUCCESS;
1637}
1638
1639
1640/** @callback_method_impl{FNCPUMRDMSR} */
1641static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7CoreThreadCount(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1642{
1643 RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1644
1645 /* Note! According to cpuid_set_info in XNU (10.7.0), Westmere CPU only
1646 have a 4-bit core count. */
1647 uint16_t cCores = pVCpu->CTX_SUFF(pVM)->cCpus;
1648 uint16_t cThreads = cCores; /** @todo hyper-threading. */
1649 *puValue = RT_MAKE_U32(cThreads, cCores);
1650 return VINF_SUCCESS;
1651}
1652
1653
1654/** @callback_method_impl{FNCPUMRDMSR} */
1655static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelP4EbcHardPowerOn(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1656{
1657 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1658 /** @todo P4 hard power on config */
1659 *puValue = pRange->uValue;
1660 return VINF_SUCCESS;
1661}
1662
1663
1664/** @callback_method_impl{FNCPUMWRMSR} */
1665static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelP4EbcHardPowerOn(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
1666{
1667 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
1668 /** @todo P4 hard power on config */
1669 return VINF_SUCCESS;
1670}
1671
1672
1673/** @callback_method_impl{FNCPUMRDMSR} */
1674static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelP4EbcSoftPowerOn(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1675{
1676 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1677 /** @todo P4 soft power on config */
1678 *puValue = pRange->uValue;
1679 return VINF_SUCCESS;
1680}
1681
1682
1683/** @callback_method_impl{FNCPUMWRMSR} */
1684static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelP4EbcSoftPowerOn(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
1685{
1686 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
1687 /** @todo P4 soft power on config */
1688 return VINF_SUCCESS;
1689}
1690
1691
1692/** @callback_method_impl{FNCPUMRDMSR} */
1693static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelP4EbcFrequencyId(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1694{
1695 RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1696
1697 uint64_t uValue;
1698 PVM pVM = pVCpu->CTX_SUFF(pVM);
1699 uint64_t uScalableBusHz = CPUMGetGuestScalableBusFrequency(pVM);
1700 if (pVM->cpum.s.GuestFeatures.uModel >= 2)
1701 {
1702 if (uScalableBusHz <= CPUM_SBUSFREQ_100MHZ && pVM->cpum.s.GuestFeatures.uModel <= 2)
1703 {
1704 uScalableBusHz = CPUM_SBUSFREQ_100MHZ;
1705 uValue = 0;
1706 }
1707 else if (uScalableBusHz <= CPUM_SBUSFREQ_133MHZ)
1708 {
1709 uScalableBusHz = CPUM_SBUSFREQ_133MHZ;
1710 uValue = 1;
1711 }
1712 else if (uScalableBusHz <= CPUM_SBUSFREQ_167MHZ)
1713 {
1714 uScalableBusHz = CPUM_SBUSFREQ_167MHZ;
1715 uValue = 3;
1716 }
1717 else if (uScalableBusHz <= CPUM_SBUSFREQ_200MHZ)
1718 {
1719 uScalableBusHz = CPUM_SBUSFREQ_200MHZ;
1720 uValue = 2;
1721 }
1722 else if (uScalableBusHz <= CPUM_SBUSFREQ_267MHZ && pVM->cpum.s.GuestFeatures.uModel > 2)
1723 {
1724 uScalableBusHz = CPUM_SBUSFREQ_267MHZ;
1725 uValue = 0;
1726 }
1727 else
1728 {
1729 uScalableBusHz = CPUM_SBUSFREQ_333MHZ;
1730 uValue = 6;
1731 }
1732 uValue <<= 16;
1733
1734 uint64_t uTscHz = TMCpuTicksPerSecond(pVM);
1735 uint8_t uTscRatio = (uint8_t)((uTscHz + uScalableBusHz / 2) / uScalableBusHz);
1736 uValue |= (uint32_t)uTscRatio << 24;
1737
1738 uValue |= pRange->uValue & ~UINT64_C(0xff0f0000);
1739 }
1740 else
1741 {
1742 /* Probably more stuff here, but intel doesn't want to tell us. */
1743 uValue = pRange->uValue;
1744 uValue &= ~(RT_BIT_64(21) | RT_BIT_64(22) | RT_BIT_64(23)); /* 100 MHz is only documented value */
1745 }
1746
1747 *puValue = uValue;
1748 return VINF_SUCCESS;
1749}
1750
1751
1752/** @callback_method_impl{FNCPUMWRMSR} */
1753static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelP4EbcFrequencyId(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
1754{
1755 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
1756 /** @todo P4 bus frequency config */
1757 return VINF_SUCCESS;
1758}
1759
1760
1761/** @callback_method_impl{FNCPUMRDMSR} */
1762static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelP6FsbFrequency(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1763{
1764 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1765
1766 /* Convert the scalable bus frequency to the encoding in the intel manual (for core+). */
1767 uint64_t uScalableBusHz = CPUMGetGuestScalableBusFrequency(pVCpu->CTX_SUFF(pVM));
1768 if (uScalableBusHz <= CPUM_SBUSFREQ_100MHZ)
1769 *puValue = 5;
1770 else if (uScalableBusHz <= CPUM_SBUSFREQ_133MHZ)
1771 *puValue = 1;
1772 else if (uScalableBusHz <= CPUM_SBUSFREQ_167MHZ)
1773 *puValue = 3;
1774 else if (uScalableBusHz <= CPUM_SBUSFREQ_200MHZ)
1775 *puValue = 2;
1776 else if (uScalableBusHz <= CPUM_SBUSFREQ_267MHZ)
1777 *puValue = 0;
1778 else if (uScalableBusHz <= CPUM_SBUSFREQ_333MHZ)
1779 *puValue = 4;
1780 else /*if (uScalableBusHz <= CPUM_SBUSFREQ_400MHZ)*/
1781 *puValue = 6;
1782
1783 *puValue |= pRange->uValue & ~UINT64_C(0x7);
1784
1785 return VINF_SUCCESS;
1786}
1787
1788
1789/** @callback_method_impl{FNCPUMRDMSR} */
1790static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelPlatformInfo(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1791{
1792 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1793
1794 /* Just indicate a fixed TSC, no turbo boost, no programmable anything. */
1795 PVM pVM = pVCpu->CTX_SUFF(pVM);
1796 uint64_t uScalableBusHz = CPUMGetGuestScalableBusFrequency(pVM);
1797 uint64_t uTscHz = TMCpuTicksPerSecond(pVM);
1798 uint8_t uTscRatio = (uint8_t)((uTscHz + uScalableBusHz / 2) / uScalableBusHz);
1799 uint64_t uValue = ((uint32_t)uTscRatio << 8) /* TSC invariant frequency. */
1800 | ((uint64_t)uTscRatio << 40); /* The max turbo frequency. */
1801
1802 /* Ivy bridge has a minimum operating ratio as well. */
1803 if (true) /** @todo detect sandy bridge. */
1804 uValue |= (uint64_t)uTscRatio << 48;
1805
1806 *puValue = uValue;
1807 return VINF_SUCCESS;
1808}
1809
1810
1811/** @callback_method_impl{FNCPUMRDMSR} */
1812static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelFlexRatio(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1813{
1814 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1815
1816 uint64_t uValue = pRange->uValue & ~UINT64_C(0x1ff00);
1817
1818 PVM pVM = pVCpu->CTX_SUFF(pVM);
1819 uint64_t uScalableBusHz = CPUMGetGuestScalableBusFrequency(pVM);
1820 uint64_t uTscHz = TMCpuTicksPerSecond(pVM);
1821 uint8_t uTscRatio = (uint8_t)((uTscHz + uScalableBusHz / 2) / uScalableBusHz);
1822 uValue |= (uint32_t)uTscRatio << 8;
1823
1824 *puValue = uValue;
1825 return VINF_SUCCESS;
1826}
1827
1828
1829/** @callback_method_impl{FNCPUMWRMSR} */
1830static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelFlexRatio(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
1831{
1832 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
1833 /** @todo implement writing MSR_FLEX_RATIO. */
1834 return VINF_SUCCESS;
1835}
1836
1837
1838/** @callback_method_impl{FNCPUMRDMSR} */
1839static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelPkgCStConfigControl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1840{
1841 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1842 *puValue = pVCpu->cpum.s.GuestMsrs.msr.PkgCStateCfgCtrl;
1843 return VINF_SUCCESS;
1844}
1845
1846
1847/** @callback_method_impl{FNCPUMWRMSR} */
1848static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelPkgCStConfigControl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
1849{
1850 RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uRawValue);
1851
1852 if (pVCpu->cpum.s.GuestMsrs.msr.PkgCStateCfgCtrl & RT_BIT_64(15))
1853 {
1854 Log(("CPUM: WRMSR %#x (%s), %#llx: Write protected -> #GP\n", idMsr, pRange->szName, uValue));
1855 return VERR_CPUM_RAISE_GP_0;
1856 }
1857#if 0 /** @todo check what real (old) hardware does. */
1858 if ((uValue & 7) >= 5)
1859 {
1860 Log(("CPUM: WRMSR %#x (%s), %#llx: Invalid limit (%d) -> #GP\n", idMsr, pRange->szName, uValue, (uint32_t)(uValue & 7)));
1861 return VERR_CPUM_RAISE_GP_0;
1862 }
1863#endif
1864 pVCpu->cpum.s.GuestMsrs.msr.PkgCStateCfgCtrl = uValue;
1865 return VINF_SUCCESS;
1866}
1867
1868
1869/** @callback_method_impl{FNCPUMRDMSR} */
1870static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelPmgIoCaptureBase(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1871{
1872 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1873 /** @todo implement I/O mwait wakeup. */
1874 *puValue = 0;
1875 return VINF_SUCCESS;
1876}
1877
1878
1879/** @callback_method_impl{FNCPUMWRMSR} */
1880static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelPmgIoCaptureBase(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
1881{
1882 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
1883 /** @todo implement I/O mwait wakeup. */
1884 return VINF_SUCCESS;
1885}
1886
1887
1888/** @callback_method_impl{FNCPUMRDMSR} */
1889static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelLastBranchFromToN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1890{
1891 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1892 /** @todo implement last branch records. */
1893 *puValue = 0;
1894 return VINF_SUCCESS;
1895}
1896
1897
1898/** @callback_method_impl{FNCPUMWRMSR} */
1899static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelLastBranchFromToN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
1900{
1901 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
1902 /** @todo implement last branch records. */
1903 return VINF_SUCCESS;
1904}
1905
1906
1907/** @callback_method_impl{FNCPUMRDMSR} */
1908static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelLastBranchFromN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1909{
1910 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1911 /** @todo implement last branch records. */
1912 *puValue = 0;
1913 return VINF_SUCCESS;
1914}
1915
1916
1917/** @callback_method_impl{FNCPUMWRMSR} */
1918static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelLastBranchFromN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
1919{
1920 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uRawValue);
1921 /** @todo implement last branch records. */
1922 /** @todo Probing indicates that bit 63 is settable on SandyBridge, at least
1923 * if the rest of the bits are zero. Automatic sign extending?
1924 * Investigate! */
1925 if (!X86_IS_CANONICAL(uValue))
1926 {
1927 Log(("CPUM: wrmsr %s(%#x), %#llx -> #GP - not canonical\n", pRange->szName, idMsr, uValue));
1928 return VERR_CPUM_RAISE_GP_0;
1929 }
1930 return VINF_SUCCESS;
1931}
1932
1933
1934/** @callback_method_impl{FNCPUMRDMSR} */
1935static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelLastBranchToN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1936{
1937 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1938 /** @todo implement last branch records. */
1939 *puValue = 0;
1940 return VINF_SUCCESS;
1941}
1942
1943
1944/** @callback_method_impl{FNCPUMWRMSR} */
1945static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelLastBranchToN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
1946{
1947 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
1948 /** @todo implement last branch records. */
1949 /** @todo Probing indicates that bit 63 is settable on SandyBridge, at least
1950 * if the rest of the bits are zero. Automatic sign extending?
1951 * Investigate! */
1952 if (!X86_IS_CANONICAL(uValue))
1953 {
1954 Log(("CPUM: wrmsr %s(%#x), %#llx -> #GP - not canonical\n", pRange->szName, idMsr, uValue));
1955 return VERR_CPUM_RAISE_GP_0;
1956 }
1957 return VINF_SUCCESS;
1958}
1959
1960
1961/** @callback_method_impl{FNCPUMRDMSR} */
1962static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelLastBranchTos(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1963{
1964 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1965 /** @todo implement last branch records. */
1966 *puValue = 0;
1967 return VINF_SUCCESS;
1968}
1969
1970
1971/** @callback_method_impl{FNCPUMWRMSR} */
1972static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelLastBranchTos(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
1973{
1974 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
1975 /** @todo implement last branch records. */
1976 return VINF_SUCCESS;
1977}
1978
1979
1980/** @callback_method_impl{FNCPUMRDMSR} */
1981static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelBblCrCtl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1982{
1983 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
1984 *puValue = pRange->uValue;
1985 return VINF_SUCCESS;
1986}
1987
1988
1989/** @callback_method_impl{FNCPUMWRMSR} */
1990static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelBblCrCtl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
1991{
1992 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
1993 return VINF_SUCCESS;
1994}
1995
1996
1997/** @callback_method_impl{FNCPUMRDMSR} */
1998static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelBblCrCtl3(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
1999{
2000 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2001 *puValue = pRange->uValue;
2002 return VINF_SUCCESS;
2003}
2004
2005
2006/** @callback_method_impl{FNCPUMWRMSR} */
2007static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelBblCrCtl3(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2008{
2009 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2010 return VINF_SUCCESS;
2011}
2012
2013
2014/** @callback_method_impl{FNCPUMRDMSR} */
2015static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7TemperatureTarget(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2016{
2017 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2018 *puValue = pRange->uValue;
2019 return VINF_SUCCESS;
2020}
2021
2022
2023/** @callback_method_impl{FNCPUMWRMSR} */
2024static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelI7TemperatureTarget(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2025{
2026 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2027 return VINF_SUCCESS;
2028}
2029
2030
2031/** @callback_method_impl{FNCPUMRDMSR} */
2032static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7MsrOffCoreResponseN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2033{
2034 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2035 /** @todo machine check. */
2036 *puValue = pRange->uValue;
2037 return VINF_SUCCESS;
2038}
2039
2040
2041/** @callback_method_impl{FNCPUMWRMSR} */
2042static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelI7MsrOffCoreResponseN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2043{
2044 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2045 /** @todo machine check. */
2046 return VINF_SUCCESS;
2047}
2048
2049
2050/** @callback_method_impl{FNCPUMRDMSR} */
2051static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7MiscPwrMgmt(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2052{
2053 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2054 *puValue = 0;
2055 return VINF_SUCCESS;
2056}
2057
2058
2059/** @callback_method_impl{FNCPUMWRMSR} */
2060static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelI7MiscPwrMgmt(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2061{
2062 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2063 return VINF_SUCCESS;
2064}
2065
2066
2067/** @callback_method_impl{FNCPUMRDMSR} */
2068static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelP6CrN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2069{
2070 RT_NOREF_PV(idMsr);
2071 int rc = CPUMGetGuestCRx(pVCpu, pRange->uValue, puValue);
2072 AssertRC(rc);
2073 return VINF_SUCCESS;
2074}
2075
2076
2077/** @callback_method_impl{FNCPUMWRMSR} */
2078static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelP6CrN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2079{
2080 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2081 /* This CRx interface differs from the MOV CRx, GReg interface in that
2082 #GP(0) isn't raised if unsupported bits are written to. Instead they
2083 are simply ignored and masked off. (Pentium M Dothan) */
2084 /** @todo Implement MSR_P6_CRx writing. Too much effort for very little, if
2085 * any, gain. */
2086 return VINF_SUCCESS;
2087}
2088
2089
2090/** @callback_method_impl{FNCPUMRDMSR} */
2091static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelCpuId1FeatureMaskEcdx(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2092{
2093 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2094 /** @todo implement CPUID masking. */
2095 *puValue = UINT64_MAX;
2096 return VINF_SUCCESS;
2097}
2098
2099
2100/** @callback_method_impl{FNCPUMWRMSR} */
2101static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelCpuId1FeatureMaskEcdx(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2102{
2103 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2104 /** @todo implement CPUID masking. */
2105 return VINF_SUCCESS;
2106}
2107
2108
2109/** @callback_method_impl{FNCPUMRDMSR} */
2110static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelCpuId1FeatureMaskEax(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2111{
2112 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2113 /** @todo implement CPUID masking. */
2114 *puValue = 0;
2115 return VINF_SUCCESS;
2116}
2117
2118
2119/** @callback_method_impl{FNCPUMWRMSR} */
2120static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelCpuId1FeatureMaskEax(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2121{
2122 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2123 /** @todo implement CPUID masking. */
2124 return VINF_SUCCESS;
2125}
2126
2127
2128
2129/** @callback_method_impl{FNCPUMRDMSR} */
2130static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelCpuId80000001FeatureMaskEcdx(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2131{
2132 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2133 /** @todo implement CPUID masking. */
2134 *puValue = UINT64_MAX;
2135 return VINF_SUCCESS;
2136}
2137
2138
2139/** @callback_method_impl{FNCPUMWRMSR} */
2140static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelCpuId80000001FeatureMaskEcdx(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2141{
2142 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2143 /** @todo implement CPUID masking. */
2144 return VINF_SUCCESS;
2145}
2146
2147
2148
2149/** @callback_method_impl{FNCPUMRDMSR} */
2150static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7SandyAesNiCtl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2151{
2152 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2153 /** @todo implement AES-NI. */
2154 *puValue = 3; /* Bit 0 is lock bit, bit 1 disables AES-NI. That's what they say. */
2155 return VINF_SUCCESS;
2156}
2157
2158
2159/** @callback_method_impl{FNCPUMWRMSR} */
2160static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelI7SandyAesNiCtl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2161{
2162 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2163 /** @todo implement AES-NI. */
2164 return VERR_CPUM_RAISE_GP_0;
2165}
2166
2167
2168/** @callback_method_impl{FNCPUMRDMSR} */
2169static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7TurboRatioLimit(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2170{
2171 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2172 /** @todo implement intel C states. */
2173 *puValue = pRange->uValue;
2174 return VINF_SUCCESS;
2175}
2176
2177
2178/** @callback_method_impl{FNCPUMWRMSR} */
2179static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelI7TurboRatioLimit(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2180{
2181 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2182 /** @todo implement intel C states. */
2183 return VINF_SUCCESS;
2184}
2185
2186
2187/** @callback_method_impl{FNCPUMRDMSR} */
2188static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7LbrSelect(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2189{
2190 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2191 /** @todo implement last-branch-records. */
2192 *puValue = 0;
2193 return VINF_SUCCESS;
2194}
2195
2196
2197/** @callback_method_impl{FNCPUMWRMSR} */
2198static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelI7LbrSelect(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2199{
2200 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2201 /** @todo implement last-branch-records. */
2202 return VINF_SUCCESS;
2203}
2204
2205
2206/** @callback_method_impl{FNCPUMRDMSR} */
2207static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7SandyErrorControl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2208{
2209 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2210 /** @todo implement memory error injection (MSR_ERROR_CONTROL). */
2211 *puValue = 0;
2212 return VINF_SUCCESS;
2213}
2214
2215
2216/** @callback_method_impl{FNCPUMWRMSR} */
2217static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelI7SandyErrorControl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2218{
2219 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2220 /** @todo implement memory error injection (MSR_ERROR_CONTROL). */
2221 return VINF_SUCCESS;
2222}
2223
2224
2225/** @callback_method_impl{FNCPUMRDMSR} */
2226static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7VirtualLegacyWireCap(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2227{
2228 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2229 /** @todo implement memory VLW? */
2230 *puValue = pRange->uValue;
2231 /* Note: A20M is known to be bit 1 as this was disclosed in spec update
2232 AAJ49/AAK51/????, which documents the inversion of this bit. The
2233 Sandy bridge CPU here has value 0x74, so it probably doesn't have a BIOS
2234 that correct things. Some guesses at the other bits:
2235 bit 2 = INTR
2236 bit 4 = SMI
2237 bit 5 = INIT
2238 bit 6 = NMI */
2239 return VINF_SUCCESS;
2240}
2241
2242
2243/** @callback_method_impl{FNCPUMRDMSR} */
2244static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7PowerCtl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2245{
2246 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2247 /** @todo intel power management */
2248 *puValue = 0;
2249 return VINF_SUCCESS;
2250}
2251
2252
2253/** @callback_method_impl{FNCPUMWRMSR} */
2254static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelI7PowerCtl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2255{
2256 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2257 /** @todo intel power management */
2258 return VINF_SUCCESS;
2259}
2260
2261
2262/** @callback_method_impl{FNCPUMRDMSR} */
2263static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7SandyPebsNumAlt(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2264{
2265 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2266 /** @todo intel performance counters. */
2267 *puValue = 0;
2268 return VINF_SUCCESS;
2269}
2270
2271
2272/** @callback_method_impl{FNCPUMWRMSR} */
2273static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelI7SandyPebsNumAlt(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2274{
2275 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2276 /** @todo intel performance counters. */
2277 return VINF_SUCCESS;
2278}
2279
2280
2281/** @callback_method_impl{FNCPUMRDMSR} */
2282static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7PebsLdLat(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2283{
2284 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2285 /** @todo intel performance counters. */
2286 *puValue = 0;
2287 return VINF_SUCCESS;
2288}
2289
2290
2291/** @callback_method_impl{FNCPUMWRMSR} */
2292static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelI7PebsLdLat(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2293{
2294 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2295 /** @todo intel performance counters. */
2296 return VINF_SUCCESS;
2297}
2298
2299
2300/** @callback_method_impl{FNCPUMRDMSR} */
2301static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7PkgCnResidencyN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2302{
2303 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2304 /** @todo intel power management. */
2305 *puValue = 0;
2306 return VINF_SUCCESS;
2307}
2308
2309
2310/** @callback_method_impl{FNCPUMRDMSR} */
2311static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7CoreCnResidencyN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2312{
2313 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2314 /** @todo intel power management. */
2315 *puValue = 0;
2316 return VINF_SUCCESS;
2317}
2318
2319
2320/** @callback_method_impl{FNCPUMRDMSR} */
2321static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7SandyVrCurrentConfig(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2322{
2323 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2324 /** @todo Figure out what MSR_VR_CURRENT_CONFIG & MSR_VR_MISC_CONFIG are. */
2325 *puValue = 0;
2326 return VINF_SUCCESS;
2327}
2328
2329
2330/** @callback_method_impl{FNCPUMWRMSR} */
2331static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelI7SandyVrCurrentConfig(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2332{
2333 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2334 /** @todo Figure out what MSR_VR_CURRENT_CONFIG & MSR_VR_MISC_CONFIG are. */
2335 return VINF_SUCCESS;
2336}
2337
2338
2339/** @callback_method_impl{FNCPUMRDMSR} */
2340static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7SandyVrMiscConfig(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2341{
2342 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2343 /** @todo Figure out what MSR_VR_CURRENT_CONFIG & MSR_VR_MISC_CONFIG are. */
2344 *puValue = 0;
2345 return VINF_SUCCESS;
2346}
2347
2348
2349/** @callback_method_impl{FNCPUMWRMSR} */
2350static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelI7SandyVrMiscConfig(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2351{
2352 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2353 /** @todo Figure out what MSR_VR_CURRENT_CONFIG & MSR_VR_MISC_CONFIG are. */
2354 return VINF_SUCCESS;
2355}
2356
2357
2358/** @callback_method_impl{FNCPUMRDMSR} */
2359static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7SandyRaplPowerUnit(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2360{
2361 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2362 /** @todo intel RAPL. */
2363 *puValue = pRange->uValue;
2364 return VINF_SUCCESS;
2365}
2366
2367
2368/** @callback_method_impl{FNCPUMWRMSR} */
2369static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelI7SandyRaplPowerUnit(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2370{
2371 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2372 /* Note! This is documented as read only and except for a Silvermont sample has
2373 always been classified as read only. This is just here to make it compile. */
2374 return VINF_SUCCESS;
2375}
2376
2377
2378/** @callback_method_impl{FNCPUMRDMSR} */
2379static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7SandyPkgCnIrtlN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2380{
2381 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2382 /** @todo intel power management. */
2383 *puValue = 0;
2384 return VINF_SUCCESS;
2385}
2386
2387
2388/** @callback_method_impl{FNCPUMWRMSR} */
2389static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelI7SandyPkgCnIrtlN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2390{
2391 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2392 /** @todo intel power management. */
2393 return VINF_SUCCESS;
2394}
2395
2396
2397/** @callback_method_impl{FNCPUMRDMSR} */
2398static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7SandyPkgC2Residency(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2399{
2400 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2401 /** @todo intel power management. */
2402 *puValue = 0;
2403 return VINF_SUCCESS;
2404}
2405
2406
2407/** @callback_method_impl{FNCPUMWRMSR} */
2408static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelI7SandyPkgC2Residency(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2409{
2410 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2411 /* Note! This is documented as read only and except for a Silvermont sample has
2412 always been classified as read only. This is just here to make it compile. */
2413 return VINF_SUCCESS;
2414}
2415
2416
2417/** @callback_method_impl{FNCPUMRDMSR} */
2418static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7RaplPkgPowerLimit(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2419{
2420 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2421 /** @todo intel RAPL. */
2422 *puValue = 0;
2423 return VINF_SUCCESS;
2424}
2425
2426
2427/** @callback_method_impl{FNCPUMWRMSR} */
2428static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelI7RaplPkgPowerLimit(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2429{
2430 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2431 /** @todo intel RAPL. */
2432 return VINF_SUCCESS;
2433}
2434
2435
2436/** @callback_method_impl{FNCPUMRDMSR} */
2437static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7RaplPkgEnergyStatus(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2438{
2439 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2440 /** @todo intel power management. */
2441 *puValue = 0;
2442 return VINF_SUCCESS;
2443}
2444
2445
2446/** @callback_method_impl{FNCPUMRDMSR} */
2447static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7RaplPkgPerfStatus(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2448{
2449 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2450 /** @todo intel power management. */
2451 *puValue = 0;
2452 return VINF_SUCCESS;
2453}
2454
2455
2456/** @callback_method_impl{FNCPUMRDMSR} */
2457static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7RaplPkgPowerInfo(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2458{
2459 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2460 /** @todo intel power management. */
2461 *puValue = 0;
2462 return VINF_SUCCESS;
2463}
2464
2465
2466/** @callback_method_impl{FNCPUMRDMSR} */
2467static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7RaplDramPowerLimit(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2468{
2469 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2470 /** @todo intel RAPL. */
2471 *puValue = 0;
2472 return VINF_SUCCESS;
2473}
2474
2475
2476/** @callback_method_impl{FNCPUMWRMSR} */
2477static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelI7RaplDramPowerLimit(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2478{
2479 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2480 /** @todo intel RAPL. */
2481 return VINF_SUCCESS;
2482}
2483
2484
2485/** @callback_method_impl{FNCPUMRDMSR} */
2486static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7RaplDramEnergyStatus(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2487{
2488 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2489 /** @todo intel power management. */
2490 *puValue = 0;
2491 return VINF_SUCCESS;
2492}
2493
2494
2495/** @callback_method_impl{FNCPUMRDMSR} */
2496static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7RaplDramPerfStatus(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2497{
2498 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2499 /** @todo intel power management. */
2500 *puValue = 0;
2501 return VINF_SUCCESS;
2502}
2503
2504
2505/** @callback_method_impl{FNCPUMRDMSR} */
2506static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7RaplDramPowerInfo(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2507{
2508 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2509 /** @todo intel power management. */
2510 *puValue = 0;
2511 return VINF_SUCCESS;
2512}
2513
2514
2515/** @callback_method_impl{FNCPUMRDMSR} */
2516static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7RaplPp0PowerLimit(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2517{
2518 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2519 /** @todo intel RAPL. */
2520 *puValue = 0;
2521 return VINF_SUCCESS;
2522}
2523
2524
2525/** @callback_method_impl{FNCPUMWRMSR} */
2526static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelI7RaplPp0PowerLimit(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2527{
2528 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2529 /** @todo intel RAPL. */
2530 return VINF_SUCCESS;
2531}
2532
2533
2534/** @callback_method_impl{FNCPUMRDMSR} */
2535static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7RaplPp0EnergyStatus(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2536{
2537 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2538 /** @todo intel power management. */
2539 *puValue = 0;
2540 return VINF_SUCCESS;
2541}
2542
2543
2544/** @callback_method_impl{FNCPUMRDMSR} */
2545static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7RaplPp0Policy(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2546{
2547 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2548 /** @todo intel RAPL. */
2549 *puValue = 0;
2550 return VINF_SUCCESS;
2551}
2552
2553
2554/** @callback_method_impl{FNCPUMWRMSR} */
2555static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelI7RaplPp0Policy(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2556{
2557 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2558 /** @todo intel RAPL. */
2559 return VINF_SUCCESS;
2560}
2561
2562
2563/** @callback_method_impl{FNCPUMRDMSR} */
2564static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7RaplPp0PerfStatus(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2565{
2566 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2567 /** @todo intel power management. */
2568 *puValue = 0;
2569 return VINF_SUCCESS;
2570}
2571
2572
2573/** @callback_method_impl{FNCPUMRDMSR} */
2574static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7RaplPp1PowerLimit(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2575{
2576 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2577 /** @todo intel RAPL. */
2578 *puValue = 0;
2579 return VINF_SUCCESS;
2580}
2581
2582
2583/** @callback_method_impl{FNCPUMWRMSR} */
2584static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelI7RaplPp1PowerLimit(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2585{
2586 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2587 /** @todo intel RAPL. */
2588 return VINF_SUCCESS;
2589}
2590
2591
2592/** @callback_method_impl{FNCPUMRDMSR} */
2593static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7RaplPp1EnergyStatus(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2594{
2595 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2596 /** @todo intel power management. */
2597 *puValue = 0;
2598 return VINF_SUCCESS;
2599}
2600
2601
2602/** @callback_method_impl{FNCPUMRDMSR} */
2603static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7RaplPp1Policy(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2604{
2605 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2606 /** @todo intel RAPL. */
2607 *puValue = 0;
2608 return VINF_SUCCESS;
2609}
2610
2611
2612/** @callback_method_impl{FNCPUMWRMSR} */
2613static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelI7RaplPp1Policy(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2614{
2615 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2616 /** @todo intel RAPL. */
2617 return VINF_SUCCESS;
2618}
2619
2620
2621/** @callback_method_impl{FNCPUMRDMSR} */
2622static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7IvyConfigTdpNominal(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2623{
2624 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2625 /** @todo intel power management. */
2626 *puValue = pRange->uValue;
2627 return VINF_SUCCESS;
2628}
2629
2630
2631/** @callback_method_impl{FNCPUMRDMSR} */
2632static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7IvyConfigTdpLevel1(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2633{
2634 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2635 /** @todo intel power management. */
2636 *puValue = pRange->uValue;
2637 return VINF_SUCCESS;
2638}
2639
2640
2641/** @callback_method_impl{FNCPUMRDMSR} */
2642static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7IvyConfigTdpLevel2(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2643{
2644 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2645 /** @todo intel power management. */
2646 *puValue = pRange->uValue;
2647 return VINF_SUCCESS;
2648}
2649
2650
2651/** @callback_method_impl{FNCPUMRDMSR} */
2652static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7IvyConfigTdpControl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2653{
2654 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2655 /** @todo intel power management. */
2656 *puValue = 0;
2657 return VINF_SUCCESS;
2658}
2659
2660
2661/** @callback_method_impl{FNCPUMWRMSR} */
2662static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelI7IvyConfigTdpControl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2663{
2664 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2665 /** @todo intel power management. */
2666 return VINF_SUCCESS;
2667}
2668
2669
2670/** @callback_method_impl{FNCPUMRDMSR} */
2671static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7IvyTurboActivationRatio(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2672{
2673 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2674 /** @todo intel power management. */
2675 *puValue = 0;
2676 return VINF_SUCCESS;
2677}
2678
2679
2680/** @callback_method_impl{FNCPUMWRMSR} */
2681static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelI7IvyTurboActivationRatio(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2682{
2683 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2684 /** @todo intel power management. */
2685 return VINF_SUCCESS;
2686}
2687
2688
2689/** @callback_method_impl{FNCPUMRDMSR} */
2690static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7UncPerfGlobalCtrl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2691{
2692 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2693 /** @todo uncore msrs. */
2694 *puValue = 0;
2695 return VINF_SUCCESS;
2696}
2697
2698
2699/** @callback_method_impl{FNCPUMWRMSR} */
2700static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelI7UncPerfGlobalCtrl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2701{
2702 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2703 /** @todo uncore msrs. */
2704 return VINF_SUCCESS;
2705}
2706
2707
2708/** @callback_method_impl{FNCPUMRDMSR} */
2709static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7UncPerfGlobalStatus(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2710{
2711 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2712 /** @todo uncore msrs. */
2713 *puValue = 0;
2714 return VINF_SUCCESS;
2715}
2716
2717
2718/** @callback_method_impl{FNCPUMWRMSR} */
2719static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelI7UncPerfGlobalStatus(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2720{
2721 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2722 /** @todo uncore msrs. */
2723 return VINF_SUCCESS;
2724}
2725
2726
2727/** @callback_method_impl{FNCPUMRDMSR} */
2728static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7UncPerfGlobalOvfCtrl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2729{
2730 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2731 /** @todo uncore msrs. */
2732 *puValue = 0;
2733 return VINF_SUCCESS;
2734}
2735
2736
2737/** @callback_method_impl{FNCPUMWRMSR} */
2738static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelI7UncPerfGlobalOvfCtrl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2739{
2740 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2741 /** @todo uncore msrs. */
2742 return VINF_SUCCESS;
2743}
2744
2745
2746/** @callback_method_impl{FNCPUMRDMSR} */
2747static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7UncPerfFixedCtrCtrl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2748{
2749 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2750 /** @todo uncore msrs. */
2751 *puValue = 0;
2752 return VINF_SUCCESS;
2753}
2754
2755
2756/** @callback_method_impl{FNCPUMWRMSR} */
2757static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelI7UncPerfFixedCtrCtrl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2758{
2759 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2760 /** @todo uncore msrs. */
2761 return VINF_SUCCESS;
2762}
2763
2764
2765/** @callback_method_impl{FNCPUMRDMSR} */
2766static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7UncPerfFixedCtr(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2767{
2768 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2769 /** @todo uncore msrs. */
2770 *puValue = 0;
2771 return VINF_SUCCESS;
2772}
2773
2774
2775/** @callback_method_impl{FNCPUMWRMSR} */
2776static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelI7UncPerfFixedCtr(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2777{
2778 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2779 /** @todo uncore msrs. */
2780 return VINF_SUCCESS;
2781}
2782
2783
2784/** @callback_method_impl{FNCPUMRDMSR} */
2785static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7UncCBoxConfig(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2786{
2787 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2788 /** @todo uncore msrs. */
2789 *puValue = 0;
2790 return VINF_SUCCESS;
2791}
2792
2793
2794/** @callback_method_impl{FNCPUMRDMSR} */
2795static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7UncArbPerfCtrN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2796{
2797 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2798 /** @todo uncore msrs. */
2799 *puValue = 0;
2800 return VINF_SUCCESS;
2801}
2802
2803
2804/** @callback_method_impl{FNCPUMWRMSR} */
2805static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelI7UncArbPerfCtrN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2806{
2807 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2808 /** @todo uncore msrs. */
2809 return VINF_SUCCESS;
2810}
2811
2812
2813/** @callback_method_impl{FNCPUMRDMSR} */
2814static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7UncArbPerfEvtSelN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2815{
2816 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2817 /** @todo uncore msrs. */
2818 *puValue = 0;
2819 return VINF_SUCCESS;
2820}
2821
2822
2823/** @callback_method_impl{FNCPUMWRMSR} */
2824static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelI7UncArbPerfEvtSelN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2825{
2826 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2827 /** @todo uncore msrs. */
2828 return VINF_SUCCESS;
2829}
2830
2831
2832/** @callback_method_impl{FNCPUMRDMSR} */
2833static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelI7SmiCount(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2834{
2835 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2836
2837 /*
2838 * 31:0 is SMI count (read only), 63:32 reserved.
2839 * Since we don't do SMI, the count is always zero.
2840 */
2841 *puValue = 0;
2842 return VINF_SUCCESS;
2843}
2844
2845
2846/** @callback_method_impl{FNCPUMRDMSR} */
2847static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelCore2EmttmCrTablesN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2848{
2849 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2850 /** @todo implement enhanced multi thread termal monitoring? */
2851 *puValue = pRange->uValue;
2852 return VINF_SUCCESS;
2853}
2854
2855
2856/** @callback_method_impl{FNCPUMWRMSR} */
2857static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelCore2EmttmCrTablesN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2858{
2859 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2860 /** @todo implement enhanced multi thread termal monitoring? */
2861 return VINF_SUCCESS;
2862}
2863
2864
2865/** @callback_method_impl{FNCPUMRDMSR} */
2866static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelCore2SmmCStMiscInfo(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2867{
2868 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2869 /** @todo SMM & C-states? */
2870 *puValue = 0;
2871 return VINF_SUCCESS;
2872}
2873
2874
2875/** @callback_method_impl{FNCPUMWRMSR} */
2876static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelCore2SmmCStMiscInfo(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2877{
2878 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2879 /** @todo SMM & C-states? */
2880 return VINF_SUCCESS;
2881}
2882
2883
2884/** @callback_method_impl{FNCPUMRDMSR} */
2885static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelCore1ExtConfig(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2886{
2887 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2888 /** @todo Core1&2 EXT_CONFIG (whatever that is)? */
2889 *puValue = 0;
2890 return VINF_SUCCESS;
2891}
2892
2893
2894/** @callback_method_impl{FNCPUMWRMSR} */
2895static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelCore1ExtConfig(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2896{
2897 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2898 /** @todo Core1&2 EXT_CONFIG (whatever that is)? */
2899 return VINF_SUCCESS;
2900}
2901
2902
2903/** @callback_method_impl{FNCPUMRDMSR} */
2904static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelCore1DtsCalControl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2905{
2906 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2907 /** @todo Core1&2(?) DTS_CAL_CTRL (whatever that is)? */
2908 *puValue = 0;
2909 return VINF_SUCCESS;
2910}
2911
2912
2913/** @callback_method_impl{FNCPUMWRMSR} */
2914static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelCore1DtsCalControl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2915{
2916 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2917 /** @todo Core1&2(?) DTS_CAL_CTRL (whatever that is)? */
2918 return VINF_SUCCESS;
2919}
2920
2921
2922/** @callback_method_impl{FNCPUMRDMSR} */
2923static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelCore2PeciControl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2924{
2925 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2926 /** @todo Core2+ platform environment control interface control register? */
2927 *puValue = 0;
2928 return VINF_SUCCESS;
2929}
2930
2931
2932/** @callback_method_impl{FNCPUMWRMSR} */
2933static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_IntelCore2PeciControl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2934{
2935 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2936 /** @todo Core2+ platform environment control interface control register? */
2937 return VINF_SUCCESS;
2938}
2939
2940
2941/** @callback_method_impl{FNCPUMRDMSR} */
2942static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_IntelAtSilvCoreC1Recidency(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2943{
2944 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2945 *puValue = 0;
2946 return VINF_SUCCESS;
2947}
2948
2949
2950/*
2951 * Multiple vendor P6 MSRs.
2952 * Multiple vendor P6 MSRs.
2953 * Multiple vendor P6 MSRs.
2954 *
2955 * These MSRs were introduced with the P6 but not elevated to architectural
2956 * MSRs, despite other vendors implementing them.
2957 */
2958
2959
2960/** @callback_method_impl{FNCPUMRDMSR} */
2961static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_P6LastBranchFromIp(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2962{
2963 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2964 /* AMD seems to just record RIP, while intel claims to record RIP+CS.BASE
2965 if I read the docs correctly, thus the need for separate functions. */
2966 /** @todo implement last branch records. */
2967 *puValue = 0;
2968 return VINF_SUCCESS;
2969}
2970
2971
2972/** @callback_method_impl{FNCPUMRDMSR} */
2973static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_P6LastBranchToIp(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2974{
2975 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2976 /** @todo implement last branch records. */
2977 *puValue = 0;
2978 return VINF_SUCCESS;
2979}
2980
2981
2982/** @callback_method_impl{FNCPUMRDMSR} */
2983static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_P6LastIntFromIp(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
2984{
2985 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
2986 /** @todo implement last exception records. */
2987 *puValue = 0;
2988 return VINF_SUCCESS;
2989}
2990
2991
2992/** @callback_method_impl{FNCPUMWRMSR} */
2993static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_P6LastIntFromIp(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
2994{
2995 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
2996 /** @todo implement last exception records. */
2997 /* Note! On many CPUs, the high bit of the 0x000001dd register is always writable, even when the result is
2998 a non-cannonical address. */
2999 return VINF_SUCCESS;
3000}
3001
3002
3003/** @callback_method_impl{FNCPUMRDMSR} */
3004static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_P6LastIntToIp(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3005{
3006 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3007 /** @todo implement last exception records. */
3008 *puValue = 0;
3009 return VINF_SUCCESS;
3010}
3011
3012
3013/** @callback_method_impl{FNCPUMWRMSR} */
3014static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_P6LastIntToIp(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3015{
3016 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3017 /** @todo implement last exception records. */
3018 return VINF_SUCCESS;
3019}
3020
3021
3022
3023/*
3024 * AMD specific
3025 * AMD specific
3026 * AMD specific
3027 */
3028
3029
3030/** @callback_method_impl{FNCPUMRDMSR} */
3031static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam15hTscRate(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3032{
3033 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3034 /** @todo Implement TscRateMsr */
3035 *puValue = RT_MAKE_U64(0, 1); /* 1.0 = reset value. */
3036 return VINF_SUCCESS;
3037}
3038
3039
3040/** @callback_method_impl{FNCPUMWRMSR} */
3041static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam15hTscRate(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3042{
3043 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3044 /** @todo Implement TscRateMsr */
3045 return VINF_SUCCESS;
3046}
3047
3048
3049/** @callback_method_impl{FNCPUMRDMSR} */
3050static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam15hLwpCfg(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3051{
3052 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3053 /** @todo Implement AMD LWP? (Instructions: LWPINS, LWPVAL, LLWPCB, SLWPCB) */
3054 /* Note: Only listes in BKDG for Family 15H. */
3055 *puValue = 0;
3056 return VINF_SUCCESS;
3057}
3058
3059
3060/** @callback_method_impl{FNCPUMWRMSR} */
3061static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam15hLwpCfg(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3062{
3063 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3064 /** @todo Implement AMD LWP? (Instructions: LWPINS, LWPVAL, LLWPCB, SLWPCB) */
3065 return VINF_SUCCESS;
3066}
3067
3068
3069/** @callback_method_impl{FNCPUMRDMSR} */
3070static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam15hLwpCbAddr(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3071{
3072 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3073 /** @todo Implement AMD LWP? (Instructions: LWPINS, LWPVAL, LLWPCB, SLWPCB) */
3074 /* Note: Only listes in BKDG for Family 15H. */
3075 *puValue = 0;
3076 return VINF_SUCCESS;
3077}
3078
3079
3080/** @callback_method_impl{FNCPUMWRMSR} */
3081static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam15hLwpCbAddr(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3082{
3083 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3084 /** @todo Implement AMD LWP? (Instructions: LWPINS, LWPVAL, LLWPCB, SLWPCB) */
3085 return VINF_SUCCESS;
3086}
3087
3088
3089/** @callback_method_impl{FNCPUMRDMSR} */
3090static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam10hMc4MiscN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3091{
3092 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3093 /** @todo machine check. */
3094 *puValue = 0;
3095 return VINF_SUCCESS;
3096}
3097
3098
3099/** @callback_method_impl{FNCPUMWRMSR} */
3100static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam10hMc4MiscN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3101{
3102 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3103 /** @todo machine check. */
3104 return VINF_SUCCESS;
3105}
3106
3107
3108/** @callback_method_impl{FNCPUMRDMSR} */
3109static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK8PerfCtlN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3110{
3111 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3112 /** @todo AMD performance events. */
3113 *puValue = 0;
3114 return VINF_SUCCESS;
3115}
3116
3117
3118/** @callback_method_impl{FNCPUMWRMSR} */
3119static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK8PerfCtlN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3120{
3121 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3122 /** @todo AMD performance events. */
3123 return VINF_SUCCESS;
3124}
3125
3126
3127/** @callback_method_impl{FNCPUMRDMSR} */
3128static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK8PerfCtrN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3129{
3130 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3131 /** @todo AMD performance events. */
3132 *puValue = 0;
3133 return VINF_SUCCESS;
3134}
3135
3136
3137/** @callback_method_impl{FNCPUMWRMSR} */
3138static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK8PerfCtrN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3139{
3140 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3141 /** @todo AMD performance events. */
3142 return VINF_SUCCESS;
3143}
3144
3145
3146/** @callback_method_impl{FNCPUMRDMSR} */
3147static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK8SysCfg(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3148{
3149 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3150 /** @todo AMD SYS_CFG */
3151 *puValue = pRange->uValue;
3152 return VINF_SUCCESS;
3153}
3154
3155
3156/** @callback_method_impl{FNCPUMWRMSR} */
3157static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK8SysCfg(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3158{
3159 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3160 /** @todo AMD SYS_CFG */
3161 return VINF_SUCCESS;
3162}
3163
3164
3165/** @callback_method_impl{FNCPUMRDMSR} */
3166static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK8HwCr(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3167{
3168 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3169 /** @todo AMD HW_CFG */
3170 *puValue = 0;
3171 return VINF_SUCCESS;
3172}
3173
3174
3175/** @callback_method_impl{FNCPUMWRMSR} */
3176static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK8HwCr(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3177{
3178 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3179 /** @todo AMD HW_CFG */
3180 return VINF_SUCCESS;
3181}
3182
3183
3184/** @callback_method_impl{FNCPUMRDMSR} */
3185static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK8IorrBaseN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3186{
3187 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3188 /** @todo AMD IorrMask/IorrBase */
3189 *puValue = 0;
3190 return VINF_SUCCESS;
3191}
3192
3193
3194/** @callback_method_impl{FNCPUMWRMSR} */
3195static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK8IorrBaseN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3196{
3197 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3198 /** @todo AMD IorrMask/IorrBase */
3199 return VINF_SUCCESS;
3200}
3201
3202
3203/** @callback_method_impl{FNCPUMRDMSR} */
3204static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK8IorrMaskN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3205{
3206 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3207 /** @todo AMD IorrMask/IorrBase */
3208 *puValue = 0;
3209 return VINF_SUCCESS;
3210}
3211
3212
3213/** @callback_method_impl{FNCPUMWRMSR} */
3214static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK8IorrMaskN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3215{
3216 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3217 /** @todo AMD IorrMask/IorrBase */
3218 return VINF_SUCCESS;
3219}
3220
3221
3222/** @callback_method_impl{FNCPUMRDMSR} */
3223static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK8TopOfMemN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3224{
3225 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3226 *puValue = 0;
3227 /** @todo return 4GB - RamHoleSize here for TOPMEM. Figure out what to return
3228 * for TOPMEM2. */
3229 //if (pRange->uValue == 0)
3230 // *puValue = _4G - RamHoleSize;
3231 return VINF_SUCCESS;
3232}
3233
3234
3235/** @callback_method_impl{FNCPUMWRMSR} */
3236static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK8TopOfMemN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3237{
3238 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3239 /** @todo AMD TOPMEM and TOPMEM2/TOM2. */
3240 return VINF_SUCCESS;
3241}
3242
3243
3244/** @callback_method_impl{FNCPUMRDMSR} */
3245static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK8NbCfg1(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3246{
3247 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3248 /** @todo AMD NB_CFG1 */
3249 *puValue = 0;
3250 return VINF_SUCCESS;
3251}
3252
3253
3254/** @callback_method_impl{FNCPUMWRMSR} */
3255static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK8NbCfg1(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3256{
3257 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3258 /** @todo AMD NB_CFG1 */
3259 return VINF_SUCCESS;
3260}
3261
3262
3263/** @callback_method_impl{FNCPUMRDMSR} */
3264static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK8McXcptRedir(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3265{
3266 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3267 /** @todo machine check. */
3268 *puValue = 0;
3269 return VINF_SUCCESS;
3270}
3271
3272
3273/** @callback_method_impl{FNCPUMWRMSR} */
3274static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK8McXcptRedir(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3275{
3276 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3277 /** @todo machine check. */
3278 return VINF_SUCCESS;
3279}
3280
3281
3282/** @callback_method_impl{FNCPUMRDMSR} */
3283static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK8CpuNameN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3284{
3285 RT_NOREF_PV(idMsr);
3286 PCPUMCPUIDLEAF pLeaf = cpumCpuIdGetLeaf(pVCpu->CTX_SUFF(pVM), pRange->uValue / 2 + 0x80000001);
3287 if (pLeaf)
3288 {
3289 if (!(pRange->uValue & 1))
3290 *puValue = RT_MAKE_U64(pLeaf->uEax, pLeaf->uEbx);
3291 else
3292 *puValue = RT_MAKE_U64(pLeaf->uEcx, pLeaf->uEdx);
3293 }
3294 else
3295 *puValue = 0;
3296 return VINF_SUCCESS;
3297}
3298
3299
3300/** @callback_method_impl{FNCPUMWRMSR} */
3301static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK8CpuNameN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3302{
3303 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3304 /** @todo Remember guest programmed CPU name. */
3305 return VINF_SUCCESS;
3306}
3307
3308
3309/** @callback_method_impl{FNCPUMRDMSR} */
3310static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK8HwThermalCtrl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3311{
3312 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3313 /** @todo AMD HTC. */
3314 *puValue = pRange->uValue;
3315 return VINF_SUCCESS;
3316}
3317
3318
3319/** @callback_method_impl{FNCPUMWRMSR} */
3320static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK8HwThermalCtrl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3321{
3322 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3323 /** @todo AMD HTC. */
3324 return VINF_SUCCESS;
3325}
3326
3327
3328/** @callback_method_impl{FNCPUMRDMSR} */
3329static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK8SwThermalCtrl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3330{
3331 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3332 /** @todo AMD STC. */
3333 *puValue = 0;
3334 return VINF_SUCCESS;
3335}
3336
3337
3338/** @callback_method_impl{FNCPUMWRMSR} */
3339static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK8SwThermalCtrl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3340{
3341 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3342 /** @todo AMD STC. */
3343 return VINF_SUCCESS;
3344}
3345
3346
3347/** @callback_method_impl{FNCPUMRDMSR} */
3348static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK8FidVidControl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3349{
3350 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3351 /** @todo AMD FIDVID_CTL. */
3352 *puValue = pRange->uValue;
3353 return VINF_SUCCESS;
3354}
3355
3356
3357/** @callback_method_impl{FNCPUMWRMSR} */
3358static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK8FidVidControl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3359{
3360 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3361 /** @todo AMD FIDVID_CTL. */
3362 return VINF_SUCCESS;
3363}
3364
3365
3366/** @callback_method_impl{FNCPUMRDMSR} */
3367static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK8FidVidStatus(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3368{
3369 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3370 /** @todo AMD FIDVID_STATUS. */
3371 *puValue = pRange->uValue;
3372 return VINF_SUCCESS;
3373}
3374
3375
3376/** @callback_method_impl{FNCPUMRDMSR} */
3377static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK8McCtlMaskN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3378{
3379 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3380 /** @todo AMD MC. */
3381 *puValue = 0;
3382 return VINF_SUCCESS;
3383}
3384
3385
3386/** @callback_method_impl{FNCPUMWRMSR} */
3387static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK8McCtlMaskN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3388{
3389 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3390 /** @todo AMD MC. */
3391 return VINF_SUCCESS;
3392}
3393
3394
3395/** @callback_method_impl{FNCPUMRDMSR} */
3396static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK8SmiOnIoTrapN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3397{
3398 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3399 /** @todo AMD SMM/SMI and I/O trap. */
3400 *puValue = 0;
3401 return VINF_SUCCESS;
3402}
3403
3404
3405/** @callback_method_impl{FNCPUMWRMSR} */
3406static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK8SmiOnIoTrapN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3407{
3408 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3409 /** @todo AMD SMM/SMI and I/O trap. */
3410 return VINF_SUCCESS;
3411}
3412
3413
3414/** @callback_method_impl{FNCPUMRDMSR} */
3415static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK8SmiOnIoTrapCtlSts(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3416{
3417 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3418 /** @todo AMD SMM/SMI and I/O trap. */
3419 *puValue = 0;
3420 return VINF_SUCCESS;
3421}
3422
3423
3424/** @callback_method_impl{FNCPUMWRMSR} */
3425static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK8SmiOnIoTrapCtlSts(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3426{
3427 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3428 /** @todo AMD SMM/SMI and I/O trap. */
3429 return VINF_SUCCESS;
3430}
3431
3432
3433/** @callback_method_impl{FNCPUMRDMSR} */
3434static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK8IntPendingMessage(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3435{
3436 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3437 /** @todo Interrupt pending message. */
3438 *puValue = 0;
3439 return VINF_SUCCESS;
3440}
3441
3442
3443/** @callback_method_impl{FNCPUMWRMSR} */
3444static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK8IntPendingMessage(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3445{
3446 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3447 /** @todo Interrupt pending message. */
3448 return VINF_SUCCESS;
3449}
3450
3451
3452/** @callback_method_impl{FNCPUMRDMSR} */
3453static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK8SmiTriggerIoCycle(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3454{
3455 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3456 /** @todo AMD SMM/SMI and trigger I/O cycle. */
3457 *puValue = 0;
3458 return VINF_SUCCESS;
3459}
3460
3461
3462/** @callback_method_impl{FNCPUMWRMSR} */
3463static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK8SmiTriggerIoCycle(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3464{
3465 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3466 /** @todo AMD SMM/SMI and trigger I/O cycle. */
3467 return VINF_SUCCESS;
3468}
3469
3470
3471/** @callback_method_impl{FNCPUMRDMSR} */
3472static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam10hMmioCfgBaseAddr(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3473{
3474 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3475 /** @todo AMD MMIO Configuration base address. */
3476 *puValue = 0;
3477 return VINF_SUCCESS;
3478}
3479
3480
3481/** @callback_method_impl{FNCPUMWRMSR} */
3482static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam10hMmioCfgBaseAddr(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3483{
3484 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3485 /** @todo AMD MMIO Configuration base address. */
3486 return VINF_SUCCESS;
3487}
3488
3489
3490/** @callback_method_impl{FNCPUMRDMSR} */
3491static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam10hTrapCtlMaybe(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3492{
3493 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3494 /** @todo AMD 0xc0010059. */
3495 *puValue = 0;
3496 return VINF_SUCCESS;
3497}
3498
3499
3500/** @callback_method_impl{FNCPUMWRMSR} */
3501static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam10hTrapCtlMaybe(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3502{
3503 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3504 /** @todo AMD 0xc0010059. */
3505 return VINF_SUCCESS;
3506}
3507
3508
3509/** @callback_method_impl{FNCPUMRDMSR} */
3510static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam10hPStateCurLimit(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3511{
3512 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3513 /** @todo AMD P-states. */
3514 *puValue = pRange->uValue;
3515 return VINF_SUCCESS;
3516}
3517
3518
3519/** @callback_method_impl{FNCPUMRDMSR} */
3520static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam10hPStateControl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3521{
3522 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3523 /** @todo AMD P-states. */
3524 *puValue = pRange->uValue;
3525 return VINF_SUCCESS;
3526}
3527
3528
3529/** @callback_method_impl{FNCPUMWRMSR} */
3530static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam10hPStateControl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3531{
3532 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3533 /** @todo AMD P-states. */
3534 return VINF_SUCCESS;
3535}
3536
3537
3538/** @callback_method_impl{FNCPUMRDMSR} */
3539static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam10hPStateStatus(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3540{
3541 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3542 /** @todo AMD P-states. */
3543 *puValue = pRange->uValue;
3544 return VINF_SUCCESS;
3545}
3546
3547
3548/** @callback_method_impl{FNCPUMWRMSR} */
3549static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam10hPStateStatus(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3550{
3551 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3552 /** @todo AMD P-states. */
3553 return VINF_SUCCESS;
3554}
3555
3556
3557/** @callback_method_impl{FNCPUMRDMSR} */
3558static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam10hPStateN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3559{
3560 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3561 /** @todo AMD P-states. */
3562 *puValue = pRange->uValue;
3563 return VINF_SUCCESS;
3564}
3565
3566
3567/** @callback_method_impl{FNCPUMWRMSR} */
3568static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam10hPStateN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3569{
3570 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3571 /** @todo AMD P-states. */
3572 return VINF_SUCCESS;
3573}
3574
3575
3576/** @callback_method_impl{FNCPUMRDMSR} */
3577static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam10hCofVidControl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3578{
3579 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3580 /** @todo AMD P-states. */
3581 *puValue = pRange->uValue;
3582 return VINF_SUCCESS;
3583}
3584
3585
3586/** @callback_method_impl{FNCPUMWRMSR} */
3587static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam10hCofVidControl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3588{
3589 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3590 /** @todo AMD P-states. */
3591 return VINF_SUCCESS;
3592}
3593
3594
3595/** @callback_method_impl{FNCPUMRDMSR} */
3596static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam10hCofVidStatus(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3597{
3598 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3599 /** @todo AMD P-states. */
3600 *puValue = pRange->uValue;
3601 return VINF_SUCCESS;
3602}
3603
3604
3605/** @callback_method_impl{FNCPUMWRMSR} */
3606static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam10hCofVidStatus(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3607{
3608 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3609 /* Note! Writing 0 seems to not GP, not sure if it does anything to the value... */
3610 /** @todo AMD P-states. */
3611 return VINF_SUCCESS;
3612}
3613
3614
3615/** @callback_method_impl{FNCPUMRDMSR} */
3616static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam10hCStateIoBaseAddr(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3617{
3618 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3619 /** @todo AMD C-states. */
3620 *puValue = 0;
3621 return VINF_SUCCESS;
3622}
3623
3624
3625/** @callback_method_impl{FNCPUMWRMSR} */
3626static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam10hCStateIoBaseAddr(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3627{
3628 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3629 /** @todo AMD C-states. */
3630 return VINF_SUCCESS;
3631}
3632
3633
3634/** @callback_method_impl{FNCPUMRDMSR} */
3635static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam10hCpuWatchdogTimer(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3636{
3637 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3638 /** @todo AMD machine checks. */
3639 *puValue = 0;
3640 return VINF_SUCCESS;
3641}
3642
3643
3644/** @callback_method_impl{FNCPUMWRMSR} */
3645static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam10hCpuWatchdogTimer(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3646{
3647 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3648 /** @todo AMD machine checks. */
3649 return VINF_SUCCESS;
3650}
3651
3652
3653/** @callback_method_impl{FNCPUMRDMSR} */
3654static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK8SmmBase(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3655{
3656 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3657 /** @todo AMD SMM. */
3658 *puValue = 0;
3659 return VINF_SUCCESS;
3660}
3661
3662
3663/** @callback_method_impl{FNCPUMWRMSR} */
3664static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK8SmmBase(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3665{
3666 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3667 /** @todo AMD SMM. */
3668 return VINF_SUCCESS;
3669}
3670
3671
3672/** @callback_method_impl{FNCPUMRDMSR} */
3673static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK8SmmAddr(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3674{
3675 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3676 /** @todo AMD SMM. */
3677 *puValue = 0;
3678 return VINF_SUCCESS;
3679}
3680
3681
3682/** @callback_method_impl{FNCPUMWRMSR} */
3683static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK8SmmAddr(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3684{
3685 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3686 /** @todo AMD SMM. */
3687 return VINF_SUCCESS;
3688}
3689
3690
3691
3692/** @callback_method_impl{FNCPUMRDMSR} */
3693static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK8SmmMask(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3694{
3695 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3696 /** @todo AMD SMM. */
3697 *puValue = 0;
3698 return VINF_SUCCESS;
3699}
3700
3701
3702/** @callback_method_impl{FNCPUMWRMSR} */
3703static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK8SmmMask(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3704{
3705 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3706 /** @todo AMD SMM. */
3707 return VINF_SUCCESS;
3708}
3709
3710
3711/** @callback_method_impl{FNCPUMRDMSR} */
3712static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK8VmCr(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3713{
3714 RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3715 PVM pVM = pVCpu->CTX_SUFF(pVM);
3716 if (pVM->cpum.s.GuestFeatures.fSvm)
3717 *puValue = MSR_K8_VM_CR_LOCK;
3718 else
3719 *puValue = 0;
3720 return VINF_SUCCESS;
3721}
3722
3723
3724/** @callback_method_impl{FNCPUMWRMSR} */
3725static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK8VmCr(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3726{
3727 RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uRawValue);
3728 PVM pVM = pVCpu->CTX_SUFF(pVM);
3729 if (pVM->cpum.s.GuestFeatures.fSvm)
3730 {
3731 /* Silently ignore writes to LOCK and SVM_DISABLE bit when the LOCK bit is set (see cpumMsrRd_AmdK8VmCr). */
3732 if (uValue & (MSR_K8_VM_CR_DPD | MSR_K8_VM_CR_R_INIT | MSR_K8_VM_CR_DIS_A20M))
3733 return VERR_CPUM_RAISE_GP_0;
3734 return VINF_SUCCESS;
3735 }
3736 return VERR_CPUM_RAISE_GP_0;
3737}
3738
3739
3740/** @callback_method_impl{FNCPUMRDMSR} */
3741static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK8IgnNe(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3742{
3743 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3744 /** @todo AMD IGNNE\# control. */
3745 *puValue = 0;
3746 return VINF_SUCCESS;
3747}
3748
3749
3750/** @callback_method_impl{FNCPUMWRMSR} */
3751static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK8IgnNe(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3752{
3753 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3754 /** @todo AMD IGNNE\# control. */
3755 return VINF_SUCCESS;
3756}
3757
3758
3759/** @callback_method_impl{FNCPUMRDMSR} */
3760static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK8SmmCtl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3761{
3762 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3763 /** @todo AMD SMM. */
3764 *puValue = 0;
3765 return VINF_SUCCESS;
3766}
3767
3768
3769/** @callback_method_impl{FNCPUMWRMSR} */
3770static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK8SmmCtl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3771{
3772 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3773 /** @todo AMD SMM. */
3774 return VINF_SUCCESS;
3775}
3776
3777
3778/** @callback_method_impl{FNCPUMRDMSR} */
3779static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK8VmHSavePa(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3780{
3781 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3782 *puValue = pVCpu->cpum.s.Guest.hwvirt.svm.uMsrHSavePa;
3783 return VINF_SUCCESS;
3784}
3785
3786
3787/** @callback_method_impl{FNCPUMWRMSR} */
3788static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK8VmHSavePa(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3789{
3790 RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uRawValue);
3791 if (uValue & UINT64_C(0xfff))
3792 {
3793 Log(("CPUM: Invalid setting of low 12 bits set writing host-state save area MSR %#x: %#llx\n", idMsr, uValue));
3794 return VERR_CPUM_RAISE_GP_0;
3795 }
3796
3797 uint64_t fInvPhysMask = ~(RT_BIT_64(pVCpu->CTX_SUFF(pVM)->cpum.s.GuestFeatures.cMaxPhysAddrWidth) - 1U);
3798 if (fInvPhysMask & uValue)
3799 {
3800 Log(("CPUM: Invalid physical address bits set writing host-state save area MSR %#x: %#llx (%#llx)\n",
3801 idMsr, uValue, uValue & fInvPhysMask));
3802 return VERR_CPUM_RAISE_GP_0;
3803 }
3804
3805 pVCpu->cpum.s.Guest.hwvirt.svm.uMsrHSavePa = uValue;
3806 return VINF_SUCCESS;
3807}
3808
3809
3810/** @callback_method_impl{FNCPUMRDMSR} */
3811static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam10hVmLockKey(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3812{
3813 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3814 /** @todo AMD SVM. */
3815 *puValue = 0; /* RAZ */
3816 return VINF_SUCCESS;
3817}
3818
3819
3820/** @callback_method_impl{FNCPUMWRMSR} */
3821static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam10hVmLockKey(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3822{
3823 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3824 /** @todo AMD SVM. */
3825 return VINF_SUCCESS;
3826}
3827
3828
3829/** @callback_method_impl{FNCPUMRDMSR} */
3830static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam10hSmmLockKey(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3831{
3832 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3833 /** @todo AMD SMM. */
3834 *puValue = 0; /* RAZ */
3835 return VINF_SUCCESS;
3836}
3837
3838
3839/** @callback_method_impl{FNCPUMWRMSR} */
3840static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam10hSmmLockKey(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3841{
3842 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3843 /** @todo AMD SMM. */
3844 return VINF_SUCCESS;
3845}
3846
3847
3848/** @callback_method_impl{FNCPUMRDMSR} */
3849static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam10hLocalSmiStatus(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3850{
3851 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3852 /** @todo AMD SMM/SMI. */
3853 *puValue = 0;
3854 return VINF_SUCCESS;
3855}
3856
3857
3858/** @callback_method_impl{FNCPUMWRMSR} */
3859static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam10hLocalSmiStatus(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3860{
3861 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3862 /** @todo AMD SMM/SMI. */
3863 return VINF_SUCCESS;
3864}
3865
3866
3867/** @callback_method_impl{FNCPUMRDMSR} */
3868static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam10hOsVisWrkIdLength(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3869{
3870 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr);
3871 /** @todo AMD OS visible workaround. */
3872 *puValue = pRange->uValue;
3873 return VINF_SUCCESS;
3874}
3875
3876
3877/** @callback_method_impl{FNCPUMWRMSR} */
3878static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam10hOsVisWrkIdLength(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3879{
3880 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3881 /** @todo AMD OS visible workaround. */
3882 return VINF_SUCCESS;
3883}
3884
3885
3886/** @callback_method_impl{FNCPUMRDMSR} */
3887static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam10hOsVisWrkStatus(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3888{
3889 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3890 /** @todo AMD OS visible workaround. */
3891 *puValue = 0;
3892 return VINF_SUCCESS;
3893}
3894
3895
3896/** @callback_method_impl{FNCPUMWRMSR} */
3897static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam10hOsVisWrkStatus(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3898{
3899 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3900 /** @todo AMD OS visible workaround. */
3901 return VINF_SUCCESS;
3902}
3903
3904
3905/** @callback_method_impl{FNCPUMRDMSR} */
3906static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam16hL2IPerfCtlN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3907{
3908 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3909 /** @todo AMD L2I performance counters. */
3910 *puValue = 0;
3911 return VINF_SUCCESS;
3912}
3913
3914
3915/** @callback_method_impl{FNCPUMWRMSR} */
3916static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam16hL2IPerfCtlN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3917{
3918 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3919 /** @todo AMD L2I performance counters. */
3920 return VINF_SUCCESS;
3921}
3922
3923
3924/** @callback_method_impl{FNCPUMRDMSR} */
3925static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam16hL2IPerfCtrN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3926{
3927 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3928 /** @todo AMD L2I performance counters. */
3929 *puValue = 0;
3930 return VINF_SUCCESS;
3931}
3932
3933
3934/** @callback_method_impl{FNCPUMWRMSR} */
3935static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam16hL2IPerfCtrN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3936{
3937 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3938 /** @todo AMD L2I performance counters. */
3939 return VINF_SUCCESS;
3940}
3941
3942
3943/** @callback_method_impl{FNCPUMRDMSR} */
3944static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam15hNorthbridgePerfCtlN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3945{
3946 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3947 /** @todo AMD Northbridge performance counters. */
3948 *puValue = 0;
3949 return VINF_SUCCESS;
3950}
3951
3952
3953/** @callback_method_impl{FNCPUMWRMSR} */
3954static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam15hNorthbridgePerfCtlN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3955{
3956 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3957 /** @todo AMD Northbridge performance counters. */
3958 return VINF_SUCCESS;
3959}
3960
3961
3962/** @callback_method_impl{FNCPUMRDMSR} */
3963static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam15hNorthbridgePerfCtrN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3964{
3965 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3966 /** @todo AMD Northbridge performance counters. */
3967 *puValue = 0;
3968 return VINF_SUCCESS;
3969}
3970
3971
3972/** @callback_method_impl{FNCPUMWRMSR} */
3973static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam15hNorthbridgePerfCtrN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3974{
3975 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3976 /** @todo AMD Northbridge performance counters. */
3977 return VINF_SUCCESS;
3978}
3979
3980
3981/** @callback_method_impl{FNCPUMRDMSR} */
3982static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK7MicrocodeCtl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
3983{
3984 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
3985 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
3986 * cpus. Need to be explored and verify K7 presence. */
3987 /** @todo Undocumented register only seen mentioned in fam15h erratum \#608. */
3988 *puValue = pRange->uValue;
3989 return VINF_SUCCESS;
3990}
3991
3992
3993/** @callback_method_impl{FNCPUMWRMSR} */
3994static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK7MicrocodeCtl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
3995{
3996 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
3997 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
3998 * cpus. Need to be explored and verify K7 presence. */
3999 /** @todo Undocumented register only seen mentioned in fam15h erratum \#608. */
4000 return VINF_SUCCESS;
4001}
4002
4003
4004/** @callback_method_impl{FNCPUMRDMSR} */
4005static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK7ClusterIdMaybe(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4006{
4007 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4008 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
4009 * cpus. Need to be explored and verify K7 presence. */
4010 /** @todo Undocumented register only seen mentioned in fam16h BKDG r3.00 when
4011 * describing EBL_CR_POWERON. */
4012 *puValue = pRange->uValue;
4013 return VINF_SUCCESS;
4014}
4015
4016
4017/** @callback_method_impl{FNCPUMWRMSR} */
4018static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK7ClusterIdMaybe(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4019{
4020 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4021 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
4022 * cpus. Need to be explored and verify K7 presence. */
4023 /** @todo Undocumented register only seen mentioned in fam16h BKDG r3.00 when
4024 * describing EBL_CR_POWERON. */
4025 return VINF_SUCCESS;
4026}
4027
4028
4029/** @callback_method_impl{FNCPUMRDMSR} */
4030static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK8CpuIdCtlStd07hEbax(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4031{
4032 RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4033 bool fIgnored;
4034 PCPUMCPUIDLEAF pLeaf = cpumCpuIdGetLeafEx(pVCpu->CTX_SUFF(pVM), 0x00000007, 0, &fIgnored);
4035 if (pLeaf)
4036 *puValue = RT_MAKE_U64(pLeaf->uEbx, pLeaf->uEax);
4037 else
4038 *puValue = 0;
4039 return VINF_SUCCESS;
4040}
4041
4042
4043/** @callback_method_impl{FNCPUMWRMSR} */
4044static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK8CpuIdCtlStd07hEbax(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4045{
4046 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4047 /** @todo Changing CPUID leaf 7/0. */
4048 return VINF_SUCCESS;
4049}
4050
4051
4052/** @callback_method_impl{FNCPUMRDMSR} */
4053static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK8CpuIdCtlStd06hEcx(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4054{
4055 RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4056 PCPUMCPUIDLEAF pLeaf = cpumCpuIdGetLeaf(pVCpu->CTX_SUFF(pVM), 0x00000006);
4057 if (pLeaf)
4058 *puValue = pLeaf->uEcx;
4059 else
4060 *puValue = 0;
4061 return VINF_SUCCESS;
4062}
4063
4064
4065/** @callback_method_impl{FNCPUMWRMSR} */
4066static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK8CpuIdCtlStd06hEcx(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4067{
4068 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4069 /** @todo Changing CPUID leaf 6. */
4070 return VINF_SUCCESS;
4071}
4072
4073
4074/** @callback_method_impl{FNCPUMRDMSR} */
4075static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK8CpuIdCtlStd01hEdcx(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4076{
4077 RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4078 PCPUMCPUIDLEAF pLeaf = cpumCpuIdGetLeaf(pVCpu->CTX_SUFF(pVM), 0x00000001);
4079 if (pLeaf)
4080 *puValue = RT_MAKE_U64(pLeaf->uEdx, pLeaf->uEcx);
4081 else
4082 *puValue = 0;
4083 return VINF_SUCCESS;
4084}
4085
4086
4087/** @callback_method_impl{FNCPUMWRMSR} */
4088static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK8CpuIdCtlStd01hEdcx(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4089{
4090 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4091 /** @todo Changing CPUID leaf 0x80000001. */
4092 return VINF_SUCCESS;
4093}
4094
4095
4096/** @callback_method_impl{FNCPUMRDMSR} */
4097static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK8CpuIdCtlExt01hEdcx(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4098{
4099 RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4100 PCPUMCPUIDLEAF pLeaf = cpumCpuIdGetLeaf(pVCpu->CTX_SUFF(pVM), 0x80000001);
4101 if (pLeaf)
4102 *puValue = RT_MAKE_U64(pLeaf->uEdx, pLeaf->uEcx);
4103 else
4104 *puValue = 0;
4105 return VINF_SUCCESS;
4106}
4107
4108
4109/** @callback_method_impl{FNCPUMWRMSR} */
4110static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK8CpuIdCtlExt01hEdcx(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4111{
4112 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4113 /** @todo Changing CPUID leaf 0x80000001. */
4114 return VINF_SUCCESS;
4115}
4116
4117
4118/** @callback_method_impl{FNCPUMRDMSR} */
4119static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK8PatchLevel(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4120{
4121 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4122 /** @todo Fake AMD microcode patching. */
4123 *puValue = pRange->uValue;
4124 return VINF_SUCCESS;
4125}
4126
4127
4128/** @callback_method_impl{FNCPUMWRMSR} */
4129static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK8PatchLoader(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4130{
4131 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4132 /** @todo Fake AMD microcode patching. */
4133 return VINF_SUCCESS;
4134}
4135
4136
4137/** @callback_method_impl{FNCPUMRDMSR} */
4138static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK7DebugStatusMaybe(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4139{
4140 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4141 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
4142 * cpus. Need to be explored and verify K7 presence. */
4143 /** @todo undocumented */
4144 *puValue = 0;
4145 return VINF_SUCCESS;
4146}
4147
4148
4149/** @callback_method_impl{FNCPUMWRMSR} */
4150static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK7DebugStatusMaybe(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4151{
4152 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4153 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
4154 * cpus. Need to be explored and verify K7 presence. */
4155 /** @todo undocumented */
4156 return VINF_SUCCESS;
4157}
4158
4159
4160/** @callback_method_impl{FNCPUMRDMSR} */
4161static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK7BHTraceBaseMaybe(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4162{
4163 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4164 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
4165 * cpus. Need to be explored and verify K7 presence. */
4166 /** @todo undocumented */
4167 *puValue = 0;
4168 return VINF_SUCCESS;
4169}
4170
4171
4172/** @callback_method_impl{FNCPUMWRMSR} */
4173static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK7BHTraceBaseMaybe(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4174{
4175 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4176 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
4177 * cpus. Need to be explored and verify K7 presence. */
4178 /** @todo undocumented */
4179 return VINF_SUCCESS;
4180}
4181
4182
4183/** @callback_method_impl{FNCPUMRDMSR} */
4184static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK7BHTracePtrMaybe(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4185{
4186 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4187 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
4188 * cpus. Need to be explored and verify K7 presence. */
4189 /** @todo undocumented */
4190 *puValue = 0;
4191 return VINF_SUCCESS;
4192}
4193
4194
4195/** @callback_method_impl{FNCPUMWRMSR} */
4196static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK7BHTracePtrMaybe(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4197{
4198 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4199 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
4200 * cpus. Need to be explored and verify K7 presence. */
4201 /** @todo undocumented */
4202 return VINF_SUCCESS;
4203}
4204
4205
4206/** @callback_method_impl{FNCPUMRDMSR} */
4207static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK7BHTraceLimitMaybe(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4208{
4209 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4210 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
4211 * cpus. Need to be explored and verify K7 presence. */
4212 /** @todo undocumented */
4213 *puValue = 0;
4214 return VINF_SUCCESS;
4215}
4216
4217
4218/** @callback_method_impl{FNCPUMWRMSR} */
4219static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK7BHTraceLimitMaybe(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4220{
4221 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4222 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
4223 * cpus. Need to be explored and verify K7 presence. */
4224 /** @todo undocumented */
4225 return VINF_SUCCESS;
4226}
4227
4228
4229/** @callback_method_impl{FNCPUMRDMSR} */
4230static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK7HardwareDebugToolCfgMaybe(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4231{
4232 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4233 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
4234 * cpus. Need to be explored and verify K7 presence. */
4235 /** @todo undocumented */
4236 *puValue = 0;
4237 return VINF_SUCCESS;
4238}
4239
4240
4241/** @callback_method_impl{FNCPUMWRMSR} */
4242static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK7HardwareDebugToolCfgMaybe(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4243{
4244 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4245 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
4246 * cpus. Need to be explored and verify K7 presence. */
4247 /** @todo undocumented */
4248 return VINF_SUCCESS;
4249}
4250
4251
4252/** @callback_method_impl{FNCPUMRDMSR} */
4253static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK7FastFlushCountMaybe(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4254{
4255 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4256 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
4257 * cpus. Need to be explored and verify K7 presence. */
4258 /** @todo undocumented */
4259 *puValue = 0;
4260 return VINF_SUCCESS;
4261}
4262
4263
4264/** @callback_method_impl{FNCPUMWRMSR} */
4265static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK7FastFlushCountMaybe(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4266{
4267 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4268 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
4269 * cpus. Need to be explored and verify K7 presence. */
4270 /** @todo undocumented */
4271 return VINF_SUCCESS;
4272}
4273
4274
4275/** @callback_method_impl{FNCPUMRDMSR} */
4276static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK7NodeId(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4277{
4278 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4279 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
4280 * cpus. Need to be explored and verify K7 presence. */
4281 /** @todo AMD node ID and bios scratch. */
4282 *puValue = 0; /* nodeid = 0; nodes-per-cpu = 1 */
4283 return VINF_SUCCESS;
4284}
4285
4286
4287/** @callback_method_impl{FNCPUMWRMSR} */
4288static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK7NodeId(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4289{
4290 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4291 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
4292 * cpus. Need to be explored and verify K7 presence. */
4293 /** @todo AMD node ID and bios scratch. */
4294 return VINF_SUCCESS;
4295}
4296
4297
4298/** @callback_method_impl{FNCPUMRDMSR} */
4299static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK7DrXAddrMaskN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4300{
4301 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4302 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
4303 * cpus. Need to be explored and verify K7 presence. */
4304 /** @todo AMD DRx address masking (range breakpoints). */
4305 *puValue = 0;
4306 return VINF_SUCCESS;
4307}
4308
4309
4310/** @callback_method_impl{FNCPUMWRMSR} */
4311static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK7DrXAddrMaskN(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4312{
4313 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4314 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
4315 * cpus. Need to be explored and verify K7 presence. */
4316 /** @todo AMD DRx address masking (range breakpoints). */
4317 return VINF_SUCCESS;
4318}
4319
4320
4321/** @callback_method_impl{FNCPUMRDMSR} */
4322static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK7Dr0DataMatchMaybe(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4323{
4324 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4325 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
4326 * cpus. Need to be explored and verify K7 presence. */
4327 /** @todo AMD undocument debugging features. */
4328 *puValue = 0;
4329 return VINF_SUCCESS;
4330}
4331
4332
4333/** @callback_method_impl{FNCPUMWRMSR} */
4334static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK7Dr0DataMatchMaybe(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4335{
4336 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4337 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
4338 * cpus. Need to be explored and verify K7 presence. */
4339 /** @todo AMD undocument debugging features. */
4340 return VINF_SUCCESS;
4341}
4342
4343
4344/** @callback_method_impl{FNCPUMRDMSR} */
4345static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK7Dr0DataMaskMaybe(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4346{
4347 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4348 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
4349 * cpus. Need to be explored and verify K7 presence. */
4350 /** @todo AMD undocument debugging features. */
4351 *puValue = 0;
4352 return VINF_SUCCESS;
4353}
4354
4355
4356/** @callback_method_impl{FNCPUMWRMSR} */
4357static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK7Dr0DataMaskMaybe(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4358{
4359 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4360 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
4361 * cpus. Need to be explored and verify K7 presence. */
4362 /** @todo AMD undocument debugging features. */
4363 return VINF_SUCCESS;
4364}
4365
4366
4367/** @callback_method_impl{FNCPUMRDMSR} */
4368static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK7LoadStoreCfg(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4369{
4370 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4371 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
4372 * cpus. Need to be explored and verify K7 presence. */
4373 /** @todo AMD load-store config. */
4374 *puValue = 0;
4375 return VINF_SUCCESS;
4376}
4377
4378
4379/** @callback_method_impl{FNCPUMWRMSR} */
4380static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK7LoadStoreCfg(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4381{
4382 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4383 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
4384 * cpus. Need to be explored and verify K7 presence. */
4385 /** @todo AMD load-store config. */
4386 return VINF_SUCCESS;
4387}
4388
4389
4390/** @callback_method_impl{FNCPUMRDMSR} */
4391static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK7InstrCacheCfg(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4392{
4393 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4394 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
4395 * cpus. Need to be explored and verify K7 presence. */
4396 /** @todo AMD instruction cache config. */
4397 *puValue = 0;
4398 return VINF_SUCCESS;
4399}
4400
4401
4402/** @callback_method_impl{FNCPUMWRMSR} */
4403static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK7InstrCacheCfg(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4404{
4405 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4406 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
4407 * cpus. Need to be explored and verify K7 presence. */
4408 /** @todo AMD instruction cache config. */
4409 return VINF_SUCCESS;
4410}
4411
4412
4413/** @callback_method_impl{FNCPUMRDMSR} */
4414static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK7DataCacheCfg(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4415{
4416 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4417 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
4418 * cpus. Need to be explored and verify K7 presence. */
4419 /** @todo AMD data cache config. */
4420 *puValue = 0;
4421 return VINF_SUCCESS;
4422}
4423
4424
4425/** @callback_method_impl{FNCPUMWRMSR} */
4426static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK7DataCacheCfg(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4427{
4428 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4429 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
4430 * cpus. Need to be explored and verify K7 presence. */
4431 /** @todo AMD data cache config. */
4432 return VINF_SUCCESS;
4433}
4434
4435
4436/** @callback_method_impl{FNCPUMRDMSR} */
4437static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK7BusUnitCfg(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4438{
4439 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4440 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
4441 * cpus. Need to be explored and verify K7 presence. */
4442 /** @todo AMD bus unit config. */
4443 *puValue = 0;
4444 return VINF_SUCCESS;
4445}
4446
4447
4448/** @callback_method_impl{FNCPUMWRMSR} */
4449static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK7BusUnitCfg(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4450{
4451 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4452 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
4453 * cpus. Need to be explored and verify K7 presence. */
4454 /** @todo AMD bus unit config. */
4455 return VINF_SUCCESS;
4456}
4457
4458
4459/** @callback_method_impl{FNCPUMRDMSR} */
4460static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdK7DebugCtl2Maybe(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4461{
4462 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4463 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
4464 * cpus. Need to be explored and verify K7 presence. */
4465 /** @todo Undocument AMD debug control register \#2. */
4466 *puValue = 0;
4467 return VINF_SUCCESS;
4468}
4469
4470
4471/** @callback_method_impl{FNCPUMWRMSR} */
4472static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdK7DebugCtl2Maybe(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4473{
4474 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4475 /** @todo Allegedly requiring edi=0x9c5a203a when execuing rdmsr/wrmsr on older
4476 * cpus. Need to be explored and verify K7 presence. */
4477 /** @todo Undocument AMD debug control register \#2. */
4478 return VINF_SUCCESS;
4479}
4480
4481
4482/** @callback_method_impl{FNCPUMRDMSR} */
4483static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam15hFpuCfg(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4484{
4485 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4486 /** @todo AMD FPU config. */
4487 *puValue = 0;
4488 return VINF_SUCCESS;
4489}
4490
4491
4492/** @callback_method_impl{FNCPUMWRMSR} */
4493static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam15hFpuCfg(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4494{
4495 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4496 /** @todo AMD FPU config. */
4497 return VINF_SUCCESS;
4498}
4499
4500
4501/** @callback_method_impl{FNCPUMRDMSR} */
4502static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam15hDecoderCfg(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4503{
4504 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4505 /** @todo AMD decoder config. */
4506 *puValue = 0;
4507 return VINF_SUCCESS;
4508}
4509
4510
4511/** @callback_method_impl{FNCPUMWRMSR} */
4512static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam15hDecoderCfg(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4513{
4514 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4515 /** @todo AMD decoder config. */
4516 return VINF_SUCCESS;
4517}
4518
4519
4520/** @callback_method_impl{FNCPUMRDMSR} */
4521static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam10hBusUnitCfg2(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4522{
4523 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4524 /* Note! 10h and 16h */
4525 /** @todo AMD bus unit config. */
4526 *puValue = 0;
4527 return VINF_SUCCESS;
4528}
4529
4530
4531/** @callback_method_impl{FNCPUMWRMSR} */
4532static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam10hBusUnitCfg2(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4533{
4534 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4535 /* Note! 10h and 16h */
4536 /** @todo AMD bus unit config. */
4537 return VINF_SUCCESS;
4538}
4539
4540
4541/** @callback_method_impl{FNCPUMRDMSR} */
4542static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam15hCombUnitCfg(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4543{
4544 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4545 /** @todo AMD unit config. */
4546 *puValue = 0;
4547 return VINF_SUCCESS;
4548}
4549
4550
4551/** @callback_method_impl{FNCPUMWRMSR} */
4552static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam15hCombUnitCfg(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4553{
4554 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4555 /** @todo AMD unit config. */
4556 return VINF_SUCCESS;
4557}
4558
4559
4560/** @callback_method_impl{FNCPUMRDMSR} */
4561static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam15hCombUnitCfg2(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4562{
4563 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4564 /** @todo AMD unit config 2. */
4565 *puValue = 0;
4566 return VINF_SUCCESS;
4567}
4568
4569
4570/** @callback_method_impl{FNCPUMWRMSR} */
4571static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam15hCombUnitCfg2(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4572{
4573 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4574 /** @todo AMD unit config 2. */
4575 return VINF_SUCCESS;
4576}
4577
4578
4579/** @callback_method_impl{FNCPUMRDMSR} */
4580static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam15hCombUnitCfg3(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4581{
4582 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4583 /** @todo AMD combined unit config 3. */
4584 *puValue = 0;
4585 return VINF_SUCCESS;
4586}
4587
4588
4589/** @callback_method_impl{FNCPUMWRMSR} */
4590static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam15hCombUnitCfg3(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4591{
4592 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4593 /** @todo AMD combined unit config 3. */
4594 return VINF_SUCCESS;
4595}
4596
4597
4598/** @callback_method_impl{FNCPUMRDMSR} */
4599static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam15hExecUnitCfg(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4600{
4601 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4602 /** @todo AMD execution unit config. */
4603 *puValue = 0;
4604 return VINF_SUCCESS;
4605}
4606
4607
4608/** @callback_method_impl{FNCPUMWRMSR} */
4609static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam15hExecUnitCfg(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4610{
4611 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4612 /** @todo AMD execution unit config. */
4613 return VINF_SUCCESS;
4614}
4615
4616
4617/** @callback_method_impl{FNCPUMRDMSR} */
4618static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam15hLoadStoreCfg2(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4619{
4620 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4621 /** @todo AMD load-store config 2. */
4622 *puValue = 0;
4623 return VINF_SUCCESS;
4624}
4625
4626
4627/** @callback_method_impl{FNCPUMWRMSR} */
4628static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam15hLoadStoreCfg2(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4629{
4630 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4631 /** @todo AMD load-store config 2. */
4632 return VINF_SUCCESS;
4633}
4634
4635
4636/** @callback_method_impl{FNCPUMRDMSR} */
4637static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam10hIbsFetchCtl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4638{
4639 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4640 /** @todo AMD IBS. */
4641 *puValue = 0;
4642 return VINF_SUCCESS;
4643}
4644
4645
4646/** @callback_method_impl{FNCPUMWRMSR} */
4647static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam10hIbsFetchCtl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4648{
4649 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4650 /** @todo AMD IBS. */
4651 return VINF_SUCCESS;
4652}
4653
4654
4655/** @callback_method_impl{FNCPUMRDMSR} */
4656static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam10hIbsFetchLinAddr(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4657{
4658 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4659 /** @todo AMD IBS. */
4660 *puValue = 0;
4661 return VINF_SUCCESS;
4662}
4663
4664
4665/** @callback_method_impl{FNCPUMWRMSR} */
4666static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam10hIbsFetchLinAddr(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4667{
4668 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4669 /** @todo AMD IBS. */
4670 return VINF_SUCCESS;
4671}
4672
4673
4674/** @callback_method_impl{FNCPUMRDMSR} */
4675static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam10hIbsFetchPhysAddr(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4676{
4677 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4678 /** @todo AMD IBS. */
4679 *puValue = 0;
4680 return VINF_SUCCESS;
4681}
4682
4683
4684/** @callback_method_impl{FNCPUMWRMSR} */
4685static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam10hIbsFetchPhysAddr(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4686{
4687 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4688 /** @todo AMD IBS. */
4689 return VINF_SUCCESS;
4690}
4691
4692
4693/** @callback_method_impl{FNCPUMRDMSR} */
4694static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam10hIbsOpExecCtl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4695{
4696 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4697 /** @todo AMD IBS. */
4698 *puValue = 0;
4699 return VINF_SUCCESS;
4700}
4701
4702
4703/** @callback_method_impl{FNCPUMWRMSR} */
4704static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam10hIbsOpExecCtl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4705{
4706 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4707 /** @todo AMD IBS. */
4708 return VINF_SUCCESS;
4709}
4710
4711
4712/** @callback_method_impl{FNCPUMRDMSR} */
4713static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam10hIbsOpRip(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4714{
4715 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4716 /** @todo AMD IBS. */
4717 *puValue = 0;
4718 return VINF_SUCCESS;
4719}
4720
4721
4722/** @callback_method_impl{FNCPUMWRMSR} */
4723static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam10hIbsOpRip(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4724{
4725 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4726 /** @todo AMD IBS. */
4727 if (!X86_IS_CANONICAL(uValue))
4728 {
4729 Log(("CPUM: wrmsr %s(%#x), %#llx -> #GP - not canonical\n", pRange->szName, idMsr, uValue));
4730 return VERR_CPUM_RAISE_GP_0;
4731 }
4732 return VINF_SUCCESS;
4733}
4734
4735
4736/** @callback_method_impl{FNCPUMRDMSR} */
4737static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam10hIbsOpData(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4738{
4739 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4740 /** @todo AMD IBS. */
4741 *puValue = 0;
4742 return VINF_SUCCESS;
4743}
4744
4745
4746/** @callback_method_impl{FNCPUMWRMSR} */
4747static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam10hIbsOpData(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4748{
4749 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4750 /** @todo AMD IBS. */
4751 return VINF_SUCCESS;
4752}
4753
4754
4755/** @callback_method_impl{FNCPUMRDMSR} */
4756static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam10hIbsOpData2(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4757{
4758 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4759 /** @todo AMD IBS. */
4760 *puValue = 0;
4761 return VINF_SUCCESS;
4762}
4763
4764
4765/** @callback_method_impl{FNCPUMWRMSR} */
4766static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam10hIbsOpData2(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4767{
4768 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4769 /** @todo AMD IBS. */
4770 return VINF_SUCCESS;
4771}
4772
4773
4774/** @callback_method_impl{FNCPUMRDMSR} */
4775static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam10hIbsOpData3(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4776{
4777 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4778 /** @todo AMD IBS. */
4779 *puValue = 0;
4780 return VINF_SUCCESS;
4781}
4782
4783
4784/** @callback_method_impl{FNCPUMWRMSR} */
4785static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam10hIbsOpData3(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4786{
4787 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4788 /** @todo AMD IBS. */
4789 return VINF_SUCCESS;
4790}
4791
4792
4793/** @callback_method_impl{FNCPUMRDMSR} */
4794static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam10hIbsDcLinAddr(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4795{
4796 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4797 /** @todo AMD IBS. */
4798 *puValue = 0;
4799 return VINF_SUCCESS;
4800}
4801
4802
4803/** @callback_method_impl{FNCPUMWRMSR} */
4804static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam10hIbsDcLinAddr(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4805{
4806 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4807 /** @todo AMD IBS. */
4808 if (!X86_IS_CANONICAL(uValue))
4809 {
4810 Log(("CPUM: wrmsr %s(%#x), %#llx -> #GP - not canonical\n", pRange->szName, idMsr, uValue));
4811 return VERR_CPUM_RAISE_GP_0;
4812 }
4813 return VINF_SUCCESS;
4814}
4815
4816
4817/** @callback_method_impl{FNCPUMRDMSR} */
4818static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam10hIbsDcPhysAddr(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4819{
4820 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4821 /** @todo AMD IBS. */
4822 *puValue = 0;
4823 return VINF_SUCCESS;
4824}
4825
4826
4827/** @callback_method_impl{FNCPUMWRMSR} */
4828static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam10hIbsDcPhysAddr(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4829{
4830 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4831 /** @todo AMD IBS. */
4832 return VINF_SUCCESS;
4833}
4834
4835
4836/** @callback_method_impl{FNCPUMRDMSR} */
4837static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam10hIbsCtl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4838{
4839 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4840 /** @todo AMD IBS. */
4841 *puValue = 0;
4842 return VINF_SUCCESS;
4843}
4844
4845
4846/** @callback_method_impl{FNCPUMWRMSR} */
4847static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam10hIbsCtl(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4848{
4849 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4850 /** @todo AMD IBS. */
4851 return VINF_SUCCESS;
4852}
4853
4854
4855/** @callback_method_impl{FNCPUMRDMSR} */
4856static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_AmdFam14hIbsBrTarget(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4857{
4858 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange);
4859 /** @todo AMD IBS. */
4860 *puValue = 0;
4861 return VINF_SUCCESS;
4862}
4863
4864
4865/** @callback_method_impl{FNCPUMWRMSR} */
4866static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_AmdFam14hIbsBrTarget(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4867{
4868 RT_NOREF_PV(pVCpu); RT_NOREF_PV(idMsr); RT_NOREF_PV(pRange); RT_NOREF_PV(uValue); RT_NOREF_PV(uRawValue);
4869 /** @todo AMD IBS. */
4870 if (!X86_IS_CANONICAL(uValue))
4871 {
4872 Log(("CPUM: wrmsr %s(%#x), %#llx -> #GP - not canonical\n", pRange->szName, idMsr, uValue));
4873 return VERR_CPUM_RAISE_GP_0;
4874 }
4875 return VINF_SUCCESS;
4876}
4877
4878
4879
4880/*
4881 * GIM MSRs.
4882 * GIM MSRs.
4883 * GIM MSRs.
4884 */
4885
4886
4887/** @callback_method_impl{FNCPUMRDMSR} */
4888static DECLCALLBACK(VBOXSTRICTRC) cpumMsrRd_Gim(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t *puValue)
4889{
4890 return GIMReadMsr(pVCpu, idMsr, pRange, puValue);
4891}
4892
4893
4894/** @callback_method_impl{FNCPUMWRMSR} */
4895static DECLCALLBACK(VBOXSTRICTRC) cpumMsrWr_Gim(PVMCPU pVCpu, uint32_t idMsr, PCCPUMMSRRANGE pRange, uint64_t uValue, uint64_t uRawValue)
4896{
4897 return GIMWriteMsr(pVCpu, idMsr, pRange, uValue, uRawValue);
4898}
4899
4900
4901/**
4902 * MSR read function table.
4903 */
4904static const PFNCPUMRDMSR g_aCpumRdMsrFns[kCpumMsrRdFn_End] =
4905{
4906 NULL, /* Invalid */
4907 cpumMsrRd_FixedValue,
4908 NULL, /* Alias */
4909 cpumMsrRd_WriteOnly,
4910 cpumMsrRd_Ia32P5McAddr,
4911 cpumMsrRd_Ia32P5McType,
4912 cpumMsrRd_Ia32TimestampCounter,
4913 cpumMsrRd_Ia32PlatformId,
4914 cpumMsrRd_Ia32ApicBase,
4915 cpumMsrRd_Ia32FeatureControl,
4916 cpumMsrRd_Ia32BiosSignId,
4917 cpumMsrRd_Ia32SmmMonitorCtl,
4918 cpumMsrRd_Ia32PmcN,
4919 cpumMsrRd_Ia32MonitorFilterLineSize,
4920 cpumMsrRd_Ia32MPerf,
4921 cpumMsrRd_Ia32APerf,
4922 cpumMsrRd_Ia32MtrrCap,
4923 cpumMsrRd_Ia32MtrrPhysBaseN,
4924 cpumMsrRd_Ia32MtrrPhysMaskN,
4925 cpumMsrRd_Ia32MtrrFixed,
4926 cpumMsrRd_Ia32MtrrDefType,
4927 cpumMsrRd_Ia32Pat,
4928 cpumMsrRd_Ia32SysEnterCs,
4929 cpumMsrRd_Ia32SysEnterEsp,
4930 cpumMsrRd_Ia32SysEnterEip,
4931 cpumMsrRd_Ia32McgCap,
4932 cpumMsrRd_Ia32McgStatus,
4933 cpumMsrRd_Ia32McgCtl,
4934 cpumMsrRd_Ia32DebugCtl,
4935 cpumMsrRd_Ia32SmrrPhysBase,
4936 cpumMsrRd_Ia32SmrrPhysMask,
4937 cpumMsrRd_Ia32PlatformDcaCap,
4938 cpumMsrRd_Ia32CpuDcaCap,
4939 cpumMsrRd_Ia32Dca0Cap,
4940 cpumMsrRd_Ia32PerfEvtSelN,
4941 cpumMsrRd_Ia32PerfStatus,
4942 cpumMsrRd_Ia32PerfCtl,
4943 cpumMsrRd_Ia32FixedCtrN,
4944 cpumMsrRd_Ia32PerfCapabilities,
4945 cpumMsrRd_Ia32FixedCtrCtrl,
4946 cpumMsrRd_Ia32PerfGlobalStatus,
4947 cpumMsrRd_Ia32PerfGlobalCtrl,
4948 cpumMsrRd_Ia32PerfGlobalOvfCtrl,
4949 cpumMsrRd_Ia32PebsEnable,
4950 cpumMsrRd_Ia32ClockModulation,
4951 cpumMsrRd_Ia32ThermInterrupt,
4952 cpumMsrRd_Ia32ThermStatus,
4953 cpumMsrRd_Ia32Therm2Ctl,
4954 cpumMsrRd_Ia32MiscEnable,
4955 cpumMsrRd_Ia32McCtlStatusAddrMiscN,
4956 cpumMsrRd_Ia32McNCtl2,
4957 cpumMsrRd_Ia32DsArea,
4958 cpumMsrRd_Ia32TscDeadline,
4959 cpumMsrRd_Ia32X2ApicN,
4960 cpumMsrRd_Ia32DebugInterface,
4961 cpumMsrRd_Ia32VmxBase,
4962 cpumMsrRd_Ia32VmxPinbasedCtls,
4963 cpumMsrRd_Ia32VmxProcbasedCtls,
4964 cpumMsrRd_Ia32VmxExitCtls,
4965 cpumMsrRd_Ia32VmxEntryCtls,
4966 cpumMsrRd_Ia32VmxMisc,
4967 cpumMsrRd_Ia32VmxCr0Fixed0,
4968 cpumMsrRd_Ia32VmxCr0Fixed1,
4969 cpumMsrRd_Ia32VmxCr4Fixed0,
4970 cpumMsrRd_Ia32VmxCr4Fixed1,
4971 cpumMsrRd_Ia32VmxVmcsEnum,
4972 cpumMsrRd_Ia32VmxProcBasedCtls2,
4973 cpumMsrRd_Ia32VmxEptVpidCap,
4974 cpumMsrRd_Ia32VmxTruePinbasedCtls,
4975 cpumMsrRd_Ia32VmxTrueProcbasedCtls,
4976 cpumMsrRd_Ia32VmxTrueExitCtls,
4977 cpumMsrRd_Ia32VmxTrueEntryCtls,
4978 cpumMsrRd_Ia32VmxVmFunc,
4979
4980 cpumMsrRd_Amd64Efer,
4981 cpumMsrRd_Amd64SyscallTarget,
4982 cpumMsrRd_Amd64LongSyscallTarget,
4983 cpumMsrRd_Amd64CompSyscallTarget,
4984 cpumMsrRd_Amd64SyscallFlagMask,
4985 cpumMsrRd_Amd64FsBase,
4986 cpumMsrRd_Amd64GsBase,
4987 cpumMsrRd_Amd64KernelGsBase,
4988 cpumMsrRd_Amd64TscAux,
4989
4990 cpumMsrRd_IntelEblCrPowerOn,
4991 cpumMsrRd_IntelI7CoreThreadCount,
4992 cpumMsrRd_IntelP4EbcHardPowerOn,
4993 cpumMsrRd_IntelP4EbcSoftPowerOn,
4994 cpumMsrRd_IntelP4EbcFrequencyId,
4995 cpumMsrRd_IntelP6FsbFrequency,
4996 cpumMsrRd_IntelPlatformInfo,
4997 cpumMsrRd_IntelFlexRatio,
4998 cpumMsrRd_IntelPkgCStConfigControl,
4999 cpumMsrRd_IntelPmgIoCaptureBase,
5000 cpumMsrRd_IntelLastBranchFromToN,
5001 cpumMsrRd_IntelLastBranchFromN,
5002 cpumMsrRd_IntelLastBranchToN,
5003 cpumMsrRd_IntelLastBranchTos,
5004 cpumMsrRd_IntelBblCrCtl,
5005 cpumMsrRd_IntelBblCrCtl3,
5006 cpumMsrRd_IntelI7TemperatureTarget,
5007 cpumMsrRd_IntelI7MsrOffCoreResponseN,
5008 cpumMsrRd_IntelI7MiscPwrMgmt,
5009 cpumMsrRd_IntelP6CrN,
5010 cpumMsrRd_IntelCpuId1FeatureMaskEcdx,
5011 cpumMsrRd_IntelCpuId1FeatureMaskEax,
5012 cpumMsrRd_IntelCpuId80000001FeatureMaskEcdx,
5013 cpumMsrRd_IntelI7SandyAesNiCtl,
5014 cpumMsrRd_IntelI7TurboRatioLimit,
5015 cpumMsrRd_IntelI7LbrSelect,
5016 cpumMsrRd_IntelI7SandyErrorControl,
5017 cpumMsrRd_IntelI7VirtualLegacyWireCap,
5018 cpumMsrRd_IntelI7PowerCtl,
5019 cpumMsrRd_IntelI7SandyPebsNumAlt,
5020 cpumMsrRd_IntelI7PebsLdLat,
5021 cpumMsrRd_IntelI7PkgCnResidencyN,
5022 cpumMsrRd_IntelI7CoreCnResidencyN,
5023 cpumMsrRd_IntelI7SandyVrCurrentConfig,
5024 cpumMsrRd_IntelI7SandyVrMiscConfig,
5025 cpumMsrRd_IntelI7SandyRaplPowerUnit,
5026 cpumMsrRd_IntelI7SandyPkgCnIrtlN,
5027 cpumMsrRd_IntelI7SandyPkgC2Residency,
5028 cpumMsrRd_IntelI7RaplPkgPowerLimit,
5029 cpumMsrRd_IntelI7RaplPkgEnergyStatus,
5030 cpumMsrRd_IntelI7RaplPkgPerfStatus,
5031 cpumMsrRd_IntelI7RaplPkgPowerInfo,
5032 cpumMsrRd_IntelI7RaplDramPowerLimit,
5033 cpumMsrRd_IntelI7RaplDramEnergyStatus,
5034 cpumMsrRd_IntelI7RaplDramPerfStatus,
5035 cpumMsrRd_IntelI7RaplDramPowerInfo,
5036 cpumMsrRd_IntelI7RaplPp0PowerLimit,
5037 cpumMsrRd_IntelI7RaplPp0EnergyStatus,
5038 cpumMsrRd_IntelI7RaplPp0Policy,
5039 cpumMsrRd_IntelI7RaplPp0PerfStatus,
5040 cpumMsrRd_IntelI7RaplPp1PowerLimit,
5041 cpumMsrRd_IntelI7RaplPp1EnergyStatus,
5042 cpumMsrRd_IntelI7RaplPp1Policy,
5043 cpumMsrRd_IntelI7IvyConfigTdpNominal,
5044 cpumMsrRd_IntelI7IvyConfigTdpLevel1,
5045 cpumMsrRd_IntelI7IvyConfigTdpLevel2,
5046 cpumMsrRd_IntelI7IvyConfigTdpControl,
5047 cpumMsrRd_IntelI7IvyTurboActivationRatio,
5048 cpumMsrRd_IntelI7UncPerfGlobalCtrl,
5049 cpumMsrRd_IntelI7UncPerfGlobalStatus,
5050 cpumMsrRd_IntelI7UncPerfGlobalOvfCtrl,
5051 cpumMsrRd_IntelI7UncPerfFixedCtrCtrl,
5052 cpumMsrRd_IntelI7UncPerfFixedCtr,
5053 cpumMsrRd_IntelI7UncCBoxConfig,
5054 cpumMsrRd_IntelI7UncArbPerfCtrN,
5055 cpumMsrRd_IntelI7UncArbPerfEvtSelN,
5056 cpumMsrRd_IntelI7SmiCount,
5057 cpumMsrRd_IntelCore2EmttmCrTablesN,
5058 cpumMsrRd_IntelCore2SmmCStMiscInfo,
5059 cpumMsrRd_IntelCore1ExtConfig,
5060 cpumMsrRd_IntelCore1DtsCalControl,
5061 cpumMsrRd_IntelCore2PeciControl,
5062 cpumMsrRd_IntelAtSilvCoreC1Recidency,
5063
5064 cpumMsrRd_P6LastBranchFromIp,
5065 cpumMsrRd_P6LastBranchToIp,
5066 cpumMsrRd_P6LastIntFromIp,
5067 cpumMsrRd_P6LastIntToIp,
5068
5069 cpumMsrRd_AmdFam15hTscRate,
5070 cpumMsrRd_AmdFam15hLwpCfg,
5071 cpumMsrRd_AmdFam15hLwpCbAddr,
5072 cpumMsrRd_AmdFam10hMc4MiscN,
5073 cpumMsrRd_AmdK8PerfCtlN,
5074 cpumMsrRd_AmdK8PerfCtrN,
5075 cpumMsrRd_AmdK8SysCfg,
5076 cpumMsrRd_AmdK8HwCr,
5077 cpumMsrRd_AmdK8IorrBaseN,
5078 cpumMsrRd_AmdK8IorrMaskN,
5079 cpumMsrRd_AmdK8TopOfMemN,
5080 cpumMsrRd_AmdK8NbCfg1,
5081 cpumMsrRd_AmdK8McXcptRedir,
5082 cpumMsrRd_AmdK8CpuNameN,
5083 cpumMsrRd_AmdK8HwThermalCtrl,
5084 cpumMsrRd_AmdK8SwThermalCtrl,
5085 cpumMsrRd_AmdK8FidVidControl,
5086 cpumMsrRd_AmdK8FidVidStatus,
5087 cpumMsrRd_AmdK8McCtlMaskN,
5088 cpumMsrRd_AmdK8SmiOnIoTrapN,
5089 cpumMsrRd_AmdK8SmiOnIoTrapCtlSts,
5090 cpumMsrRd_AmdK8IntPendingMessage,
5091 cpumMsrRd_AmdK8SmiTriggerIoCycle,
5092 cpumMsrRd_AmdFam10hMmioCfgBaseAddr,
5093 cpumMsrRd_AmdFam10hTrapCtlMaybe,
5094 cpumMsrRd_AmdFam10hPStateCurLimit,
5095 cpumMsrRd_AmdFam10hPStateControl,
5096 cpumMsrRd_AmdFam10hPStateStatus,
5097 cpumMsrRd_AmdFam10hPStateN,
5098 cpumMsrRd_AmdFam10hCofVidControl,
5099 cpumMsrRd_AmdFam10hCofVidStatus,
5100 cpumMsrRd_AmdFam10hCStateIoBaseAddr,
5101 cpumMsrRd_AmdFam10hCpuWatchdogTimer,
5102 cpumMsrRd_AmdK8SmmBase,
5103 cpumMsrRd_AmdK8SmmAddr,
5104 cpumMsrRd_AmdK8SmmMask,
5105 cpumMsrRd_AmdK8VmCr,
5106 cpumMsrRd_AmdK8IgnNe,
5107 cpumMsrRd_AmdK8SmmCtl,
5108 cpumMsrRd_AmdK8VmHSavePa,
5109 cpumMsrRd_AmdFam10hVmLockKey,
5110 cpumMsrRd_AmdFam10hSmmLockKey,
5111 cpumMsrRd_AmdFam10hLocalSmiStatus,
5112 cpumMsrRd_AmdFam10hOsVisWrkIdLength,
5113 cpumMsrRd_AmdFam10hOsVisWrkStatus,
5114 cpumMsrRd_AmdFam16hL2IPerfCtlN,
5115 cpumMsrRd_AmdFam16hL2IPerfCtrN,
5116 cpumMsrRd_AmdFam15hNorthbridgePerfCtlN,
5117 cpumMsrRd_AmdFam15hNorthbridgePerfCtrN,
5118 cpumMsrRd_AmdK7MicrocodeCtl,
5119 cpumMsrRd_AmdK7ClusterIdMaybe,
5120 cpumMsrRd_AmdK8CpuIdCtlStd07hEbax,
5121 cpumMsrRd_AmdK8CpuIdCtlStd06hEcx,
5122 cpumMsrRd_AmdK8CpuIdCtlStd01hEdcx,
5123 cpumMsrRd_AmdK8CpuIdCtlExt01hEdcx,
5124 cpumMsrRd_AmdK8PatchLevel,
5125 cpumMsrRd_AmdK7DebugStatusMaybe,
5126 cpumMsrRd_AmdK7BHTraceBaseMaybe,
5127 cpumMsrRd_AmdK7BHTracePtrMaybe,
5128 cpumMsrRd_AmdK7BHTraceLimitMaybe,
5129 cpumMsrRd_AmdK7HardwareDebugToolCfgMaybe,
5130 cpumMsrRd_AmdK7FastFlushCountMaybe,
5131 cpumMsrRd_AmdK7NodeId,
5132 cpumMsrRd_AmdK7DrXAddrMaskN,
5133 cpumMsrRd_AmdK7Dr0DataMatchMaybe,
5134 cpumMsrRd_AmdK7Dr0DataMaskMaybe,
5135 cpumMsrRd_AmdK7LoadStoreCfg,
5136 cpumMsrRd_AmdK7InstrCacheCfg,
5137 cpumMsrRd_AmdK7DataCacheCfg,
5138 cpumMsrRd_AmdK7BusUnitCfg,
5139 cpumMsrRd_AmdK7DebugCtl2Maybe,
5140 cpumMsrRd_AmdFam15hFpuCfg,
5141 cpumMsrRd_AmdFam15hDecoderCfg,
5142 cpumMsrRd_AmdFam10hBusUnitCfg2,
5143 cpumMsrRd_AmdFam15hCombUnitCfg,
5144 cpumMsrRd_AmdFam15hCombUnitCfg2,
5145 cpumMsrRd_AmdFam15hCombUnitCfg3,
5146 cpumMsrRd_AmdFam15hExecUnitCfg,
5147 cpumMsrRd_AmdFam15hLoadStoreCfg2,
5148 cpumMsrRd_AmdFam10hIbsFetchCtl,
5149 cpumMsrRd_AmdFam10hIbsFetchLinAddr,
5150 cpumMsrRd_AmdFam10hIbsFetchPhysAddr,
5151 cpumMsrRd_AmdFam10hIbsOpExecCtl,
5152 cpumMsrRd_AmdFam10hIbsOpRip,
5153 cpumMsrRd_AmdFam10hIbsOpData,
5154 cpumMsrRd_AmdFam10hIbsOpData2,
5155 cpumMsrRd_AmdFam10hIbsOpData3,
5156 cpumMsrRd_AmdFam10hIbsDcLinAddr,
5157 cpumMsrRd_AmdFam10hIbsDcPhysAddr,
5158 cpumMsrRd_AmdFam10hIbsCtl,
5159 cpumMsrRd_AmdFam14hIbsBrTarget,
5160
5161 cpumMsrRd_Gim
5162};
5163
5164
5165/**
5166 * MSR write function table.
5167 */
5168static const PFNCPUMWRMSR g_aCpumWrMsrFns[kCpumMsrWrFn_End] =
5169{
5170 NULL, /* Invalid */
5171 cpumMsrWr_IgnoreWrite,
5172 cpumMsrWr_ReadOnly,
5173 NULL, /* Alias */
5174 cpumMsrWr_Ia32P5McAddr,
5175 cpumMsrWr_Ia32P5McType,
5176 cpumMsrWr_Ia32TimestampCounter,
5177 cpumMsrWr_Ia32ApicBase,
5178 cpumMsrWr_Ia32FeatureControl,
5179 cpumMsrWr_Ia32BiosSignId,
5180 cpumMsrWr_Ia32BiosUpdateTrigger,
5181 cpumMsrWr_Ia32SmmMonitorCtl,
5182 cpumMsrWr_Ia32PmcN,
5183 cpumMsrWr_Ia32MonitorFilterLineSize,
5184 cpumMsrWr_Ia32MPerf,
5185 cpumMsrWr_Ia32APerf,
5186 cpumMsrWr_Ia32MtrrPhysBaseN,
5187 cpumMsrWr_Ia32MtrrPhysMaskN,
5188 cpumMsrWr_Ia32MtrrFixed,
5189 cpumMsrWr_Ia32MtrrDefType,
5190 cpumMsrWr_Ia32Pat,
5191 cpumMsrWr_Ia32SysEnterCs,
5192 cpumMsrWr_Ia32SysEnterEsp,
5193 cpumMsrWr_Ia32SysEnterEip,
5194 cpumMsrWr_Ia32McgStatus,
5195 cpumMsrWr_Ia32McgCtl,
5196 cpumMsrWr_Ia32DebugCtl,
5197 cpumMsrWr_Ia32SmrrPhysBase,
5198 cpumMsrWr_Ia32SmrrPhysMask,
5199 cpumMsrWr_Ia32PlatformDcaCap,
5200 cpumMsrWr_Ia32Dca0Cap,
5201 cpumMsrWr_Ia32PerfEvtSelN,
5202 cpumMsrWr_Ia32PerfStatus,
5203 cpumMsrWr_Ia32PerfCtl,
5204 cpumMsrWr_Ia32FixedCtrN,
5205 cpumMsrWr_Ia32PerfCapabilities,
5206 cpumMsrWr_Ia32FixedCtrCtrl,
5207 cpumMsrWr_Ia32PerfGlobalStatus,
5208 cpumMsrWr_Ia32PerfGlobalCtrl,
5209 cpumMsrWr_Ia32PerfGlobalOvfCtrl,
5210 cpumMsrWr_Ia32PebsEnable,
5211 cpumMsrWr_Ia32ClockModulation,
5212 cpumMsrWr_Ia32ThermInterrupt,
5213 cpumMsrWr_Ia32ThermStatus,
5214 cpumMsrWr_Ia32Therm2Ctl,
5215 cpumMsrWr_Ia32MiscEnable,
5216 cpumMsrWr_Ia32McCtlStatusAddrMiscN,
5217 cpumMsrWr_Ia32McNCtl2,
5218 cpumMsrWr_Ia32DsArea,
5219 cpumMsrWr_Ia32TscDeadline,
5220 cpumMsrWr_Ia32X2ApicN,
5221 cpumMsrWr_Ia32DebugInterface,
5222
5223 cpumMsrWr_Amd64Efer,
5224 cpumMsrWr_Amd64SyscallTarget,
5225 cpumMsrWr_Amd64LongSyscallTarget,
5226 cpumMsrWr_Amd64CompSyscallTarget,
5227 cpumMsrWr_Amd64SyscallFlagMask,
5228 cpumMsrWr_Amd64FsBase,
5229 cpumMsrWr_Amd64GsBase,
5230 cpumMsrWr_Amd64KernelGsBase,
5231 cpumMsrWr_Amd64TscAux,
5232
5233 cpumMsrWr_IntelEblCrPowerOn,
5234 cpumMsrWr_IntelP4EbcHardPowerOn,
5235 cpumMsrWr_IntelP4EbcSoftPowerOn,
5236 cpumMsrWr_IntelP4EbcFrequencyId,
5237 cpumMsrWr_IntelFlexRatio,
5238 cpumMsrWr_IntelPkgCStConfigControl,
5239 cpumMsrWr_IntelPmgIoCaptureBase,
5240 cpumMsrWr_IntelLastBranchFromToN,
5241 cpumMsrWr_IntelLastBranchFromN,
5242 cpumMsrWr_IntelLastBranchToN,
5243 cpumMsrWr_IntelLastBranchTos,
5244 cpumMsrWr_IntelBblCrCtl,
5245 cpumMsrWr_IntelBblCrCtl3,
5246 cpumMsrWr_IntelI7TemperatureTarget,
5247 cpumMsrWr_IntelI7MsrOffCoreResponseN,
5248 cpumMsrWr_IntelI7MiscPwrMgmt,
5249 cpumMsrWr_IntelP6CrN,
5250 cpumMsrWr_IntelCpuId1FeatureMaskEcdx,
5251 cpumMsrWr_IntelCpuId1FeatureMaskEax,
5252 cpumMsrWr_IntelCpuId80000001FeatureMaskEcdx,
5253 cpumMsrWr_IntelI7SandyAesNiCtl,
5254 cpumMsrWr_IntelI7TurboRatioLimit,
5255 cpumMsrWr_IntelI7LbrSelect,
5256 cpumMsrWr_IntelI7SandyErrorControl,
5257 cpumMsrWr_IntelI7PowerCtl,
5258 cpumMsrWr_IntelI7SandyPebsNumAlt,
5259 cpumMsrWr_IntelI7PebsLdLat,
5260 cpumMsrWr_IntelI7SandyVrCurrentConfig,
5261 cpumMsrWr_IntelI7SandyVrMiscConfig,
5262 cpumMsrWr_IntelI7SandyRaplPowerUnit,
5263 cpumMsrWr_IntelI7SandyPkgCnIrtlN,
5264 cpumMsrWr_IntelI7SandyPkgC2Residency,
5265 cpumMsrWr_IntelI7RaplPkgPowerLimit,
5266 cpumMsrWr_IntelI7RaplDramPowerLimit,
5267 cpumMsrWr_IntelI7RaplPp0PowerLimit,
5268 cpumMsrWr_IntelI7RaplPp0Policy,
5269 cpumMsrWr_IntelI7RaplPp1PowerLimit,
5270 cpumMsrWr_IntelI7RaplPp1Policy,
5271 cpumMsrWr_IntelI7IvyConfigTdpControl,
5272 cpumMsrWr_IntelI7IvyTurboActivationRatio,
5273 cpumMsrWr_IntelI7UncPerfGlobalCtrl,
5274 cpumMsrWr_IntelI7UncPerfGlobalStatus,
5275 cpumMsrWr_IntelI7UncPerfGlobalOvfCtrl,
5276 cpumMsrWr_IntelI7UncPerfFixedCtrCtrl,
5277 cpumMsrWr_IntelI7UncPerfFixedCtr,
5278 cpumMsrWr_IntelI7UncArbPerfCtrN,
5279 cpumMsrWr_IntelI7UncArbPerfEvtSelN,
5280 cpumMsrWr_IntelCore2EmttmCrTablesN,
5281 cpumMsrWr_IntelCore2SmmCStMiscInfo,
5282 cpumMsrWr_IntelCore1ExtConfig,
5283 cpumMsrWr_IntelCore1DtsCalControl,
5284 cpumMsrWr_IntelCore2PeciControl,
5285
5286 cpumMsrWr_P6LastIntFromIp,
5287 cpumMsrWr_P6LastIntToIp,
5288
5289 cpumMsrWr_AmdFam15hTscRate,
5290 cpumMsrWr_AmdFam15hLwpCfg,
5291 cpumMsrWr_AmdFam15hLwpCbAddr,
5292 cpumMsrWr_AmdFam10hMc4MiscN,
5293 cpumMsrWr_AmdK8PerfCtlN,
5294 cpumMsrWr_AmdK8PerfCtrN,
5295 cpumMsrWr_AmdK8SysCfg,
5296 cpumMsrWr_AmdK8HwCr,
5297 cpumMsrWr_AmdK8IorrBaseN,
5298 cpumMsrWr_AmdK8IorrMaskN,
5299 cpumMsrWr_AmdK8TopOfMemN,
5300 cpumMsrWr_AmdK8NbCfg1,
5301 cpumMsrWr_AmdK8McXcptRedir,
5302 cpumMsrWr_AmdK8CpuNameN,
5303 cpumMsrWr_AmdK8HwThermalCtrl,
5304 cpumMsrWr_AmdK8SwThermalCtrl,
5305 cpumMsrWr_AmdK8FidVidControl,
5306 cpumMsrWr_AmdK8McCtlMaskN,
5307 cpumMsrWr_AmdK8SmiOnIoTrapN,
5308 cpumMsrWr_AmdK8SmiOnIoTrapCtlSts,
5309 cpumMsrWr_AmdK8IntPendingMessage,
5310 cpumMsrWr_AmdK8SmiTriggerIoCycle,
5311 cpumMsrWr_AmdFam10hMmioCfgBaseAddr,
5312 cpumMsrWr_AmdFam10hTrapCtlMaybe,
5313 cpumMsrWr_AmdFam10hPStateControl,
5314 cpumMsrWr_AmdFam10hPStateStatus,
5315 cpumMsrWr_AmdFam10hPStateN,
5316 cpumMsrWr_AmdFam10hCofVidControl,
5317 cpumMsrWr_AmdFam10hCofVidStatus,
5318 cpumMsrWr_AmdFam10hCStateIoBaseAddr,
5319 cpumMsrWr_AmdFam10hCpuWatchdogTimer,
5320 cpumMsrWr_AmdK8SmmBase,
5321 cpumMsrWr_AmdK8SmmAddr,
5322 cpumMsrWr_AmdK8SmmMask,
5323 cpumMsrWr_AmdK8VmCr,
5324 cpumMsrWr_AmdK8IgnNe,
5325 cpumMsrWr_AmdK8SmmCtl,
5326 cpumMsrWr_AmdK8VmHSavePa,
5327 cpumMsrWr_AmdFam10hVmLockKey,
5328 cpumMsrWr_AmdFam10hSmmLockKey,
5329 cpumMsrWr_AmdFam10hLocalSmiStatus,
5330 cpumMsrWr_AmdFam10hOsVisWrkIdLength,
5331 cpumMsrWr_AmdFam10hOsVisWrkStatus,
5332 cpumMsrWr_AmdFam16hL2IPerfCtlN,
5333 cpumMsrWr_AmdFam16hL2IPerfCtrN,
5334 cpumMsrWr_AmdFam15hNorthbridgePerfCtlN,
5335 cpumMsrWr_AmdFam15hNorthbridgePerfCtrN,
5336 cpumMsrWr_AmdK7MicrocodeCtl,
5337 cpumMsrWr_AmdK7ClusterIdMaybe,
5338 cpumMsrWr_AmdK8CpuIdCtlStd07hEbax,
5339 cpumMsrWr_AmdK8CpuIdCtlStd06hEcx,
5340 cpumMsrWr_AmdK8CpuIdCtlStd01hEdcx,
5341 cpumMsrWr_AmdK8CpuIdCtlExt01hEdcx,
5342 cpumMsrWr_AmdK8PatchLoader,
5343 cpumMsrWr_AmdK7DebugStatusMaybe,
5344 cpumMsrWr_AmdK7BHTraceBaseMaybe,
5345 cpumMsrWr_AmdK7BHTracePtrMaybe,
5346 cpumMsrWr_AmdK7BHTraceLimitMaybe,
5347 cpumMsrWr_AmdK7HardwareDebugToolCfgMaybe,
5348 cpumMsrWr_AmdK7FastFlushCountMaybe,
5349 cpumMsrWr_AmdK7NodeId,
5350 cpumMsrWr_AmdK7DrXAddrMaskN,
5351 cpumMsrWr_AmdK7Dr0DataMatchMaybe,
5352 cpumMsrWr_AmdK7Dr0DataMaskMaybe,
5353 cpumMsrWr_AmdK7LoadStoreCfg,
5354 cpumMsrWr_AmdK7InstrCacheCfg,
5355 cpumMsrWr_AmdK7DataCacheCfg,
5356 cpumMsrWr_AmdK7BusUnitCfg,
5357 cpumMsrWr_AmdK7DebugCtl2Maybe,
5358 cpumMsrWr_AmdFam15hFpuCfg,
5359 cpumMsrWr_AmdFam15hDecoderCfg,
5360 cpumMsrWr_AmdFam10hBusUnitCfg2,
5361 cpumMsrWr_AmdFam15hCombUnitCfg,
5362 cpumMsrWr_AmdFam15hCombUnitCfg2,
5363 cpumMsrWr_AmdFam15hCombUnitCfg3,
5364 cpumMsrWr_AmdFam15hExecUnitCfg,
5365 cpumMsrWr_AmdFam15hLoadStoreCfg2,
5366 cpumMsrWr_AmdFam10hIbsFetchCtl,
5367 cpumMsrWr_AmdFam10hIbsFetchLinAddr,
5368 cpumMsrWr_AmdFam10hIbsFetchPhysAddr,
5369 cpumMsrWr_AmdFam10hIbsOpExecCtl,
5370 cpumMsrWr_AmdFam10hIbsOpRip,
5371 cpumMsrWr_AmdFam10hIbsOpData,
5372 cpumMsrWr_AmdFam10hIbsOpData2,
5373 cpumMsrWr_AmdFam10hIbsOpData3,
5374 cpumMsrWr_AmdFam10hIbsDcLinAddr,
5375 cpumMsrWr_AmdFam10hIbsDcPhysAddr,
5376 cpumMsrWr_AmdFam10hIbsCtl,
5377 cpumMsrWr_AmdFam14hIbsBrTarget,
5378
5379 cpumMsrWr_Gim
5380};
5381
5382
5383/**
5384 * Looks up the range for the given MSR.
5385 *
5386 * @returns Pointer to the range if found, NULL if not.
5387 * @param pVM The cross context VM structure.
5388 * @param idMsr The MSR to look up.
5389 */
5390# ifndef IN_RING3
5391static
5392# endif
5393PCPUMMSRRANGE cpumLookupMsrRange(PVM pVM, uint32_t idMsr)
5394{
5395 /*
5396 * Binary lookup.
5397 */
5398 uint32_t cRanges = pVM->cpum.s.GuestInfo.cMsrRanges;
5399 if (!cRanges)
5400 return NULL;
5401 PCPUMMSRRANGE paRanges = pVM->cpum.s.GuestInfo.CTX_SUFF(paMsrRanges);
5402 for (;;)
5403 {
5404 uint32_t i = cRanges / 2;
5405 if (idMsr < paRanges[i].uFirst)
5406 {
5407 if (i == 0)
5408 break;
5409 cRanges = i;
5410 }
5411 else if (idMsr > paRanges[i].uLast)
5412 {
5413 i++;
5414 if (i >= cRanges)
5415 break;
5416 cRanges -= i;
5417 paRanges = &paRanges[i];
5418 }
5419 else
5420 {
5421 if (paRanges[i].enmRdFn == kCpumMsrRdFn_MsrAlias)
5422 return cpumLookupMsrRange(pVM, paRanges[i].uValue);
5423 return &paRanges[i];
5424 }
5425 }
5426
5427# ifdef VBOX_STRICT
5428 /*
5429 * Linear lookup to verify the above binary search.
5430 */
5431 uint32_t cLeft = pVM->cpum.s.GuestInfo.cMsrRanges;
5432 PCPUMMSRRANGE pCur = pVM->cpum.s.GuestInfo.CTX_SUFF(paMsrRanges);
5433 while (cLeft-- > 0)
5434 {
5435 if (idMsr >= pCur->uFirst && idMsr <= pCur->uLast)
5436 {
5437 AssertFailed();
5438 if (pCur->enmRdFn == kCpumMsrRdFn_MsrAlias)
5439 return cpumLookupMsrRange(pVM, pCur->uValue);
5440 return pCur;
5441 }
5442 pCur++;
5443 }
5444# endif
5445 return NULL;
5446}
5447
5448
5449/**
5450 * Query a guest MSR.
5451 *
5452 * The caller is responsible for checking privilege if the call is the result of
5453 * a RDMSR instruction. We'll do the rest.
5454 *
5455 * @retval VINF_SUCCESS on success.
5456 * @retval VINF_CPUM_R3_MSR_READ if the MSR read could not be serviced in the
5457 * current context (raw-mode or ring-0).
5458 * @retval VERR_CPUM_RAISE_GP_0 on failure (invalid MSR), the caller is
5459 * expected to take the appropriate actions. @a *puValue is set to 0.
5460 * @param pVCpu The cross context virtual CPU structure.
5461 * @param idMsr The MSR.
5462 * @param puValue Where to return the value.
5463 *
5464 * @remarks This will always return the right values, even when we're in the
5465 * recompiler.
5466 */
5467VMMDECL(VBOXSTRICTRC) CPUMQueryGuestMsr(PVMCPU pVCpu, uint32_t idMsr, uint64_t *puValue)
5468{
5469 *puValue = 0;
5470
5471 VBOXSTRICTRC rcStrict;
5472 PVM pVM = pVCpu->CTX_SUFF(pVM);
5473 PCPUMMSRRANGE pRange = cpumLookupMsrRange(pVM, idMsr);
5474 if (pRange)
5475 {
5476 CPUMMSRRDFN enmRdFn = (CPUMMSRRDFN)pRange->enmRdFn;
5477 AssertReturn(enmRdFn > kCpumMsrRdFn_Invalid && enmRdFn < kCpumMsrRdFn_End, VERR_CPUM_IPE_1);
5478
5479 PFNCPUMRDMSR pfnRdMsr = g_aCpumRdMsrFns[enmRdFn];
5480 AssertReturn(pfnRdMsr, VERR_CPUM_IPE_2);
5481
5482 STAM_COUNTER_INC(&pRange->cReads);
5483 STAM_REL_COUNTER_INC(&pVM->cpum.s.cMsrReads);
5484
5485 rcStrict = pfnRdMsr(pVCpu, idMsr, pRange, puValue);
5486 if (rcStrict == VINF_SUCCESS)
5487 Log2(("CPUM: RDMSR %#x (%s) -> %#llx\n", idMsr, pRange->szName, *puValue));
5488 else if (rcStrict == VERR_CPUM_RAISE_GP_0)
5489 {
5490 Log(("CPUM: RDMSR %#x (%s) -> #GP(0)\n", idMsr, pRange->szName));
5491 STAM_COUNTER_INC(&pRange->cGps);
5492 STAM_REL_COUNTER_INC(&pVM->cpum.s.cMsrReadsRaiseGp);
5493 }
5494#ifndef IN_RING3
5495 else if (rcStrict == VINF_CPUM_R3_MSR_READ)
5496 Log(("CPUM: RDMSR %#x (%s) -> ring-3\n", idMsr, pRange->szName));
5497#endif
5498 else
5499 {
5500 Log(("CPUM: RDMSR %#x (%s) -> rcStrict=%Rrc\n", idMsr, pRange->szName, VBOXSTRICTRC_VAL(rcStrict)));
5501 AssertMsgStmt(RT_FAILURE_NP(rcStrict), ("%Rrc idMsr=%#x\n", VBOXSTRICTRC_VAL(rcStrict), idMsr),
5502 rcStrict = VERR_IPE_UNEXPECTED_INFO_STATUS);
5503 Assert(rcStrict != VERR_EM_INTERPRETER);
5504 }
5505 }
5506 else
5507 {
5508 Log(("CPUM: Unknown RDMSR %#x -> #GP(0)\n", idMsr));
5509 STAM_REL_COUNTER_INC(&pVM->cpum.s.cMsrReads);
5510 STAM_REL_COUNTER_INC(&pVM->cpum.s.cMsrReadsUnknown);
5511 rcStrict = VERR_CPUM_RAISE_GP_0;
5512 }
5513 return rcStrict;
5514}
5515
5516
5517/**
5518 * Writes to a guest MSR.
5519 *
5520 * The caller is responsible for checking privilege if the call is the result of
5521 * a WRMSR instruction. We'll do the rest.
5522 *
5523 * @retval VINF_SUCCESS on success.
5524 * @retval VINF_CPUM_R3_MSR_WRITE if the MSR write could not be serviced in the
5525 * current context (raw-mode or ring-0).
5526 * @retval VERR_CPUM_RAISE_GP_0 on failure, the caller is expected to take the
5527 * appropriate actions.
5528 *
5529 * @param pVCpu The cross context virtual CPU structure.
5530 * @param idMsr The MSR id.
5531 * @param uValue The value to set.
5532 *
5533 * @remarks Everyone changing MSR values, including the recompiler, shall do it
5534 * by calling this method. This makes sure we have current values and
5535 * that we trigger all the right actions when something changes.
5536 *
5537 * For performance reasons, this actually isn't entirely true for some
5538 * MSRs when in HM mode. The code here and in HM must be aware of
5539 * this.
5540 */
5541VMMDECL(VBOXSTRICTRC) CPUMSetGuestMsr(PVMCPU pVCpu, uint32_t idMsr, uint64_t uValue)
5542{
5543 VBOXSTRICTRC rcStrict;
5544 PVM pVM = pVCpu->CTX_SUFF(pVM);
5545 PCPUMMSRRANGE pRange = cpumLookupMsrRange(pVM, idMsr);
5546 if (pRange)
5547 {
5548 STAM_COUNTER_INC(&pRange->cWrites);
5549 STAM_REL_COUNTER_INC(&pVM->cpum.s.cMsrWrites);
5550
5551 if (!(uValue & pRange->fWrGpMask))
5552 {
5553 CPUMMSRWRFN enmWrFn = (CPUMMSRWRFN)pRange->enmWrFn;
5554 AssertReturn(enmWrFn > kCpumMsrWrFn_Invalid && enmWrFn < kCpumMsrWrFn_End, VERR_CPUM_IPE_1);
5555
5556 PFNCPUMWRMSR pfnWrMsr = g_aCpumWrMsrFns[enmWrFn];
5557 AssertReturn(pfnWrMsr, VERR_CPUM_IPE_2);
5558
5559 uint64_t uValueAdjusted = uValue & ~pRange->fWrIgnMask;
5560 if (uValueAdjusted != uValue)
5561 {
5562 STAM_COUNTER_INC(&pRange->cIgnoredBits);
5563 STAM_REL_COUNTER_INC(&pVM->cpum.s.cMsrWritesToIgnoredBits);
5564 }
5565
5566 rcStrict = pfnWrMsr(pVCpu, idMsr, pRange, uValueAdjusted, uValue);
5567 if (rcStrict == VINF_SUCCESS)
5568 Log2(("CPUM: WRMSR %#x (%s), %#llx [%#llx]\n", idMsr, pRange->szName, uValueAdjusted, uValue));
5569 else if (rcStrict == VERR_CPUM_RAISE_GP_0)
5570 {
5571 Log(("CPUM: WRMSR %#x (%s), %#llx [%#llx] -> #GP(0)\n", idMsr, pRange->szName, uValueAdjusted, uValue));
5572 STAM_COUNTER_INC(&pRange->cGps);
5573 STAM_REL_COUNTER_INC(&pVM->cpum.s.cMsrWritesRaiseGp);
5574 }
5575#ifndef IN_RING3
5576 else if (rcStrict == VINF_CPUM_R3_MSR_WRITE)
5577 Log(("CPUM: WRMSR %#x (%s), %#llx [%#llx] -> ring-3\n", idMsr, pRange->szName, uValueAdjusted, uValue));
5578#endif
5579 else
5580 {
5581 Log(("CPUM: WRMSR %#x (%s), %#llx [%#llx] -> rcStrict=%Rrc\n",
5582 idMsr, pRange->szName, uValueAdjusted, uValue, VBOXSTRICTRC_VAL(rcStrict)));
5583 AssertMsgStmt(RT_FAILURE_NP(rcStrict), ("%Rrc idMsr=%#x\n", VBOXSTRICTRC_VAL(rcStrict), idMsr),
5584 rcStrict = VERR_IPE_UNEXPECTED_INFO_STATUS);
5585 Assert(rcStrict != VERR_EM_INTERPRETER);
5586 }
5587 }
5588 else
5589 {
5590 Log(("CPUM: WRMSR %#x (%s), %#llx -> #GP(0) - invalid bits %#llx\n",
5591 idMsr, pRange->szName, uValue, uValue & pRange->fWrGpMask));
5592 STAM_COUNTER_INC(&pRange->cGps);
5593 STAM_REL_COUNTER_INC(&pVM->cpum.s.cMsrWritesRaiseGp);
5594 rcStrict = VERR_CPUM_RAISE_GP_0;
5595 }
5596 }
5597 else
5598 {
5599 Log(("CPUM: Unknown WRMSR %#x, %#llx -> #GP(0)\n", idMsr, uValue));
5600 STAM_REL_COUNTER_INC(&pVM->cpum.s.cMsrWrites);
5601 STAM_REL_COUNTER_INC(&pVM->cpum.s.cMsrWritesUnknown);
5602 rcStrict = VERR_CPUM_RAISE_GP_0;
5603 }
5604 return rcStrict;
5605}
5606
5607
5608#if defined(VBOX_STRICT) && defined(IN_RING3)
5609/**
5610 * Performs some checks on the static data related to MSRs.
5611 *
5612 * @returns VINF_SUCCESS on success, error on failure.
5613 */
5614int cpumR3MsrStrictInitChecks(void)
5615{
5616#define CPUM_ASSERT_RD_MSR_FN(a_Register) \
5617 AssertReturn(g_aCpumRdMsrFns[kCpumMsrRdFn_##a_Register] == cpumMsrRd_##a_Register, VERR_CPUM_IPE_2);
5618#define CPUM_ASSERT_WR_MSR_FN(a_Register) \
5619 AssertReturn(g_aCpumWrMsrFns[kCpumMsrWrFn_##a_Register] == cpumMsrWr_##a_Register, VERR_CPUM_IPE_2);
5620
5621 AssertReturn(g_aCpumRdMsrFns[kCpumMsrRdFn_Invalid] == NULL, VERR_CPUM_IPE_2);
5622 CPUM_ASSERT_RD_MSR_FN(FixedValue);
5623 CPUM_ASSERT_RD_MSR_FN(WriteOnly);
5624 CPUM_ASSERT_RD_MSR_FN(Ia32P5McAddr);
5625 CPUM_ASSERT_RD_MSR_FN(Ia32P5McType);
5626 CPUM_ASSERT_RD_MSR_FN(Ia32TimestampCounter);
5627 CPUM_ASSERT_RD_MSR_FN(Ia32PlatformId);
5628 CPUM_ASSERT_RD_MSR_FN(Ia32ApicBase);
5629 CPUM_ASSERT_RD_MSR_FN(Ia32FeatureControl);
5630 CPUM_ASSERT_RD_MSR_FN(Ia32BiosSignId);
5631 CPUM_ASSERT_RD_MSR_FN(Ia32SmmMonitorCtl);
5632 CPUM_ASSERT_RD_MSR_FN(Ia32PmcN);
5633 CPUM_ASSERT_RD_MSR_FN(Ia32MonitorFilterLineSize);
5634 CPUM_ASSERT_RD_MSR_FN(Ia32MPerf);
5635 CPUM_ASSERT_RD_MSR_FN(Ia32APerf);
5636 CPUM_ASSERT_RD_MSR_FN(Ia32MtrrCap);
5637 CPUM_ASSERT_RD_MSR_FN(Ia32MtrrPhysBaseN);
5638 CPUM_ASSERT_RD_MSR_FN(Ia32MtrrPhysMaskN);
5639 CPUM_ASSERT_RD_MSR_FN(Ia32MtrrFixed);
5640 CPUM_ASSERT_RD_MSR_FN(Ia32MtrrDefType);
5641 CPUM_ASSERT_RD_MSR_FN(Ia32Pat);
5642 CPUM_ASSERT_RD_MSR_FN(Ia32SysEnterCs);
5643 CPUM_ASSERT_RD_MSR_FN(Ia32SysEnterEsp);
5644 CPUM_ASSERT_RD_MSR_FN(Ia32SysEnterEip);
5645 CPUM_ASSERT_RD_MSR_FN(Ia32McgCap);
5646 CPUM_ASSERT_RD_MSR_FN(Ia32McgStatus);
5647 CPUM_ASSERT_RD_MSR_FN(Ia32McgCtl);
5648 CPUM_ASSERT_RD_MSR_FN(Ia32DebugCtl);
5649 CPUM_ASSERT_RD_MSR_FN(Ia32SmrrPhysBase);
5650 CPUM_ASSERT_RD_MSR_FN(Ia32SmrrPhysMask);
5651 CPUM_ASSERT_RD_MSR_FN(Ia32PlatformDcaCap);
5652 CPUM_ASSERT_RD_MSR_FN(Ia32CpuDcaCap);
5653 CPUM_ASSERT_RD_MSR_FN(Ia32Dca0Cap);
5654 CPUM_ASSERT_RD_MSR_FN(Ia32PerfEvtSelN);
5655 CPUM_ASSERT_RD_MSR_FN(Ia32PerfStatus);
5656 CPUM_ASSERT_RD_MSR_FN(Ia32PerfCtl);
5657 CPUM_ASSERT_RD_MSR_FN(Ia32FixedCtrN);
5658 CPUM_ASSERT_RD_MSR_FN(Ia32PerfCapabilities);
5659 CPUM_ASSERT_RD_MSR_FN(Ia32FixedCtrCtrl);
5660 CPUM_ASSERT_RD_MSR_FN(Ia32PerfGlobalStatus);
5661 CPUM_ASSERT_RD_MSR_FN(Ia32PerfGlobalCtrl);
5662 CPUM_ASSERT_RD_MSR_FN(Ia32PerfGlobalOvfCtrl);
5663 CPUM_ASSERT_RD_MSR_FN(Ia32PebsEnable);
5664 CPUM_ASSERT_RD_MSR_FN(Ia32ClockModulation);
5665 CPUM_ASSERT_RD_MSR_FN(Ia32ThermInterrupt);
5666 CPUM_ASSERT_RD_MSR_FN(Ia32ThermStatus);
5667 CPUM_ASSERT_RD_MSR_FN(Ia32MiscEnable);
5668 CPUM_ASSERT_RD_MSR_FN(Ia32McCtlStatusAddrMiscN);
5669 CPUM_ASSERT_RD_MSR_FN(Ia32McNCtl2);
5670 CPUM_ASSERT_RD_MSR_FN(Ia32DsArea);
5671 CPUM_ASSERT_RD_MSR_FN(Ia32TscDeadline);
5672 CPUM_ASSERT_RD_MSR_FN(Ia32X2ApicN);
5673 CPUM_ASSERT_RD_MSR_FN(Ia32DebugInterface);
5674 CPUM_ASSERT_RD_MSR_FN(Ia32VmxBase);
5675 CPUM_ASSERT_RD_MSR_FN(Ia32VmxPinbasedCtls);
5676 CPUM_ASSERT_RD_MSR_FN(Ia32VmxProcbasedCtls);
5677 CPUM_ASSERT_RD_MSR_FN(Ia32VmxExitCtls);
5678 CPUM_ASSERT_RD_MSR_FN(Ia32VmxEntryCtls);
5679 CPUM_ASSERT_RD_MSR_FN(Ia32VmxMisc);
5680 CPUM_ASSERT_RD_MSR_FN(Ia32VmxCr0Fixed0);
5681 CPUM_ASSERT_RD_MSR_FN(Ia32VmxCr0Fixed1);
5682 CPUM_ASSERT_RD_MSR_FN(Ia32VmxCr4Fixed0);
5683 CPUM_ASSERT_RD_MSR_FN(Ia32VmxCr4Fixed1);
5684 CPUM_ASSERT_RD_MSR_FN(Ia32VmxVmcsEnum);
5685 CPUM_ASSERT_RD_MSR_FN(Ia32VmxProcBasedCtls2);
5686 CPUM_ASSERT_RD_MSR_FN(Ia32VmxEptVpidCap);
5687 CPUM_ASSERT_RD_MSR_FN(Ia32VmxTruePinbasedCtls);
5688 CPUM_ASSERT_RD_MSR_FN(Ia32VmxTrueProcbasedCtls);
5689 CPUM_ASSERT_RD_MSR_FN(Ia32VmxTrueExitCtls);
5690 CPUM_ASSERT_RD_MSR_FN(Ia32VmxTrueEntryCtls);
5691 CPUM_ASSERT_RD_MSR_FN(Ia32VmxVmFunc);
5692
5693 CPUM_ASSERT_RD_MSR_FN(Amd64Efer);
5694 CPUM_ASSERT_RD_MSR_FN(Amd64SyscallTarget);
5695 CPUM_ASSERT_RD_MSR_FN(Amd64LongSyscallTarget);
5696 CPUM_ASSERT_RD_MSR_FN(Amd64CompSyscallTarget);
5697 CPUM_ASSERT_RD_MSR_FN(Amd64SyscallFlagMask);
5698 CPUM_ASSERT_RD_MSR_FN(Amd64FsBase);
5699 CPUM_ASSERT_RD_MSR_FN(Amd64GsBase);
5700 CPUM_ASSERT_RD_MSR_FN(Amd64KernelGsBase);
5701 CPUM_ASSERT_RD_MSR_FN(Amd64TscAux);
5702
5703 CPUM_ASSERT_RD_MSR_FN(IntelEblCrPowerOn);
5704 CPUM_ASSERT_RD_MSR_FN(IntelI7CoreThreadCount);
5705 CPUM_ASSERT_RD_MSR_FN(IntelP4EbcHardPowerOn);
5706 CPUM_ASSERT_RD_MSR_FN(IntelP4EbcSoftPowerOn);
5707 CPUM_ASSERT_RD_MSR_FN(IntelP4EbcFrequencyId);
5708 CPUM_ASSERT_RD_MSR_FN(IntelP6FsbFrequency);
5709 CPUM_ASSERT_RD_MSR_FN(IntelPlatformInfo);
5710 CPUM_ASSERT_RD_MSR_FN(IntelFlexRatio);
5711 CPUM_ASSERT_RD_MSR_FN(IntelPkgCStConfigControl);
5712 CPUM_ASSERT_RD_MSR_FN(IntelPmgIoCaptureBase);
5713 CPUM_ASSERT_RD_MSR_FN(IntelLastBranchFromToN);
5714 CPUM_ASSERT_RD_MSR_FN(IntelLastBranchFromN);
5715 CPUM_ASSERT_RD_MSR_FN(IntelLastBranchToN);
5716 CPUM_ASSERT_RD_MSR_FN(IntelLastBranchTos);
5717 CPUM_ASSERT_RD_MSR_FN(IntelBblCrCtl);
5718 CPUM_ASSERT_RD_MSR_FN(IntelBblCrCtl3);
5719 CPUM_ASSERT_RD_MSR_FN(IntelI7TemperatureTarget);
5720 CPUM_ASSERT_RD_MSR_FN(IntelI7MsrOffCoreResponseN);
5721 CPUM_ASSERT_RD_MSR_FN(IntelI7MiscPwrMgmt);
5722 CPUM_ASSERT_RD_MSR_FN(IntelP6CrN);
5723 CPUM_ASSERT_RD_MSR_FN(IntelCpuId1FeatureMaskEcdx);
5724 CPUM_ASSERT_RD_MSR_FN(IntelCpuId1FeatureMaskEax);
5725 CPUM_ASSERT_RD_MSR_FN(IntelCpuId80000001FeatureMaskEcdx);
5726 CPUM_ASSERT_RD_MSR_FN(IntelI7SandyAesNiCtl);
5727 CPUM_ASSERT_RD_MSR_FN(IntelI7TurboRatioLimit);
5728 CPUM_ASSERT_RD_MSR_FN(IntelI7LbrSelect);
5729 CPUM_ASSERT_RD_MSR_FN(IntelI7SandyErrorControl);
5730 CPUM_ASSERT_RD_MSR_FN(IntelI7VirtualLegacyWireCap);
5731 CPUM_ASSERT_RD_MSR_FN(IntelI7PowerCtl);
5732 CPUM_ASSERT_RD_MSR_FN(IntelI7SandyPebsNumAlt);
5733 CPUM_ASSERT_RD_MSR_FN(IntelI7PebsLdLat);
5734 CPUM_ASSERT_RD_MSR_FN(IntelI7PkgCnResidencyN);
5735 CPUM_ASSERT_RD_MSR_FN(IntelI7CoreCnResidencyN);
5736 CPUM_ASSERT_RD_MSR_FN(IntelI7SandyVrCurrentConfig);
5737 CPUM_ASSERT_RD_MSR_FN(IntelI7SandyVrMiscConfig);
5738 CPUM_ASSERT_RD_MSR_FN(IntelI7SandyRaplPowerUnit);
5739 CPUM_ASSERT_RD_MSR_FN(IntelI7SandyPkgCnIrtlN);
5740 CPUM_ASSERT_RD_MSR_FN(IntelI7SandyPkgC2Residency);
5741 CPUM_ASSERT_RD_MSR_FN(IntelI7RaplPkgPowerLimit);
5742 CPUM_ASSERT_RD_MSR_FN(IntelI7RaplPkgEnergyStatus);
5743 CPUM_ASSERT_RD_MSR_FN(IntelI7RaplPkgPerfStatus);
5744 CPUM_ASSERT_RD_MSR_FN(IntelI7RaplPkgPowerInfo);
5745 CPUM_ASSERT_RD_MSR_FN(IntelI7RaplDramPowerLimit);
5746 CPUM_ASSERT_RD_MSR_FN(IntelI7RaplDramEnergyStatus);
5747 CPUM_ASSERT_RD_MSR_FN(IntelI7RaplDramPerfStatus);
5748 CPUM_ASSERT_RD_MSR_FN(IntelI7RaplDramPowerInfo);
5749 CPUM_ASSERT_RD_MSR_FN(IntelI7RaplPp0PowerLimit);
5750 CPUM_ASSERT_RD_MSR_FN(IntelI7RaplPp0EnergyStatus);
5751 CPUM_ASSERT_RD_MSR_FN(IntelI7RaplPp0Policy);
5752 CPUM_ASSERT_RD_MSR_FN(IntelI7RaplPp0PerfStatus);
5753 CPUM_ASSERT_RD_MSR_FN(IntelI7RaplPp1PowerLimit);
5754 CPUM_ASSERT_RD_MSR_FN(IntelI7RaplPp1EnergyStatus);
5755 CPUM_ASSERT_RD_MSR_FN(IntelI7RaplPp1Policy);
5756 CPUM_ASSERT_RD_MSR_FN(IntelI7IvyConfigTdpNominal);
5757 CPUM_ASSERT_RD_MSR_FN(IntelI7IvyConfigTdpLevel1);
5758 CPUM_ASSERT_RD_MSR_FN(IntelI7IvyConfigTdpLevel2);
5759 CPUM_ASSERT_RD_MSR_FN(IntelI7IvyConfigTdpControl);
5760 CPUM_ASSERT_RD_MSR_FN(IntelI7IvyTurboActivationRatio);
5761 CPUM_ASSERT_RD_MSR_FN(IntelI7UncPerfGlobalCtrl);
5762 CPUM_ASSERT_RD_MSR_FN(IntelI7UncPerfGlobalStatus);
5763 CPUM_ASSERT_RD_MSR_FN(IntelI7UncPerfGlobalOvfCtrl);
5764 CPUM_ASSERT_RD_MSR_FN(IntelI7UncPerfFixedCtrCtrl);
5765 CPUM_ASSERT_RD_MSR_FN(IntelI7UncPerfFixedCtr);
5766 CPUM_ASSERT_RD_MSR_FN(IntelI7UncCBoxConfig);
5767 CPUM_ASSERT_RD_MSR_FN(IntelI7UncArbPerfCtrN);
5768 CPUM_ASSERT_RD_MSR_FN(IntelI7UncArbPerfEvtSelN);
5769 CPUM_ASSERT_RD_MSR_FN(IntelI7SmiCount);
5770 CPUM_ASSERT_RD_MSR_FN(IntelCore2EmttmCrTablesN);
5771 CPUM_ASSERT_RD_MSR_FN(IntelCore2SmmCStMiscInfo);
5772 CPUM_ASSERT_RD_MSR_FN(IntelCore1ExtConfig);
5773 CPUM_ASSERT_RD_MSR_FN(IntelCore1DtsCalControl);
5774 CPUM_ASSERT_RD_MSR_FN(IntelCore2PeciControl);
5775 CPUM_ASSERT_RD_MSR_FN(IntelAtSilvCoreC1Recidency);
5776
5777 CPUM_ASSERT_RD_MSR_FN(P6LastBranchFromIp);
5778 CPUM_ASSERT_RD_MSR_FN(P6LastBranchToIp);
5779 CPUM_ASSERT_RD_MSR_FN(P6LastIntFromIp);
5780 CPUM_ASSERT_RD_MSR_FN(P6LastIntToIp);
5781
5782 CPUM_ASSERT_RD_MSR_FN(AmdFam15hTscRate);
5783 CPUM_ASSERT_RD_MSR_FN(AmdFam15hLwpCfg);
5784 CPUM_ASSERT_RD_MSR_FN(AmdFam15hLwpCbAddr);
5785 CPUM_ASSERT_RD_MSR_FN(AmdFam10hMc4MiscN);
5786 CPUM_ASSERT_RD_MSR_FN(AmdK8PerfCtlN);
5787 CPUM_ASSERT_RD_MSR_FN(AmdK8PerfCtrN);
5788 CPUM_ASSERT_RD_MSR_FN(AmdK8SysCfg);
5789 CPUM_ASSERT_RD_MSR_FN(AmdK8HwCr);
5790 CPUM_ASSERT_RD_MSR_FN(AmdK8IorrBaseN);
5791 CPUM_ASSERT_RD_MSR_FN(AmdK8IorrMaskN);
5792 CPUM_ASSERT_RD_MSR_FN(AmdK8TopOfMemN);
5793 CPUM_ASSERT_RD_MSR_FN(AmdK8NbCfg1);
5794 CPUM_ASSERT_RD_MSR_FN(AmdK8McXcptRedir);
5795 CPUM_ASSERT_RD_MSR_FN(AmdK8CpuNameN);
5796 CPUM_ASSERT_RD_MSR_FN(AmdK8HwThermalCtrl);
5797 CPUM_ASSERT_RD_MSR_FN(AmdK8SwThermalCtrl);
5798 CPUM_ASSERT_RD_MSR_FN(AmdK8FidVidControl);
5799 CPUM_ASSERT_RD_MSR_FN(AmdK8FidVidStatus);
5800 CPUM_ASSERT_RD_MSR_FN(AmdK8McCtlMaskN);
5801 CPUM_ASSERT_RD_MSR_FN(AmdK8SmiOnIoTrapN);
5802 CPUM_ASSERT_RD_MSR_FN(AmdK8SmiOnIoTrapCtlSts);
5803 CPUM_ASSERT_RD_MSR_FN(AmdK8IntPendingMessage);
5804 CPUM_ASSERT_RD_MSR_FN(AmdK8SmiTriggerIoCycle);
5805 CPUM_ASSERT_RD_MSR_FN(AmdFam10hMmioCfgBaseAddr);
5806 CPUM_ASSERT_RD_MSR_FN(AmdFam10hTrapCtlMaybe);
5807 CPUM_ASSERT_RD_MSR_FN(AmdFam10hPStateCurLimit);
5808 CPUM_ASSERT_RD_MSR_FN(AmdFam10hPStateControl);
5809 CPUM_ASSERT_RD_MSR_FN(AmdFam10hPStateStatus);
5810 CPUM_ASSERT_RD_MSR_FN(AmdFam10hPStateN);
5811 CPUM_ASSERT_RD_MSR_FN(AmdFam10hCofVidControl);
5812 CPUM_ASSERT_RD_MSR_FN(AmdFam10hCofVidStatus);
5813 CPUM_ASSERT_RD_MSR_FN(AmdFam10hCStateIoBaseAddr);
5814 CPUM_ASSERT_RD_MSR_FN(AmdFam10hCpuWatchdogTimer);
5815 CPUM_ASSERT_RD_MSR_FN(AmdK8SmmBase);
5816 CPUM_ASSERT_RD_MSR_FN(AmdK8SmmAddr);
5817 CPUM_ASSERT_RD_MSR_FN(AmdK8SmmMask);
5818 CPUM_ASSERT_RD_MSR_FN(AmdK8VmCr);
5819 CPUM_ASSERT_RD_MSR_FN(AmdK8IgnNe);
5820 CPUM_ASSERT_RD_MSR_FN(AmdK8SmmCtl);
5821 CPUM_ASSERT_RD_MSR_FN(AmdK8VmHSavePa);
5822 CPUM_ASSERT_RD_MSR_FN(AmdFam10hVmLockKey);
5823 CPUM_ASSERT_RD_MSR_FN(AmdFam10hSmmLockKey);
5824 CPUM_ASSERT_RD_MSR_FN(AmdFam10hLocalSmiStatus);
5825 CPUM_ASSERT_RD_MSR_FN(AmdFam10hOsVisWrkIdLength);
5826 CPUM_ASSERT_RD_MSR_FN(AmdFam10hOsVisWrkStatus);
5827 CPUM_ASSERT_RD_MSR_FN(AmdFam16hL2IPerfCtlN);
5828 CPUM_ASSERT_RD_MSR_FN(AmdFam16hL2IPerfCtrN);
5829 CPUM_ASSERT_RD_MSR_FN(AmdFam15hNorthbridgePerfCtlN);
5830 CPUM_ASSERT_RD_MSR_FN(AmdFam15hNorthbridgePerfCtrN);
5831 CPUM_ASSERT_RD_MSR_FN(AmdK7MicrocodeCtl);
5832 CPUM_ASSERT_RD_MSR_FN(AmdK7ClusterIdMaybe);
5833 CPUM_ASSERT_RD_MSR_FN(AmdK8CpuIdCtlStd07hEbax);
5834 CPUM_ASSERT_RD_MSR_FN(AmdK8CpuIdCtlStd06hEcx);
5835 CPUM_ASSERT_RD_MSR_FN(AmdK8CpuIdCtlStd01hEdcx);
5836 CPUM_ASSERT_RD_MSR_FN(AmdK8CpuIdCtlExt01hEdcx);
5837 CPUM_ASSERT_RD_MSR_FN(AmdK8PatchLevel);
5838 CPUM_ASSERT_RD_MSR_FN(AmdK7DebugStatusMaybe);
5839 CPUM_ASSERT_RD_MSR_FN(AmdK7BHTraceBaseMaybe);
5840 CPUM_ASSERT_RD_MSR_FN(AmdK7BHTracePtrMaybe);
5841 CPUM_ASSERT_RD_MSR_FN(AmdK7BHTraceLimitMaybe);
5842 CPUM_ASSERT_RD_MSR_FN(AmdK7HardwareDebugToolCfgMaybe);
5843 CPUM_ASSERT_RD_MSR_FN(AmdK7FastFlushCountMaybe);
5844 CPUM_ASSERT_RD_MSR_FN(AmdK7NodeId);
5845 CPUM_ASSERT_RD_MSR_FN(AmdK7DrXAddrMaskN);
5846 CPUM_ASSERT_RD_MSR_FN(AmdK7Dr0DataMatchMaybe);
5847 CPUM_ASSERT_RD_MSR_FN(AmdK7Dr0DataMaskMaybe);
5848 CPUM_ASSERT_RD_MSR_FN(AmdK7LoadStoreCfg);
5849 CPUM_ASSERT_RD_MSR_FN(AmdK7InstrCacheCfg);
5850 CPUM_ASSERT_RD_MSR_FN(AmdK7DataCacheCfg);
5851 CPUM_ASSERT_RD_MSR_FN(AmdK7BusUnitCfg);
5852 CPUM_ASSERT_RD_MSR_FN(AmdK7DebugCtl2Maybe);
5853 CPUM_ASSERT_RD_MSR_FN(AmdFam15hFpuCfg);
5854 CPUM_ASSERT_RD_MSR_FN(AmdFam15hDecoderCfg);
5855 CPUM_ASSERT_RD_MSR_FN(AmdFam10hBusUnitCfg2);
5856 CPUM_ASSERT_RD_MSR_FN(AmdFam15hCombUnitCfg);
5857 CPUM_ASSERT_RD_MSR_FN(AmdFam15hCombUnitCfg2);
5858 CPUM_ASSERT_RD_MSR_FN(AmdFam15hCombUnitCfg3);
5859 CPUM_ASSERT_RD_MSR_FN(AmdFam15hExecUnitCfg);
5860 CPUM_ASSERT_RD_MSR_FN(AmdFam15hLoadStoreCfg2);
5861 CPUM_ASSERT_RD_MSR_FN(AmdFam10hIbsFetchCtl);
5862 CPUM_ASSERT_RD_MSR_FN(AmdFam10hIbsFetchLinAddr);
5863 CPUM_ASSERT_RD_MSR_FN(AmdFam10hIbsFetchPhysAddr);
5864 CPUM_ASSERT_RD_MSR_FN(AmdFam10hIbsOpExecCtl);
5865 CPUM_ASSERT_RD_MSR_FN(AmdFam10hIbsOpRip);
5866 CPUM_ASSERT_RD_MSR_FN(AmdFam10hIbsOpData);
5867 CPUM_ASSERT_RD_MSR_FN(AmdFam10hIbsOpData2);
5868 CPUM_ASSERT_RD_MSR_FN(AmdFam10hIbsOpData3);
5869 CPUM_ASSERT_RD_MSR_FN(AmdFam10hIbsDcLinAddr);
5870 CPUM_ASSERT_RD_MSR_FN(AmdFam10hIbsDcPhysAddr);
5871 CPUM_ASSERT_RD_MSR_FN(AmdFam10hIbsCtl);
5872 CPUM_ASSERT_RD_MSR_FN(AmdFam14hIbsBrTarget);
5873
5874 CPUM_ASSERT_RD_MSR_FN(Gim)
5875
5876 AssertReturn(g_aCpumWrMsrFns[kCpumMsrWrFn_Invalid] == NULL, VERR_CPUM_IPE_2);
5877 CPUM_ASSERT_WR_MSR_FN(Ia32P5McAddr);
5878 CPUM_ASSERT_WR_MSR_FN(Ia32P5McType);
5879 CPUM_ASSERT_WR_MSR_FN(Ia32TimestampCounter);
5880 CPUM_ASSERT_WR_MSR_FN(Ia32ApicBase);
5881 CPUM_ASSERT_WR_MSR_FN(Ia32FeatureControl);
5882 CPUM_ASSERT_WR_MSR_FN(Ia32BiosSignId);
5883 CPUM_ASSERT_WR_MSR_FN(Ia32BiosUpdateTrigger);
5884 CPUM_ASSERT_WR_MSR_FN(Ia32SmmMonitorCtl);
5885 CPUM_ASSERT_WR_MSR_FN(Ia32PmcN);
5886 CPUM_ASSERT_WR_MSR_FN(Ia32MonitorFilterLineSize);
5887 CPUM_ASSERT_WR_MSR_FN(Ia32MPerf);
5888 CPUM_ASSERT_WR_MSR_FN(Ia32APerf);
5889 CPUM_ASSERT_WR_MSR_FN(Ia32MtrrPhysBaseN);
5890 CPUM_ASSERT_WR_MSR_FN(Ia32MtrrPhysMaskN);
5891 CPUM_ASSERT_WR_MSR_FN(Ia32MtrrFixed);
5892 CPUM_ASSERT_WR_MSR_FN(Ia32MtrrDefType);
5893 CPUM_ASSERT_WR_MSR_FN(Ia32Pat);
5894 CPUM_ASSERT_WR_MSR_FN(Ia32SysEnterCs);
5895 CPUM_ASSERT_WR_MSR_FN(Ia32SysEnterEsp);
5896 CPUM_ASSERT_WR_MSR_FN(Ia32SysEnterEip);
5897 CPUM_ASSERT_WR_MSR_FN(Ia32McgStatus);
5898 CPUM_ASSERT_WR_MSR_FN(Ia32McgCtl);
5899 CPUM_ASSERT_WR_MSR_FN(Ia32DebugCtl);
5900 CPUM_ASSERT_WR_MSR_FN(Ia32SmrrPhysBase);
5901 CPUM_ASSERT_WR_MSR_FN(Ia32SmrrPhysMask);
5902 CPUM_ASSERT_WR_MSR_FN(Ia32PlatformDcaCap);
5903 CPUM_ASSERT_WR_MSR_FN(Ia32Dca0Cap);
5904 CPUM_ASSERT_WR_MSR_FN(Ia32PerfEvtSelN);
5905 CPUM_ASSERT_WR_MSR_FN(Ia32PerfStatus);
5906 CPUM_ASSERT_WR_MSR_FN(Ia32PerfCtl);
5907 CPUM_ASSERT_WR_MSR_FN(Ia32FixedCtrN);
5908 CPUM_ASSERT_WR_MSR_FN(Ia32PerfCapabilities);
5909 CPUM_ASSERT_WR_MSR_FN(Ia32FixedCtrCtrl);
5910 CPUM_ASSERT_WR_MSR_FN(Ia32PerfGlobalStatus);
5911 CPUM_ASSERT_WR_MSR_FN(Ia32PerfGlobalCtrl);
5912 CPUM_ASSERT_WR_MSR_FN(Ia32PerfGlobalOvfCtrl);
5913 CPUM_ASSERT_WR_MSR_FN(Ia32PebsEnable);
5914 CPUM_ASSERT_WR_MSR_FN(Ia32ClockModulation);
5915 CPUM_ASSERT_WR_MSR_FN(Ia32ThermInterrupt);
5916 CPUM_ASSERT_WR_MSR_FN(Ia32ThermStatus);
5917 CPUM_ASSERT_WR_MSR_FN(Ia32MiscEnable);
5918 CPUM_ASSERT_WR_MSR_FN(Ia32McCtlStatusAddrMiscN);
5919 CPUM_ASSERT_WR_MSR_FN(Ia32McNCtl2);
5920 CPUM_ASSERT_WR_MSR_FN(Ia32DsArea);
5921 CPUM_ASSERT_WR_MSR_FN(Ia32TscDeadline);
5922 CPUM_ASSERT_WR_MSR_FN(Ia32X2ApicN);
5923 CPUM_ASSERT_WR_MSR_FN(Ia32DebugInterface);
5924
5925 CPUM_ASSERT_WR_MSR_FN(Amd64Efer);
5926 CPUM_ASSERT_WR_MSR_FN(Amd64SyscallTarget);
5927 CPUM_ASSERT_WR_MSR_FN(Amd64LongSyscallTarget);
5928 CPUM_ASSERT_WR_MSR_FN(Amd64CompSyscallTarget);
5929 CPUM_ASSERT_WR_MSR_FN(Amd64SyscallFlagMask);
5930 CPUM_ASSERT_WR_MSR_FN(Amd64FsBase);
5931 CPUM_ASSERT_WR_MSR_FN(Amd64GsBase);
5932 CPUM_ASSERT_WR_MSR_FN(Amd64KernelGsBase);
5933 CPUM_ASSERT_WR_MSR_FN(Amd64TscAux);
5934
5935 CPUM_ASSERT_WR_MSR_FN(IntelEblCrPowerOn);
5936 CPUM_ASSERT_WR_MSR_FN(IntelP4EbcHardPowerOn);
5937 CPUM_ASSERT_WR_MSR_FN(IntelP4EbcSoftPowerOn);
5938 CPUM_ASSERT_WR_MSR_FN(IntelP4EbcFrequencyId);
5939 CPUM_ASSERT_WR_MSR_FN(IntelFlexRatio);
5940 CPUM_ASSERT_WR_MSR_FN(IntelPkgCStConfigControl);
5941 CPUM_ASSERT_WR_MSR_FN(IntelPmgIoCaptureBase);
5942 CPUM_ASSERT_WR_MSR_FN(IntelLastBranchFromToN);
5943 CPUM_ASSERT_WR_MSR_FN(IntelLastBranchFromN);
5944 CPUM_ASSERT_WR_MSR_FN(IntelLastBranchToN);
5945 CPUM_ASSERT_WR_MSR_FN(IntelLastBranchTos);
5946 CPUM_ASSERT_WR_MSR_FN(IntelBblCrCtl);
5947 CPUM_ASSERT_WR_MSR_FN(IntelBblCrCtl3);
5948 CPUM_ASSERT_WR_MSR_FN(IntelI7TemperatureTarget);
5949 CPUM_ASSERT_WR_MSR_FN(IntelI7MsrOffCoreResponseN);
5950 CPUM_ASSERT_WR_MSR_FN(IntelI7MiscPwrMgmt);
5951 CPUM_ASSERT_WR_MSR_FN(IntelP6CrN);
5952 CPUM_ASSERT_WR_MSR_FN(IntelCpuId1FeatureMaskEcdx);
5953 CPUM_ASSERT_WR_MSR_FN(IntelCpuId1FeatureMaskEax);
5954 CPUM_ASSERT_WR_MSR_FN(IntelCpuId80000001FeatureMaskEcdx);
5955 CPUM_ASSERT_WR_MSR_FN(IntelI7SandyAesNiCtl);
5956 CPUM_ASSERT_WR_MSR_FN(IntelI7TurboRatioLimit);
5957 CPUM_ASSERT_WR_MSR_FN(IntelI7LbrSelect);
5958 CPUM_ASSERT_WR_MSR_FN(IntelI7SandyErrorControl);
5959 CPUM_ASSERT_WR_MSR_FN(IntelI7PowerCtl);
5960 CPUM_ASSERT_WR_MSR_FN(IntelI7SandyPebsNumAlt);
5961 CPUM_ASSERT_WR_MSR_FN(IntelI7PebsLdLat);
5962 CPUM_ASSERT_WR_MSR_FN(IntelI7SandyVrCurrentConfig);
5963 CPUM_ASSERT_WR_MSR_FN(IntelI7SandyVrMiscConfig);
5964 CPUM_ASSERT_WR_MSR_FN(IntelI7SandyPkgCnIrtlN);
5965 CPUM_ASSERT_WR_MSR_FN(IntelI7SandyPkgC2Residency);
5966 CPUM_ASSERT_WR_MSR_FN(IntelI7RaplPkgPowerLimit);
5967 CPUM_ASSERT_WR_MSR_FN(IntelI7RaplDramPowerLimit);
5968 CPUM_ASSERT_WR_MSR_FN(IntelI7RaplPp0PowerLimit);
5969 CPUM_ASSERT_WR_MSR_FN(IntelI7RaplPp0Policy);
5970 CPUM_ASSERT_WR_MSR_FN(IntelI7RaplPp1PowerLimit);
5971 CPUM_ASSERT_WR_MSR_FN(IntelI7RaplPp1Policy);
5972 CPUM_ASSERT_WR_MSR_FN(IntelI7IvyConfigTdpControl);
5973 CPUM_ASSERT_WR_MSR_FN(IntelI7IvyTurboActivationRatio);
5974 CPUM_ASSERT_WR_MSR_FN(IntelI7UncPerfGlobalCtrl);
5975 CPUM_ASSERT_WR_MSR_FN(IntelI7UncPerfGlobalStatus);
5976 CPUM_ASSERT_WR_MSR_FN(IntelI7UncPerfGlobalOvfCtrl);
5977 CPUM_ASSERT_WR_MSR_FN(IntelI7UncPerfFixedCtrCtrl);
5978 CPUM_ASSERT_WR_MSR_FN(IntelI7UncPerfFixedCtr);
5979 CPUM_ASSERT_WR_MSR_FN(IntelI7UncArbPerfCtrN);
5980 CPUM_ASSERT_WR_MSR_FN(IntelI7UncArbPerfEvtSelN);
5981 CPUM_ASSERT_WR_MSR_FN(IntelCore2EmttmCrTablesN);
5982 CPUM_ASSERT_WR_MSR_FN(IntelCore2SmmCStMiscInfo);
5983 CPUM_ASSERT_WR_MSR_FN(IntelCore1ExtConfig);
5984 CPUM_ASSERT_WR_MSR_FN(IntelCore1DtsCalControl);
5985 CPUM_ASSERT_WR_MSR_FN(IntelCore2PeciControl);
5986
5987 CPUM_ASSERT_WR_MSR_FN(P6LastIntFromIp);
5988 CPUM_ASSERT_WR_MSR_FN(P6LastIntToIp);
5989
5990 CPUM_ASSERT_WR_MSR_FN(AmdFam15hTscRate);
5991 CPUM_ASSERT_WR_MSR_FN(AmdFam15hLwpCfg);
5992 CPUM_ASSERT_WR_MSR_FN(AmdFam15hLwpCbAddr);
5993 CPUM_ASSERT_WR_MSR_FN(AmdFam10hMc4MiscN);
5994 CPUM_ASSERT_WR_MSR_FN(AmdK8PerfCtlN);
5995 CPUM_ASSERT_WR_MSR_FN(AmdK8PerfCtrN);
5996 CPUM_ASSERT_WR_MSR_FN(AmdK8SysCfg);
5997 CPUM_ASSERT_WR_MSR_FN(AmdK8HwCr);
5998 CPUM_ASSERT_WR_MSR_FN(AmdK8IorrBaseN);
5999 CPUM_ASSERT_WR_MSR_FN(AmdK8IorrMaskN);
6000 CPUM_ASSERT_WR_MSR_FN(AmdK8TopOfMemN);
6001 CPUM_ASSERT_WR_MSR_FN(AmdK8NbCfg1);
6002 CPUM_ASSERT_WR_MSR_FN(AmdK8McXcptRedir);
6003 CPUM_ASSERT_WR_MSR_FN(AmdK8CpuNameN);
6004 CPUM_ASSERT_WR_MSR_FN(AmdK8HwThermalCtrl);
6005 CPUM_ASSERT_WR_MSR_FN(AmdK8SwThermalCtrl);
6006 CPUM_ASSERT_WR_MSR_FN(AmdK8FidVidControl);
6007 CPUM_ASSERT_WR_MSR_FN(AmdK8McCtlMaskN);
6008 CPUM_ASSERT_WR_MSR_FN(AmdK8SmiOnIoTrapN);
6009 CPUM_ASSERT_WR_MSR_FN(AmdK8SmiOnIoTrapCtlSts);
6010 CPUM_ASSERT_WR_MSR_FN(AmdK8IntPendingMessage);
6011 CPUM_ASSERT_WR_MSR_FN(AmdK8SmiTriggerIoCycle);
6012 CPUM_ASSERT_WR_MSR_FN(AmdFam10hMmioCfgBaseAddr);
6013 CPUM_ASSERT_WR_MSR_FN(AmdFam10hTrapCtlMaybe);
6014 CPUM_ASSERT_WR_MSR_FN(AmdFam10hPStateControl);
6015 CPUM_ASSERT_WR_MSR_FN(AmdFam10hPStateStatus);
6016 CPUM_ASSERT_WR_MSR_FN(AmdFam10hPStateN);
6017 CPUM_ASSERT_WR_MSR_FN(AmdFam10hCofVidControl);
6018 CPUM_ASSERT_WR_MSR_FN(AmdFam10hCofVidStatus);
6019 CPUM_ASSERT_WR_MSR_FN(AmdFam10hCStateIoBaseAddr);
6020 CPUM_ASSERT_WR_MSR_FN(AmdFam10hCpuWatchdogTimer);
6021 CPUM_ASSERT_WR_MSR_FN(AmdK8SmmBase);
6022 CPUM_ASSERT_WR_MSR_FN(AmdK8SmmAddr);
6023 CPUM_ASSERT_WR_MSR_FN(AmdK8SmmMask);
6024 CPUM_ASSERT_WR_MSR_FN(AmdK8VmCr);
6025 CPUM_ASSERT_WR_MSR_FN(AmdK8IgnNe);
6026 CPUM_ASSERT_WR_MSR_FN(AmdK8SmmCtl);
6027 CPUM_ASSERT_WR_MSR_FN(AmdK8VmHSavePa);
6028 CPUM_ASSERT_WR_MSR_FN(AmdFam10hVmLockKey);
6029 CPUM_ASSERT_WR_MSR_FN(AmdFam10hSmmLockKey);
6030 CPUM_ASSERT_WR_MSR_FN(AmdFam10hLocalSmiStatus);
6031 CPUM_ASSERT_WR_MSR_FN(AmdFam10hOsVisWrkIdLength);
6032 CPUM_ASSERT_WR_MSR_FN(AmdFam10hOsVisWrkStatus);
6033 CPUM_ASSERT_WR_MSR_FN(AmdFam16hL2IPerfCtlN);
6034 CPUM_ASSERT_WR_MSR_FN(AmdFam16hL2IPerfCtrN);
6035 CPUM_ASSERT_WR_MSR_FN(AmdFam15hNorthbridgePerfCtlN);
6036 CPUM_ASSERT_WR_MSR_FN(AmdFam15hNorthbridgePerfCtrN);
6037 CPUM_ASSERT_WR_MSR_FN(AmdK7MicrocodeCtl);
6038 CPUM_ASSERT_WR_MSR_FN(AmdK7ClusterIdMaybe);
6039 CPUM_ASSERT_WR_MSR_FN(AmdK8CpuIdCtlStd07hEbax);
6040 CPUM_ASSERT_WR_MSR_FN(AmdK8CpuIdCtlStd06hEcx);
6041 CPUM_ASSERT_WR_MSR_FN(AmdK8CpuIdCtlStd01hEdcx);
6042 CPUM_ASSERT_WR_MSR_FN(AmdK8CpuIdCtlExt01hEdcx);
6043 CPUM_ASSERT_WR_MSR_FN(AmdK8PatchLoader);
6044 CPUM_ASSERT_WR_MSR_FN(AmdK7DebugStatusMaybe);
6045 CPUM_ASSERT_WR_MSR_FN(AmdK7BHTraceBaseMaybe);
6046 CPUM_ASSERT_WR_MSR_FN(AmdK7BHTracePtrMaybe);
6047 CPUM_ASSERT_WR_MSR_FN(AmdK7BHTraceLimitMaybe);
6048 CPUM_ASSERT_WR_MSR_FN(AmdK7HardwareDebugToolCfgMaybe);
6049 CPUM_ASSERT_WR_MSR_FN(AmdK7FastFlushCountMaybe);
6050 CPUM_ASSERT_WR_MSR_FN(AmdK7NodeId);
6051 CPUM_ASSERT_WR_MSR_FN(AmdK7DrXAddrMaskN);
6052 CPUM_ASSERT_WR_MSR_FN(AmdK7Dr0DataMatchMaybe);
6053 CPUM_ASSERT_WR_MSR_FN(AmdK7Dr0DataMaskMaybe);
6054 CPUM_ASSERT_WR_MSR_FN(AmdK7LoadStoreCfg);
6055 CPUM_ASSERT_WR_MSR_FN(AmdK7InstrCacheCfg);
6056 CPUM_ASSERT_WR_MSR_FN(AmdK7DataCacheCfg);
6057 CPUM_ASSERT_WR_MSR_FN(AmdK7BusUnitCfg);
6058 CPUM_ASSERT_WR_MSR_FN(AmdK7DebugCtl2Maybe);
6059 CPUM_ASSERT_WR_MSR_FN(AmdFam15hFpuCfg);
6060 CPUM_ASSERT_WR_MSR_FN(AmdFam15hDecoderCfg);
6061 CPUM_ASSERT_WR_MSR_FN(AmdFam10hBusUnitCfg2);
6062 CPUM_ASSERT_WR_MSR_FN(AmdFam15hCombUnitCfg);
6063 CPUM_ASSERT_WR_MSR_FN(AmdFam15hCombUnitCfg2);
6064 CPUM_ASSERT_WR_MSR_FN(AmdFam15hCombUnitCfg3);
6065 CPUM_ASSERT_WR_MSR_FN(AmdFam15hExecUnitCfg);
6066 CPUM_ASSERT_WR_MSR_FN(AmdFam15hLoadStoreCfg2);
6067 CPUM_ASSERT_WR_MSR_FN(AmdFam10hIbsFetchCtl);
6068 CPUM_ASSERT_WR_MSR_FN(AmdFam10hIbsFetchLinAddr);
6069 CPUM_ASSERT_WR_MSR_FN(AmdFam10hIbsFetchPhysAddr);
6070 CPUM_ASSERT_WR_MSR_FN(AmdFam10hIbsOpExecCtl);
6071 CPUM_ASSERT_WR_MSR_FN(AmdFam10hIbsOpRip);
6072 CPUM_ASSERT_WR_MSR_FN(AmdFam10hIbsOpData);
6073 CPUM_ASSERT_WR_MSR_FN(AmdFam10hIbsOpData2);
6074 CPUM_ASSERT_WR_MSR_FN(AmdFam10hIbsOpData3);
6075 CPUM_ASSERT_WR_MSR_FN(AmdFam10hIbsDcLinAddr);
6076 CPUM_ASSERT_WR_MSR_FN(AmdFam10hIbsDcPhysAddr);
6077 CPUM_ASSERT_WR_MSR_FN(AmdFam10hIbsCtl);
6078 CPUM_ASSERT_WR_MSR_FN(AmdFam14hIbsBrTarget);
6079
6080 CPUM_ASSERT_WR_MSR_FN(Gim);
6081
6082 return VINF_SUCCESS;
6083}
6084#endif /* VBOX_STRICT && IN_RING3 */
6085
6086
6087/**
6088 * Gets the scalable bus frequency.
6089 *
6090 * The bus frequency is used as a base in several MSRs that gives the CPU and
6091 * other frequency ratios.
6092 *
6093 * @returns Scalable bus frequency in Hz. Will not return CPUM_SBUSFREQ_UNKNOWN.
6094 * @param pVM The cross context VM structure.
6095 */
6096VMMDECL(uint64_t) CPUMGetGuestScalableBusFrequency(PVM pVM)
6097{
6098 uint64_t uFreq = pVM->cpum.s.GuestInfo.uScalableBusFreq;
6099 if (uFreq == CPUM_SBUSFREQ_UNKNOWN)
6100 uFreq = CPUM_SBUSFREQ_100MHZ;
6101 return uFreq;
6102}
6103
6104
6105/**
6106 * Validates an EFER MSR write.
6107 *
6108 * @returns VBox status code.
6109 * @param pVM The cross context VM structure.
6110 * @param uCr0 The CR0 of the CPU corresponding to the EFER MSR.
6111 * @param uOldEfer Value of the previous EFER MSR on the CPU if any.
6112 * @param uNewEfer The new EFER MSR value being written.
6113 * @param puValidEfer Where to store the validated EFER (only updated if
6114 * this function returns VINF_SUCCESS).
6115 */
6116VMMDECL(int) CPUMQueryValidatedGuestEfer(PVM pVM, uint64_t uCr0, uint64_t uOldEfer, uint64_t uNewEfer, uint64_t *puValidEfer)
6117{
6118 uint32_t const fExtFeatures = pVM->cpum.s.aGuestCpuIdPatmExt[0].uEax >= 0x80000001
6119 ? pVM->cpum.s.aGuestCpuIdPatmExt[1].uEdx
6120 : 0;
6121 uint64_t fMask = 0;
6122 uint64_t const fIgnoreMask = MSR_K6_EFER_LMA;
6123
6124 /* Filter out those bits the guest is allowed to change. (e.g. LMA is read-only) */
6125 if (fExtFeatures & X86_CPUID_EXT_FEATURE_EDX_NX)
6126 fMask |= MSR_K6_EFER_NXE;
6127 if (fExtFeatures & X86_CPUID_EXT_FEATURE_EDX_LONG_MODE)
6128 fMask |= MSR_K6_EFER_LME;
6129 if (fExtFeatures & X86_CPUID_EXT_FEATURE_EDX_SYSCALL)
6130 fMask |= MSR_K6_EFER_SCE;
6131 if (fExtFeatures & X86_CPUID_AMD_FEATURE_EDX_FFXSR)
6132 fMask |= MSR_K6_EFER_FFXSR;
6133 if (pVM->cpum.s.GuestFeatures.fSvm)
6134 fMask |= MSR_K6_EFER_SVME;
6135
6136 /* #GP(0) If anything outside the allowed bits is set. */
6137 if (uNewEfer & ~(fIgnoreMask | fMask))
6138 {
6139 Log(("CPUM: Settings disallowed EFER bit. uNewEfer=%#RX64 fAllowed=%#RX64 -> #GP(0)\n", uNewEfer, fMask));
6140 return VERR_CPUM_RAISE_GP_0;
6141 }
6142
6143 /* Check for illegal MSR_K6_EFER_LME transitions: not allowed to change LME if
6144 paging is enabled. (AMD Arch. Programmer's Manual Volume 2: Table 14-5) */
6145 if ( (uOldEfer & MSR_K6_EFER_LME) != (uNewEfer & fMask & MSR_K6_EFER_LME)
6146 && (uCr0 & X86_CR0_PG))
6147 {
6148 Log(("CPUM: Illegal MSR_K6_EFER_LME change: paging is enabled!!\n"));
6149 return VERR_CPUM_RAISE_GP_0;
6150 }
6151
6152 /* There are a few more: e.g. MSR_K6_EFER_LMSLE */
6153 AssertMsg(!(uNewEfer & ~( MSR_K6_EFER_NXE
6154 | MSR_K6_EFER_LME
6155 | MSR_K6_EFER_LMA /* ignored anyway */
6156 | MSR_K6_EFER_SCE
6157 | MSR_K6_EFER_FFXSR
6158 | MSR_K6_EFER_SVME)),
6159 ("Unexpected value %#RX64\n", uNewEfer));
6160
6161 *puValidEfer = (uOldEfer & ~fMask) | (uNewEfer & fMask);
6162 return VINF_SUCCESS;
6163}
6164
6165#ifdef IN_RING0
6166
6167/**
6168 * Fast way for HM to access the MSR_K8_TSC_AUX register.
6169 *
6170 * @returns The register value.
6171 * @param pVCpu The cross context virtual CPU structure of the calling EMT.
6172 * @thread EMT(pVCpu)
6173 */
6174VMMR0_INT_DECL(uint64_t) CPUMR0GetGuestTscAux(PVMCPU pVCpu)
6175{
6176 return pVCpu->cpum.s.GuestMsrs.msr.TscAux;
6177}
6178
6179
6180/**
6181 * Fast way for HM to access the MSR_K8_TSC_AUX register.
6182 *
6183 * @param pVCpu The cross context virtual CPU structure of the calling EMT.
6184 * @param uValue The new value.
6185 * @thread EMT(pVCpu)
6186 */
6187VMMR0_INT_DECL(void) CPUMR0SetGuestTscAux(PVMCPU pVCpu, uint64_t uValue)
6188{
6189 pVCpu->cpum.s.GuestMsrs.msr.TscAux = uValue;
6190}
6191
6192#endif /* IN_RING0 */
6193
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