mirror of
				https://git.proxmox.com/git/mirror_edk2
				synced 2025-10-26 01:26:21 +00:00 
			
		
		
		
	 6e2d15e3c4
			
		
	
	
		6e2d15e3c4
		
	
	
	
	
		
			
			Replace invocations of StrHexToUintn() with StrHexToUint64(), so that we can drop the former. Contributed-under: TianoCore Contribution Agreement 1.1 Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org> Reviewed-by: Jaben Carsey <jaben.carsey@intel.com> Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com> Reviewed-by: Laszlo Ersek <lersek@redhat.com> Reviewed-by: Liming Gao <liming.gao@intel.com>
		
			
				
	
	
		
			3527 lines
		
	
	
		
			107 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			3527 lines
		
	
	
		
			107 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /** @file
 | |
|   DevicePathFromText protocol as defined in the UEFI 2.0 specification.
 | |
| 
 | |
| Copyright (c) 2017 - 2018, Intel Corporation. All rights reserved.<BR>
 | |
| This program and the accompanying materials
 | |
| are licensed and made available under the terms and conditions of the BSD License
 | |
| which accompanies this distribution.  The full text of the license may be found at
 | |
| http://opensource.org/licenses/bsd-license.php
 | |
| 
 | |
| THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
 | |
| WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
 | |
| 
 | |
| **/
 | |
| 
 | |
| #include "UefiDevicePathLib.h"
 | |
| 
 | |
| /**
 | |
| 
 | |
|   Duplicates a string.
 | |
| 
 | |
|   @param  Src  Source string.
 | |
| 
 | |
|   @return The duplicated string.
 | |
| 
 | |
| **/
 | |
| CHAR16 *
 | |
| UefiDevicePathLibStrDuplicate (
 | |
|    CONST CHAR16  *Src
 | |
|   )
 | |
| {
 | |
|   return AllocateCopyPool (StrSize (Src), Src);
 | |
| }
 | |
| 
 | |
| /**
 | |
| 
 | |
|   Get parameter in a pair of parentheses follow the given node name.
 | |
|   For example, given the "Pci(0,1)" and NodeName "Pci", it returns "0,1".
 | |
| 
 | |
|   @param  Str      Device Path Text.
 | |
|   @param  NodeName Name of the node.
 | |
| 
 | |
|   @return Parameter text for the node.
 | |
| 
 | |
| **/
 | |
| CHAR16 *
 | |
| GetParamByNodeName (
 | |
|    CHAR16 *Str,
 | |
|    CHAR16 *NodeName
 | |
|   )
 | |
