/** @file\r
Usb Credential Provider driver implemenetation.\r
\r
-Copyright (c) 2009 - 2010, Intel Corporation. All rights reserved.<BR>\r
+Copyright (c) 2009 - 2011, 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
USB_PROVIDER_CALLBACK_INFO *mCallbackInfo = NULL;\r
USB_CREDENTIAL_INFO *mUsbInfoHandle = NULL;\r
\r
-//\r
-// Used for save password credential and form browser\r
-// And used as provider identifier\r
-//\r
-EFI_GUID mUsbCredentialGuid = USB_CREDENTIAL_PROVIDER_GUID;\r
-\r
-HII_VENDOR_DEVICE_PATH mHiiVendorDevicePath = {\r
- {\r
- {\r
- HARDWARE_DEVICE_PATH,\r
- HW_VENDOR_DP,\r
- {\r
- (UINT8) (sizeof (VENDOR_DEVICE_PATH)),\r
- (UINT8) ((sizeof (VENDOR_DEVICE_PATH)) >> 8)\r
- }\r
- },\r
- { 0x9463f883, 0x48f6, 0x4a7a, { 0x97, 0x2d, 0x9f, 0x8f, 0x38, 0xf2, 0xdd, 0x91 } }\r
- },\r
- {\r
- END_DEVICE_PATH_TYPE,\r
- END_ENTIRE_DEVICE_PATH_SUBTYPE,\r
- {\r
- (UINT8) (END_DEVICE_PATH_LENGTH),\r
- (UINT8) ((END_DEVICE_PATH_LENGTH) >> 8)\r
- }\r
- }\r
-};\r
-\r
EFI_USER_CREDENTIAL_PROTOCOL gUsbCredentialProviderDriver = {\r
USB_CREDENTIAL_PROVIDER_GUID,\r
EFI_USER_CREDENTIAL_CLASS_SECURE_CARD,\r
//\r
Status = gRT->SetVariable (\r
L"UsbCredential",\r
- &mUsbCredentialGuid,\r
+ &gUsbCredentialProviderGuid,\r
EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_BOOTSERVICE_ACCESS,\r
mUsbTable->Count * sizeof (USB_INFO),\r
&mUsbTable->UserInfo\r
Var = NULL;\r
Status = gRT->GetVariable (\r
L"UsbCredential", \r
- &mUsbCredentialGuid, \r
+ &gUsbCredentialProviderGuid, \r
NULL, \r
&VarSize,\r
Var\r
}\r
Status = gRT->GetVariable (\r
L"UsbCredential", \r
- &mUsbCredentialGuid, \r
+ &gUsbCredentialProviderGuid, \r
NULL, \r
&VarSize,\r
Var\r
// Publish HII data.\r
//\r
CallbackInfo->HiiHandle = HiiAddPackages (\r
- &mUsbCredentialGuid,\r
+ &gUsbCredentialProviderGuid,\r
CallbackInfo->DriverHandle,\r
UsbCredentialProviderStrings,\r
NULL\r
} \r
}\r
}\r
- FreePool (UserInfo);\r
- \r
- //\r
- // The read token mismatch with the User's Token.\r
- // Only check token.\r
- //\r
- for (Index = 0; Index < mUsbTable->Count; Index++) {\r
- UserToken = mUsbTable->UserInfo[Index].Token;\r
- if (CompareMem (UserToken, ReadToken, HASHED_CREDENTIAL_LEN) == 0) {\r
- //\r
- // The read token matches with the one in UsbTable.\r
- //\r
- UserId = (UINT8 *) &mUsbTable->UserInfo[Index].UserId;\r
- CopyMem (Identifier, UserId, sizeof (EFI_USER_INFO_IDENTIFIER));\r
- return EFI_SUCCESS;\r
- } \r
- }\r
- \r
- return EFI_NOT_FOUND;\r
+\r
+ FreePool (UserInfo); \r
+ \r
+ return EFI_NOT_READY;\r
}\r
\r
\r
Info->InfoType = EFI_USER_INFO_CREDENTIAL_PROVIDER_RECORD;\r
Info->InfoSize = (UINT32) InfoLen;\r
Info->InfoAttribs = EFI_USER_INFO_PROTECTED;\r
- CopyGuid (&Info->Credential, &mUsbCredentialGuid);\r
- CopyGuid ((EFI_GUID *)(Info + 1), &mUsbCredentialGuid);\r
+ CopyGuid (&Info->Credential, &gUsbCredentialProviderGuid);\r
+ CopyGuid ((EFI_GUID *)(Info + 1), &gUsbCredentialProviderGuid);\r
\r
mUsbInfoHandle->Info[0] = Info;\r
mUsbInfoHandle->Count++;\r
Info->InfoType = EFI_USER_INFO_CREDENTIAL_PROVIDER_NAME_RECORD;\r
Info->InfoSize = (UINT32) InfoLen;\r
Info->InfoAttribs = EFI_USER_INFO_PROTECTED;\r
- CopyGuid (&Info->Credential, &mUsbCredentialGuid);\r
+ CopyGuid (&Info->Credential, &gUsbCredentialProviderGuid);\r
CopyMem ((UINT8*)(Info + 1), ProvNameStr, ProvStrLen);\r
FreePool (ProvNameStr);\r
\r
Info->InfoType = EFI_USER_INFO_CREDENTIAL_TYPE_RECORD;\r
Info->InfoSize = (UINT32) InfoLen;\r
Info->InfoAttribs = EFI_USER_INFO_PROTECTED;\r
- CopyGuid (&Info->Credential, &mUsbCredentialGuid);\r
+ CopyGuid (&Info->Credential, &gUsbCredentialProviderGuid);\r
CopyGuid ((EFI_GUID *)(Info + 1), &gEfiUserCredentialClassSecureCardGuid);\r
\r
mUsbInfoHandle->Info[2] = Info;\r
Info->InfoType = EFI_USER_INFO_CREDENTIAL_PROVIDER_NAME_RECORD;\r
Info->InfoSize = (UINT32) InfoLen;\r
Info->InfoAttribs = EFI_USER_INFO_PROTECTED;\r
- CopyGuid (&Info->Credential, &mUsbCredentialGuid);\r
+ CopyGuid (&Info->Credential, &gUsbCredentialProviderGuid);\r
CopyMem ((UINT8*)(Info + 1), ProvNameStr, ProvStrLen);\r
FreePool (ProvNameStr);\r
\r