]> git.proxmox.com Git - mirror_edk2.git/blame - MdePkg/Library/BaseLib/x86FxSave.c
Update the comments.
[mirror_edk2.git] / MdePkg / Library / BaseLib / x86FxSave.c
CommitLineData
e1f414b6 1/** @file\r
2 IA-32/x64 AsmFxSave()\r
3\r
4 Copyright (c) 2006, Intel Corporation<BR>\r
5 All rights reserved. This program and the accompanying materials\r
6 are licensed and made available under the terms and conditions of the BSD License\r
7 which accompanies this distribution. The full text of the license may be found at\r
8 http://opensource.org/licenses/bsd-license.php\r
9\r
10 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
11 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
12\r
e1f414b6 13**/\r
14\r
15//\r
16// Include common header file for this module.\r
17//\r
f734a10a 18\r
e1f414b6 19\r
20#include "BaseLibInternals.h"\r
21\r
22/**\r
23 Save the current floating point/SSE/SSE2 context to a buffer.\r
24\r
25 Saves the current floating point/SSE/SSE2 state to the buffer specified by\r
26 Buffer. Buffer must be aligned on a 16-byte boundary. This function is only\r
27 available on IA-32 and X64.\r
28\r
29 If Buffer is NULL, then ASSERT().\r
30 If Buffer is not aligned on a 16-byte boundary, then ASSERT().\r
31\r
32 @param Buffer Pointer to a buffer to save the floating point/SSE/SSE2 context.\r
33\r
34**/\r
35VOID\r
36EFIAPI\r
37AsmFxSave (\r
38 OUT IA32_FX_BUFFER *Buffer\r
39 )\r
40{\r
41 ASSERT (Buffer != NULL);\r
38bbd3d9 42 ASSERT (0 == ((UINTN)Buffer & 0xf));\r
e1f414b6 43\r
44 InternalX86FxSave (Buffer);\r
45\r
46 //\r
47 // Mark one flag at end of Buffer, it will be check by AsmFxRestor()\r
48 //\r
49 *(UINT32 *) (&Buffer[sizeof (IA32_FX_BUFFER) - 4]) = 0xAA5555AA;\r
50}\r