/** @file\r
\r
- Copyright (c) 2015, Intel Corporation. All rights reserved.<BR>\r
+ Copyright (c) 2015 - 2018, Intel Corporation. All rights reserved.<BR>\r
This program and the accompanying materials\r
are licensed and made available under the terms and conditions of the BSD License\r
which accompanies this distribution. The full text of the license may be found at\r
//\r
// Check ImplementationID\r
//\r
- for (Index = 0; Index < sizeof(Hsti->ImplementationID); Index++) {\r
+ for (Index = 0; Index < sizeof(Hsti->ImplementationID)/sizeof(Hsti->ImplementationID[0]); Index++) {\r
if (Hsti->ImplementationID[Index] == 0) {\r
break;\r
}\r
}\r
- if (Index == sizeof(Hsti->ImplementationID)) {\r
- DEBUG ((EFI_D_ERROR, "ImplementationID is no NUL CHAR\n"));\r
+ if (Index == sizeof(Hsti->ImplementationID)/sizeof(Hsti->ImplementationID[0])) {\r
+ DEBUG ((EFI_D_ERROR, "ImplementationID has no NUL CHAR\n"));\r
return FALSE;\r
}\r
\r
ErrorStringSize = HstiSize - sizeof(ADAPTER_INFO_PLATFORM_SECURITY) - Hsti->SecurityFeaturesSize * 3;\r
- ErrorString = (CHAR16 *)((UINTN)Hsti + sizeof(ADAPTER_INFO_PLATFORM_SECURITY) - Hsti->SecurityFeaturesSize * 3);\r
+ ErrorString = (CHAR16 *)((UINTN)Hsti + sizeof(ADAPTER_INFO_PLATFORM_SECURITY) + Hsti->SecurityFeaturesSize * 3);\r
\r
//\r
// basic check for ErrorString\r
return EFI_OUT_OF_RESOURCES;\r
}\r
HstiAip->Hsti = AllocateCopyPool (HstiSize, Hsti);\r
- if (HstiAip == NULL) {\r
+ if (HstiAip->Hsti == NULL) {\r
FreePool (HstiAip);\r
return EFI_OUT_OF_RESOURCES;\r
}\r
UINT8 *SecurityFeaturesVerified;\r
EFI_STATUS Status;\r
\r
- Aip = InternalHstiFindAip (Role, ImplementationID, &Hsti, &HstiSize);\r
+ Aip = InternalHstiFindAip (Role, ImplementationID, (VOID **)&Hsti, &HstiSize);\r
if (Aip == NULL) {\r
return EFI_NOT_STARTED;\r
}\r
Hsti,\r
HstiSize\r
);\r
+ FreePool (Hsti);\r
return Status;\r
}\r
\r
UINTN Offset;\r
EFI_STATUS Status;\r
\r
- Aip = InternalHstiFindAip (Role, ImplementationID, &Hsti, &HstiSize);\r
+ Aip = InternalHstiFindAip (Role, ImplementationID, (VOID **)&Hsti, &HstiSize);\r
if (Aip == NULL) {\r
return EFI_NOT_STARTED;\r
}\r
NewHsti,\r
NewHstiSize\r
);\r
+ FreePool (Hsti);\r
+ FreePool (NewHsti);\r
return Status;\r
}\r
\r