UINT16 StringTableIdx; \r
UINT32 LocalTokenNumber;\r
\r
-\r
+ //\r
+ // TokenNumber Zero is reserved as PCD_INVALID_TOKEN_NUMBER.\r
+ // We have to decrement TokenNumber by 1 to make it usable\r
+ // as the array index.\r
+ //\r
+ TokenNumber--;\r
+ \r
ASSERT (TokenNumber < PCD_TOTAL_TOKEN_NUMBER);\r
\r
- Size = DxePcdGetSize (TokenNumber);\r
+ Size = DxePcdGetSize (TokenNumber + 1);\r
ASSERT (GetSize == Size || GetSize == 0);\r
\r
\r
Name = &(StringTable[VariableHead->StringIndex]);\r
\r
Status = GetHiiVariable (Guid, Name, &Data, &DataSize);\r
- ASSERT_EFI_ERROR (Status);\r
- ASSERT (DataSize >= (UINTN) (VariableHead->Offset + Size));\r
-\r
- return (UINT8 *) Data + VariableHead->Offset;\r
+ if (Status == EFI_SUCCESS) {\r
+ ASSERT (DataSize >= (UINTN) (VariableHead->Offset + Size));\r
+ return (UINT8 *) Data + VariableHead->Offset;\r
+ } else {\r
+ //\r
+ // Return the default value specified by Platform Integrator \r
+ //\r
+ return (VOID *) ((UINT8 *) PcdDb + VariableHead->DefaultValueOffset);\r
+ }\r
\r
case PCD_TYPE_STRING:\r
StringTableIdx = (UINT16) *((UINT8 *) PcdDb + Offset);\r
TokenNumber = GetExPcdTokenNumber (Guid, (UINT32) TokenNumber);\r
}\r
\r
+ //\r
+ // TokenNumber Zero is reserved as PCD_INVALID_TOKEN_NUMBER.\r
+ // We have to decrement TokenNumber by 1 to make it usable\r
+ // as the array index.\r
+ //\r
+ TokenNumber--;\r
+\r
ListHead = &mCallbackFnTable[TokenNumber];\r
ListNode = GetFirstNode (ListHead);\r
\r
TokenNumber = GetExPcdTokenNumber (Guid, (UINT32) TokenNumber);\r
}\r
\r
+ //\r
+ // TokenNumber Zero is reserved as PCD_INVALID_TOKEN_NUMBER.\r
+ // We have to decrement TokenNumber by 1 to make it usable\r
+ // as the array index.\r
+ //\r
+ TokenNumber--;\r
+\r
ListHead = &mCallbackFnTable[TokenNumber];\r
ListNode = GetFirstNode (ListHead);\r
\r
if (TokenNumber == PCD_INVALID_TOKEN_NUMBER) {\r
return ExMapTable[Idx].ExTokenNumber;\r
}\r
- \r
+\r
for ( ; Idx < SizeOfExMapTable; Idx++) {\r
if (ExMapTable[Idx].ExTokenNumber == TokenNumber) {\r
Idx++;\r
EFI_STATUS Status;\r
VOID *Buffer;\r
\r
+ Size = 0;\r
+ Buffer = NULL;\r
+ \r
Status = EfiGetVariable (\r
(UINT16 *)VariableName,\r
VariableGuid,\r
NULL,\r
&Size,\r
- NULL\r
+ Buffer\r
);\r
- ASSERT (Status == EFI_BUFFER_TOO_SMALL);\r
+ \r
+ if (Status == EFI_BUFFER_TOO_SMALL) {\r
\r
- Buffer = AllocatePool (Size);\r
+ Buffer = AllocatePool (Size);\r
\r
- ASSERT (Buffer != NULL);\r
+ ASSERT (Buffer != NULL);\r
\r
- Status = EfiGetVariable (\r
- VariableName,\r
- VariableGuid,\r
- NULL,\r
- &Size,\r
- Buffer\r
- );\r
+ Status = EfiGetVariable (\r
+ VariableName,\r
+ VariableGuid,\r
+ NULL,\r
+ &Size,\r
+ Buffer\r
+ );\r
+\r
+ ASSERT (Status == EFI_SUCCESS);\r
+ }\r
+\r
+ *VariableData = Buffer;\r
+ *VariableSize = Size;\r
\r
return Status;\r
\r
LIST_ENTRY *ListHead;\r
LIST_ENTRY *ListNode;\r
\r
+ //\r
+ // TokenNumber Zero is reserved as PCD_INVALID_TOKEN_NUMBER.\r
+ // We have to decrement TokenNumber by 1 to make it usable\r
+ // as the array index.\r
+ //\r
+ TokenNumber--;\r
+ \r
ListHead = &mCallbackFnTable[TokenNumber];\r
ListNode = GetFirstNode (ListHead);\r
\r
UINT16 *StringTable;\r
EFI_GUID *Guid;\r
UINT16 *Name;\r
+ UINTN VariableOffset;\r
VOID *InternalData;\r
VARIABLE_HEAD *VariableHead;\r
UINTN Offset;\r
UINT8 *PcdDb;\r
\r
-\r
+ //\r
+ // TokenNumber Zero is reserved as PCD_INVALID_TOKEN_NUMBER.\r
+ // We have to decrement TokenNumber by 1 to make it usable\r
+ // as the array index.\r
+ //\r
+ TokenNumber--;\r
+ \r
ASSERT (TokenNumber < PCD_TOTAL_TOKEN_NUMBER);\r
\r
if (PtrType) {\r
- ASSERT (Size <= DxePcdGetSize (TokenNumber));\r
+ ASSERT (Size <= DxePcdGetSize (TokenNumber + 1));\r
} else {\r
- ASSERT (Size == DxePcdGetSize (TokenNumber));\r
+ ASSERT (Size == DxePcdGetSize (TokenNumber + 1));\r
}\r
\r
IsPeiDb = (TokenNumber < PEI_LOCAL_TOKEN_NUMBER) ? TRUE : FALSE;\r
\r
if ((TokenNumber < PEI_NEX_TOKEN_NUMBER) ||\r
(TokenNumber >= PEI_LOCAL_TOKEN_NUMBER || TokenNumber < (PEI_LOCAL_TOKEN_NUMBER + DXE_NEX_TOKEN_NUMBER))) {\r
- InvokeCallbackOnSet (0, NULL, TokenNumber, Data, Size);\r
+ InvokeCallbackOnSet (0, NULL, TokenNumber + 1, Data, Size);\r
}\r
\r
TokenNumber = IsPeiDb ? TokenNumber\r
\r
case PCD_TYPE_STRING:\r
CopyMem (&StringTable[*((UINT16 *)InternalData)], Data, Size);\r
- break;\r
+ return EFI_SUCCESS;\r
\r
case PCD_TYPE_HII:\r
//\r
\r
Guid = &(GuidTable[VariableHead->GuidTableIndex]);\r
Name = &(StringTable[VariableHead->StringIndex]);\r
+ VariableOffset = VariableHead->Offset;\r
\r
- return EFI_SUCCESS;\r
+ return SetHiiVariable (Guid, Name, Data, Size, VariableOffset);\r
\r
case PCD_TYPE_DATA:\r
if (PtrType) {\r
NULL\r
);\r
\r
- ASSERT (Status == EFI_BUFFER_TOO_SMALL);\r
+ if (Status == EFI_BUFFER_TOO_SMALL) {\r
\r
- Buffer = AllocatePool (Size);\r
+ Buffer = AllocatePool (Size);\r
\r
- ASSERT (Buffer != NULL);\r
+ ASSERT (Buffer != NULL);\r
\r
- Status = EfiGetVariable (\r
- VariableName,\r
- VariableGuid,\r
- &Attribute,\r
- &Size,\r
- Buffer\r
- );\r
+ Status = EfiGetVariable (\r
+ VariableName,\r
+ VariableGuid,\r
+ &Attribute,\r
+ &Size,\r
+ Buffer\r
+ );\r
+ \r
+ ASSERT_EFI_ERROR (Status);\r
+\r
+ CopyMem ((UINT8 *)Buffer + Offset, Data, DataSize);\r
\r
+ } else {\r
\r
- CopyMem ((UINT8 *)Buffer + Offset, Data, DataSize);\r
+ Attribute = EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_RUNTIME_ACCESS;\r
+ Size = DataSize + Offset;\r
+ Buffer = AllocateZeroPool (Size);\r
+ ASSERT (Buffer != NULL);\r
+ CopyMem ((UINT8 *)Buffer + Offset, Data, DataSize);\r
+ \r
+ }\r
\r
return EfiSetVariable (\r
- VariableName,\r
- VariableGuid,\r
- Attribute,\r
- Size,\r
- Buffer\r
- );\r
+ VariableName,\r
+ VariableGuid,\r
+ Attribute,\r
+ Size,\r
+ Buffer\r
+ );\r
\r
}\r
\r
EFI_GUID *MatchGuid;\r
UINTN MatchGuidIdx;\r
\r
- ExMap = mPcdDatabase->PeiDb.Init.ExMapTable;\r
- GuidTable = mPcdDatabase->PeiDb.Init.GuidTable;\r
- \r
- MatchGuid = ScanGuid (GuidTable, sizeof(mPcdDatabase->PeiDb.Init.GuidTable), Guid);\r
- ASSERT (MatchGuid != NULL);\r
+ if (!PEI_DATABASE_EMPTY) {\r
+ ExMap = mPcdDatabase->PeiDb.Init.ExMapTable;\r
+ GuidTable = mPcdDatabase->PeiDb.Init.GuidTable;\r
+ \r
+ MatchGuid = ScanGuid (GuidTable, sizeof(mPcdDatabase->PeiDb.Init.GuidTable), Guid);\r
+ \r
+ if (MatchGuid != NULL) {\r
\r
- MatchGuidIdx = MatchGuid - GuidTable;\r
- \r
- for (i = 0; i < PEI_EXMAPPING_TABLE_SIZE; i++) {\r
- if ((ExTokenNumber == ExMap[i].ExTokenNumber) &&\r
- (MatchGuidIdx == ExMap[i].ExGuidIndex)) {\r
- return ExMap[i].LocalTokenNumber;\r
+ MatchGuidIdx = MatchGuid - GuidTable;\r
+ \r
+ for (i = 0; i < PEI_EXMAPPING_TABLE_SIZE; i++) {\r
+ if ((ExTokenNumber == ExMap[i].ExTokenNumber) &&\r
+ (MatchGuidIdx == ExMap[i].ExGuidIndex)) {\r
+ return ExMap[i].LocalTokenNumber;\r
\r
+ }\r
+ }\r
}\r
}\r
\r
GuidTable = mPcdDatabase->DxeDb.Init.GuidTable;\r
\r
MatchGuid = ScanGuid (GuidTable, sizeof(mPcdDatabase->DxeDb.Init.GuidTable), Guid);\r
+ //\r
+ // We need to ASSERT here. If GUID can't be found in GuidTable, this is a\r
+ // error in the BUILD system.\r
+ //\r
ASSERT (MatchGuid != NULL);\r
\r
MatchGuidIdx = MatchGuid - GuidTable;\r
for (i = 0; i < DXE_EXMAPPING_TABLE_SIZE; i++) {\r
if ((ExTokenNumber == ExMap[i].ExTokenNumber) &&\r
(MatchGuidIdx == ExMap[i].ExGuidIndex)) {\r
- return ExMap[i].LocalTokenNumber + PEI_LOCAL_TOKEN_NUMBER;\r
+ return ExMap[i].LocalTokenNumber;\r
}\r
}\r
\r