git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@11311 6f19259b-4bc3-4df7-8a09-765794883524
		
			
				
	
	
		
			251 lines
		
	
	
		
			8.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			251 lines
		
	
	
		
			8.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /** @file
 | |
| 
 | |
|   Implment all four UEFI runtime variable services and 
 | |
|   install variable architeture protocol.
 | |
|   
 | |
| Copyright (c) 2006 - 2010, Intel Corporation. All rights reserved.<BR>
 | |
| 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.
 | |
| 
 | |
| **/
 | |
| 
 | |
| #include "Variable.h"
 | |
| 
 | |
| EFI_EVENT   mVirtualAddressChangeEvent = NULL;
 | |
| 
 | |
| /**
 | |
| 
 | |
|   This code finds variable in storage blocks (Volatile or Non-Volatile).
 | |
| 
 | |
|   @param VariableName               Name of Variable to be found.
 | |
|   @param VendorGuid                 Variable vendor GUID.
 | |
|   @param Attributes                 Attribute value of the variable found.
 | |
|   @param DataSize                   Size of Data found. If size is less than the
 | |
|                                     data, this value contains the required size.
 | |
|   @param Data                       Data pointer.
 | |
|                       
 | |
|   @return EFI_INVALID_PARAMETER     Invalid parameter
 | |
|   @return EFI_SUCCESS               Find the specified variable
 | |
|   @return EFI_NOT_FOUND             Not found
 | |
|   @return EFI_BUFFER_TO_SMALL       DataSize is too small for the result
 | |
| 
 | |
| **/
 | |
| EFI_STATUS
 | |
| EFIAPI
 | |
| RuntimeServiceGetVariable (
 | |
|   IN CHAR16        *VariableName,
 | |
|   IN EFI_GUID      *VendorGuid,
 | |
|   OUT UINT32       *Attributes OPTIONAL,
 | |
|   IN OUT UINTN     *DataSize,
 | |
|   OUT VOID         *Data
 | |
|   )
 | |
| {
 | |
|   return EmuGetVariable (
 | |
|           VariableName,
 | |
|           VendorGuid,
 | |
|           Attributes OPTIONAL,
 | |
|           DataSize,
 | |
|           Data,
 | |
|           &mVariableModuleGlobal->VariableGlobal[Physical]
 | |
|           );
 | |
| }
 | |
| 
 | |
| /**
 | |
| 
 | |
|   This code Finds the Next available variable.
 | |
| 
 | |
|   @param VariableNameSize           Size of the variable name
 | |
|   @param VariableName               Pointer to variable name
 | |
|   @param VendorGuid                 Variable Vendor Guid
 | |
| 
 | |
|   @return EFI_INVALID_PARAMETER     Invalid parameter
 | |
|   @return EFI_SUCCESS               Find the specified variable
 | |
|   @return EFI_NOT_FOUND             Not found
 | |
|   @return EFI_BUFFER_TO_SMALL       DataSize is too small for the result
 | |
| 
 | |
| **/
 | |
| EFI_STATUS
 | |
| EFIAPI
 | |
| RuntimeServiceGetNextVariableName (
 | |
|   IN OUT UINTN     *VariableNameSize,
 | |
|   IN OUT CHAR16    *VariableName,
 | |
|   IN OUT EFI_GUID  *VendorGuid
 | |
|   )
 | |
| {
 | |
|   return EmuGetNextVariableName (
 | |
|           VariableNameSize,
 | |
|           VariableName,
 | |
|           VendorGuid,
 | |
|           &mVariableModuleGlobal->VariableGlobal[Physical]
 | |
|           );
 | |
| }
 | |
| 
 | |
