VirtualBox

source: vbox/trunk/src/VBox/Runtime/common/asm/ASMSetXcr0.asm@ 76553

Last change on this file since 76553 was 76553, checked in by vboxsync, 6 years ago

scm --update-copyright-year

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 2.0 KB
Line 
1; $Id: ASMSetXcr0.asm 76553 2019-01-01 01:45:53Z vboxsync $
2;; @file
3; IPRT - ASMSetXcr0().
4;
5
6;
7; Copyright (C) 2006-2019 Oracle Corporation
8;
9; This file is part of VirtualBox Open Source Edition (OSE), as
10; available from http://www.virtualbox.org. This file is free software;
11; you can redistribute it and/or modify it under the terms of the GNU
12; General Public License (GPL) as published by the Free Software
13; Foundation, in version 2 as it comes in the "COPYING" file of the
14; VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15; hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16;
17; The contents of this file may alternatively be used under the terms
18; of the Common Development and Distribution License Version 1.0
19; (CDDL) only, as it comes in the "COPYING.CDDL" file of the
20; VirtualBox OSE distribution, in which case the provisions of the
21; CDDL are applicable instead of those of the GPL.
22;
23; You may elect to license modified versions of this file under the
24; terms and conditions of either the GPL or the CDDL or both.
25;
26
27;*******************************************************************************
28;* Header Files *
29;*******************************************************************************
30%define RT_ASM_WITH_SEH64
31%include "iprt/asmdefs.mac"
32
33BEGINCODE
34
35;;
36; Sets the content of the Xcr0 CPU register.
37; @param uXcr0 The new XCR0 content.
38; msc=rcx, gcc=rdi, x86=[esp+4]
39;
40BEGINPROC_EXPORTED ASMSetXcr0
41SEH64_END_PROLOGUE
42%ifdef ASM_CALL64_MSC
43 mov rdx, rcx
44 shr rdx, 32
45 mov eax, ecx
46%elifdef ASM_CALL64_GCC
47 mov rdx, rdi
48 shr rdx, 32
49 mov eax, edi
50%elif ARCH_BITS == 32
51 mov eax, [esp + 4]
52 mov edx, [esp + 8]
53%elif ARCH_BITS == 16
54 push bp
55 mov bp, sp
56 mov eax, [bp + 4]
57 mov edx, [bp + 8]
58%else
59 %error "Undefined arch?"
60%endif
61
62 xor ecx, ecx
63 xsetbv
64
65%if ARCH_BITS == 16
66 leave
67%endif
68 ret
69ENDPROC ASMSetXcr0
70
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