+DxeUnRegisterCallBackWorker (\r
+ IN UINTN TokenNumber,\r
+ IN CONST GUID *Guid, OPTIONAL\r
+ IN PCD_PROTOCOL_CALLBACK CallBackFunction\r
+)\r
+{\r
+ CALLBACK_FN_ENTRY *FnTableEntry;\r
+ EX_PCD_ENTRY_ATTRIBUTE ExAttr;\r
+ LIST_ENTRY *ListHead;\r
+ LIST_ENTRY *ListNode;\r
+\r
+ if (Guid != NULL) {\r
+ GetExPcdTokenAttributes (Guid, TokenNumber, &ExAttr);\r
+ TokenNumber = ExAttr.LocalTokenNumberAlias;\r
+ }\r
+\r
+ ListHead = &mCallbackFnTable[TokenNumber];\r
+ ListNode = GetFirstNode (ListHead);\r
+\r
+ while (ListNode != ListHead) {\r
+ FnTableEntry = CR_FNENTRY_FROM_LISTNODE(ListNode, CALLBACK_FN_ENTRY, Node);\r
+\r
+ if (FnTableEntry->CallbackFn == CallBackFunction) {\r
+ //\r
+ // We only allow a Callback function to be register once\r
+ // for a TokenNumber. So we can safely remove the Node from\r
+ // the Link List and return EFI_SUCCESS.\r
+ //\r
+ RemoveEntryList (ListNode);\r
+ FreePool (FnTableEntry);\r
+ \r
+ return EFI_SUCCESS;\r
+ }\r
+ ListNode = GetNextNode (ListHead, ListNode);\r
+ }\r
+\r
+ return EFI_INVALID_PARAMETER;\r
+}\r
+\r
+\r
+\r
+PCD_TOKEN_NUMBER\r
+ExGetNextTokeNumber (\r
+ IN CONST EFI_GUID *Guid,\r
+ IN PCD_TOKEN_NUMBER TokenNumber,\r
+ IN EFI_GUID *GuidTable,\r
+ IN UINTN SizeOfGuidTable,\r
+ IN DYNAMICEX_MAPPING *ExMapTable,\r
+ IN UINTN SizeOfExMapTable\r