VirtualBox

source: vbox/trunk/src/VBox/VMM/VMMR0/HWACCMR0A.asm@ 8213

Last change on this file since 8213 was 8155, checked in by vboxsync, 17 years ago

The Big Sun Rebranding Header Change

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id
File size: 18.0 KB
Line 
1; $Id: HWACCMR0A.asm 8155 2008-04-18 15:16:47Z vboxsync $
2;; @file
3; VMXM - R0 vmx helpers
4;
5
6;
7; Copyright (C) 2006-2007 Sun Microsystems, Inc.
8;
9; This file is part of VirtualBox Open Source Edition (OSE), as
10; available from http://www.virtualbox.org. This file is free software;
11; you can redistribute it and/or modify it under the terms of the GNU
12; General Public License (GPL) as published by the Free Software
13; Foundation, in version 2 as it comes in the "COPYING" file of the
14; VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15; hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16;
17; Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
18; Clara, CA 95054 USA or visit http://www.sun.com if you need
19; additional information or have any questions.
20;
21
22;*******************************************************************************
23;* Header Files *
24;*******************************************************************************
25%include "VBox/asmdefs.mac"
26%include "VBox/err.mac"
27%include "VBox/hwacc_vmx.mac"
28%include "VBox/cpum.mac"
29%include "VBox/x86.mac"
30
31%ifdef RT_OS_OS2 ;; @todo fix OMF support in yasm and kick nasm out completely.
32 %macro vmwrite 2,
33 int3
34 %endmacro
35 %define vmlaunch int3
36 %define vmresume int3
37 %define vmsave int3
38 %define vmload int3
39 %define vmrun int3
40 %define clgi int3
41 %define stgi int3
42 %macro invlpga 2,
43 int3
44 %endmacro
45%endif
46
47
48;; @def MYPUSHAD
49; Macro generating an equivalent to pushad
50
51;; @def MYPOPAD
52; Macro generating an equivalent to popad
53
54;; @def MYPUSHSEGS
55; Macro saving all segment registers on the stack.
56; @param 1 full width register name
57; @param 2 16-bit regsiter name for \a 1.
58
59;; @def MYPOPSEGS
60; Macro restoring all segment registers on the stack
61; @param 1 full width register name
62; @param 2 16-bit regsiter name for \a 1.
63
64%ifdef RT_ARCH_AMD64
65 %ifdef ASM_CALL64_GCC
66 %macro MYPUSHAD 0
67 push r15
68 push r14
69 push r13
70 push r12
71 push rbx
72 %endmacro
73 %macro MYPOPAD 0
74 pop rbx
75 pop r12
76 pop r13
77 pop r14
78 pop r15
79 %endmacro
80
81 %else ; ASM_CALL64_MSC
82 %macro MYPUSHAD 0
83 push r15
84 push r14
85 push r13
86 push r12
87 push rbx
88 push rsi
89 push rdi
90 %endmacro
91 %macro MYPOPAD 0
92 pop rdi
93 pop rsi
94 pop rbx
95 pop r12
96 pop r13
97 pop r14
98 pop r15
99 %endmacro
100 %endif
101
102 %macro MYPUSHSEGS 2
103 mov %2, es
104 push %1
105 mov %2, ds
106 push %1
107 push fs
108 ; Special case for GS; OSes typically use swapgs to reset the hidden base register for GS on entry into the kernel. The same happens on exit
109 push rcx
110 mov ecx, MSR_K8_GS_BASE
111 rdmsr
112 pop rcx
113 push rdx
114 push rax
115 push gs
116 %endmacro
117
118 %macro MYPOPSEGS 2
119 ; Note: do not step through this code with a debugger!
120 pop gs
121 pop rax
122 pop rdx
123 push rcx
124 mov ecx, MSR_K8_GS_BASE
125 wrmsr
126 pop rcx
127 ; Now it's safe to step again
128
129 pop fs
130 pop %1
131 mov ds, %2
132 pop %1
133 mov es, %2
134 %endmacro
135
136%else ; RT_ARCH_X86
137 %macro MYPUSHAD 0
138 pushad
139 %endmacro
140 %macro MYPOPAD 0
141 popad
142 %endmacro
143
144 %macro MYPUSHSEGS 2
145 push ds
146 push es
147 push fs
148 push gs
149 %endmacro
150 %macro MYPOPSEGS 2
151 pop gs
152 pop fs
153 pop es
154 pop ds
155 %endmacro
156%endif
157
158
159BEGINCODE
160
161;/**
162; * Prepares for and executes VMLAUNCH
163; *
164; * @note identical to VMXResumeVM, except for the vmlaunch/vmresume opcode
165; *
166; * @returns VBox status code
167; * @param pCtx Guest context
168; */
169BEGINPROC VMXStartVM
170 push xBP
171 mov xBP, xSP
172
173 pushf
174 cli
175
176 ;/* First we have to save some final CPU context registers. */
177%ifdef RT_ARCH_AMD64
178 mov rax, qword .vmlaunch_done
179 push rax
180%else
181 push .vmlaunch_done
182%endif
183 mov eax, VMX_VMCS_HOST_RIP ;/* return address (too difficult to continue after VMLAUNCH?) */
184 vmwrite xAX, [xSP]
185 ;/* @todo assumes success... */
186 add xSP, xS
187
188 ;/* Manual save and restore:
189 ; * - General purpose registers except RIP, RSP
190 ; *
191 ; * Trashed:
192 ; * - CR2 (we don't care)
193 ; * - LDTR (reset to 0)
194 ; * - DRx (presumably not changed at all)
195 ; * - DR7 (reset to 0x400)
196 ; * - EFLAGS (reset to RT_BIT(1); not relevant)
197 ; *
198 ; */
199
200 ;/* Save all general purpose host registers. */
201 MYPUSHAD
202
203 ;/* Save segment registers */
204 MYPUSHSEGS xAX, ax
205
206 ;/* Save the Guest CPU context pointer. */
207%ifdef RT_ARCH_AMD64
208 %ifdef ASM_CALL64_GCC
209 mov rsi, rdi ; pCtx
210 %else
211 mov rsi, rcx ; pCtx
212 %endif
213%else
214 mov esi, [ebp + 8] ; pCtx
215%endif
216 push xSI
217
218 ; Save LDTR
219 xor eax, eax
220 sldt ax
221 push xAX
222
223 ; VMX only saves the base of the GDTR & IDTR and resets the limit to 0xffff; we must restore the limit correctly!
224 sub xSP, xS*2
225 sgdt [xSP]
226
227 sub xSP, xS*2
228 sidt [xSP]
229
230 ; Restore CR2
231 mov ebx, [xSI + CPUMCTX.cr2]
232 mov cr2, xBX
233
234 mov eax, VMX_VMCS_HOST_RSP
235 vmwrite xAX, xSP
236 ;/* @todo assumes success... */
237 ;/* Don't mess with ESP anymore!! */
238
239 ;/* Restore Guest's general purpose registers. */
240 mov eax, [xSI + CPUMCTX.eax]
241 mov ebx, [xSI + CPUMCTX.ebx]
242 mov ecx, [xSI + CPUMCTX.ecx]
243 mov edx, [xSI + CPUMCTX.edx]
244 mov edi, [xSI + CPUMCTX.edi]
245 mov ebp, [xSI + CPUMCTX.ebp]
246 mov esi, [xSI + CPUMCTX.esi]
247
248 vmlaunch
249 jmp .vmlaunch_done; ;/* here if vmlaunch detected a failure. */
250
251ALIGNCODE(16)
252.vmlaunch_done:
253 jc near .vmxstart_invalid_vmxon_ptr
254 jz near .vmxstart_start_failed
255
256 ; Restore base and limit of the IDTR & GDTR
257 lidt [xSP]
258 add xSP, xS*2
259 lgdt [xSP]
260 add xSP, xS*2
261
262 push xDI
263 mov xDI, [xSP + xS * 2] ; pCtx
264
265 mov [ss:xDI + CPUMCTX.eax], eax
266 mov [ss:xDI + CPUMCTX.ebx], ebx
267 mov [ss:xDI + CPUMCTX.ecx], ecx
268 mov [ss:xDI + CPUMCTX.edx], edx
269 mov [ss:xDI + CPUMCTX.esi], esi
270 mov [ss:xDI + CPUMCTX.ebp], ebp
271%ifdef RT_ARCH_AMD64
272 pop xAX ; the guest edi we pushed above
273 mov dword [ss:xDI + CPUMCTX.edi], eax
274%else
275 pop dword [ss:xDI + CPUMCTX.edi] ; the guest edi we pushed above
276%endif
277
278 pop xAX ; saved LDTR
279 lldt ax
280
281 add xSP, xS ; pCtx
282
283 ; Restore segment registers
284 MYPOPSEGS xAX, ax
285
286 ; Restore general purpose registers
287 MYPOPAD
288
289 mov eax, VINF_SUCCESS
290
291.vmstart_end:
292 popf
293 pop xBP
294 ret
295
296
297.vmxstart_invalid_vmxon_ptr:
298 ; Restore base and limit of the IDTR & GDTR
299 lidt [xSP]
300 add xSP, xS*2
301 lgdt [xSP]
302 add xSP, xS*2
303
304 pop xAX ; saved LDTR
305 lldt ax
306
307 add xSP, xS ; pCtx
308
309 ; Restore segment registers
310 MYPOPSEGS xAX, ax
311
312 ; Restore all general purpose host registers.
313 MYPOPAD
314 mov eax, VERR_VMX_INVALID_VMXON_PTR
315 jmp .vmstart_end
316
317.vmxstart_start_failed:
318 ; Restore base and limit of the IDTR & GDTR
319 lidt [xSP]
320 add xSP, xS*2
321 lgdt [xSP]
322 add xSP, xS*2
323
324 pop xAX ; saved LDTR
325 lldt ax
326
327 add xSP, xS ; pCtx
328
329 ; Restore segment registers
330 MYPOPSEGS xAX, ax
331
332 ; Restore all general purpose host registers.
333 MYPOPAD
334 mov eax, VERR_VMX_UNABLE_TO_START_VM
335 jmp .vmstart_end
336
337ENDPROC VMXStartVM
338
339
340;/**
341; * Prepares for and executes VMRESUME
342; *
343; * @note identical to VMXStartVM, except for the vmlaunch/vmresume opcode
344; *
345; * @returns VBox status code
346; * @param pCtx Guest context
347; */
348BEGINPROC VMXResumeVM
349 push xBP
350 mov xBP, xSP
351
352 pushf
353 cli
354
355 ;/* First we have to save some final CPU context registers. */
356%ifdef RT_ARCH_AMD64
357 mov rax, qword .vmresume_done
358 push rax
359%else
360 push .vmresume_done
361%endif
362 mov eax, VMX_VMCS_HOST_RIP ;/* return address (too difficult to continue after VMLAUNCH?) */
363 vmwrite xAX, [xSP]
364 ;/* @todo assumes success... */
365 add xSP, xS
366
367 ;/* Manual save and restore:
368 ; * - General purpose registers except RIP, RSP
369 ; *
370 ; * Trashed:
371 ; * - CR2 (we don't care)
372 ; * - LDTR (reset to 0)
373 ; * - DRx (presumably not changed at all)
374 ; * - DR7 (reset to 0x400)
375 ; * - EFLAGS (reset to RT_BIT(1); not relevant)
376 ; *
377 ; */
378
379 ;/* Save all general purpose host registers. */
380 MYPUSHAD
381
382 ;/* Save segment registers */
383 MYPUSHSEGS xAX, ax
384
385 ;/* Save the Guest CPU context pointer. */
386%ifdef RT_ARCH_AMD64
387 %ifdef ASM_CALL64_GCC
388 mov rsi, rdi ; pCtx
389 %else
390 mov rsi, rcx ; pCtx
391 %endif
392%else
393 mov esi, [ebp + 8] ; pCtx
394%endif
395 push xSI
396
397 ; Save LDTR
398 xor eax, eax
399 sldt ax
400 push xAX
401
402 ; VMX only saves the base of the GDTR & IDTR and resets the limit to 0xffff; we must restore the limit correctly!
403 sub xSP, xS*2
404 sgdt [xSP]
405
406 sub xSP, xS*2
407 sidt [xSP]
408
409 ; Restore CR2
410 mov xBX, [xSI + CPUMCTX.cr2]
411 mov cr2, xBX
412
413 mov eax, VMX_VMCS_HOST_RSP
414 vmwrite xAX, xSP
415 ;/* @todo assumes success... */
416 ;/* Don't mess with ESP anymore!! */
417
418 ;/* Restore Guest's general purpose registers. */
419 mov eax, [xSI + CPUMCTX.eax]
420 mov ebx, [xSI + CPUMCTX.ebx]
421 mov ecx, [xSI + CPUMCTX.ecx]
422 mov edx, [xSI + CPUMCTX.edx]
423 mov edi, [xSI + CPUMCTX.edi]
424 mov ebp, [xSI + CPUMCTX.ebp]
425 mov esi, [xSI + CPUMCTX.esi]
426
427 vmresume
428 jmp .vmresume_done; ;/* here if vmresume detected a failure. */
429
430ALIGNCODE(16)
431.vmresume_done:
432 jc near .vmxresume_invalid_vmxon_ptr
433 jz near .vmxresume_start_failed
434
435 ; Restore base and limit of the IDTR & GDTR
436 lidt [xSP]
437 add xSP, xS*2
438 lgdt [xSP]
439 add xSP, xS*2
440
441 push xDI
442 mov xDI, [xSP + xS * 2] ; pCtx
443
444 mov [ss:xDI + CPUMCTX.eax], eax
445 mov [ss:xDI + CPUMCTX.ebx], ebx
446 mov [ss:xDI + CPUMCTX.ecx], ecx
447 mov [ss:xDI + CPUMCTX.edx], edx
448 mov [ss:xDI + CPUMCTX.esi], esi
449 mov [ss:xDI + CPUMCTX.ebp], ebp
450%ifdef RT_ARCH_AMD64
451 pop xAX ; the guest edi we pushed above
452 mov dword [ss:xDI + CPUMCTX.edi], eax
453%else
454 pop dword [ss:xDI + CPUMCTX.edi] ; the guest edi we pushed above
455%endif
456
457 pop xAX ; saved LDTR
458 lldt ax
459
460 add xSP, xS ; pCtx
461
462 ; Restore segment registers
463 MYPOPSEGS xAX, ax
464
465 ; Restore general purpose registers
466 MYPOPAD
467
468 mov eax, VINF_SUCCESS
469
470.vmresume_end:
471 popf
472 pop xBP
473 ret
474
475.vmxresume_invalid_vmxon_ptr:
476 ; Restore base and limit of the IDTR & GDTR
477 lidt [xSP]
478 add xSP, xS*2
479 lgdt [xSP]
480 add xSP, xS*2
481
482 pop xAX ; saved LDTR
483 lldt ax
484
485 add xSP, xS ; pCtx
486
487 ; Restore segment registers
488 MYPOPSEGS xAX, ax
489
490 ; Restore all general purpose host registers.
491 MYPOPAD
492 mov eax, VERR_VMX_INVALID_VMXON_PTR
493 jmp .vmresume_end
494
495.vmxresume_start_failed:
496 ; Restore base and limit of the IDTR & GDTR
497 lidt [xSP]
498 add xSP, xS*2
499 lgdt [xSP]
500 add xSP, xS*2
501
502 pop xAX ; saved LDTR
503 lldt ax
504
505 add xSP, xS ; pCtx
506
507 ; Restore segment registers
508 MYPOPSEGS xAX, ax
509
510 ; Restore all general purpose host registers.
511 MYPOPAD
512 mov eax, VERR_VMX_UNABLE_TO_RESUME_VM
513 jmp .vmresume_end
514
515ENDPROC VMXResumeVM
516
517
518%ifdef RT_ARCH_AMD64
519;/**
520; * Executes VMWRITE
521; *
522; * @returns VBox status code
523; * @param idxField x86: [ebp + 08h] msc: rcx gcc: edi VMCS index
524; * @param pData x86: [ebp + 0ch] msc: rdx gcc: rsi VM field value
525; */
526BEGINPROC VMXWriteVMCS64
527%ifdef ASM_CALL64_GCC
528 mov eax, 0ffffffffh
529 and rdi, rax
530 xor rax, rax
531 vmwrite rdi, rsi
532%else
533 mov eax, 0ffffffffh
534 and rcx, rax
535 xor rax, rax
536 vmwrite rcx, rdx
537%endif
538 jnc .valid_vmcs
539 mov eax, VERR_VMX_INVALID_VMCS_PTR
540 ret
541.valid_vmcs:
542 jnz .the_end
543 mov eax, VERR_VMX_INVALID_VMCS_FIELD
544.the_end:
545 ret
546ENDPROC VMXWriteVMCS64
547
548;/**
549; * Executes VMREAD
550; *
551; * @returns VBox status code
552; * @param idxField VMCS index
553; * @param pData Ptr to store VM field value
554; */
555;DECLASM(int) VMXReadVMCS64(uint32_t idxField, uint64_t *pData);
556BEGINPROC VMXReadVMCS64
557%ifdef ASM_CALL64_GCC
558 mov eax, 0ffffffffh
559 and rdi, rax
560 xor rax, rax
561 vmread [rsi], rdi
562%else
563 mov eax, 0ffffffffh
564 and rcx, rax
565 xor rax, rax
566 vmread [rdx], rcx
567%endif
568 jnc .valid_vmcs
569 mov eax, VERR_VMX_INVALID_VMCS_PTR
570 ret
571.valid_vmcs:
572 jnz .the_end
573 mov eax, VERR_VMX_INVALID_VMCS_FIELD
574.the_end:
575 ret
576ENDPROC VMXReadVMCS64
577
578
579;/**
580; * Executes VMXON
581; *
582; * @returns VBox status code
583; * @param HCPhysVMXOn Physical address of VMXON structure
584; */
585;DECLASM(int) VMXEnable(RTHCPHYS HCPhysVMXOn);
586BEGINPROC VMXEnable
587%ifdef RT_ARCH_AMD64
588 xor rax, rax
589 %ifdef ASM_CALL64_GCC
590 push rdi
591 %else
592 push rcx
593 %endif
594 vmxon [rsp]
595%else
596 xor eax, eax
597 vmxon [esp + 4]
598%endif
599 jnc .good
600 mov eax, VERR_VMX_INVALID_VMXON_PTR
601 jmp .the_end
602
603.good:
604 jnz .the_end
605 mov eax, VERR_VMX_GENERIC
606
607.the_end:
608%ifdef RT_ARCH_AMD64
609 add rsp, 8
610%endif
611 ret
612ENDPROC VMXEnable
613
614
615;/**
616; * Executes VMXOFF
617; */
618;DECLASM(void) VMXDisable(void);
619BEGINPROC VMXDisable
620 vmxoff
621 ret
622ENDPROC VMXDisable
623
624
625;/**
626; * Executes VMCLEAR
627; *
628; * @returns VBox status code
629; * @param HCPhysVMCS Physical address of VM control structure
630; */
631;DECLASM(int) VMXClearVMCS(RTHCPHYS HCPhysVMCS);
632BEGINPROC VMXClearVMCS
633%ifdef RT_ARCH_AMD64
634 xor rax, rax
635 %ifdef ASM_CALL64_GCC
636 push rdi
637 %else
638 push rcx
639 %endif
640 vmclear [rsp]
641%else
642 xor eax, eax
643 vmclear [esp + 4]
644%endif
645 jnc .the_end
646 mov eax, VERR_VMX_INVALID_VMCS_PTR
647.the_end:
648%ifdef RT_ARCH_AMD64
649 add rsp, 8
650%endif
651 ret
652ENDPROC VMXClearVMCS
653
654
655;/**
656; * Executes VMPTRLD
657; *
658; * @returns VBox status code
659; * @param HCPhysVMCS Physical address of VMCS structure
660; */
661;DECLASM(int) VMXActivateVMCS(RTHCPHYS HCPhysVMCS);
662BEGINPROC VMXActivateVMCS
663%ifdef RT_ARCH_AMD64
664 xor rax, rax
665 %ifdef ASM_CALL64_GCC
666 push rdi
667 %else
668 push rcx
669 %endif
670 vmptrld [rsp]
671%else
672 xor eax, eax
673 vmptrld [esp + 4]
674%endif
675 jnc .the_end
676 mov eax, VERR_VMX_INVALID_VMCS_PTR
677.the_end:
678%ifdef RT_ARCH_AMD64
679 add rsp, 8
680%endif
681 ret
682ENDPROC VMXActivateVMCS
683
684%endif ; RT_ARCH_AMD64
685
686
687;/**
688; * Prepares for and executes VMRUN
689; *
690; * @returns VBox status code
691; * @param HCPhysVMCB Physical address of host VMCB
692; * @param HCPhysVMCB Physical address of guest VMCB
693; * @param pCtx Guest context
694; */
695BEGINPROC SVMVMRun
696%ifdef RT_ARCH_AMD64 ; fake a cdecl stack frame - I'm lazy, sosume.
697 %ifdef ASM_CALL64_GCC
698 push rdx
699 push rsi
700 push rdi
701 %else
702 push r8
703 push rdx
704 push rcx
705 %endif
706 push 0
707%endif
708 push xBP
709 mov xBP, xSP
710
711 ;/* Manual save and restore:
712 ; * - General purpose registers except RIP, RSP, RAX
713 ; *
714 ; * Trashed:
715 ; * - CR2 (we don't care)
716 ; * - LDTR (reset to 0)
717 ; * - DRx (presumably not changed at all)
718 ; * - DR7 (reset to 0x400)
719 ; */
720
721 ;/* Save all general purpose host registers. */
722 MYPUSHAD
723
724 ;/* Save the Guest CPU context pointer. */
725 mov xSI, [xBP + xS*2 + RTHCPHYS_CB*2] ; pCtx
726 push xSI ; push for saving the state at the end
727
728 ; Restore CR2
729 mov ebx, [xSI + CPUMCTX.cr2]
730 mov cr2, xBX
731
732 ; save host fs, gs, sysenter msr etc
733 mov xAX, [xBP + xS*2] ; pVMCBHostPhys (64 bits physical address; x86: take low dword only)
734 push xAX ; save for the vmload after vmrun
735 vmsave
736
737 ; setup eax for VMLOAD
738 mov xAX, [xBP + xS*2 + RTHCPHYS_CB] ; pVMCBPhys (64 bits physical address; take low dword only)
739
740 ;/* Restore Guest's general purpose registers. */
741 ;/* EAX is loaded from the VMCB by VMRUN */
742 mov ebx, [xSI + CPUMCTX.ebx]
743 mov ecx, [xSI + CPUMCTX.ecx]
744 mov edx, [xSI + CPUMCTX.edx]
745 mov edi, [xSI + CPUMCTX.edi]
746 mov ebp, [xSI + CPUMCTX.ebp]
747 mov esi, [xSI + CPUMCTX.esi]
748
749 ; Clear the global interrupt flag & execute sti to make sure external interrupts cause a world switch
750 clgi
751 sti
752
753 ; load guest fs, gs, sysenter msr etc
754 vmload
755 ; run the VM
756 vmrun
757
758 ;/* EAX is in the VMCB already; we can use it here. */
759
760 ; save guest fs, gs, sysenter msr etc
761 vmsave
762
763 ; load host fs, gs, sysenter msr etc
764 pop xAX ; pushed above
765 vmload
766
767 ; Set the global interrupt flag again, but execute cli to make sure IF=0.
768 cli
769 stgi
770
771 pop xAX ; pCtx
772
773 mov [ss:xAX + CPUMCTX.ebx], ebx
774 mov [ss:xAX + CPUMCTX.ecx], ecx
775 mov [ss:xAX + CPUMCTX.edx], edx
776 mov [ss:xAX + CPUMCTX.esi], esi
777 mov [ss:xAX + CPUMCTX.edi], edi
778 mov [ss:xAX + CPUMCTX.ebp], ebp
779
780 ; Restore general purpose registers
781 MYPOPAD
782
783 mov eax, VINF_SUCCESS
784
785 pop xBP
786%ifdef RT_ARCH_AMD64
787 add xSP, 4*xS
788%endif
789 ret
790ENDPROC SVMVMRun
791
792
793;;
794; Executes INVLPGA
795;
796; @param pPageGC msc:ecx gcc:edi x86:[esp+04] Virtual page to invalidate
797; @param uASID msc:edx gcc:esi x86:[esp+08] Tagged TLB id
798;
799;DECLASM(void) SVMInvlpgA(RTGCPTR pPageGC, uint32_t uASID);
800BEGINPROC SVMInvlpgA
801%ifdef RT_ARCH_AMD64
802 %ifdef ASM_CALL64_GCC
803 mov eax, edi ;; @todo 64-bit guest.
804 mov ecx, esi
805 %else
806 mov eax, ecx ;; @todo 64-bit guest.
807 mov ecx, edx
808 %endif
809%else
810 mov eax, [esp + 4]
811 mov ecx, [esp + 8]
812%endif
813 invlpga [xAX], ecx
814 ret
815ENDPROC SVMInvlpgA
816
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