summaryrefslogtreecommitdiff
path: root/OvmfPkg/Library/NvVarsFileLib/NvVarsFileLib.h
diff options
context:
space:
mode:
Diffstat (limited to 'OvmfPkg/Library/NvVarsFileLib/NvVarsFileLib.h')
-rw-r--r--OvmfPkg/Library/NvVarsFileLib/NvVarsFileLib.h103
1 files changed, 103 insertions, 0 deletions
diff --git a/OvmfPkg/Library/NvVarsFileLib/NvVarsFileLib.h b/OvmfPkg/Library/NvVarsFileLib/NvVarsFileLib.h
new file mode 100644
index 0000000000..6241dc8842
--- /dev/null
+++ b/OvmfPkg/Library/NvVarsFileLib/NvVarsFileLib.h
@@ -0,0 +1,103 @@
+/** @file
+ Save Non-Volatile Variables to a file system.
+
+ Copyright (c) 2009, Intel Corporation
+ All rights reserved. This program and the accompanying materials
+ are licensed and made available under the terms and conditions of the BSD License
+ which accompanies this distribution. The full text of the license may be found at
+ http://opensource.org/licenses/bsd-license.php
+
+ THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
+ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
+
+**/
+
+#ifndef __NV_VARS_FILE_LIB_INSTANCE__
+#define __NV_VARS_FILE_LIB_INSTANCE__
+
+#include <Uefi.h>
+
+#include <Guid/FileInfo.h>
+
+#include <Protocol/SimpleFileSystem.h>
+
+#include <Library/BaseLib.h>
+#include <Library/FileHandleLib.h>
+#include <Library/UefiBootServicesTableLib.h>
+#include <Library/UefiRuntimeServicesTableLib.h>
+#include <Library/UefiLib.h>
+
+/**
+ Loads the non-volatile variables from the NvVars file on the
+ given file system.
+
+ @param[in] FsHandle - Handle for a gEfiSimpleFileSystemProtocolGuid instance
+
+ @return EFI_STATUS based on the success or failure of load operation
+
+**/
+EFI_STATUS
+LoadNvVarsFromFs (
+ EFI_HANDLE FsHandle
+ );
+
+
+/**
+ Saves the non-volatile variables into the NvVars file on the
+ given file system.
+
+ @param[in] FsHandle - Handle for a gEfiSimpleFileSystemProtocolGuid instance
+
+ @return EFI_STATUS based on the success or failure of load operation
+
+**/
+EFI_STATUS
+SaveNvVarsToFs (
+ EFI_HANDLE FsHandle
+ );
+
+
+/**
+ Examines the NvVars file contents, and updates variables based on it.
+
+ @param[in] VarsBuffer - Buffer with NvVars data
+ @param[in] VarsBufferSize - Size of VarsBuffer in bytes
+
+ @return EFI_STATUS based on the success or failure of the operation
+
+**/
+EFI_STATUS
+SetVariablesFromBuffer (
+ IN VOID *VarsBuffer,
+ IN UINTN VarsBufferSize
+ );
+
+
+/**
+ Writes the variable into the file so it can be restored from
+ the file on future boots of the system.
+
+ @param[in] File - The file to write to
+ @param[in] Name - Variable name string
+ @param[in] NameSize - Size of Name in bytes
+ @param[in] Guid - GUID of variable
+ @param[in] Attributes - Attributes of variable
+ @param[in] Data - Buffer containing Data for variable
+ @param[in] DataSize - Size of Data in bytes
+
+ @return EFI_STATUS based on the success or failure of the operation
+
+**/
+EFI_STATUS
+PackVariableIntoFile (
+ IN EFI_FILE_HANDLE File,
+ IN CHAR16 *Name,
+ IN UINT32 NameSize,
+ IN EFI_GUID *Guid,
+ IN UINT32 Attributes,
+ IN VOID *Data,
+ IN UINT32 DataSize
+ );
+
+#endif
+