/** @file\r
This file also installs UEFI PLATFORM_DRIVER_OVERRIDE_PROTOCOL.\r
- \r
+\r
The main code offers a UI interface in device manager to let user configure\r
platform override protocol to override the default algorithm for matching\r
drivers to controllers.\r
4. It save all the mapping info in NV variables which will be consumed\r
by platform override protocol driver to publish the platform override protocol.\r
\r
-Copyright (c) 2007 - 2014, Intel Corporation. All rights reserved.<BR>\r
+Copyright (c) 2007 - 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
END_DEVICE_PATH_TYPE,\r
END_ENTIRE_DEVICE_PATH_SUBTYPE,\r
- { \r
+ {\r
(UINT8) (END_DEVICE_PATH_LENGTH),\r
(UINT8) ((END_DEVICE_PATH_LENGTH) >> 8)\r
}\r
Converting a given device to an unicode string.\r
\r
@param DevPath Given device path instance\r
- \r
+\r
@return Converted string from given device path.\r
@retval L"?" Converting failed.\r
**/\r
}\r
\r
/**\r
- Worker function to get the driver name by ComponentName or ComponentName2 protocol \r
+ Worker function to get the driver name by ComponentName or ComponentName2 protocol\r
according to the driver binding handle.\r
\r
@param DriverBindingHandle The Handle of DriverBinding.\r
\r
\r
/**\r
- Get the driver name by ComponentName or ComponentName2 protocol \r
+ Get the driver name by ComponentName or ComponentName2 protocol\r
according to the driver binding handle\r
\r
@param DriverBindingHandle The Handle of DriverBinding.\r
DriverName = GetComponentNameWorker (DriverBindingHandle, &gEfiComponentName2ProtocolGuid, L"PlatformLang");\r
if (DriverName == NULL) {\r
//\r
- // If we can not get driver name from Component Name 2 protocol, we can try ISO 639-2 Component Name protocol. \r
+ // If we can not get driver name from Component Name 2 protocol, we can try ISO 639-2 Component Name protocol.\r
//\r
DriverName = GetComponentNameWorker (DriverBindingHandle, &gEfiComponentNameProtocolGuid, L"Lang");\r
}\r
// Make sure device path node is aligned when accessing it's FV Name Guid field.\r
//\r
AlignedDevPathNode = AllocateCopyPool (DevicePathNodeLength(DevPathNode), DevPathNode);\r
- \r
+\r
//\r
// Find the Fv File path\r
//\r
Buffer = NULL;\r
}\r
}\r
- \r
+\r
FreePool (AlignedDevPathNode);\r
- \r
+\r
//\r
// Next device path node\r
//\r
EFI_STATUS Status;\r
UINTN Index;\r
UINTN DevicePathHandleCount;\r
+ UINTN NewStrSize;\r
CHAR16 *NewString;\r
EFI_STRING_ID NewStringToken;\r
CHAR16 *ControllerName;\r
VOID *StartOpCodeHandle;\r
VOID *EndOpCodeHandle;\r
EFI_IFR_GUID_LABEL *StartLabel;\r
- EFI_IFR_GUID_LABEL *EndLabel; \r
+ EFI_IFR_GUID_LABEL *EndLabel;\r
\r
//\r
// Set current page form ID.\r
//\r
- mCurrentPage = FORM_ID_DEVICE; \r
- \r
+ mCurrentPage = FORM_ID_DEVICE;\r
+\r
//\r
// Initial the mapping database in memory\r
//\r
// Export the driver name string and create item in set options page\r
//\r
Len = StrSize (ControllerName);\r
- NewString = AllocateZeroPool (Len + StrSize (L"--"));\r
+ NewStrSize = Len + StrSize (L"--");\r
+ NewString = AllocateZeroPool (NewStrSize);\r
ASSERT (NewString != NULL);\r
if (EFI_ERROR (CheckMapping (ControllerDevicePath,NULL, &mMappingDataBase, NULL, NULL))) {\r
- StrCat (NewString, L"--");\r
+ StrCatS (NewString, NewStrSize/sizeof(CHAR16), L"--");\r
} else {\r
- StrCat (NewString, L"**");\r
+ StrCatS (NewString, NewStrSize/sizeof(CHAR16), L"**");\r
}\r
- StrCat (NewString, ControllerName);\r
+ StrCatS (NewString, NewStrSize/sizeof(CHAR16), ControllerName);\r
\r
NewStringToken = HiiSetString (Private->RegisteredHandle, mControllerToken[Index], NewString, NULL);\r
ASSERT (NewStringToken != 0);\r
// Save the device path string toke for next access use\r
//\r
mControllerToken[Index] = NewStringToken;\r
- \r
+\r
HiiCreateGotoOpCode (\r
StartOpCodeHandle,\r
FORM_ID_DRIVER,\r
@param ImageHandle The Image handle\r
\r
@return Handle to Driver binding\r
- @retval NULL The paramter is not valid or the driver binding handle is not found.\r
+ @retval NULL The parameter is not valid or the driver binding handle is not found.\r
\r
**/\r
EFI_HANDLE\r
if (EFI_ERROR (Status) || (DriverBindingHandleCount == 0)) {\r
return NULL;\r
}\r
- \r
+\r
//\r
// Get the first Driver Binding handle which has the specific image handle.\r
//\r
{\r
EFI_STATUS Status;\r
UINTN Index;\r
+ UINTN NewStrSize;\r
CHAR16 *NewString;\r
EFI_STRING_ID NewStringToken;\r
EFI_STRING_ID NewStringHelpToken;\r
//\r
// First create the driver image name\r
//\r
- NewString = AllocateZeroPool (StrSize (DriverName));\r
- ASSERT (NewString != NULL); \r
+ NewStrSize = StrSize (DriverName);\r
+ NewString = AllocateZeroPool (NewStrSize);\r
+ ASSERT (NewString != NULL);\r
if (EFI_ERROR (CheckMapping (mControllerDevicePathProtocol[mSelectedCtrIndex], LoadedImageDevicePath, &mMappingDataBase, NULL, NULL))) {\r
mDriSelection[Index] = FALSE;\r
} else {\r
mDriSelection[Index] = TRUE;\r
mLastSavedDriverImageNum++;\r
}\r
- StrCat (NewString, DriverName);\r
+ StrCatS (NewString, NewStrSize/sizeof(CHAR16), DriverName);\r
NewStringToken = HiiSetString (Private->RegisteredHandle, mDriverImageToken[Index], NewString, NULL);\r
ASSERT (NewStringToken != 0);\r
mDriverImageToken[Index] = NewStringToken;\r
//\r
DriverName = DevicePathToStr (LoadedImageDevicePath);\r
\r
- NewString = AllocateZeroPool (StrSize (DriverName));\r
- ASSERT (NewString != NULL); \r
- StrCat (NewString, DriverName);\r
+ NewStrSize = StrSize (DriverName);\r
+ NewString = AllocateZeroPool (NewStrSize);\r
+ ASSERT (NewString != NULL);\r
+ StrCatS (NewString, NewStrSize/sizeof(CHAR16), DriverName);\r
NewStringHelpToken = HiiSetString (Private->RegisteredHandle, DriverImageFilePathToken[Index], NewString, NULL);\r
ASSERT (NewStringHelpToken != 0);\r
DriverImageFilePathToken[Index] = NewStringHelpToken;\r
FakeNvData->DriOrder[Index] = (UINT8) OrderNO[MinNO];\r
TempNO[MinNO] = MAX_CHOICE_NUM + 1;\r
}\r
- \r
+\r
//\r
// Create Order List OpCode\r
//\r
if (!HiiIsConfigHdrMatch (Configuration, &gPlatformOverridesManagerGuid, mVariableName)) {\r
return EFI_NOT_FOUND;\r
}\r
- \r
+\r
*Progress = Configuration + StrLen (Configuration);\r
Private = EFI_CALLBACK_INFO_FROM_THIS (This);\r
FakeNvData = &Private->FakeNvData;\r
if (Value == NULL) {\r
return EFI_INVALID_PARAMETER;\r
}\r
- \r
+\r
if (KeyValue == KEY_VALUE_DRIVER_GOTO_PREVIOUS) {\r
UpdateDeviceSelectPage (Private, KeyValue, FakeNvData);\r
//\r
ASSERT (FALSE);\r
}\r
break;\r
- \r
+\r
case KEY_VALUE_ORDER_SAVE_AND_EXIT:\r
Status = CommitChanges (Private, KeyValue, FakeNvData);\r
*ActionRequest = EFI_BROWSER_ACTION_REQUEST_SUBMIT;\r
\r
Status = InitOverridesMapping (&mMappingDataBase);\r
if (EFI_ERROR (Status)){\r
- DEBUG ((DEBUG_ERROR, "The status to Get Platform Driver Override Variable is %r\n", Status));\r
+ DEBUG ((DEBUG_INFO, "The status to Get Platform Driver Override Variable is %r\n", Status));\r
InitializeListHead (&mMappingDataBase);\r
return EFI_NOT_FOUND;\r
}\r
This driver doesn't support this API.\r
\r
@param This A pointer to the EFI_PLATFORM_DRIVER_OVERRIDE_\r
- PROTOCOL instance. \r
+ PROTOCOL instance.\r
@param ControllerHandle The device handle of the controller to check if a driver override\r
- exists. \r
+ exists.\r
@param DriverImagePath On input, a pointer to the previous driver device path returned by\r
GetDriverPath(). On output, a pointer to the next driver\r
device path. Passing in a pointer to NULL, will return the first\r
driver device path for ControllerHandle.\r
- \r
+\r
@retval EFI_UNSUPPORTED\r
**/\r
EFI_STATUS\r
\r
/**\r
Used to associate a driver image handle with a device path that was returned on a prior call to the\r
- GetDriverPath() service. This driver image handle will then be available through the \r
+ GetDriverPath() service. This driver image handle will then be available through the\r
GetDriver() service. This driver doesn't support this API.\r
\r
@param This A pointer to the EFI_PLATFORM_DRIVER_OVERRIDE_\r
- PROTOCOL instance. \r
- @param ControllerHandle The device handle of the controller. \r
+ PROTOCOL instance.\r
+ @param ControllerHandle The device handle of the controller.\r
@param DriverImagePath A pointer to the driver device path that was returned in a prior\r
- call to GetDriverPath(). \r
+ call to GetDriverPath().\r
@param DriverImageHandle The driver image handle that was returned by LoadImage()\r
- when the driver specified by DriverImagePath was loaded \r
- into memory. \r
- \r
+ when the driver specified by DriverImagePath was loaded\r
+ into memory.\r
+\r
@retval EFI_UNSUPPORTED\r
**/\r
EFI_STATUS\r
}\r
\r
/**\r
- The driver Entry Point. The funciton will export a disk device class formset and\r
+ The driver Entry Point. The function will export a disk device class formset and\r
its callback function to hii database.\r
\r
@param ImageHandle The firmware allocated handle for the EFI image.\r
EFI_STATUS Status;\r
EFI_FORM_BROWSER2_PROTOCOL *FormBrowser2;\r
VOID *Instance;\r
- \r
+\r
//\r
// There should only be one Form Configuration protocol\r
//\r
if (!EFI_ERROR (Status)) {\r
return EFI_ALREADY_STARTED;\r
}\r
- \r
+\r
mCallerImageHandle = ImageHandle;\r
mCallbackInfo = AllocateZeroPool (sizeof (EFI_CALLBACK_INFO));\r
if (mCallbackInfo == NULL) {\r
mCallbackInfo->PlatformDriverOverride.GetDriver = GetDriver;\r
mCallbackInfo->PlatformDriverOverride.GetDriverPath = GetDriverPath;\r
mCallbackInfo->PlatformDriverOverride.DriverLoaded = DriverLoaded;\r
+\r
+ //\r
+ // Locate ConfigRouting protocol\r
+ //\r
+ Status = gBS->LocateProtocol (\r
+ &gEfiHiiConfigRoutingProtocolGuid,\r
+ NULL,\r
+ (VOID **) &mCallbackInfo->HiiConfigRouting\r
+ );\r
+ if (EFI_ERROR (Status)) {\r
+ goto Finish;\r
+ }\r
+\r
//\r
// Install Device Path Protocol and Config Access protocol to driver handle\r
// Install Platform Driver Override Protocol to driver handle\r
goto Finish;\r
}\r
\r
- //\r
- // Locate ConfigRouting protocol\r
- //\r
- Status = gBS->LocateProtocol (\r
- &gEfiHiiConfigRoutingProtocolGuid,\r
- NULL,\r
- (VOID **) &mCallbackInfo->HiiConfigRouting\r
- );\r
- if (EFI_ERROR (Status)) {\r
- goto Finish;\r
- }\r
-\r
//\r
// Clear all the globle variable\r
//\r
mDriverImageHandleCount = 0;\r
mCurrentPage = 0;\r
- \r
+\r
return EFI_SUCCESS;\r
\r
Finish:\r