| {
 | |
|   CHAR16  *ParamStr;
 | |
|   CHAR16  *StrPointer;
 | |
|   UINTN   NodeNameLength;
 | |
|   UINTN   ParameterLength;
 | |
| 
 | |
|   //
 | |
|   // Check whether the node name matchs
 | |
|   //
 | |
|   NodeNameLength = StrLen (NodeName);
 | |
|   if (StrnCmp (Str, NodeName, NodeNameLength) != 0) {
 | |
|     return NULL;
 | |
|   }
 | |
| 
 | |
|   ParamStr = Str + NodeNameLength;
 | |
|   if (!IS_LEFT_PARENTH (*ParamStr)) {
 | |
|     return NULL;
 | |
|   }
 | |
| 
 | |
|   //
 | |
|   // Skip the found '(' and find first occurrence of ')'
 | |
|   //
 | |
|   ParamStr++;
 | |
|   ParameterLength = 0;
 | |
|   StrPointer = ParamStr;
 | |
|   while (!IS_NULL (*StrPointer)) {
 | |
|     if (IS_RIGHT_PARENTH (*StrPointer)) {
 | |
|       break;
 | |
|     }
 | |
|     StrPointer++;
 | |
|     ParameterLength++;
 | |
|   }
 | |
|   if (IS_NULL (*StrPointer)) {
 | |
|     //
 | |
|     // ')' not found
 | |
|     //
 | |
|     return NULL;
 | |
|   }
 | |
| 
 | |
|   ParamStr = AllocateCopyPool ((ParameterLength + 1) * sizeof (CHAR16), ParamStr);
 | |
|   if (ParamStr == NULL) {
 | |
|     return NULL;
 | |
|   }
 | |
|   //
 | |
|   // Terminate the parameter string
 | |
|   //
 | |
|   ParamStr[ParameterLength] = L'\0';
 | |
| 
 | |
|   return ParamStr;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Gets the next parameter string from the list.
 | |
| 
 | |
|   @param List            A string list separated by the specified separator
 | |
| 
 | |
|   @return A pointer to the current sub-string
 | |
| 
 | |
| **/
 | |
| CHAR16 *
 | |
| GetNextParamStr (
 | |
|     CHAR16 **List
 | |
|   )
 | |
| {
 | |
|   //
 | |
|   // The separator is comma
 | |
|   //
 | |
|   return SplitStr (List, L',');
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Get one device node from entire device path text.
 | |
| 
 | |
|   @param DevicePath      On input, the current Device Path node; on output, the next device path node
 | |
|   @param IsInstanceEnd   This node is the end of a device path instance
 | |
| 
 | |
|   @return A device node text or NULL if no more device node available
 | |
| 
 | |
| **/
 | |
| CHAR16 *
 | |
| GetNextDeviceNodeStr (
 | |
|     CHAR16   **DevicePath,
 | |
|       BOOLEAN  *IsInstanceEnd
 | |
|   )
 | |
| {
 | |
|   CHAR16  *Str;
 | |
|   CHAR16  *ReturnStr;
 | |
|   UINTN   ParenthesesStack;
 | |
| 
 | |
|   Str = *DevicePath;
 | |
|   if (IS_NULL (*Str)) {
 | |
|     return NULL;
 | |
|   }
 | |
| 
 | |
|   //
 | |
|   // Skip the leading '/', '(', ')' and ','
 | |
|   //
 | |
|   while (!IS_NULL (*Str)) {
 | |
|     if (!IS_SLASH (*Str) &&
 | |
|         !IS_COMMA (*Str) &&
 | |
|         !IS_LEFT_PARENTH (*Str) &&
 | |
|         !IS_RIGHT_PARENTH (*Str)) {
 | |
|       break;
 | |
|     }
 | |
|     Str++;
 | |
|   }
 | |
| 
 | |
|   ReturnStr = Str;
 | |
| 
 | |
|   //
 | |
|   // Scan for the separator of this device node, '/' or ','
 | |
|   //
 | |
|   ParenthesesStack = 0;
 | |
|   while (!IS_NULL (*Str)) {
 | |
|     if ((IS_COMMA (*Str) || IS_SLASH (*Str)) && (ParenthesesStack == 0)) {
 | |
|       break;
 | |
|     }
 | |
| 
 | |
|     if (IS_LEFT_PARENTH (*Str)) {
 | |
|       ParenthesesStack++;
 | |
|     } else if (IS_RIGHT_PARENTH (*Str)) {
 | |
|       ParenthesesStack--;
 | |
|     }
 | |
| 
 | |
|     Str++;
 | |
|   }
 | |
| 
 | |
|   if (ParenthesesStack != 0) {
 | |
|     //
 | |
|     // The '(' doesn't pair with ')', invalid device path text
 | |
|     //
 | |
|     return NULL;
 | |
|   }
 | |
| 
 | |
|   if (IS_COMMA (*Str)) {
 | |
|     *IsInstanceEnd = TRUE;
 | |
|     *Str = L'\0';
 | |
|     Str++;
 | |
|   } else {
 | |
|     *IsInstanceEnd = FALSE;
 | |
|     if (!IS_NULL (*Str)) {
 | |
|       *Str = L'\0';
 | |
|       Str++;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   *DevicePath = Str;
 | |
| 
 | |
|   return ReturnStr;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a generic text device path node to device path structure.
 | |
| 
 | |
|   @param Type            The type of the device path node.
 | |
|   @param TextDeviceNode  The input text device path node.
 | |
| 
 | |
|   @return A pointer to device path structure.
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextGenericPath (
 | |
|    UINT8  Type,
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   EFI_DEVICE_PATH_PROTOCOL *Node;
 | |
|   CHAR16                   *SubtypeStr;
 | |
|   CHAR16                   *DataStr;
 | |
|   UINTN                    DataLength;
 | |
| 
 | |
|   SubtypeStr = GetNextParamStr (&TextDeviceNode);
 | |
|   DataStr    = GetNextParamStr (&TextDeviceNode);
 | |
| 
 | |
|   if (DataStr == NULL) {
 | |
|     DataLength = 0;
 | |
|   } else {
 | |
|     DataLength = StrLen (DataStr) / 2;
 | |
|   }
 | |
|   Node = CreateDeviceNode (
 | |
|            Type,
 | |
|            (UINT8) Strtoi (SubtypeStr),
 | |
|            (UINT16) (sizeof (EFI_DEVICE_PATH_PROTOCOL) + DataLength)
 | |
|            );
 | |
| 
 | |
|   StrHexToBytes (DataStr, DataLength * 2, (UINT8 *) (Node + 1), DataLength);
 | |
|   return Node;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a generic text device path node to device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextPath (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16                   *TypeStr;
 | |
| 
 | |
|   TypeStr    = GetNextParamStr (&TextDeviceNode);
 | |
| 
 | |
|   return DevPathFromTextGenericPath ((UINT8) Strtoi (TypeStr), TextDeviceNode);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a generic hardware text device path node to Hardware device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to Hardware device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextHardwarePath (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   return DevPathFromTextGenericPath (HARDWARE_DEVICE_PATH, TextDeviceNode);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to Hardware PCI device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to Hardware PCI device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextPci (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16          *FunctionStr;
 | |
|   CHAR16          *DeviceStr;
 | |
|   PCI_DEVICE_PATH *Pci;
 | |
| 
 | |
|   DeviceStr   = GetNextParamStr (&TextDeviceNode);
 | |
|   FunctionStr = GetNextParamStr (&TextDeviceNode);
 | |
|   Pci         = (PCI_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                       HARDWARE_DEVICE_PATH,
 | |
|                                       HW_PCI_DP,
 | |
|                                       (UINT16) sizeof (PCI_DEVICE_PATH)
 | |
|                                       );
 | |
| 
 | |
|   Pci->Function = (UINT8) Strtoi (FunctionStr);
 | |
|   Pci->Device   = (UINT8) Strtoi (DeviceStr);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) Pci;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to Hardware PC card device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to Hardware PC card device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextPcCard (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16              *FunctionNumberStr;
 | |
|   PCCARD_DEVICE_PATH  *Pccard;
 | |
| 
 | |
|   FunctionNumberStr = GetNextParamStr (&TextDeviceNode);
 | |
|   Pccard            = (PCCARD_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                                HARDWARE_DEVICE_PATH,
 | |
|                                                HW_PCCARD_DP,
 | |
|                                                (UINT16) sizeof (PCCARD_DEVICE_PATH)
 | |
|                                                );
 | |
| 
 | |
|   Pccard->FunctionNumber  = (UINT8) Strtoi (FunctionNumberStr);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) Pccard;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to Hardware memory map device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to Hardware memory map device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextMemoryMapped (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16              *MemoryTypeStr;
 | |
|   CHAR16              *StartingAddressStr;
 | |
|   CHAR16              *EndingAddressStr;
 | |
|   MEMMAP_DEVICE_PATH  *MemMap;
 | |
| 
 | |
|   MemoryTypeStr      = GetNextParamStr (&TextDeviceNode);
 | |
|   StartingAddressStr = GetNextParamStr (&TextDeviceNode);
 | |
|   EndingAddressStr   = GetNextParamStr (&TextDeviceNode);
 | |
|   MemMap             = (MEMMAP_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                                HARDWARE_DEVICE_PATH,
 | |
|                                                HW_MEMMAP_DP,
 | |
|                                                (UINT16) sizeof (MEMMAP_DEVICE_PATH)
 | |
|                                                );
 | |
| 
 | |
|   MemMap->MemoryType = (UINT32) Strtoi (MemoryTypeStr);
 | |
|   Strtoi64 (StartingAddressStr, &MemMap->StartingAddress);
 | |
|   Strtoi64 (EndingAddressStr, &MemMap->EndingAddress);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) MemMap;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to Vendor device path structure based on the input Type
 | |
|   and SubType.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
|   @param Type            The type of device path node.
 | |
|   @param SubType         The subtype of device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created Vendor device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| ConvertFromTextVendor (
 | |
|    CHAR16 *TextDeviceNode,
 | |
|    UINT8  Type,
 | |
|    UINT8  SubType
 | |
|   )
 | |
| {
 | |
|   CHAR16              *GuidStr;
 | |
|   CHAR16              *DataStr;
 | |
|   UINTN               Length;
 | |
|   VENDOR_DEVICE_PATH  *Vendor;
 | |
| 
 | |
|   GuidStr = GetNextParamStr (&TextDeviceNode);
 | |
| 
 | |
|   DataStr = GetNextParamStr (&TextDeviceNode);
 | |
|   Length  = StrLen (DataStr);
 | |
|   //
 | |
|   // Two hex characters make up 1 buffer byte
 | |
|   //
 | |
|   Length  = (Length + 1) / 2;
 | |
| 
 | |
|   Vendor  = (VENDOR_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                      Type,
 | |
|                                      SubType,
 | |
|                                      (UINT16) (sizeof (VENDOR_DEVICE_PATH) + Length)
 | |
|                                      );
 | |
| 
 | |
|   StrToGuid (GuidStr, &Vendor->Guid);
 | |
|   StrHexToBytes (DataStr, Length * 2, (UINT8 *) (Vendor + 1), Length);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) Vendor;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to Vendor Hardware device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created Vendor Hardware device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextVenHw (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   return ConvertFromTextVendor (
 | |
|            TextDeviceNode,
 | |
|            HARDWARE_DEVICE_PATH,
 | |
|            HW_VENDOR_DP
 | |
|            );
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to Hardware Controller device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created Hardware Controller device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextCtrl (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16                  *ControllerStr;
 | |
|   CONTROLLER_DEVICE_PATH  *Controller;
 | |
| 
 | |
|   ControllerStr = GetNextParamStr (&TextDeviceNode);
 | |
|   Controller    = (CONTROLLER_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                                HARDWARE_DEVICE_PATH,
 | |
|                                                HW_CONTROLLER_DP,
 | |
|                                                (UINT16) sizeof (CONTROLLER_DEVICE_PATH)
 | |
|                                                );
 | |
|   Controller->ControllerNumber = (UINT32) Strtoi (ControllerStr);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) Controller;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to BMC device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created BMC device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextBmc (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16                *InterfaceTypeStr;
 | |
|   CHAR16                *BaseAddressStr;
 | |
|   BMC_DEVICE_PATH       *BmcDp;
 | |
| 
 | |
|   InterfaceTypeStr = GetNextParamStr (&TextDeviceNode);
 | |
|   BaseAddressStr   = GetNextParamStr (&TextDeviceNode);
 | |
|   BmcDp            = (BMC_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                            HARDWARE_DEVICE_PATH,
 | |
|                                            HW_BMC_DP,
 | |
|                                            (UINT16) sizeof (BMC_DEVICE_PATH)
 | |
|                                            );
 | |
| 
 | |
|   BmcDp->InterfaceType = (UINT8) Strtoi (InterfaceTypeStr);
 | |
|   WriteUnaligned64 (
 | |
|     (UINT64 *) (&BmcDp->BaseAddress),
 | |
|     StrHexToUint64 (BaseAddressStr)
 | |
|     );
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) BmcDp;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a generic ACPI text device path node to ACPI device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to ACPI device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextAcpiPath (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   return DevPathFromTextGenericPath (ACPI_DEVICE_PATH, TextDeviceNode);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a string to EisaId.
 | |
| 
 | |
|   @param Text   The input string.
 | |
| 
 | |
|   @return UINT32 EISA ID.
 | |
| **/
 | |
| UINT32
 | |
| EisaIdFromText (
 | |
|    CHAR16 *Text
 | |
|   )
 | |
| {
 | |
|   return (((Text[0] - 'A' + 1) & 0x1f) << 10)
 | |
|        + (((Text[1] - 'A' + 1) & 0x1f) <<  5)
 | |
|        + (((Text[2] - 'A' + 1) & 0x1f) <<  0)
 | |
|        + (UINT32) (StrHexToUint64 (&Text[3]) << 16)
 | |
|        ;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to ACPI HID device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created ACPI HID device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextAcpi (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16                *HIDStr;
 | |
|   CHAR16                *UIDStr;
 | |
|   ACPI_HID_DEVICE_PATH  *Acpi;
 | |
| 
 | |
|   HIDStr = GetNextParamStr (&TextDeviceNode);
 | |
|   UIDStr = GetNextParamStr (&TextDeviceNode);
 | |
|   Acpi   = (ACPI_HID_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                       ACPI_DEVICE_PATH,
 | |
|                                       ACPI_DP,
 | |
|                                       (UINT16) sizeof (ACPI_HID_DEVICE_PATH)
 | |
|                                       );
 | |
| 
 | |
|   Acpi->HID = EisaIdFromText (HIDStr);
 | |
|   Acpi->UID = (UINT32) Strtoi (UIDStr);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) Acpi;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to ACPI HID device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
|   @param PnPId           The input plug and play identification.
 | |
| 
 | |
|   @return A pointer to the newly-created ACPI HID device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| ConvertFromTextAcpi (
 | |
|    CHAR16 *TextDeviceNode,
 | |
|    UINT32  PnPId
 | |
|   )
 | |
| {
 | |
|   CHAR16                *UIDStr;
 | |
|   ACPI_HID_DEVICE_PATH  *Acpi;
 | |
| 
 | |
|   UIDStr = GetNextParamStr (&TextDeviceNode);
 | |
|   Acpi   = (ACPI_HID_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                       ACPI_DEVICE_PATH,
 | |
|                                       ACPI_DP,
 | |
|                                       (UINT16) sizeof (ACPI_HID_DEVICE_PATH)
 | |
|                                       );
 | |
| 
 | |
|   Acpi->HID = EFI_PNP_ID (PnPId);
 | |
|   Acpi->UID = (UINT32) Strtoi (UIDStr);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) Acpi;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to PCI root device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created PCI root device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextPciRoot (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   return ConvertFromTextAcpi (TextDeviceNode, 0x0a03);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to PCIE root device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created PCIE root device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextPcieRoot (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   return ConvertFromTextAcpi (TextDeviceNode, 0x0a08);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to Floppy device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created Floppy device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextFloppy (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   return ConvertFromTextAcpi (TextDeviceNode, 0x0604);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to Keyboard device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created  Keyboard device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextKeyboard (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   return ConvertFromTextAcpi (TextDeviceNode, 0x0301);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to Serial device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created Serial device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextSerial (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   return ConvertFromTextAcpi (TextDeviceNode, 0x0501);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to Parallel Port device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created Parallel Port device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextParallelPort (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   return ConvertFromTextAcpi (TextDeviceNode, 0x0401);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to ACPI extension device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created ACPI extension device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextAcpiEx (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16                         *HIDStr;
 | |
|   CHAR16                         *CIDStr;
 | |
|   CHAR16                         *UIDStr;
 | |
|   CHAR16                         *HIDSTRStr;
 | |
|   CHAR16                         *CIDSTRStr;
 | |
|   CHAR16                         *UIDSTRStr;
 | |
|   CHAR8                          *AsciiStr;
 | |
|   UINT16                         Length;
 | |
|   ACPI_EXTENDED_HID_DEVICE_PATH  *AcpiEx;
 | |
| 
 | |
|   HIDStr    = GetNextParamStr (&TextDeviceNode);
 | |
|   CIDStr    = GetNextParamStr (&TextDeviceNode);
 | |
|   UIDStr    = GetNextParamStr (&TextDeviceNode);
 | |
|   HIDSTRStr = GetNextParamStr (&TextDeviceNode);
 | |
|   CIDSTRStr = GetNextParamStr (&TextDeviceNode);
 | |
|   UIDSTRStr = GetNextParamStr (&TextDeviceNode);
 | |
| 
 | |
|   Length    = (UINT16) (sizeof (ACPI_EXTENDED_HID_DEVICE_PATH) + StrLen (HIDSTRStr) + 1);
 | |
|   Length    = (UINT16) (Length + StrLen (UIDSTRStr) + 1);
 | |
|   Length    = (UINT16) (Length + StrLen (CIDSTRStr) + 1);
 | |
|   AcpiEx = (ACPI_EXTENDED_HID_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                                ACPI_DEVICE_PATH,
 | |
|                                                ACPI_EXTENDED_DP,
 | |
|                                                Length
 | |
|                                                );
 | |
| 
 | |
|   AcpiEx->HID = EisaIdFromText (HIDStr);
 | |
|   AcpiEx->CID = EisaIdFromText (CIDStr);
 | |
|   AcpiEx->UID = (UINT32) Strtoi (UIDStr);
 | |
| 
 | |
|   AsciiStr = (CHAR8 *) ((UINT8 *)AcpiEx + sizeof (ACPI_EXTENDED_HID_DEVICE_PATH));
 | |
|   StrToAscii (HIDSTRStr, &AsciiStr);
 | |
|   StrToAscii (UIDSTRStr, &AsciiStr);
 | |
|   StrToAscii (CIDSTRStr, &AsciiStr);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) AcpiEx;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to ACPI extension device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created ACPI extension device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextAcpiExp (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16                         *HIDStr;
 | |
|   CHAR16                         *CIDStr;
 | |
|   CHAR16                         *UIDSTRStr;
 | |
|   CHAR8                          *AsciiStr;
 | |
|   UINT16                         Length;
 | |
|   ACPI_EXTENDED_HID_DEVICE_PATH  *AcpiEx;
 | |
| 
 | |
|   HIDStr    = GetNextParamStr (&TextDeviceNode);
 | |
|   CIDStr    = GetNextParamStr (&TextDeviceNode);
 | |
|   UIDSTRStr = GetNextParamStr (&TextDeviceNode);
 | |
|   Length    = (UINT16) (sizeof (ACPI_EXTENDED_HID_DEVICE_PATH) + StrLen (UIDSTRStr) + 3);
 | |
|   AcpiEx    = (ACPI_EXTENDED_HID_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                                   ACPI_DEVICE_PATH,
 | |
|                                                   ACPI_EXTENDED_DP,
 | |
|                                                   Length
 | |
|                                                   );
 | |
| 
 | |
|   AcpiEx->HID = EisaIdFromText (HIDStr);
 | |
|   //
 | |
|   // According to UEFI spec, the CID parametr is optional and has a default value of 0.
 | |
|   // So when the CID parametr is not specified or specified as 0 in the text device node.
 | |
|   // Set the CID to 0 in the ACPI extension device path structure.
 | |
|   //
 | |
|   if (*CIDStr == L'\0' || *CIDStr == L'0') {
 | |
|     AcpiEx->CID = 0;
 | |
|   } else {
 | |
|     AcpiEx->CID = EisaIdFromText (CIDStr);
 | |
|   }
 | |
|   AcpiEx->UID = 0;
 | |
| 
 | |
|   AsciiStr = (CHAR8 *) ((UINT8 *)AcpiEx + sizeof (ACPI_EXTENDED_HID_DEVICE_PATH));
 | |
|   //
 | |
|   // HID string is NULL
 | |
|   //
 | |
|   *AsciiStr = '\0';
 | |
|   //
 | |
|   // Convert UID string
 | |
|   //
 | |
|   AsciiStr++;
 | |
|   StrToAscii (UIDSTRStr, &AsciiStr);
 | |
|   //
 | |
|   // CID string is NULL
 | |
|   //
 | |
|   *AsciiStr = '\0';
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) AcpiEx;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to ACPI _ADR device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created ACPI _ADR device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextAcpiAdr (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16                *DisplayDeviceStr;
 | |
|   ACPI_ADR_DEVICE_PATH  *AcpiAdr;
 | |
|   UINTN                 Index;
 | |
|   UINTN                 Length;
 | |
| 
 | |
|   AcpiAdr = (ACPI_ADR_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                        ACPI_DEVICE_PATH,
 | |
|                                        ACPI_ADR_DP,
 | |
|                                        (UINT16) sizeof (ACPI_ADR_DEVICE_PATH)
 | |
|                                        );
 | |
|   ASSERT (AcpiAdr != NULL);
 | |
| 
 | |
|   for (Index = 0; ; Index++) {
 | |
|     DisplayDeviceStr = GetNextParamStr (&TextDeviceNode);
 | |
|     if (IS_NULL (*DisplayDeviceStr)) {
 | |
|       break;
 | |
|     }
 | |
|     if (Index > 0) {
 | |
|       Length  = DevicePathNodeLength (AcpiAdr);
 | |
|       AcpiAdr = ReallocatePool (
 | |
|                   Length,
 | |
|                   Length + sizeof (UINT32),
 | |
|                   AcpiAdr
 | |
|                   );
 | |
|       ASSERT (AcpiAdr != NULL);
 | |
|       SetDevicePathNodeLength (AcpiAdr, Length + sizeof (UINT32));
 | |
|     }
 | |
| 
 | |
|     (&AcpiAdr->ADR)[Index] = (UINT32) Strtoi (DisplayDeviceStr);
 | |
|   }
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) AcpiAdr;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a generic messaging text device path node to messaging device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to messaging device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextMsg (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   return DevPathFromTextGenericPath (MESSAGING_DEVICE_PATH, TextDeviceNode);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to Parallel Port device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created Parallel Port device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextAta (
 | |
|  CHAR16 *TextDeviceNode
 | |
| )
 | |
| {
 | |
|   CHAR16            *PrimarySecondaryStr;
 | |
|   CHAR16            *SlaveMasterStr;
 | |
|   CHAR16            *LunStr;
 | |
|   ATAPI_DEVICE_PATH *Atapi;
 | |
| 
 | |
|   Atapi = (ATAPI_DEVICE_PATH *) CreateDeviceNode (
 | |
|     MESSAGING_DEVICE_PATH,
 | |
|     MSG_ATAPI_DP,
 | |
|     (UINT16) sizeof (ATAPI_DEVICE_PATH)
 | |
|     );
 | |
| 
 | |
|   PrimarySecondaryStr = GetNextParamStr (&TextDeviceNode);
 | |
|   SlaveMasterStr      = GetNextParamStr (&TextDeviceNode);
 | |
|   LunStr              = GetNextParamStr (&TextDeviceNode);
 | |
| 
 | |
|   if (StrCmp (PrimarySecondaryStr, L"Primary") == 0) {
 | |
|     Atapi->PrimarySecondary = 0;
 | |
|   } else if (StrCmp (PrimarySecondaryStr, L"Secondary") == 0) {
 | |
|     Atapi->PrimarySecondary = 1;
 | |
|   } else {
 | |
|     Atapi->PrimarySecondary = (UINT8) Strtoi (PrimarySecondaryStr);
 | |
|   }
 | |
|   if (StrCmp (SlaveMasterStr, L"Master") == 0) {
 | |
|     Atapi->SlaveMaster      = 0;
 | |
|   } else if (StrCmp (SlaveMasterStr, L"Slave") == 0) {
 | |
|     Atapi->SlaveMaster      = 1;
 | |
|   } else {
 | |
|     Atapi->SlaveMaster      = (UINT8) Strtoi (SlaveMasterStr);
 | |
|   }
 | |
| 
 | |
|   Atapi->Lun                = (UINT16) Strtoi (LunStr);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) Atapi;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to SCSI device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created SCSI device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextScsi (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16            *PunStr;
 | |
|   CHAR16            *LunStr;
 | |
|   SCSI_DEVICE_PATH  *Scsi;
 | |
| 
 | |
|   PunStr = GetNextParamStr (&TextDeviceNode);
 | |
|   LunStr = GetNextParamStr (&TextDeviceNode);
 | |
|   Scsi   = (SCSI_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                    MESSAGING_DEVICE_PATH,
 | |
|                                    MSG_SCSI_DP,
 | |
|                                    (UINT16) sizeof (SCSI_DEVICE_PATH)
 | |
|                                    );
 | |
| 
 | |
|   Scsi->Pun = (UINT16) Strtoi (PunStr);
 | |
|   Scsi->Lun = (UINT16) Strtoi (LunStr);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) Scsi;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to Fibre device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created Fibre device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextFibre (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16                    *WWNStr;
 | |
|   CHAR16                    *LunStr;
 | |
|   FIBRECHANNEL_DEVICE_PATH  *Fibre;
 | |
| 
 | |
|   WWNStr = GetNextParamStr (&TextDeviceNode);
 | |
|   LunStr = GetNextParamStr (&TextDeviceNode);
 | |
|   Fibre  = (FIBRECHANNEL_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                           MESSAGING_DEVICE_PATH,
 | |
|                                           MSG_FIBRECHANNEL_DP,
 | |
|                                           (UINT16) sizeof (FIBRECHANNEL_DEVICE_PATH)
 | |
|                                           );
 | |
| 
 | |
|   Fibre->Reserved = 0;
 | |
|   Strtoi64 (WWNStr, &Fibre->WWN);
 | |
|   Strtoi64 (LunStr, &Fibre->Lun);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) Fibre;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to FibreEx device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created FibreEx device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextFibreEx (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16                      *WWNStr;
 | |
|   CHAR16                      *LunStr;
 | |
|   FIBRECHANNELEX_DEVICE_PATH  *FibreEx;
 | |
| 
 | |
|   WWNStr  = GetNextParamStr (&TextDeviceNode);
 | |
|   LunStr  = GetNextParamStr (&TextDeviceNode);
 | |
|   FibreEx = (FIBRECHANNELEX_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                              MESSAGING_DEVICE_PATH,
 | |
|                                              MSG_FIBRECHANNELEX_DP,
 | |
|                                              (UINT16) sizeof (FIBRECHANNELEX_DEVICE_PATH)
 | |
|                                              );
 | |
| 
 | |
|   FibreEx->Reserved = 0;
 | |
|   Strtoi64 (WWNStr, (UINT64 *) (&FibreEx->WWN));
 | |
|   Strtoi64 (LunStr, (UINT64 *) (&FibreEx->Lun));
 | |
| 
 | |
|   *(UINT64 *) (&FibreEx->WWN) = SwapBytes64 (*(UINT64 *) (&FibreEx->WWN));
 | |
|   *(UINT64 *) (&FibreEx->Lun) = SwapBytes64 (*(UINT64 *) (&FibreEx->Lun));
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) FibreEx;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to 1394 device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created 1394 device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromText1394 (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16            *GuidStr;
 | |
|   F1394_DEVICE_PATH *F1394DevPath;
 | |
| 
 | |
|   GuidStr = GetNextParamStr (&TextDeviceNode);
 | |
|   F1394DevPath  = (F1394_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                           MESSAGING_DEVICE_PATH,
 | |
|                                           MSG_1394_DP,
 | |
|                                           (UINT16) sizeof (F1394_DEVICE_PATH)
 | |
|                                           );
 | |
| 
 | |
|   F1394DevPath->Reserved = 0;
 | |
|   F1394DevPath->Guid     = StrHexToUint64 (GuidStr);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) F1394DevPath;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to USB device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created USB device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextUsb (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16          *PortStr;
 | |
|   CHAR16          *InterfaceStr;
 | |
|   USB_DEVICE_PATH *Usb;
 | |
| 
 | |
|   PortStr               = GetNextParamStr (&TextDeviceNode);
 | |
|   InterfaceStr          = GetNextParamStr (&TextDeviceNode);
 | |
|   Usb                   = (USB_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                                 MESSAGING_DEVICE_PATH,
 | |
|                                                 MSG_USB_DP,
 | |
|                                                 (UINT16) sizeof (USB_DEVICE_PATH)
 | |
|                                                 );
 | |
| 
 | |
|   Usb->ParentPortNumber = (UINT8) Strtoi (PortStr);
 | |
|   Usb->InterfaceNumber  = (UINT8) Strtoi (InterfaceStr);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) Usb;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to I20 device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created I20 device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextI2O (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16          *TIDStr;
 | |
|   I2O_DEVICE_PATH *I2ODevPath;
 | |
| 
 | |
|   TIDStr     = GetNextParamStr (&TextDeviceNode);
 | |
|   I2ODevPath = (I2O_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                     MESSAGING_DEVICE_PATH,
 | |
|                                     MSG_I2O_DP,
 | |
|                                     (UINT16) sizeof (I2O_DEVICE_PATH)
 | |
|                                     );
 | |
| 
 | |
|   I2ODevPath->Tid  = (UINT32) Strtoi (TIDStr);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) I2ODevPath;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to Infini Band device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created Infini Band device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextInfiniband (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16                  *FlagsStr;
 | |
|   CHAR16                  *GuidStr;
 | |
|   CHAR16                  *SidStr;
 | |
|   CHAR16                  *TidStr;
 | |
|   CHAR16                  *DidStr;
 | |
|   INFINIBAND_DEVICE_PATH  *InfiniBand;
 | |
| 
 | |
|   FlagsStr   = GetNextParamStr (&TextDeviceNode);
 | |
|   GuidStr    = GetNextParamStr (&TextDeviceNode);
 | |
|   SidStr     = GetNextParamStr (&TextDeviceNode);
 | |
|   TidStr     = GetNextParamStr (&TextDeviceNode);
 | |
|   DidStr     = GetNextParamStr (&TextDeviceNode);
 | |
|   InfiniBand = (INFINIBAND_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                             MESSAGING_DEVICE_PATH,
 | |
|                                             MSG_INFINIBAND_DP,
 | |
|                                             (UINT16) sizeof (INFINIBAND_DEVICE_PATH)
 | |
|                                             );
 | |
| 
 | |
|   InfiniBand->ResourceFlags = (UINT32) Strtoi (FlagsStr);
 | |
|   StrToGuid (GuidStr, (EFI_GUID *) InfiniBand->PortGid);
 | |
|   Strtoi64 (SidStr, &InfiniBand->ServiceId);
 | |
|   Strtoi64 (TidStr, &InfiniBand->TargetPortId);
 | |
|   Strtoi64 (DidStr, &InfiniBand->DeviceId);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) InfiniBand;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to Vendor-Defined Messaging device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created Vendor-Defined Messaging device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextVenMsg (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   return ConvertFromTextVendor (
 | |
|             TextDeviceNode,
 | |
|             MESSAGING_DEVICE_PATH,
 | |
|             MSG_VENDOR_DP
 | |
|             );
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to Vendor defined PC-ANSI device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created Vendor defined PC-ANSI device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextVenPcAnsi (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   VENDOR_DEVICE_PATH  *Vendor;
 | |
| 
 | |
|   Vendor = (VENDOR_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                     MESSAGING_DEVICE_PATH,
 | |
|                                     MSG_VENDOR_DP,
 | |
|                                     (UINT16) sizeof (VENDOR_DEVICE_PATH));
 | |
|   CopyGuid (&Vendor->Guid, &gEfiPcAnsiGuid);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) Vendor;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to Vendor defined VT100 device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created Vendor defined VT100 device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextVenVt100 (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   VENDOR_DEVICE_PATH  *Vendor;
 | |
| 
 | |
|   Vendor = (VENDOR_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                     MESSAGING_DEVICE_PATH,
 | |
|                                     MSG_VENDOR_DP,
 | |
|                                     (UINT16) sizeof (VENDOR_DEVICE_PATH));
 | |
|   CopyGuid (&Vendor->Guid, &gEfiVT100Guid);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) Vendor;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to Vendor defined VT100 Plus device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created Vendor defined VT100 Plus device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextVenVt100Plus (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   VENDOR_DEVICE_PATH  *Vendor;
 | |
| 
 | |
|   Vendor = (VENDOR_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                     MESSAGING_DEVICE_PATH,
 | |
|                                     MSG_VENDOR_DP,
 | |
|                                     (UINT16) sizeof (VENDOR_DEVICE_PATH));
 | |
|   CopyGuid (&Vendor->Guid, &gEfiVT100PlusGuid);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) Vendor;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to Vendor defined UTF8 device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created Vendor defined UTF8 device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextVenUtf8 (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   VENDOR_DEVICE_PATH  *Vendor;
 | |
| 
 | |
|   Vendor = (VENDOR_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                     MESSAGING_DEVICE_PATH,
 | |
|                                     MSG_VENDOR_DP,
 | |
|                                     (UINT16) sizeof (VENDOR_DEVICE_PATH));
 | |
|   CopyGuid (&Vendor->Guid, &gEfiVTUTF8Guid);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) Vendor;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to UART Flow Control device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created UART Flow Control device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextUartFlowCtrl (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16                        *ValueStr;
 | |
|   UART_FLOW_CONTROL_DEVICE_PATH *UartFlowControl;
 | |
| 
 | |
|   ValueStr        = GetNextParamStr (&TextDeviceNode);
 | |
|   UartFlowControl = (UART_FLOW_CONTROL_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                                         MESSAGING_DEVICE_PATH,
 | |
|                                                         MSG_VENDOR_DP,
 | |
|                                                         (UINT16) sizeof (UART_FLOW_CONTROL_DEVICE_PATH)
 | |
|                                                         );
 | |
| 
 | |
|   CopyGuid (&UartFlowControl->Guid, &gEfiUartDevicePathGuid);
 | |
|   if (StrCmp (ValueStr, L"XonXoff") == 0) {
 | |
|     UartFlowControl->FlowControlMap = 2;
 | |
|   } else if (StrCmp (ValueStr, L"Hardware") == 0) {
 | |
|     UartFlowControl->FlowControlMap = 1;
 | |
|   } else {
 | |
|     UartFlowControl->FlowControlMap = 0;
 | |
|   }
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) UartFlowControl;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to Serial Attached SCSI device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created Serial Attached SCSI device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextSAS (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16          *AddressStr;
 | |
|   CHAR16          *LunStr;
 | |
|   CHAR16          *RTPStr;
 | |
|   CHAR16          *SASSATAStr;
 | |
|   CHAR16          *LocationStr;
 | |
|   CHAR16          *ConnectStr;
 | |
|   CHAR16          *DriveBayStr;
 | |
|   CHAR16          *ReservedStr;
 | |
|   UINT16          Info;
 | |
|   UINT16          Uint16;
 | |
|   SAS_DEVICE_PATH *Sas;
 | |
| 
 | |
|   AddressStr  = GetNextParamStr (&TextDeviceNode);
 | |
|   LunStr      = GetNextParamStr (&TextDeviceNode);
 | |
|   RTPStr      = GetNextParamStr (&TextDeviceNode);
 | |
|   SASSATAStr  = GetNextParamStr (&TextDeviceNode);
 | |
|   LocationStr = GetNextParamStr (&TextDeviceNode);
 | |
|   ConnectStr  = GetNextParamStr (&TextDeviceNode);
 | |
|   DriveBayStr = GetNextParamStr (&TextDeviceNode);
 | |
|   ReservedStr = GetNextParamStr (&TextDeviceNode);
 | |
|   Sas         = (SAS_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                        MESSAGING_DEVICE_PATH,
 | |
|                                        MSG_VENDOR_DP,
 | |
|                                        (UINT16) sizeof (SAS_DEVICE_PATH)
 | |
|                                        );
 | |
| 
 | |
|   CopyGuid (&Sas->Guid, &gEfiSasDevicePathGuid);
 | |
|   Strtoi64 (AddressStr, &Sas->SasAddress);
 | |
|   Strtoi64 (LunStr, &Sas->Lun);
 | |
|   Sas->RelativeTargetPort = (UINT16) Strtoi (RTPStr);
 | |
| 
 | |
|   if (StrCmp (SASSATAStr, L"NoTopology") == 0) {
 | |
|     Info = 0x0;
 | |
| 
 | |
|   } else if ((StrCmp (SASSATAStr, L"SATA") == 0) || (StrCmp (SASSATAStr, L"SAS") == 0)) {
 | |
| 
 | |
|     Uint16 = (UINT16) Strtoi (DriveBayStr);
 | |
|     if (Uint16 == 0) {
 | |
|       Info = 0x1;
 | |
|     } else {
 | |
|       Info = (UINT16) (0x2 | ((Uint16 - 1) << 8));
 | |
|     }
 | |
| 
 | |
|     if (StrCmp (SASSATAStr, L"SATA") == 0) {
 | |
|       Info |= BIT4;
 | |
|     }
 | |
| 
 | |
|     //
 | |
|     // Location is an integer between 0 and 1 or else
 | |
|     // the keyword Internal (0) or External (1).
 | |
|     //
 | |
|     if (StrCmp (LocationStr, L"External") == 0) {
 | |
|       Uint16 = 1;
 | |
|     } else if (StrCmp (LocationStr, L"Internal") == 0) {
 | |
|       Uint16 = 0;
 | |
|     } else {
 | |
|       Uint16 = ((UINT16) Strtoi (LocationStr) & BIT0);
 | |
|     }
 | |
|     Info |= (Uint16 << 5);
 | |
| 
 | |
|     //
 | |
|     // Connect is an integer between 0 and 3 or else
 | |
|     // the keyword Direct (0) or Expanded (1).
 | |
|     //
 | |
|     if (StrCmp (ConnectStr, L"Expanded") == 0) {
 | |
|       Uint16 = 1;
 | |
|     } else if (StrCmp (ConnectStr, L"Direct") == 0) {
 | |
|       Uint16 = 0;
 | |
|     } else {
 | |
|       Uint16 = ((UINT16) Strtoi (ConnectStr) & (BIT0 | BIT1));
 | |
|     }
 | |
|     Info |= (Uint16 << 6);
 | |
| 
 | |
|   } else {
 | |
|     Info = (UINT16) Strtoi (SASSATAStr);
 | |
|   }
 | |
| 
 | |
|   Sas->DeviceTopology = Info;
 | |
|   Sas->Reserved       = (UINT32) Strtoi (ReservedStr);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) Sas;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to Serial Attached SCSI Ex device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created Serial Attached SCSI Ex device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextSasEx (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16            *AddressStr;
 | |
|   CHAR16            *LunStr;
 | |
|   CHAR16            *RTPStr;
 | |
|   CHAR16            *SASSATAStr;
 | |
|   CHAR16            *LocationStr;
 | |
|   CHAR16            *ConnectStr;
 | |
|   CHAR16            *DriveBayStr;
 | |
|   UINT16            Info;
 | |
|   UINT16            Uint16;
 | |
|   UINT64            SasAddress;
 | |
|   UINT64            Lun;
 | |
|   SASEX_DEVICE_PATH *SasEx;
 | |
| 
 | |
|   AddressStr  = GetNextParamStr (&TextDeviceNode);
 | |
|   LunStr      = GetNextParamStr (&TextDeviceNode);
 | |
|   RTPStr      = GetNextParamStr (&TextDeviceNode);
 | |
|   SASSATAStr  = GetNextParamStr (&TextDeviceNode);
 | |
|   LocationStr = GetNextParamStr (&TextDeviceNode);
 | |
|   ConnectStr  = GetNextParamStr (&TextDeviceNode);
 | |
|   DriveBayStr = GetNextParamStr (&TextDeviceNode);
 | |
|   SasEx       = (SASEX_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                         MESSAGING_DEVICE_PATH,
 | |
|                                         MSG_SASEX_DP,
 | |
|                                         (UINT16) sizeof (SASEX_DEVICE_PATH)
 | |
|                                         );
 | |
| 
 | |
|   Strtoi64 (AddressStr, &SasAddress);
 | |
|   Strtoi64 (LunStr,     &Lun);
 | |
|   WriteUnaligned64 ((UINT64 *) &SasEx->SasAddress, SwapBytes64 (SasAddress));
 | |
|   WriteUnaligned64 ((UINT64 *) &SasEx->Lun,        SwapBytes64 (Lun));
 | |
|   SasEx->RelativeTargetPort      = (UINT16) Strtoi (RTPStr);
 | |
| 
 | |
|   if (StrCmp (SASSATAStr, L"NoTopology") == 0) {
 | |
|     Info = 0x0;
 | |
| 
 | |
|   } else if ((StrCmp (SASSATAStr, L"SATA") == 0) || (StrCmp (SASSATAStr, L"SAS") == 0)) {
 | |
| 
 | |
|     Uint16 = (UINT16) Strtoi (DriveBayStr);
 | |
|     if (Uint16 == 0) {
 | |
|       Info = 0x1;
 | |
|     } else {
 | |
|       Info = (UINT16) (0x2 | ((Uint16 - 1) << 8));
 | |
|     }
 | |
| 
 | |
|     if (StrCmp (SASSATAStr, L"SATA") == 0) {
 | |
|       Info |= BIT4;
 | |
|     }
 | |
| 
 | |
|     //
 | |
|     // Location is an integer between 0 and 1 or else
 | |
|     // the keyword Internal (0) or External (1).
 | |
|     //
 | |
|     if (StrCmp (LocationStr, L"External") == 0) {
 | |
|       Uint16 = 1;
 | |
|     } else if (StrCmp (LocationStr, L"Internal") == 0) {
 | |
|       Uint16 = 0;
 | |
|     } else {
 | |
|       Uint16 = ((UINT16) Strtoi (LocationStr) & BIT0);
 | |
|     }
 | |
|     Info |= (Uint16 << 5);
 | |
| 
 | |
|     //
 | |
|     // Connect is an integer between 0 and 3 or else
 | |
|     // the keyword Direct (0) or Expanded (1).
 | |
|     //
 | |
|     if (StrCmp (ConnectStr, L"Expanded") == 0) {
 | |
|       Uint16 = 1;
 | |
|     } else if (StrCmp (ConnectStr, L"Direct") == 0) {
 | |
|       Uint16 = 0;
 | |
|     } else {
 | |
|       Uint16 = ((UINT16) Strtoi (ConnectStr) & (BIT0 | BIT1));
 | |
|     }
 | |
|     Info |= (Uint16 << 6);
 | |
| 
 | |
|   } else {
 | |
|     Info = (UINT16) Strtoi (SASSATAStr);
 | |
|   }
 | |
| 
 | |
|   SasEx->DeviceTopology = Info;
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) SasEx;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to NVM Express Namespace device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created NVM Express Namespace device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextNVMe (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16                     *NamespaceIdStr;
 | |
|   CHAR16                     *NamespaceUuidStr;
 | |
|   NVME_NAMESPACE_DEVICE_PATH *Nvme;
 | |
|   UINT8                      *Uuid;
 | |
|   UINTN                      Index;
 | |
| 
 | |
|   NamespaceIdStr   = GetNextParamStr (&TextDeviceNode);
 | |
|   NamespaceUuidStr = GetNextParamStr (&TextDeviceNode);
 | |
|   Nvme = (NVME_NAMESPACE_DEVICE_PATH *) CreateDeviceNode (
 | |
|     MESSAGING_DEVICE_PATH,
 | |
|     MSG_NVME_NAMESPACE_DP,
 | |
|     (UINT16) sizeof (NVME_NAMESPACE_DEVICE_PATH)
 | |
|     );
 | |
| 
 | |
|   Nvme->NamespaceId = (UINT32) Strtoi (NamespaceIdStr);
 | |
|   Uuid = (UINT8 *) &Nvme->NamespaceUuid;
 | |
| 
 | |
|   Index = sizeof (Nvme->NamespaceUuid) / sizeof (UINT8);
 | |
|   while (Index-- != 0) {
 | |
|     Uuid[Index] = (UINT8) StrHexToUint64 (SplitStr (&NamespaceUuidStr, L'-'));
 | |
|   }
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) Nvme;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to UFS device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created UFS device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextUfs (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16            *PunStr;
 | |
|   CHAR16            *LunStr;
 | |
|   UFS_DEVICE_PATH   *Ufs;
 | |
| 
 | |
|   PunStr = GetNextParamStr (&TextDeviceNode);
 | |
|   LunStr = GetNextParamStr (&TextDeviceNode);
 | |
|   Ufs    = (UFS_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                  MESSAGING_DEVICE_PATH,
 | |
|                                  MSG_UFS_DP,
 | |
|                                  (UINT16) sizeof (UFS_DEVICE_PATH)
 | |
|                                  );
 | |
| 
 | |
|   Ufs->Pun = (UINT8) Strtoi (PunStr);
 | |
|   Ufs->Lun = (UINT8) Strtoi (LunStr);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) Ufs;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to SD (Secure Digital) device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created SD device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextSd (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16            *SlotNumberStr;
 | |
|   SD_DEVICE_PATH    *Sd;
 | |
| 
 | |
|   SlotNumberStr = GetNextParamStr (&TextDeviceNode);
 | |
|   Sd            = (SD_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                        MESSAGING_DEVICE_PATH,
 | |
|                                        MSG_SD_DP,
 | |
|                                        (UINT16) sizeof (SD_DEVICE_PATH)
 | |
|                                        );
 | |
| 
 | |
|   Sd->SlotNumber = (UINT8) Strtoi (SlotNumberStr);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) Sd;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to EMMC (Embedded MMC) device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created EMMC device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextEmmc (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16            *SlotNumberStr;
 | |
|   EMMC_DEVICE_PATH  *Emmc;
 | |
| 
 | |
|   SlotNumberStr = GetNextParamStr (&TextDeviceNode);
 | |
|   Emmc          = (EMMC_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                        MESSAGING_DEVICE_PATH,
 | |
|                                        MSG_EMMC_DP,
 | |
|                                        (UINT16) sizeof (EMMC_DEVICE_PATH)
 | |
|                                        );
 | |
| 
 | |
|   Emmc->SlotNumber = (UINT8) Strtoi (SlotNumberStr);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) Emmc;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to Debug Port device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created Debug Port device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextDebugPort (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   VENDOR_DEVICE_PATH  *Vend;
 | |
| 
 | |
|   Vend = (VENDOR_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                                     MESSAGING_DEVICE_PATH,
 | |
|                                                     MSG_VENDOR_DP,
 | |
|                                                     (UINT16) sizeof (VENDOR_DEVICE_PATH)
 | |
|                                                     );
 | |
| 
 | |
|   CopyGuid (&Vend->Guid, &gEfiDebugPortProtocolGuid);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) Vend;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to MAC device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created MAC device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextMAC (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16                *AddressStr;
 | |
|   CHAR16                *IfTypeStr;
 | |
|   UINTN                 Length;
 | |
|   MAC_ADDR_DEVICE_PATH  *MACDevPath;
 | |
| 
 | |
|   AddressStr    = GetNextParamStr (&TextDeviceNode);
 | |
|   IfTypeStr     = GetNextParamStr (&TextDeviceNode);
 | |
|   MACDevPath    = (MAC_ADDR_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                               MESSAGING_DEVICE_PATH,
 | |
|                                               MSG_MAC_ADDR_DP,
 | |
|                                               (UINT16) sizeof (MAC_ADDR_DEVICE_PATH)
 | |
|                                               );
 | |
| 
 | |
|   MACDevPath->IfType   = (UINT8) Strtoi (IfTypeStr);
 | |
| 
 | |
|   Length = sizeof (EFI_MAC_ADDRESS);
 | |
|   if (MACDevPath->IfType == 0x01 || MACDevPath->IfType == 0x00) {
 | |
|     Length = 6;
 | |
|   }
 | |
| 
 | |
|   StrHexToBytes (AddressStr, Length * 2, MACDevPath->MacAddress.Addr, Length);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) MACDevPath;
 | |
| }
 | |
| 
 | |
| 
 | |
| /**
 | |
|   Converts a text format to the network protocol ID.
 | |
| 
 | |
|   @param Text  String of protocol field.
 | |
| 
 | |
|   @return Network protocol ID .
 | |
| 
 | |
| **/
 | |
| UINTN
 | |
| NetworkProtocolFromText (
 | |
|    CHAR16 *Text
 | |
|   )
 | |
| {
 | |
|   if (StrCmp (Text, L"UDP") == 0) {
 | |
|     return RFC_1700_UDP_PROTOCOL;
 | |
|   }
 | |
| 
 | |
|   if (StrCmp (Text, L"TCP") == 0) {
 | |
|     return RFC_1700_TCP_PROTOCOL;
 | |
|   }
 | |
| 
 | |
|   return Strtoi (Text);
 | |
| }
 | |
| 
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to IPV4 device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created IPV4 device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextIPv4 (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16            *RemoteIPStr;
 | |
|   CHAR16            *ProtocolStr;
 | |
|   CHAR16            *TypeStr;
 | |
|   CHAR16            *LocalIPStr;
 | |
|   CHAR16            *GatewayIPStr;
 | |
|   CHAR16            *SubnetMaskStr;
 | |
|   IPv4_DEVICE_PATH  *IPv4;
 | |
| 
 | |
|   RemoteIPStr           = GetNextParamStr (&TextDeviceNode);
 | |
|   ProtocolStr           = GetNextParamStr (&TextDeviceNode);
 | |
|   TypeStr               = GetNextParamStr (&TextDeviceNode);
 | |
|   LocalIPStr            = GetNextParamStr (&TextDeviceNode);
 | |
|   GatewayIPStr          = GetNextParamStr (&TextDeviceNode);
 | |
|   SubnetMaskStr         = GetNextParamStr (&TextDeviceNode);
 | |
|   IPv4                  = (IPv4_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                                  MESSAGING_DEVICE_PATH,
 | |
|                                                  MSG_IPv4_DP,
 | |
|                                                  (UINT16) sizeof (IPv4_DEVICE_PATH)
 | |
|                                                  );
 | |
| 
 | |
|   StrToIpv4Address (RemoteIPStr, NULL, &IPv4->RemoteIpAddress, NULL);
 | |
|   IPv4->Protocol = (UINT16) NetworkProtocolFromText (ProtocolStr);
 | |
|   if (StrCmp (TypeStr, L"Static") == 0) {
 | |
|     IPv4->StaticIpAddress = TRUE;
 | |
|   } else {
 | |
|     IPv4->StaticIpAddress = FALSE;
 | |
|   }
 | |
| 
 | |
|   StrToIpv4Address (LocalIPStr, NULL, &IPv4->LocalIpAddress, NULL);
 | |
|   if (!IS_NULL (*GatewayIPStr) && !IS_NULL (*SubnetMaskStr)) {
 | |
|     StrToIpv4Address (GatewayIPStr,  NULL, &IPv4->GatewayIpAddress, NULL);
 | |
|     StrToIpv4Address (SubnetMaskStr, NULL, &IPv4->SubnetMask,       NULL);
 | |
|   } else {
 | |
|     ZeroMem (&IPv4->GatewayIpAddress, sizeof (IPv4->GatewayIpAddress));
 | |
|     ZeroMem (&IPv4->SubnetMask,    sizeof (IPv4->SubnetMask));
 | |
|   }
 | |
| 
 | |
|   IPv4->LocalPort       = 0;
 | |
|   IPv4->RemotePort      = 0;
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) IPv4;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to IPV6 device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created IPV6 device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextIPv6 (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16            *RemoteIPStr;
 | |
|   CHAR16            *ProtocolStr;
 | |
|   CHAR16            *TypeStr;
 | |
|   CHAR16            *LocalIPStr;
 | |
|   CHAR16            *GatewayIPStr;
 | |
|   CHAR16            *PrefixLengthStr;
 | |
|   IPv6_DEVICE_PATH  *IPv6;
 | |
| 
 | |
|   RemoteIPStr           = GetNextParamStr (&TextDeviceNode);
 | |
|   ProtocolStr           = GetNextParamStr (&TextDeviceNode);
 | |
|   TypeStr               = GetNextParamStr (&TextDeviceNode);
 | |
|   LocalIPStr            = GetNextParamStr (&TextDeviceNode);
 | |
|   PrefixLengthStr       = GetNextParamStr (&TextDeviceNode);
 | |
|   GatewayIPStr          = GetNextParamStr (&TextDeviceNode);
 | |
|   IPv6                  = (IPv6_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                                  MESSAGING_DEVICE_PATH,
 | |
|                                                  MSG_IPv6_DP,
 | |
|                                                  (UINT16) sizeof (IPv6_DEVICE_PATH)
 | |
|                                                  );
 | |
| 
 | |
|   StrToIpv6Address (RemoteIPStr, NULL, &IPv6->RemoteIpAddress, NULL);
 | |
|   IPv6->Protocol        = (UINT16) NetworkProtocolFromText (ProtocolStr);
 | |
|   if (StrCmp (TypeStr, L"Static") == 0) {
 | |
|     IPv6->IpAddressOrigin = 0;
 | |
|   } else if (StrCmp (TypeStr, L"StatelessAutoConfigure") == 0) {
 | |
|     IPv6->IpAddressOrigin = 1;
 | |
|   } else {
 | |
|     IPv6->IpAddressOrigin = 2;
 | |
|   }
 | |
| 
 | |
|   StrToIpv6Address (LocalIPStr, NULL, &IPv6->LocalIpAddress, NULL);
 | |
|   if (!IS_NULL (*GatewayIPStr) && !IS_NULL (*PrefixLengthStr)) {
 | |
|     StrToIpv6Address (GatewayIPStr, NULL, &IPv6->GatewayIpAddress, NULL);
 | |
|     IPv6->PrefixLength = (UINT8) Strtoi (PrefixLengthStr);
 | |
|   } else {
 | |
|     ZeroMem (&IPv6->GatewayIpAddress, sizeof (IPv6->GatewayIpAddress));
 | |
|     IPv6->PrefixLength = 0;
 | |
|   }
 | |
| 
 | |
|   IPv6->LocalPort       = 0;
 | |
|   IPv6->RemotePort      = 0;
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) IPv6;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to UART device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created UART device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextUart (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16            *BaudStr;
 | |
|   CHAR16            *DataBitsStr;
 | |
|   CHAR16            *ParityStr;
 | |
|   CHAR16            *StopBitsStr;
 | |
|   UART_DEVICE_PATH  *Uart;
 | |
| 
 | |
|   BaudStr         = GetNextParamStr (&TextDeviceNode);
 | |
|   DataBitsStr     = GetNextParamStr (&TextDeviceNode);
 | |
|   ParityStr       = GetNextParamStr (&TextDeviceNode);
 | |
|   StopBitsStr     = GetNextParamStr (&TextDeviceNode);
 | |
|   Uart            = (UART_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                            MESSAGING_DEVICE_PATH,
 | |
|                                            MSG_UART_DP,
 | |
|                                            (UINT16) sizeof (UART_DEVICE_PATH)
 | |
|                                            );
 | |
| 
 | |
|   if (StrCmp (BaudStr, L"DEFAULT") == 0) {
 | |
|     Uart->BaudRate = 115200;
 | |
|   } else {
 | |
|     Strtoi64 (BaudStr, &Uart->BaudRate);
 | |
|   }
 | |
|   Uart->DataBits  = (UINT8) ((StrCmp (DataBitsStr, L"DEFAULT") == 0) ? 8 : Strtoi (DataBitsStr));
 | |
|   switch (*ParityStr) {
 | |
|   case L'D':
 | |
|     Uart->Parity = 0;
 | |
|     break;
 | |
| 
 | |
|   case L'N':
 | |
|     Uart->Parity = 1;
 | |
|     break;
 | |
| 
 | |
|   case L'E':
 | |
|     Uart->Parity = 2;
 | |
|     break;
 | |
| 
 | |
|   case L'O':
 | |
|     Uart->Parity = 3;
 | |
|     break;
 | |
| 
 | |
|   case L'M':
 | |
|     Uart->Parity = 4;
 | |
|     break;
 | |
| 
 | |
|   case L'S':
 | |
|     Uart->Parity = 5;
 | |
|     break;
 | |
| 
 | |
|   default:
 | |
|     Uart->Parity = (UINT8) Strtoi (ParityStr);
 | |
|     break;
 | |
|   }
 | |
| 
 | |
|   if (StrCmp (StopBitsStr, L"D") == 0) {
 | |
|     Uart->StopBits = (UINT8) 0;
 | |
|   } else if (StrCmp (StopBitsStr, L"1") == 0) {
 | |
|     Uart->StopBits = (UINT8) 1;
 | |
|   } else if (StrCmp (StopBitsStr, L"1.5") == 0) {
 | |
|     Uart->StopBits = (UINT8) 2;
 | |
|   } else if (StrCmp (StopBitsStr, L"2") == 0) {
 | |
|     Uart->StopBits = (UINT8) 3;
 | |
|   } else {
 | |
|     Uart->StopBits = (UINT8) Strtoi (StopBitsStr);
 | |
|   }
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) Uart;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to USB class device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
|   @param UsbClassText    A pointer to USB_CLASS_TEXT structure to be integrated to USB Class Text.
 | |
| 
 | |
|   @return A pointer to the newly-created USB class device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| ConvertFromTextUsbClass (
 | |
|    CHAR16         *TextDeviceNode,
 | |
|    USB_CLASS_TEXT *UsbClassText
 | |
|   )
 | |
| {
 | |
|   CHAR16                *VIDStr;
 | |
|   CHAR16                *PIDStr;
 | |
|   CHAR16                *ClassStr;
 | |
|   CHAR16                *SubClassStr;
 | |
|   CHAR16                *ProtocolStr;
 | |
|   USB_CLASS_DEVICE_PATH *UsbClass;
 | |
| 
 | |
|   UsbClass    = (USB_CLASS_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                             MESSAGING_DEVICE_PATH,
 | |
|                                             MSG_USB_CLASS_DP,
 | |
|                                             (UINT16) sizeof (USB_CLASS_DEVICE_PATH)
 | |
|                                             );
 | |
| 
 | |
|   VIDStr      = GetNextParamStr (&TextDeviceNode);
 | |
|   PIDStr      = GetNextParamStr (&TextDeviceNode);
 | |
|   if (UsbClassText->ClassExist) {
 | |
|     ClassStr = GetNextParamStr (&TextDeviceNode);
 | |
|     if (*ClassStr == L'\0') {
 | |
|       UsbClass->DeviceClass = 0xFF;
 | |
|     } else {
 | |
|       UsbClass->DeviceClass = (UINT8) Strtoi (ClassStr);
 | |
|     }
 | |
|   } else {
 | |
|     UsbClass->DeviceClass = UsbClassText->Class;
 | |
|   }
 | |
|   if (UsbClassText->SubClassExist) {
 | |
|     SubClassStr = GetNextParamStr (&TextDeviceNode);
 | |
|     if (*SubClassStr == L'\0') {
 | |
|       UsbClass->DeviceSubClass = 0xFF;
 | |
|     } else {
 | |
|       UsbClass->DeviceSubClass = (UINT8) Strtoi (SubClassStr);
 | |
|     }
 | |
|   } else {
 | |
|     UsbClass->DeviceSubClass = UsbClassText->SubClass;
 | |
|   }
 | |
| 
 | |
|   ProtocolStr = GetNextParamStr (&TextDeviceNode);
 | |
| 
 | |
|   if (*VIDStr == L'\0') {
 | |
|     UsbClass->VendorId        = 0xFFFF;
 | |
|   } else {
 | |
|     UsbClass->VendorId        = (UINT16) Strtoi (VIDStr);
 | |
|   }
 | |
|   if (*PIDStr == L'\0') {
 | |
|     UsbClass->ProductId       = 0xFFFF;
 | |
|   } else {
 | |
|     UsbClass->ProductId       = (UINT16) Strtoi (PIDStr);
 | |
|   }
 | |
|   if (*ProtocolStr == L'\0') {
 | |
|     UsbClass->DeviceProtocol  = 0xFF;
 | |
|   } else {
 | |
|     UsbClass->DeviceProtocol  = (UINT8) Strtoi (ProtocolStr);
 | |
|   }
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) UsbClass;
 | |
| }
 | |
| 
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to USB class device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created USB class device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextUsbClass (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   USB_CLASS_TEXT  UsbClassText;
 | |
| 
 | |
|   UsbClassText.ClassExist    = TRUE;
 | |
|   UsbClassText.SubClassExist = TRUE;
 | |
| 
 | |
|   return ConvertFromTextUsbClass (TextDeviceNode, &UsbClassText);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to USB audio device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created USB audio device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextUsbAudio (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   USB_CLASS_TEXT  UsbClassText;
 | |
| 
 | |
|   UsbClassText.ClassExist    = FALSE;
 | |
|   UsbClassText.Class         = USB_CLASS_AUDIO;
 | |
|   UsbClassText.SubClassExist = TRUE;
 | |
| 
 | |
|   return ConvertFromTextUsbClass (TextDeviceNode, &UsbClassText);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to USB CDC Control device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created USB CDC Control device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextUsbCDCControl (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   USB_CLASS_TEXT  UsbClassText;
 | |
| 
 | |
|   UsbClassText.ClassExist    = FALSE;
 | |
|   UsbClassText.Class         = USB_CLASS_CDCCONTROL;
 | |
|   UsbClassText.SubClassExist = TRUE;
 | |
| 
 | |
|   return ConvertFromTextUsbClass (TextDeviceNode, &UsbClassText);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to USB HID device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created USB HID device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextUsbHID (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   USB_CLASS_TEXT  UsbClassText;
 | |
| 
 | |
|   UsbClassText.ClassExist    = FALSE;
 | |
|   UsbClassText.Class         = USB_CLASS_HID;
 | |
|   UsbClassText.SubClassExist = TRUE;
 | |
| 
 | |
|   return ConvertFromTextUsbClass (TextDeviceNode, &UsbClassText);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to USB Image device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created USB Image device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextUsbImage (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   USB_CLASS_TEXT  UsbClassText;
 | |
| 
 | |
|   UsbClassText.ClassExist    = FALSE;
 | |
|   UsbClassText.Class         = USB_CLASS_IMAGE;
 | |
|   UsbClassText.SubClassExist = TRUE;
 | |
| 
 | |
|   return ConvertFromTextUsbClass (TextDeviceNode, &UsbClassText);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to USB Print device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created USB Print device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextUsbPrinter (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   USB_CLASS_TEXT  UsbClassText;
 | |
| 
 | |
|   UsbClassText.ClassExist    = FALSE;
 | |
|   UsbClassText.Class         = USB_CLASS_PRINTER;
 | |
|   UsbClassText.SubClassExist = TRUE;
 | |
| 
 | |
|   return ConvertFromTextUsbClass (TextDeviceNode, &UsbClassText);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to USB mass storage device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created USB mass storage device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextUsbMassStorage (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   USB_CLASS_TEXT  UsbClassText;
 | |
| 
 | |
|   UsbClassText.ClassExist    = FALSE;
 | |
|   UsbClassText.Class         = USB_CLASS_MASS_STORAGE;
 | |
|   UsbClassText.SubClassExist = TRUE;
 | |
| 
 | |
|   return ConvertFromTextUsbClass (TextDeviceNode, &UsbClassText);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to USB HUB device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created USB HUB device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextUsbHub (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   USB_CLASS_TEXT  UsbClassText;
 | |
| 
 | |
|   UsbClassText.ClassExist    = FALSE;
 | |
|   UsbClassText.Class         = USB_CLASS_HUB;
 | |
|   UsbClassText.SubClassExist = TRUE;
 | |
| 
 | |
|   return ConvertFromTextUsbClass (TextDeviceNode, &UsbClassText);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to USB CDC data device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created USB CDC data device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextUsbCDCData (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   USB_CLASS_TEXT  UsbClassText;
 | |
| 
 | |
|   UsbClassText.ClassExist    = FALSE;
 | |
|   UsbClassText.Class         = USB_CLASS_CDCDATA;
 | |
|   UsbClassText.SubClassExist = TRUE;
 | |
| 
 | |
|   return ConvertFromTextUsbClass (TextDeviceNode, &UsbClassText);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to USB smart card device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created USB smart card device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextUsbSmartCard (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   USB_CLASS_TEXT  UsbClassText;
 | |
| 
 | |
|   UsbClassText.ClassExist    = FALSE;
 | |
|   UsbClassText.Class         = USB_CLASS_SMART_CARD;
 | |
|   UsbClassText.SubClassExist = TRUE;
 | |
| 
 | |
|   return ConvertFromTextUsbClass (TextDeviceNode, &UsbClassText);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to USB video device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created USB video device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextUsbVideo (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   USB_CLASS_TEXT  UsbClassText;
 | |
| 
 | |
|   UsbClassText.ClassExist    = FALSE;
 | |
|   UsbClassText.Class         = USB_CLASS_VIDEO;
 | |
|   UsbClassText.SubClassExist = TRUE;
 | |
| 
 | |
|   return ConvertFromTextUsbClass (TextDeviceNode, &UsbClassText);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to USB diagnostic device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created USB diagnostic device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextUsbDiagnostic (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   USB_CLASS_TEXT  UsbClassText;
 | |
| 
 | |
|   UsbClassText.ClassExist    = FALSE;
 | |
|   UsbClassText.Class         = USB_CLASS_DIAGNOSTIC;
 | |
|   UsbClassText.SubClassExist = TRUE;
 | |
| 
 | |
|   return ConvertFromTextUsbClass (TextDeviceNode, &UsbClassText);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to USB wireless device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created USB wireless device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextUsbWireless (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   USB_CLASS_TEXT  UsbClassText;
 | |
| 
 | |
|   UsbClassText.ClassExist    = FALSE;
 | |
|   UsbClassText.Class         = USB_CLASS_WIRELESS;
 | |
|   UsbClassText.SubClassExist = TRUE;
 | |
| 
 | |
|   return ConvertFromTextUsbClass (TextDeviceNode, &UsbClassText);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to USB device firmware update device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created USB device firmware update device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextUsbDeviceFirmwareUpdate (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   USB_CLASS_TEXT  UsbClassText;
 | |
| 
 | |
|   UsbClassText.ClassExist    = FALSE;
 | |
|   UsbClassText.Class         = USB_CLASS_RESERVE;
 | |
|   UsbClassText.SubClassExist = FALSE;
 | |
|   UsbClassText.SubClass      = USB_SUBCLASS_FW_UPDATE;
 | |
| 
 | |
|   return ConvertFromTextUsbClass (TextDeviceNode, &UsbClassText);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to USB IRDA bridge device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created USB IRDA bridge device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextUsbIrdaBridge (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   USB_CLASS_TEXT  UsbClassText;
 | |
| 
 | |
|   UsbClassText.ClassExist    = FALSE;
 | |
|   UsbClassText.Class         = USB_CLASS_RESERVE;
 | |
|   UsbClassText.SubClassExist = FALSE;
 | |
|   UsbClassText.SubClass      = USB_SUBCLASS_IRDA_BRIDGE;
 | |
| 
 | |
|   return ConvertFromTextUsbClass (TextDeviceNode, &UsbClassText);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to USB text and measurement device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created USB text and measurement device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextUsbTestAndMeasurement (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   USB_CLASS_TEXT  UsbClassText;
 | |
| 
 | |
|   UsbClassText.ClassExist    = FALSE;
 | |
|   UsbClassText.Class         = USB_CLASS_RESERVE;
 | |
|   UsbClassText.SubClassExist = FALSE;
 | |
|   UsbClassText.SubClass      = USB_SUBCLASS_TEST;
 | |
| 
 | |
|   return ConvertFromTextUsbClass (TextDeviceNode, &UsbClassText);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to USB WWID device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created USB WWID device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextUsbWwid (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16                *VIDStr;
 | |
|   CHAR16                *PIDStr;
 | |
|   CHAR16                *InterfaceNumStr;
 | |
|   CHAR16                *SerialNumberStr;
 | |
|   USB_WWID_DEVICE_PATH  *UsbWwid;
 | |
|   UINTN                 SerialNumberStrLen;
 | |
| 
 | |
|   VIDStr                   = GetNextParamStr (&TextDeviceNode);
 | |
|   PIDStr                   = GetNextParamStr (&TextDeviceNode);
 | |
|   InterfaceNumStr          = GetNextParamStr (&TextDeviceNode);
 | |
|   SerialNumberStr          = GetNextParamStr (&TextDeviceNode);
 | |
|   SerialNumberStrLen       = StrLen (SerialNumberStr);
 | |
|   if (SerialNumberStrLen >= 2 &&
 | |
|       SerialNumberStr[0] == L'\"' &&
 | |
|       SerialNumberStr[SerialNumberStrLen - 1] == L'\"'
 | |
|     ) {
 | |
|     SerialNumberStr[SerialNumberStrLen - 1] = L'\0';
 | |
|     SerialNumberStr++;
 | |
|     SerialNumberStrLen -= 2;
 | |
|   }
 | |
|   UsbWwid                  = (USB_WWID_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                                          MESSAGING_DEVICE_PATH,
 | |
|                                                          MSG_USB_WWID_DP,
 | |
|                                                          (UINT16) (sizeof (USB_WWID_DEVICE_PATH) + SerialNumberStrLen * sizeof (CHAR16))
 | |
|                                                          );
 | |
|   UsbWwid->VendorId        = (UINT16) Strtoi (VIDStr);
 | |
|   UsbWwid->ProductId       = (UINT16) Strtoi (PIDStr);
 | |
|   UsbWwid->InterfaceNumber = (UINT16) Strtoi (InterfaceNumStr);
 | |
| 
 | |
|   //
 | |
|   // There is no memory allocated in UsbWwid for the '\0' in SerialNumberStr.
 | |
|   // Therefore, the '\0' will not be copied.
 | |
|   //
 | |
|   memcpy (
 | |
|     (UINT8 *) UsbWwid + sizeof (USB_WWID_DEVICE_PATH),
 | |
|     SerialNumberStr,
 | |
|     SerialNumberStrLen * sizeof (CHAR16)
 | |
|     );
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) UsbWwid;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to Logic Unit device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created Logic Unit device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextUnit (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16                          *LunStr;
 | |
|   DEVICE_LOGICAL_UNIT_DEVICE_PATH *LogicalUnit;
 | |
| 
 | |
|   LunStr      = GetNextParamStr (&TextDeviceNode);
 | |
|   LogicalUnit = (DEVICE_LOGICAL_UNIT_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                                       MESSAGING_DEVICE_PATH,
 | |
|                                                       MSG_DEVICE_LOGICAL_UNIT_DP,
 | |
|                                                       (UINT16) sizeof (DEVICE_LOGICAL_UNIT_DEVICE_PATH)
 | |
|                                                       );
 | |
| 
 | |
|   LogicalUnit->Lun  = (UINT8) Strtoi (LunStr);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) LogicalUnit;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to iSCSI device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created iSCSI device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextiSCSI (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   UINT16                      Options;
 | |
|   CHAR16                      *NameStr;
 | |
|   CHAR16                      *PortalGroupStr;
 | |
|   CHAR16                      *LunStr;
 | |
|   CHAR16                      *HeaderDigestStr;
 | |
|   CHAR16                      *DataDigestStr;
 | |
|   CHAR16                      *AuthenticationStr;
 | |
|   CHAR16                      *ProtocolStr;
 | |
|   CHAR8                       *AsciiStr;
 | |
|   ISCSI_DEVICE_PATH_WITH_NAME *ISCSIDevPath;
 | |
|   UINT64                      Lun;
 | |
| 
 | |
|   NameStr           = GetNextParamStr (&TextDeviceNode);
 | |
|   PortalGroupStr    = GetNextParamStr (&TextDeviceNode);
 | |
|   LunStr            = GetNextParamStr (&TextDeviceNode);
 | |
|   HeaderDigestStr   = GetNextParamStr (&TextDeviceNode);
 | |
|   DataDigestStr     = GetNextParamStr (&TextDeviceNode);
 | |
|   AuthenticationStr = GetNextParamStr (&TextDeviceNode);
 | |
|   ProtocolStr       = GetNextParamStr (&TextDeviceNode);
 | |
|   ISCSIDevPath      = (ISCSI_DEVICE_PATH_WITH_NAME *) CreateDeviceNode (
 | |
|                                                         MESSAGING_DEVICE_PATH,
 | |
|                                                         MSG_ISCSI_DP,
 | |
|                                                         (UINT16) (sizeof (ISCSI_DEVICE_PATH_WITH_NAME) + StrLen (NameStr))
 | |
|                                                         );
 | |
| 
 | |
|   AsciiStr = ISCSIDevPath->TargetName;
 | |
|   StrToAscii (NameStr, &AsciiStr);
 | |
| 
 | |
|   ISCSIDevPath->TargetPortalGroupTag = (UINT16) Strtoi (PortalGroupStr);
 | |
|   Strtoi64 (LunStr, &Lun);
 | |
|   WriteUnaligned64 ((UINT64 *) &ISCSIDevPath->Lun, SwapBytes64 (Lun));
 | |
| 
 | |
|   Options = 0x0000;
 | |
|   if (StrCmp (HeaderDigestStr, L"CRC32C") == 0) {
 | |
|     Options |= 0x0002;
 | |
|   }
 | |
| 
 | |
|   if (StrCmp (DataDigestStr, L"CRC32C") == 0) {
 | |
|     Options |= 0x0008;
 | |
|   }
 | |
| 
 | |
|   if (StrCmp (AuthenticationStr, L"None") == 0) {
 | |
|     Options |= 0x0800;
 | |
|   }
 | |
| 
 | |
|   if (StrCmp (AuthenticationStr, L"CHAP_UNI") == 0) {
 | |
|     Options |= 0x1000;
 | |
|   }
 | |
| 
 | |
|   ISCSIDevPath->LoginOption      = (UINT16) Options;
 | |
| 
 | |
|   if (IS_NULL (*ProtocolStr) || (StrCmp (ProtocolStr, L"TCP") == 0)) {
 | |
|     ISCSIDevPath->NetworkProtocol = 0;
 | |
|   } else {
 | |
|     //
 | |
|     // Undefined and reserved.
 | |
|     //
 | |
|     ISCSIDevPath->NetworkProtocol = 1;
 | |
|   }
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) ISCSIDevPath;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to VLAN device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created VLAN device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextVlan (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16            *VlanStr;
 | |
|   VLAN_DEVICE_PATH  *Vlan;
 | |
| 
 | |
|   VlanStr = GetNextParamStr (&TextDeviceNode);
 | |
|   Vlan    = (VLAN_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                    MESSAGING_DEVICE_PATH,
 | |
|                                    MSG_VLAN_DP,
 | |
|                                    (UINT16) sizeof (VLAN_DEVICE_PATH)
 | |
|                                    );
 | |
| 
 | |
|   Vlan->VlanId = (UINT16) Strtoi (VlanStr);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) Vlan;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to Bluetooth device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created Bluetooth device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextBluetooth (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16                  *BluetoothStr;
 | |
|   BLUETOOTH_DEVICE_PATH   *BluetoothDp;
 | |
| 
 | |
|   BluetoothStr = GetNextParamStr (&TextDeviceNode);
 | |
|   BluetoothDp  = (BLUETOOTH_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                              MESSAGING_DEVICE_PATH,
 | |
|                                              MSG_BLUETOOTH_DP,
 | |
|                                              (UINT16) sizeof (BLUETOOTH_DEVICE_PATH)
 | |
|                                              );
 | |
|   StrHexToBytes (
 | |
|     BluetoothStr,
 | |
|     sizeof (BLUETOOTH_ADDRESS) * 2,
 | |
|     BluetoothDp->BD_ADDR.Address,
 | |
|     sizeof (BLUETOOTH_ADDRESS)
 | |
|     );
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) BluetoothDp;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to Wi-Fi device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created Wi-Fi device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextWiFi (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16                *SSIdStr;
 | |
|   CHAR8                 AsciiStr[33];
 | |
|   UINTN                 DataLen;
 | |
|   WIFI_DEVICE_PATH      *WiFiDp;
 | |
| 
 | |
|   SSIdStr = GetNextParamStr (&TextDeviceNode);
 | |
|   WiFiDp  = (WIFI_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                    MESSAGING_DEVICE_PATH,
 | |
|                                    MSG_WIFI_DP,
 | |
|                                    (UINT16) sizeof (WIFI_DEVICE_PATH)
 | |
|                                    );
 | |
| 
 | |
|   if (NULL != SSIdStr) {
 | |
|     DataLen = StrLen (SSIdStr);
 | |
|     if (StrLen (SSIdStr) > 32) {
 | |
|       SSIdStr[32] = L'\0';
 | |
|       DataLen     = 32;
 | |
|     }
 | |
| 
 | |
|     UnicodeStrToAsciiStrS (SSIdStr, AsciiStr, sizeof (AsciiStr));
 | |
|     memcpy (WiFiDp->SSId, AsciiStr, DataLen);
 | |
|   }
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) WiFiDp;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to Bluetooth LE device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created Bluetooth LE device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextBluetoothLE (
 | |
|   IN CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16                     *BluetoothLeAddrStr;
 | |
|   CHAR16                     *BluetoothLeAddrTypeStr;
 | |
|   BLUETOOTH_LE_DEVICE_PATH   *BluetoothLeDp;
 | |
| 
 | |
|   BluetoothLeAddrStr     = GetNextParamStr (&TextDeviceNode);
 | |
|   BluetoothLeAddrTypeStr = GetNextParamStr (&TextDeviceNode);
 | |
|   BluetoothLeDp = (BLUETOOTH_LE_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                                  MESSAGING_DEVICE_PATH,
 | |
|                                                  MSG_BLUETOOTH_LE_DP,
 | |
|                                                  (UINT16) sizeof (BLUETOOTH_LE_DEVICE_PATH)
 | |
|                                                  );
 | |
| 
 | |
|   BluetoothLeDp->Address.Type = (UINT8) Strtoi (BluetoothLeAddrTypeStr);
 | |
|   StrHexToBytes (
 | |
|     BluetoothLeAddrStr, sizeof (BluetoothLeDp->Address.Address) * 2,
 | |
|     BluetoothLeDp->Address.Address, sizeof (BluetoothLeDp->Address.Address)
 | |
|     );
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) BluetoothLeDp;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to DNS device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created DNS device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextDns (
 | |
|   IN CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16            *DeviceNodeStr;
 | |
|   CHAR16            *DeviceNodeStrPtr;
 | |
|   UINT32            DnsServerIpCount;
 | |
|   UINT16            DnsDeviceNodeLength;
 | |
|   DNS_DEVICE_PATH   *DnsDeviceNode;
 | |
|   UINT32            DnsServerIpIndex;
 | |
|   CHAR16            *DnsServerIp;
 | |
| 
 | |
| 
 | |
|   //
 | |
|   // Count the DNS server address number.
 | |
|   //
 | |
|   DeviceNodeStr = UefiDevicePathLibStrDuplicate (TextDeviceNode);
 | |
|   if (DeviceNodeStr == NULL) {
 | |
|     return NULL;
 | |
|   }
 | |
| 
 | |
|   DeviceNodeStrPtr = DeviceNodeStr;
 | |
| 
 | |
|   DnsServerIpCount = 0;
 | |
|   while (DeviceNodeStrPtr != NULL && *DeviceNodeStrPtr != L'\0') {
 | |
|     GetNextParamStr (&DeviceNodeStrPtr);
 | |
|     DnsServerIpCount ++;
 | |
|   }
 | |
| 
 | |
|   free (DeviceNodeStr);
 | |
|   DeviceNodeStr = NULL;
 | |
| 
 | |
|   //
 | |
|   // One or more instances of the DNS server address in EFI_IP_ADDRESS,
 | |
|   // otherwise, NULL will be returned.
 | |
|   //
 | |
|   if (DnsServerIpCount == 0) {
 | |
|     return NULL;
 | |
|   }
 | |
| 
 | |
|   //
 | |
|   // Create the DNS DeviceNode.
 | |
|   //
 | |
|   DnsDeviceNodeLength = (UINT16) (sizeof (EFI_DEVICE_PATH_PROTOCOL) + sizeof (UINT8) + DnsServerIpCount * sizeof (EFI_IP_ADDRESS));
 | |
|   DnsDeviceNode       = (DNS_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                               MESSAGING_DEVICE_PATH,
 | |
|                                               MSG_DNS_DP,
 | |
|                                               DnsDeviceNodeLength
 | |
|                                               );
 | |
|   if (DnsDeviceNode == NULL) {
 | |
|     return NULL;
 | |
|   }
 | |
| 
 | |
|   //
 | |
|   // Confirm the DNS server address is IPv4 or IPv6 type.
 | |
|   //
 | |
|   DeviceNodeStrPtr = TextDeviceNode;
 | |
|   while (!IS_NULL (*DeviceNodeStrPtr)) {
 | |
|     if (*DeviceNodeStrPtr == L'.') {
 | |
|       DnsDeviceNode->IsIPv6 = 0x00;
 | |
|       break;
 | |
|     }
 | |
| 
 | |
|     if (*DeviceNodeStrPtr == L':') {
 | |
|       DnsDeviceNode->IsIPv6 = 0x01;
 | |
|       break;
 | |
|     }
 | |
| 
 | |
|     DeviceNodeStrPtr++;
 | |
|   }
 | |
| 
 | |
|   for (DnsServerIpIndex = 0; DnsServerIpIndex < DnsServerIpCount; DnsServerIpIndex++) {
 | |
|     DnsServerIp = GetNextParamStr (&TextDeviceNode);
 | |
|     if (DnsDeviceNode->IsIPv6 == 0x00) {
 | |
|       StrToIpv4Address (DnsServerIp,  NULL, &(DnsDeviceNode->DnsServerIp[DnsServerIpIndex].v4), NULL);
 | |
|     } else {
 | |
|       StrToIpv6Address (DnsServerIp, NULL, &(DnsDeviceNode->DnsServerIp[DnsServerIpIndex].v6), NULL);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) DnsDeviceNode;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to URI device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created URI device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextUri (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16           *UriStr;
 | |
|   UINTN            UriLength;
 | |
|   URI_DEVICE_PATH  *Uri;
 | |
| 
 | |
|   UriStr = GetNextParamStr (&TextDeviceNode);
 | |
|   UriLength = StrnLenS (UriStr, MAX_UINT16 - sizeof (URI_DEVICE_PATH));
 | |
|   Uri    = (URI_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                  MESSAGING_DEVICE_PATH,
 | |
|                                  MSG_URI_DP,
 | |
|                                  (UINT16) (sizeof (URI_DEVICE_PATH) + UriLength)
 | |
|                                  );
 | |
| 
 | |
|   while (UriLength-- != 0) {
 | |
|     Uri->Uri[UriLength] = (CHAR8) UriStr[UriLength];
 | |
|   }
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) Uri;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a media text device path node to media device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to media device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextMediaPath (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   return DevPathFromTextGenericPath (MEDIA_DEVICE_PATH, TextDeviceNode);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to HD device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created HD device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextHD (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16                *PartitionStr;
 | |
|   CHAR16                *TypeStr;
 | |
|   CHAR16                *SignatureStr;
 | |
|   CHAR16                *StartStr;
 | |
|   CHAR16                *SizeStr;
 | |
|   UINT32                Signature32;
 | |
|   HARDDRIVE_DEVICE_PATH *Hd;
 | |
| 
 | |
|   PartitionStr        = GetNextParamStr (&TextDeviceNode);
 | |
|   TypeStr             = GetNextParamStr (&TextDeviceNode);
 | |
|   SignatureStr        = GetNextParamStr (&TextDeviceNode);
 | |
|   StartStr            = GetNextParamStr (&TextDeviceNode);
 | |
|   SizeStr             = GetNextParamStr (&TextDeviceNode);
 | |
|   Hd                  = (HARDDRIVE_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                                     MEDIA_DEVICE_PATH,
 | |
|                                                     MEDIA_HARDDRIVE_DP,
 | |
|                                                     (UINT16) sizeof (HARDDRIVE_DEVICE_PATH)
 | |
|                                                     );
 | |
| 
 | |
|   Hd->PartitionNumber = (UINT32) Strtoi (PartitionStr);
 | |
| 
 | |
|   ZeroMem (Hd->Signature, 16);
 | |
|   Hd->MBRType = (UINT8) 0;
 | |
| 
 | |
|   if (StrCmp (TypeStr, L"MBR") == 0) {
 | |
|     Hd->SignatureType = SIGNATURE_TYPE_MBR;
 | |
|     Hd->MBRType       = 0x01;
 | |
| 
 | |
|     Signature32       = (UINT32) Strtoi (SignatureStr);
 | |
|     memcpy (Hd->Signature, &Signature32, sizeof (UINT32));
 | |
|   } else if (StrCmp (TypeStr, L"GPT") == 0) {
 | |
|     Hd->SignatureType = SIGNATURE_TYPE_GUID;
 | |
|     Hd->MBRType       = 0x02;
 | |
| 
 | |
|     StrToGuid (SignatureStr, (EFI_GUID *) Hd->Signature);
 | |
|   } else {
 | |
|     Hd->SignatureType = (UINT8) Strtoi (TypeStr);
 | |
|   }
 | |
| 
 | |
|   Strtoi64 (StartStr, &Hd->PartitionStart);
 | |
|   Strtoi64 (SizeStr, &Hd->PartitionSize);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) Hd;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to CDROM device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created CDROM device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextCDROM (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16            *EntryStr;
 | |
|   CHAR16            *StartStr;
 | |
|   CHAR16            *SizeStr;
 | |
|   CDROM_DEVICE_PATH *CDROMDevPath;
 | |
| 
 | |
|   EntryStr              = GetNextParamStr (&TextDeviceNode);
 | |
|   StartStr              = GetNextParamStr (&TextDeviceNode);
 | |
|   SizeStr               = GetNextParamStr (&TextDeviceNode);
 | |
|   CDROMDevPath          = (CDROM_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                                   MEDIA_DEVICE_PATH,
 | |
|                                                   MEDIA_CDROM_DP,
 | |
|                                                   (UINT16) sizeof (CDROM_DEVICE_PATH)
 | |
|                                                   );
 | |
| 
 | |
|   CDROMDevPath->BootEntry = (UINT32) Strtoi (EntryStr);
 | |
|   Strtoi64 (StartStr, &CDROMDevPath->PartitionStart);
 | |
|   Strtoi64 (SizeStr, &CDROMDevPath->PartitionSize);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) CDROMDevPath;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to Vendor-defined media device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created Vendor-defined media device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextVenMedia (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   return ConvertFromTextVendor (
 | |
|            TextDeviceNode,
 | |
|            MEDIA_DEVICE_PATH,
 | |
|            MEDIA_VENDOR_DP
 | |
|            );
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to File device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created File device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextFilePath (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   FILEPATH_DEVICE_PATH  *File;
 | |
| 
 | |
|   File = (FILEPATH_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                     MEDIA_DEVICE_PATH,
 | |
|                                     MEDIA_FILEPATH_DP,
 | |
|                                     (UINT16) (sizeof (FILEPATH_DEVICE_PATH) + StrLen (TextDeviceNode) * 2)
 | |
|                                     );
 | |
| 
 | |
|   StrCpyS (File->PathName, StrLen (TextDeviceNode) + 1, TextDeviceNode);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) File;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to Media protocol device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created Media protocol device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextMedia (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16                      *GuidStr;
 | |
|   MEDIA_PROTOCOL_DEVICE_PATH  *Media;
 | |
| 
 | |
|   GuidStr = GetNextParamStr (&TextDeviceNode);
 | |
|   Media   = (MEDIA_PROTOCOL_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                              MEDIA_DEVICE_PATH,
 | |
|                                              MEDIA_PROTOCOL_DP,
 | |
|                                              (UINT16) sizeof (MEDIA_PROTOCOL_DEVICE_PATH)
 | |
|                                              );
 | |
| 
 | |
|   StrToGuid (GuidStr, &Media->Protocol);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) Media;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to firmware volume device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created firmware volume device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextFv (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16                    *GuidStr;
 | |
|   MEDIA_FW_VOL_DEVICE_PATH  *Fv;
 | |
| 
 | |
|   GuidStr = GetNextParamStr (&TextDeviceNode);
 | |
|   Fv      = (MEDIA_FW_VOL_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                            MEDIA_DEVICE_PATH,
 | |
|                                            MEDIA_PIWG_FW_VOL_DP,
 | |
|                                            (UINT16) sizeof (MEDIA_FW_VOL_DEVICE_PATH)
 | |
|                                            );
 | |
| 
 | |
|   StrToGuid (GuidStr, &Fv->FvName);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) Fv;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to firmware file device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created firmware file device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextFvFile (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16                             *GuidStr;
 | |
|   MEDIA_FW_VOL_FILEPATH_DEVICE_PATH  *FvFile;
 | |
| 
 | |
|   GuidStr = GetNextParamStr (&TextDeviceNode);
 | |
|   FvFile  = (MEDIA_FW_VOL_FILEPATH_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                                     MEDIA_DEVICE_PATH,
 | |
|                                                     MEDIA_PIWG_FW_FILE_DP,
 | |
|                                                     (UINT16) sizeof (MEDIA_FW_VOL_FILEPATH_DEVICE_PATH)
 | |
|                                                     );
 | |
| 
 | |
|   StrToGuid (GuidStr, &FvFile->FvFileName);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) FvFile;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to text relative offset device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created Text device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextRelativeOffsetRange (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16                                  *StartingOffsetStr;
 | |
|   CHAR16                                  *EndingOffsetStr;
 | |
|   MEDIA_RELATIVE_OFFSET_RANGE_DEVICE_PATH *Offset;
 | |
| 
 | |
|   StartingOffsetStr = GetNextParamStr (&TextDeviceNode);
 | |
|   EndingOffsetStr   = GetNextParamStr (&TextDeviceNode);
 | |
|   Offset            = (MEDIA_RELATIVE_OFFSET_RANGE_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                                                     MEDIA_DEVICE_PATH,
 | |
|                                                                     MEDIA_RELATIVE_OFFSET_RANGE_DP,
 | |
|                                                                     (UINT16) sizeof (MEDIA_RELATIVE_OFFSET_RANGE_DEVICE_PATH)
 | |
|                                                                     );
 | |
| 
 | |
|   Strtoi64 (StartingOffsetStr, &Offset->StartingOffset);
 | |
|   Strtoi64 (EndingOffsetStr, &Offset->EndingOffset);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) Offset;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to text ram disk device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created Text device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextRamDisk (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16                                  *StartingAddrStr;
 | |
|   CHAR16                                  *EndingAddrStr;
 | |
|   CHAR16                                  *TypeGuidStr;
 | |
|   CHAR16                                  *InstanceStr;
 | |
|   MEDIA_RAM_DISK_DEVICE_PATH              *RamDisk;
 | |
|   UINT64                                  StartingAddr;
 | |
|   UINT64                                  EndingAddr;
 | |
| 
 | |
|   StartingAddrStr = GetNextParamStr (&TextDeviceNode);
 | |
|   EndingAddrStr   = GetNextParamStr (&TextDeviceNode);
 | |
|   InstanceStr     = GetNextParamStr (&TextDeviceNode);
 | |
|   TypeGuidStr     = GetNextParamStr (&TextDeviceNode);
 | |
|   RamDisk         = (MEDIA_RAM_DISK_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                                      MEDIA_DEVICE_PATH,
 | |
|                                                      MEDIA_RAM_DISK_DP,
 | |
|                                                      (UINT16) sizeof (MEDIA_RAM_DISK_DEVICE_PATH)
 | |
|                                                      );
 | |
| 
 | |
|   Strtoi64 (StartingAddrStr, &StartingAddr);
 | |
|   WriteUnaligned64 ((UINT64 *) &(RamDisk->StartingAddr[0]), StartingAddr);
 | |
|   Strtoi64 (EndingAddrStr, &EndingAddr);
 | |
|   WriteUnaligned64 ((UINT64 *) &(RamDisk->EndingAddr[0]), EndingAddr);
 | |
|   RamDisk->Instance = (UINT16) Strtoi (InstanceStr);
 | |
|   StrToGuid (TypeGuidStr, &RamDisk->TypeGuid);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) RamDisk;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to text virtual disk device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created Text device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextVirtualDisk (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16                                  *StartingAddrStr;
 | |
|   CHAR16                                  *EndingAddrStr;
 | |
|   CHAR16                                  *InstanceStr;
 | |
|   MEDIA_RAM_DISK_DEVICE_PATH              *RamDisk;
 | |
|   UINT64                                  StartingAddr;
 | |
|   UINT64                                  EndingAddr;
 | |
| 
 | |
|   StartingAddrStr = GetNextParamStr (&TextDeviceNode);
 | |
|   EndingAddrStr   = GetNextParamStr (&TextDeviceNode);
 | |
|   InstanceStr     = GetNextParamStr (&TextDeviceNode);
 | |
| 
 | |
|   RamDisk         = (MEDIA_RAM_DISK_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                                      MEDIA_DEVICE_PATH,
 | |
|                                                      MEDIA_RAM_DISK_DP,
 | |
|                                                      (UINT16) sizeof (MEDIA_RAM_DISK_DEVICE_PATH)
 | |
|                                                      );
 | |
| 
 | |
|   Strtoi64 (StartingAddrStr, &StartingAddr);
 | |
|   WriteUnaligned64 ((UINT64 *) &(RamDisk->StartingAddr[0]), StartingAddr);
 | |
|   Strtoi64 (EndingAddrStr, &EndingAddr);
 | |
|   WriteUnaligned64 ((UINT64 *) &(RamDisk->EndingAddr[0]), EndingAddr);
 | |
|   RamDisk->Instance = (UINT16) Strtoi (InstanceStr);
 | |
|   CopyGuid (&RamDisk->TypeGuid, &gEfiVirtualDiskGuid);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) RamDisk;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to text virtual cd device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created Text device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextVirtualCd (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16                                  *StartingAddrStr;
 | |
|   CHAR16                                  *EndingAddrStr;
 | |
|   CHAR16                                  *InstanceStr;
 | |
|   MEDIA_RAM_DISK_DEVICE_PATH              *RamDisk;
 | |
|   UINT64                                  StartingAddr;
 | |
|   UINT64                                  EndingAddr;
 | |
| 
 | |
|   StartingAddrStr = GetNextParamStr (&TextDeviceNode);
 | |
|   EndingAddrStr   = GetNextParamStr (&TextDeviceNode);
 | |
|   InstanceStr     = GetNextParamStr (&TextDeviceNode);
 | |
| 
 | |
|   RamDisk         = (MEDIA_RAM_DISK_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                                      MEDIA_DEVICE_PATH,
 | |
|                                                      MEDIA_RAM_DISK_DP,
 | |
|                                                      (UINT16) sizeof (MEDIA_RAM_DISK_DEVICE_PATH)
 | |
|                                                      );
 | |
| 
 | |
|   Strtoi64 (StartingAddrStr, &StartingAddr);
 | |
|   WriteUnaligned64 ((UINT64 *) &(RamDisk->StartingAddr[0]), StartingAddr);
 | |
|   Strtoi64 (EndingAddrStr, &EndingAddr);
 | |
|   WriteUnaligned64 ((UINT64 *) &(RamDisk->EndingAddr[0]), EndingAddr);
 | |
|   RamDisk->Instance = (UINT16) Strtoi (InstanceStr);
 | |
|   CopyGuid (&RamDisk->TypeGuid, &gEfiVirtualCdGuid);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) RamDisk;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to text persistent virtual disk device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created Text device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextPersistentVirtualDisk (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16                                  *StartingAddrStr;
 | |
|   CHAR16                                  *EndingAddrStr;
 | |
|   CHAR16                                  *InstanceStr;
 | |
|   MEDIA_RAM_DISK_DEVICE_PATH              *RamDisk;
 | |
|   UINT64                                  StartingAddr;
 | |
|   UINT64                                  EndingAddr;
 | |
| 
 | |
|   StartingAddrStr = GetNextParamStr (&TextDeviceNode);
 | |
|   EndingAddrStr   = GetNextParamStr (&TextDeviceNode);
 | |
|   InstanceStr     = GetNextParamStr (&TextDeviceNode);
 | |
| 
 | |
|   RamDisk         = (MEDIA_RAM_DISK_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                                      MEDIA_DEVICE_PATH,
 | |
|                                                      MEDIA_RAM_DISK_DP,
 | |
|                                                      (UINT16) sizeof (MEDIA_RAM_DISK_DEVICE_PATH)
 | |
|                                                      );
 | |
| 
 | |
|   Strtoi64 (StartingAddrStr, &StartingAddr);
 | |
|   WriteUnaligned64 ((UINT64 *) &(RamDisk->StartingAddr[0]), StartingAddr);
 | |
|   Strtoi64 (EndingAddrStr, &EndingAddr);
 | |
|   WriteUnaligned64 ((UINT64 *) &(RamDisk->EndingAddr[0]), EndingAddr);
 | |
|   RamDisk->Instance = (UINT16) Strtoi (InstanceStr);
 | |
|   CopyGuid (&RamDisk->TypeGuid, &gEfiPersistentVirtualDiskGuid);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) RamDisk;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to text persistent virtual cd device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created Text device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextPersistentVirtualCd (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16                                  *StartingAddrStr;
 | |
|   CHAR16                                  *EndingAddrStr;
 | |
|   CHAR16                                  *InstanceStr;
 | |
|   MEDIA_RAM_DISK_DEVICE_PATH              *RamDisk;
 | |
|   UINT64                                  StartingAddr;
 | |
|   UINT64                                  EndingAddr;
 | |
| 
 | |
|   StartingAddrStr = GetNextParamStr (&TextDeviceNode);
 | |
|   EndingAddrStr   = GetNextParamStr (&TextDeviceNode);
 | |
|   InstanceStr     = GetNextParamStr (&TextDeviceNode);
 | |
| 
 | |
|   RamDisk         = (MEDIA_RAM_DISK_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                                      MEDIA_DEVICE_PATH,
 | |
|                                                      MEDIA_RAM_DISK_DP,
 | |
|                                                      (UINT16) sizeof (MEDIA_RAM_DISK_DEVICE_PATH)
 | |
|                                                      );
 | |
| 
 | |
|   Strtoi64 (StartingAddrStr, &StartingAddr);
 | |
|   WriteUnaligned64 ((UINT64 *) &(RamDisk->StartingAddr[0]), StartingAddr);
 | |
|   Strtoi64 (EndingAddrStr, &EndingAddr);
 | |
|   WriteUnaligned64 ((UINT64 *) &(RamDisk->EndingAddr[0]), EndingAddr);
 | |
|   RamDisk->Instance = (UINT16) Strtoi (InstanceStr);
 | |
|   CopyGuid (&RamDisk->TypeGuid, &gEfiPersistentVirtualCdGuid);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) RamDisk;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a BBS text device path node to BBS device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to BBS device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextBbsPath (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   return DevPathFromTextGenericPath (BBS_DEVICE_PATH, TextDeviceNode);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to BIOS Boot Specification device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created BIOS Boot Specification device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextBBS (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   CHAR16              *TypeStr;
 | |
|   CHAR16              *IdStr;
 | |
|   CHAR16              *FlagsStr;
 | |
|   CHAR8               *AsciiStr;
 | |
|   BBS_BBS_DEVICE_PATH *Bbs;
 | |
| 
 | |
|   TypeStr   = GetNextParamStr (&TextDeviceNode);
 | |
|   IdStr     = GetNextParamStr (&TextDeviceNode);
 | |
|   FlagsStr  = GetNextParamStr (&TextDeviceNode);
 | |
|   Bbs       = (BBS_BBS_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                         BBS_DEVICE_PATH,
 | |
|                                         BBS_BBS_DP,
 | |
|                                         (UINT16) (sizeof (BBS_BBS_DEVICE_PATH) + StrLen (IdStr))
 | |
|                                         );
 | |
| 
 | |
|   if (StrCmp (TypeStr, L"Floppy") == 0) {
 | |
|     Bbs->DeviceType = BBS_TYPE_FLOPPY;
 | |
|   } else if (StrCmp (TypeStr, L"HD") == 0) {
 | |
|     Bbs->DeviceType = BBS_TYPE_HARDDRIVE;
 | |
|   } else if (StrCmp (TypeStr, L"CDROM") == 0) {
 | |
|     Bbs->DeviceType = BBS_TYPE_CDROM;
 | |
|   } else if (StrCmp (TypeStr, L"PCMCIA") == 0) {
 | |
|     Bbs->DeviceType = BBS_TYPE_PCMCIA;
 | |
|   } else if (StrCmp (TypeStr, L"USB") == 0) {
 | |
|     Bbs->DeviceType = BBS_TYPE_USB;
 | |
|   } else if (StrCmp (TypeStr, L"Network") == 0) {
 | |
|     Bbs->DeviceType = BBS_TYPE_EMBEDDED_NETWORK;
 | |
|   } else {
 | |
|     Bbs->DeviceType = (UINT16) Strtoi (TypeStr);
 | |
|   }
 | |
| 
 | |
|   AsciiStr = Bbs->String;
 | |
|   StrToAscii (IdStr, &AsciiStr);
 | |
| 
 | |
|   Bbs->StatusFlag = (UINT16) Strtoi (FlagsStr);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) Bbs;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a text device path node to SATA device path structure.
 | |
| 
 | |
|   @param TextDeviceNode  The input Text device path node.
 | |
| 
 | |
|   @return A pointer to the newly-created SATA device path structure.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| DevPathFromTextSata (
 | |
|    CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   SATA_DEVICE_PATH *Sata;
 | |
|   CHAR16           *Param1;
 | |
|   CHAR16           *Param2;
 | |
|   CHAR16           *Param3;
 | |
| 
 | |
|   Param1 = GetNextParamStr (&TextDeviceNode);
 | |
|   Param2 = GetNextParamStr (&TextDeviceNode);
 | |
|   Param3 = GetNextParamStr (&TextDeviceNode);
 | |
| 
 | |
|   Sata = (SATA_DEVICE_PATH *) CreateDeviceNode (
 | |
|                                 MESSAGING_DEVICE_PATH,
 | |
|                                 MSG_SATA_DP,
 | |
|                                 (UINT16) sizeof (SATA_DEVICE_PATH)
 | |
|                                 );
 | |
|   Sata->HBAPortNumber            = (UINT16) Strtoi (Param1);
 | |
| 
 | |
|   //
 | |
|   // According to UEFI spec, if PMPN is not provided, the default is 0xFFFF
 | |
|   //
 | |
|   if (*Param2 == L'\0' ) {
 | |
|     Sata->PortMultiplierPortNumber = 0xFFFF;
 | |
|   } else {
 | |
|     Sata->PortMultiplierPortNumber = (UINT16) Strtoi (Param2);
 | |
|   }
 | |
|   Sata->Lun                      = (UINT16) Strtoi (Param3);
 | |
| 
 | |
|   return (EFI_DEVICE_PATH_PROTOCOL *) Sata;
 | |
| }
 | |
| 
 | |
| DEVICE_PATH_FROM_TEXT_TABLE mUefiDevicePathLibDevPathFromTextTable[] = {
 | |
|   {L"Path",                    DevPathFromTextPath                    },
 | |
| 
 | |
|   {L"HardwarePath",            DevPathFromTextHardwarePath            },
 | |
|   {L"Pci",                     DevPathFromTextPci                     },
 | |
|   {L"PcCard",                  DevPathFromTextPcCard                  },
 | |
|   {L"MemoryMapped",            DevPathFromTextMemoryMapped            },
 | |
|   {L"VenHw",                   DevPathFromTextVenHw                   },
 | |
|   {L"Ctrl",                    DevPathFromTextCtrl                    },
 | |
|   {L"BMC",                     DevPathFromTextBmc                     },
 | |
| 
 | |
|   {L"AcpiPath",                DevPathFromTextAcpiPath                },
 | |
|   {L"Acpi",                    DevPathFromTextAcpi                    },
 | |
|   {L"PciRoot",                 DevPathFromTextPciRoot                 },
 | |
|   {L"PcieRoot",                DevPathFromTextPcieRoot                },
 | |
|   {L"Floppy",                  DevPathFromTextFloppy                  },
 | |
|   {L"Keyboard",                DevPathFromTextKeyboard                },
 | |
|   {L"Serial",                  DevPathFromTextSerial                  },
 | |
|   {L"ParallelPort",            DevPathFromTextParallelPort            },
 | |
|   {L"AcpiEx",                  DevPathFromTextAcpiEx                  },
 | |
|   {L"AcpiExp",                 DevPathFromTextAcpiExp                 },
 | |
|   {L"AcpiAdr",                 DevPathFromTextAcpiAdr                 },
 | |
| 
 | |
|   {L"Msg",                     DevPathFromTextMsg                     },
 | |
|   {L"Ata",                     DevPathFromTextAta                     },
 | |
|   {L"Scsi",                    DevPathFromTextScsi                    },
 | |
|   {L"Fibre",                   DevPathFromTextFibre                   },
 | |
|   {L"FibreEx",                 DevPathFromTextFibreEx                 },
 | |
|   {L"I1394",                   DevPathFromText1394                    },
 | |
|   {L"USB",                     DevPathFromTextUsb                     },
 | |
|   {L"I2O",                     DevPathFromTextI2O                     },
 | |
|   {L"Infiniband",              DevPathFromTextInfiniband              },
 | |
|   {L"VenMsg",                  DevPathFromTextVenMsg                  },
 | |
|   {L"VenPcAnsi",               DevPathFromTextVenPcAnsi               },
 | |
|   {L"VenVt100",                DevPathFromTextVenVt100                },
 | |
|   {L"VenVt100Plus",            DevPathFromTextVenVt100Plus            },
 | |
|   {L"VenUtf8",                 DevPathFromTextVenUtf8                 },
 | |
|   {L"UartFlowCtrl",            DevPathFromTextUartFlowCtrl            },
 | |
|   {L"SAS",                     DevPathFromTextSAS                     },
 | |
|   {L"SasEx",                   DevPathFromTextSasEx                   },
 | |
|   {L"NVMe",                    DevPathFromTextNVMe                    },
 | |
|   {L"UFS",                     DevPathFromTextUfs                     },
 | |
|   {L"SD",                      DevPathFromTextSd                      },
 | |
|   {L"eMMC",                    DevPathFromTextEmmc                    },
 | |
|   {L"DebugPort",               DevPathFromTextDebugPort               },
 | |
|   {L"MAC",                     DevPathFromTextMAC                     },
 | |
|   {L"IPv4",                    DevPathFromTextIPv4                    },
 | |
|   {L"IPv6",                    DevPathFromTextIPv6                    },
 | |
|   {L"Uart",                    DevPathFromTextUart                    },
 | |
|   {L"UsbClass",                DevPathFromTextUsbClass                },
 | |
|   {L"UsbAudio",                DevPathFromTextUsbAudio                },
 | |
|   {L"UsbCDCControl",           DevPathFromTextUsbCDCControl           },
 | |
|   {L"UsbHID",                  DevPathFromTextUsbHID                  },
 | |
|   {L"UsbImage",                DevPathFromTextUsbImage                },
 | |
|   {L"UsbPrinter",              DevPathFromTextUsbPrinter              },
 | |
|   {L"UsbMassStorage",          DevPathFromTextUsbMassStorage          },
 | |
|   {L"UsbHub",                  DevPathFromTextUsbHub                  },
 | |
|   {L"UsbCDCData",              DevPathFromTextUsbCDCData              },
 | |
|   {L"UsbSmartCard",            DevPathFromTextUsbSmartCard            },
 | |
|   {L"UsbVideo",                DevPathFromTextUsbVideo                },
 | |
|   {L"UsbDiagnostic",           DevPathFromTextUsbDiagnostic           },
 | |
|   {L"UsbWireless",             DevPathFromTextUsbWireless             },
 | |
|   {L"UsbDeviceFirmwareUpdate", DevPathFromTextUsbDeviceFirmwareUpdate },
 | |
|   {L"UsbIrdaBridge",           DevPathFromTextUsbIrdaBridge           },
 | |
|   {L"UsbTestAndMeasurement",   DevPathFromTextUsbTestAndMeasurement   },
 | |
|   {L"UsbWwid",                 DevPathFromTextUsbWwid                 },
 | |
|   {L"Unit",                    DevPathFromTextUnit                    },
 | |
|   {L"iSCSI",                   DevPathFromTextiSCSI                   },
 | |
|   {L"Vlan",                    DevPathFromTextVlan                    },
 | |
|   {L"Dns",                     DevPathFromTextDns                     },
 | |
|   {L"Uri",                     DevPathFromTextUri                     },
 | |
|   {L"Bluetooth",               DevPathFromTextBluetooth               },
 | |
|   {L"Wi-Fi",                   DevPathFromTextWiFi                    },
 | |
|   {L"BluetoothLE",             DevPathFromTextBluetoothLE             },
 | |
|   {L"MediaPath",               DevPathFromTextMediaPath               },
 | |
|   {L"HD",                      DevPathFromTextHD                      },
 | |
|   {L"CDROM",                   DevPathFromTextCDROM                   },
 | |
|   {L"VenMedia",                DevPathFromTextVenMedia                },
 | |
|   {L"Media",                   DevPathFromTextMedia                   },
 | |
|   {L"Fv",                      DevPathFromTextFv                      },
 | |
|   {L"FvFile",                  DevPathFromTextFvFile                  },
 | |
|   {L"Offset",                  DevPathFromTextRelativeOffsetRange     },
 | |
|   {L"RamDisk",                 DevPathFromTextRamDisk                 },
 | |
|   {L"VirtualDisk",             DevPathFromTextVirtualDisk             },
 | |
|   {L"VirtualCD",               DevPathFromTextVirtualCd               },
 | |
|   {L"PersistentVirtualDisk",   DevPathFromTextPersistentVirtualDisk   },
 | |
|   {L"PersistentVirtualCD",     DevPathFromTextPersistentVirtualCd     },
 | |
| 
 | |
|   {L"BbsPath",                 DevPathFromTextBbsPath                 },
 | |
|   {L"BBS",                     DevPathFromTextBBS                     },
 | |
|   {L"Sata",                    DevPathFromTextSata                    },
 | |
|   {NULL, NULL}
 | |
| };
 | |
| 
 | |
| /**
 | |
|   Convert text to the binary representation of a device node.
 | |
| 
 | |
|   @param TextDeviceNode  TextDeviceNode points to the text representation of a device
 | |
|                          node. Conversion starts with the first character and continues
 | |
|                          until the first non-device node character.
 | |
| 
 | |
|   @return A pointer to the EFI device node or NULL if TextDeviceNode is NULL or there was
 | |
|           insufficient memory or text unsupported.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| UefiDevicePathLibConvertTextToDeviceNode (
 | |
|    CONST CHAR16 *TextDeviceNode
 | |
|   )
 | |
| {
 | |
|   DEVICE_PATH_FROM_TEXT    FromText;
 | |
|   CHAR16                   *ParamStr;
 | |
|   EFI_DEVICE_PATH_PROTOCOL *DeviceNode;
 | |
|   CHAR16                   *DeviceNodeStr;
 | |
|   UINTN                    Index;
 | |
| 
 | |
|   if ((TextDeviceNode == NULL) || (IS_NULL (*TextDeviceNode))) {
 | |
|     return NULL;
 | |
|   }
 | |
| 
 | |
|   ParamStr      = NULL;
 | |
|   FromText      = NULL;
 | |
|   DeviceNodeStr = UefiDevicePathLibStrDuplicate (TextDeviceNode);
 | |
|   ASSERT (DeviceNodeStr != NULL);
 | |
| 
 | |
|   for (Index = 0; mUefiDevicePathLibDevPathFromTextTable[Index].Function != NULL; Index++) {
 | |
|     ParamStr = GetParamByNodeName (DeviceNodeStr, mUefiDevicePathLibDevPathFromTextTable[Index].DevicePathNodeText);
 | |
|     if (ParamStr != NULL) {
 | |
|       FromText = mUefiDevicePathLibDevPathFromTextTable[Index].Function;
 | |
|       break;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   if (FromText == NULL) {
 | |
|     //
 | |
|     // A file path
 | |
|     //
 | |
|     FromText = DevPathFromTextFilePath;
 | |
|     DeviceNode = FromText (DeviceNodeStr);
 | |
|     //
 | |
|     // According to above logic, if 'FromText' is NULL in the 'if' statement,
 | |
|     // then 'ParamStr' must be NULL as well. No memory allocation has been made
 | |
|     // in this case.
 | |
|     //
 | |
|     // The below check is for addressing a false positive potential memory leak
 | |
|     // issue raised from static analysis.
 | |
|     //
 | |
|     if (ParamStr != NULL) {
 | |
|       free (ParamStr);
 | |
|     }
 | |
|   } else {
 | |
|     DeviceNode = FromText (ParamStr);
 | |
|     free (ParamStr);
 | |
|   }
 | |
| 
 | |
|   free (DeviceNodeStr);
 | |
| 
 | |
|   return DeviceNode;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Convert text to the binary representation of a device path.
 | |
| 
 | |
| 
 | |
|   @param TextDevicePath  TextDevicePath points to the text representation of a device
 | |
|                          path. Conversion starts with the first character and continues
 | |
|                          until the first non-device node character.
 | |
| 
 | |
|   @return A pointer to the allocated device path or NULL if TextDeviceNode is NULL or
 | |
|           there was insufficient memory.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| UefiDevicePathLibConvertTextToDevicePath (
 | |
|    CONST CHAR16 *TextDevicePath
 | |
|   )
 | |
| {
 | |
|   EFI_DEVICE_PATH_PROTOCOL *DeviceNode;
 | |
|   EFI_DEVICE_PATH_PROTOCOL *NewDevicePath;
 | |
|   CHAR16                   *DevicePathStr;
 | |
|   CHAR16                   *Str;
 | |
|   CHAR16                   *DeviceNodeStr;
 | |
|   BOOLEAN                  IsInstanceEnd;
 | |
|   EFI_DEVICE_PATH_PROTOCOL *DevicePath;
 | |
| 
 | |
|   if ((TextDevicePath == NULL) || (IS_NULL (*TextDevicePath))) {
 | |
|     return NULL;
 | |
|   }
 | |
| 
 | |
|   DevicePath = (EFI_DEVICE_PATH_PROTOCOL *) AllocatePool (END_DEVICE_PATH_LENGTH);
 | |
|   ASSERT (DevicePath != NULL);
 | |
|   SetDevicePathEndNode (DevicePath);
 | |
| 
 | |
|   DevicePathStr = UefiDevicePathLibStrDuplicate (TextDevicePath);
 | |
| 
 | |
|   Str           = DevicePathStr;
 | |
|   while ((DeviceNodeStr = GetNextDeviceNodeStr (&Str, &IsInstanceEnd)) != NULL) {
 | |
|     DeviceNode = UefiDevicePathLibConvertTextToDeviceNode (DeviceNodeStr);
 | |
| 
 | |
|     NewDevicePath = AppendDevicePathNode (DevicePath, DeviceNode);
 | |
|     free (DevicePath);
 | |
|     free (DeviceNode);
 | |
|     DevicePath = NewDevicePath;
 | |
| 
 | |
|     if (IsInstanceEnd) {
 | |
|       DeviceNode = (EFI_DEVICE_PATH_PROTOCOL *) AllocatePool (END_DEVICE_PATH_LENGTH);
 | |
|       ASSERT (DeviceNode != NULL);
 | |
|       SetDevicePathEndNode (DeviceNode);
 | |
|       DeviceNode->SubType = END_INSTANCE_DEVICE_PATH_SUBTYPE;
 | |
| 
 | |
|       NewDevicePath = AppendDevicePathNode (DevicePath, DeviceNode);
 | |
|       free (DevicePath);
 | |
|       free (DeviceNode);
 | |
|       DevicePath = NewDevicePath;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   free (DevicePathStr);
 | |
|   return DevicePath;
 | |
| }
 |