\r
Abstract:\r
\r
-Revision History\r
+ Provide support functions for variable services.\r
\r
--*/\r
\r
\r
Returns:\r
\r
- EFI STATUS\r
+ EFI_INVALID_PARAMETER - Parameters not valid\r
+ EFI_SUCCESS - Variable store successfully updated\r
\r
--*/\r
{\r
if ((DataPtr + DataSize) >= ((UINTN) ((UINT8 *) VolatileBase + VolatileBase->Size))) {\r
return EFI_INVALID_PARAMETER;\r
}\r
- }\r
- //\r
- // If Volatile Variable just do a simple mem copy.\r
- //\r
- if (Volatile) {\r
+\r
+ //\r
+ // If Volatile Variable just do a simple mem copy.\r
+ //\r
CopyMem ((UINT8 *) ((UINTN) DataPtr), Buffer, DataSize);\r
return EFI_SUCCESS;\r
}\r
&CurrWriteSize,\r
CurrBuffer\r
);\r
- if (EFI_ERROR (Status)) {\r
- return Status;\r
- }\r
+ return Status;\r
} else {\r
Size = (UINT32) (LinearOffset + PtrBlockMapEntry->BlockLength - CurrWritePtr);\r
Status = EfiFvbWriteBlock (\r
\r
mVariableModuleGlobal->NonVolatileLastVariableOffset = (UINTN) NextVariable - (UINTN) CurrPtr;\r
\r
+ //\r
+ // Check if the free area is blow a threshold\r
+ //\r
+ if ((((VARIABLE_STORE_HEADER *)((UINTN) CurrPtr))->Size - mVariableModuleGlobal->NonVolatileLastVariableOffset) < VARIABLE_RECLAIM_THRESHOLD) {\r
+ Status = Reclaim (\r
+ mVariableModuleGlobal->VariableBase[Physical].NonVolatileVariableBase,\r
+ &mVariableModuleGlobal->NonVolatileLastVariableOffset,\r
+ FALSE\r
+ );\r
+ }\r
+\r
+ if (EFI_ERROR (Status)) {\r
+ gBS->FreePool (mVariableModuleGlobal);\r
+ gBS->FreePool (VolatileVariableStore);\r
+ return Status;\r
+ }\r
+\r
//\r
// Check if the free area is really free.\r
//\r