]> git.proxmox.com Git - mirror_edk2.git/blob - MdePkg/Include/Protocol/S3SmmSaveState.h
MdePkg/ProcessorBind: add defines for page allocation granularity
[mirror_edk2.git] / MdePkg / Include / Protocol / S3SmmSaveState.h
1 /** @file
2 S3 SMM Save State Protocol as defined in PI1.2 Specification VOLUME 5 Standard.
3
4 The EFI_S3_SMM_SAVE_STATE_PROTOCOL publishes the PI SMMboot script abstractions
5 On an S3 resume boot path the data stored via this protocol is replayed in the order it was stored.
6 The order of replay is the order either of the S3 Save State Protocol or S3 SMM Save State Protocol
7 Write() functions were called during the boot process. Insert(), Label(), and
8 Compare() operations are ordered relative other S3 SMM Save State Protocol write() operations
9 and the order relative to S3 State Save Write() operations is not defined. Due to these ordering
10 restrictions it is recommended that the S3 State Save Protocol be used during the DXE phase when
11 every possible.
12 The EFI_S3_SMM_SAVE_STATE_PROTOCOL can be called at runtime and
13 EFI_OUT_OF_RESOURCES may be returned from a runtime call. It is the responsibility of the
14 platform to ensure enough memory resource exists to save the system state. It is recommended that
15 runtime calls be minimized by the caller.
16
17 Copyright (c) 2009, Intel Corporation. All rights reserved.<BR>
18 This program and the accompanying materials
19 are licensed and made available under the terms and conditions of the BSD License
20 which accompanies this distribution. The full text of the license may be found at
21 http://opensource.org/licenses/bsd-license.php
22
23 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
24 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
25
26 @par Revision Reference:
27 This PPI is defined in UEFI Platform Initialization Specification 1.2 Volume 5:
28 Standards
29
30 **/
31
32 #ifndef __S3_SMM_SAVE_STATE_H__
33 #define __S3_SMM_SAVE_STATE_H__
34
35 #include <Protocol/S3SaveState.h>
36
37 #define EFI_S3_SMM_SAVE_STATE_PROTOCOL_GUID \
38 {0x320afe62, 0xe593, 0x49cb, { 0xa9, 0xf1, 0xd4, 0xc2, 0xf4, 0xaf, 0x1, 0x4c }}
39
40
41 typedef EFI_S3_SAVE_STATE_PROTOCOL EFI_S3_SMM_SAVE_STATE_PROTOCOL;
42
43 extern EFI_GUID gEfiS3SmmSaveStateProtocolGuid;
44
45 #endif // __S3_SMM_SAVE_STATE_H__
46