| /**
 | |
| 
 | |
|   This code sets variable in storage blocks (Volatile or Non-Volatile).
 | |
| 
 | |
|   @param VariableName                     Name of Variable to be found
 | |
|   @param VendorGuid                       Variable vendor GUID
 | |
|   @param Attributes                       Attribute value of the variable found
 | |
|   @param DataSize                         Size of Data found. If size is less than the
 | |
|                                           data, this value contains the required size.
 | |
|   @param Data                             Data pointer
 | |
| 
 | |
|   @return EFI_INVALID_PARAMETER           Invalid parameter
 | |
|   @return EFI_SUCCESS                     Set successfully
 | |
|   @return EFI_OUT_OF_RESOURCES            Resource not enough to set variable
 | |
|   @return EFI_NOT_FOUND                   Not found
 | |
|   @return EFI_WRITE_PROTECTED             Variable is read-only
 | |
| 
 | |
| **/
 | |
| EFI_STATUS
 | |
| EFIAPI
 | |
| RuntimeServiceSetVariable (
 | |
|   IN CHAR16        *VariableName,
 | |
|   IN EFI_GUID      *VendorGuid,
 | |
|   IN UINT32        Attributes,
 | |
|   IN UINTN         DataSize,
 | |
|   IN VOID          *Data
 | |
|   )
 | |
| {
 | |
|   return EmuSetVariable (
 | |
|           VariableName,
 | |
|           VendorGuid,
 | |
|           Attributes,
 | |
|           DataSize,
 | |
|           Data,
 | |
|           &mVariableModuleGlobal->VariableGlobal[Physical],
 | |
|           &mVariableModuleGlobal->VolatileLastVariableOffset,
 | |
|           &mVariableModuleGlobal->NonVolatileLastVariableOffset
 | |
|           );
 | |
| }
 | |
| 
 | |
| /**
 | |
| 
 | |
|   This code returns information about the EFI variables.
 | |
| 
 | |
|   @param Attributes                     Attributes bitmask to specify the type of variables
 | |
|                                         on which to return information.
 | |
|   @param MaximumVariableStorageSize     Pointer to the maximum size of the storage space available
 | |
|                                         for the EFI variables associated with the attributes specified.
 | |
|   @param RemainingVariableStorageSize   Pointer to the remaining size of the storage space available
 | |
|                                         for EFI variables associated with the attributes specified.
 | |
|   @param MaximumVariableSize            Pointer to the maximum size of an individual EFI variables
 | |
|                                         associated with the attributes specified.
 | |
| 
 | |
|   @return EFI_INVALID_PARAMETER         An invalid combination of attribute bits was supplied.
 | |
|   @return EFI_SUCCESS                   Query successfully.
 | |
|   @return EFI_UNSUPPORTED               The attribute is not supported on this platform.
 | |
| 
 | |
| **/
 | |
| EFI_STATUS
 | |
| EFIAPI
 | |
| RuntimeServiceQueryVariableInfo (
 | |
|   IN  UINT32                 Attributes,
 | |
|   OUT UINT64                 *MaximumVariableStorageSize,
 | |
|   OUT UINT64                 *RemainingVariableStorageSize,
 | |
|   OUT UINT64                 *MaximumVariableSize
 | |
|   )
 | |
