]> git.proxmox.com Git - mirror_edk2.git/blame - MdePkg/Library/BaseLib/x86FxRestore.c
1. Removed #ifndef to enable Capsule architecture protocol on IPF.
[mirror_edk2.git] / MdePkg / Library / BaseLib / x86FxRestore.c
CommitLineData
3f566587 1/** @file\r
2 IA-32/x64 AsmFxRestore()\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
13 Module Name: x86FxRestore.c\r
14\r
15**/\r
16\r
17#include "BaseLibInternals.h"\r
18\r
19/**\r
20 Restores the current floating point/SSE/SSE2 context from a buffer.\r
21\r
22 Restores the current floating point/SSE/SSE2 state from the buffer specified\r
23 by Buffer. Buffer must be aligned on a 16-byte boundary. This function is\r
24 only available on IA-32 and X64.\r
25\r
26 If Buffer is NULL, then ASSERT().\r
27 If Buffer is not aligned on a 16-byte boundary, then ASSERT().\r
28 If Buffer was not saved with AsmFxSave(), then ASSERT().\r
29\r
30 @param Buffer Pointer to a buffer to save the floating point/SSE/SSE2 context.\r
31\r
32**/\r
33VOID\r
34EFIAPI\r
35AsmFxRestore (\r
36 IN CONST IA32_FX_BUFFER *Buffer\r
37 )\r
38{\r
39 ASSERT (Buffer != NULL);\r
40 ASSERT (((UINTN)Buffer & 0xf) == 0);\r
41\r
42 //\r
43 // Check the flag recorded by AsmFxSave()\r
44 //\r
45 ASSERT (*(UINT32 *) (&Buffer[sizeof (IA32_FX_BUFFER) - 4]) == 0xAA5555AA);\r
46\r
47 InternalX86FxRestore (Buffer);\r
48}\r