| {
 | |
|   return EmuQueryVariableInfo (
 | |
|           Attributes,
 | |
|           MaximumVariableStorageSize,
 | |
|           RemainingVariableStorageSize,
 | |
|           MaximumVariableSize,
 | |
|           &mVariableModuleGlobal->VariableGlobal[Physical]
 | |
|           );
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Notification function of EVT_SIGNAL_VIRTUAL_ADDRESS_CHANGE.
 | |
| 
 | |
|   This is a notification function registered on EVT_SIGNAL_VIRTUAL_ADDRESS_CHANGE event.
 | |
|   It convers pointer to new virtual address.
 | |
| 
 | |
|   @param  Event        Event whose notification function is being invoked.
 | |
|   @param  Context      Pointer to the notification function's context.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| EFIAPI
 | |
| VariableClassAddressChangeEvent (
 | |
|   IN EFI_EVENT        Event,
 | |
|   IN VOID             *Context
 | |
|   )
 | |
| {
 | |
|   EfiConvertPointer (0x0, (VOID **) &mVariableModuleGlobal->PlatformLangCodes);
 | |
|   EfiConvertPointer (0x0, (VOID **) &mVariableModuleGlobal->LangCodes);
 | |
|   EfiConvertPointer (0x0, (VOID **) &mVariableModuleGlobal->PlatformLang);
 | |
|   EfiConvertPointer (
 | |
|     0x0,
 | |
|     (VOID **) &mVariableModuleGlobal->VariableGlobal[Physical].NonVolatileVariableBase
 | |
|     );
 | |
|   EfiConvertPointer (
 | |
|     0x0,
 | |
|     (VOID **) &mVariableModuleGlobal->VariableGlobal[Physical].VolatileVariableBase
 | |
|     );
 | |
|   EfiConvertPointer (0x0, (VOID **) &mVariableModuleGlobal);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   EmuVariable Driver main entry point. The Variable driver places the 4 EFI
 | |
|   runtime services in the EFI System Table and installs arch protocols 
 | |
|   for variable read and write services being available. It also registers
 | |
|   notification function for EVT_SIGNAL_VIRTUAL_ADDRESS_CHANGE event.
 | |
| 
 | |
|   @param[in] ImageHandle    The firmware allocated handle for the EFI image.  
 | |
|   @param[in] SystemTable    A pointer to the EFI System Table.
 | |
|   
 | |
|   @retval EFI_SUCCESS       Variable service successfully initialized.
 | |
| 
 | |
| **/
 | |
| EFI_STATUS
 | |
| EFIAPI
 | |
| VariableServiceInitialize (
 | |
|   IN EFI_HANDLE         ImageHandle,
 | |
|   IN EFI_SYSTEM_TABLE   *SystemTable
 | |
|   )
 | |
| {
 | |
|   EFI_HANDLE  NewHandle;
 | |
|   EFI_STATUS  Status;
 | |
| 
 | |
|   Status = VariableCommonInitialize (ImageHandle, SystemTable);
 | |
|   ASSERT_EFI_ERROR (Status);
 | |
| 
 | |
|   SystemTable->RuntimeServices->GetVariable         = RuntimeServiceGetVariable;
 | |
|   SystemTable->RuntimeServices->GetNextVariableName = RuntimeServiceGetNextVariableName;
 | |
|   SystemTable->RuntimeServices->SetVariable         = RuntimeServiceSetVariable;
 | |
|   SystemTable->RuntimeServices->QueryVariableInfo   = RuntimeServiceQueryVariableInfo;
 | |
| 
 | |
|   //
 | |
|   // Now install the Variable Runtime Architectural Protocol on a new handle
 | |
|   //
 | |
|   NewHandle = NULL;
 | |
|   Status = gBS->InstallMultipleProtocolInterfaces (
 | |
|                   &NewHandle,
 | |
|                   &gEfiVariableArchProtocolGuid,
 | |
|                   NULL,
 | |
|                   &gEfiVariableWriteArchProtocolGuid,
 | |
|                   NULL,
 | |
|                   NULL
 | |
|                   );
 | |
|   ASSERT_EFI_ERROR (Status);
 | |
| 
 | |
|   Status = gBS->CreateEventEx (
 | |
|                   EVT_NOTIFY_SIGNAL,
 | |
|                   TPL_NOTIFY,
 | |
|                   VariableClassAddressChangeEvent,
 | |
|                   NULL,
 | |
|                   &gEfiEventVirtualAddressChangeGuid,
 | |
|                   &mVirtualAddressChangeEvent
 | |
|                   );
 | |
|   ASSERT_EFI_ERROR (Status);
 | |
| 
 | |
|   return EFI_SUCCESS;
 | |
| }
 |