mirror of
				https://git.proxmox.com/git/mirror_edk2
				synced 2025-10-25 09:06:22 +00:00 
			
		
		
		
	 572f5d8a7b
			
		
	
	
		572f5d8a7b
		
	
	
	
	
		
			
			git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@5479 6f19259b-4bc3-4df7-8a09-765794883524
		
			
				
	
	
		
			1926 lines
		
	
	
		
			59 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			1926 lines
		
	
	
		
			59 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /** @file
 | |
|   DevicePathToText protocol as defined in the UEFI 2.0 specification.
 | |
| 
 | |
| Copyright (c) 2006 - 2008, Intel Corporation. <BR>
 | |
| All rights reserved. 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 "DevicePath.h"
 | |
| 
 | |
| /**
 | |
|   Function unpacks a device path data structure so that all the nodes of a device path
 | |
|   are naturally aligned.
 | |
| 
 | |
|   @param DevPath         A pointer to a device path data structure
 | |
| 
 | |
|   @return If the memory for the device path is successfully allocated, then a pointer to the
 | |
|           new device path is returned.  Otherwise, NULL is returned.
 | |
| 
 | |
| **/
 | |
| EFI_DEVICE_PATH_PROTOCOL *
 | |
| UnpackDevicePath (
 | |
|   IN CONST EFI_DEVICE_PATH_PROTOCOL  *DevPath
 | |
|   )
 | |
| {
 | |
|   CONST EFI_DEVICE_PATH_PROTOCOL  *Src;
 | |
|   EFI_DEVICE_PATH_PROTOCOL  *Dest;
 | |
|   EFI_DEVICE_PATH_PROTOCOL  *NewPath;
 | |
|   UINTN                     Size;
 | |
| 
 | |
|   if (DevPath == NULL) {
 | |
|     return NULL;
 | |
|   }
 | |
|   //
 | |
|   // Walk device path and round sizes to valid boundries
 | |
|   //
 | |
|   Src   = DevPath;
 | |
|   Size  = 0;
 | |
|   for (;;) {
 | |
|     Size += DevicePathNodeLength (Src);
 | |
|     Size += ALIGN_SIZE (Size);
 | |
| 
 | |
|     if (IsDevicePathEnd (Src)) {
 | |
|       break;
 | |
|     }
 | |
| 
 | |
|     Src = (EFI_DEVICE_PATH_PROTOCOL *) NextDevicePathNode (Src);
 | |
|   }
 | |
|   //
 | |
|   // Allocate space for the unpacked path
 | |
|   //
 | |
|   NewPath = AllocateZeroPool (Size);
 | |
|   if (NewPath != NULL) {
 | |
| 
 | |
|     ASSERT (((UINTN) NewPath) % MIN_ALIGNMENT_SIZE == 0);
 | |
| 
 | |
|     //
 | |
|     // Copy each node
 | |
|     //
 | |
|     Src   = DevPath;
 | |
|     Dest  = NewPath;
 | |
|     for (;;) {
 | |
|       Size = DevicePathNodeLength (Src);
 | |
|       CopyMem (Dest, Src, Size);
 | |
|       Size += ALIGN_SIZE (Size);
 | |
|       SetDevicePathNodeLength (Dest, Size);
 | |
|       Dest->Type |= EFI_DP_TYPE_UNPACKED;
 | |
|       Dest = (EFI_DEVICE_PATH_PROTOCOL *) (((UINT8 *) Dest) + Size);
 | |
| 
 | |
|       if (IsDevicePathEnd (Src)) {
 | |
|         break;
 | |
|       }
 | |
| 
 | |
|       Src = (EFI_DEVICE_PATH_PROTOCOL *) NextDevicePathNode (Src);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   return NewPath;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Adjusts the size of a previously allocated buffer.
 | |
| 
 | |
|   @param OldPool         A pointer to the buffer whose size is being adjusted.
 | |
|   @param OldSize         The size of the current buffer.
 | |
|   @param NewSize         The size of the new buffer.
 | |
| 
 | |
|   @return A pointer to the new buffer or NULL if allocation fails.
 | |
| 
 | |
| **/
 | |
| VOID *
 | |
| ReallocatePool (
 | |
|   IN VOID                 *OldPool,
 | |
|   IN UINTN                OldSize,
 | |
|   IN UINTN                NewSize
 | |
|   )
 | |
| {
 | |
|   VOID  *NewPool;
 | |
| 
 | |
|   NewPool = NULL;
 | |
|   if (NewSize != 0) {
 | |
|     NewPool = AllocateZeroPool (NewSize);
 | |
|   }
 | |
| 
 | |
|   if (OldPool != NULL) {
 | |
|     if (NewPool != NULL) {
 | |
|       CopyMem (NewPool, OldPool, OldSize < NewSize ? OldSize : NewSize);
 | |
|     }
 | |
| 
 | |
|     FreePool (OldPool);
 | |
|   }
 | |
| 
 | |
|   return NewPool;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Concatenates a formatted unicode string to allocated pool. The caller must
 | |
|   free the resulting buffer.
 | |
| 
 | |
|   @param Str             Tracks the allocated pool, size in use, and
 | |
|                          amount of pool allocated.
 | |
|   @param Fmt             The format string
 | |
|   @param ...             Variable arguments based on the format string.
 | |
| 
 | |
|   @return Allocated buffer with the formatted string printed in it.
 | |
|           The caller must free the allocated buffer. The buffer
 | |
|           allocation is not packed.
 | |
| 
 | |
| **/
 | |
| CHAR16 *
 | |
| CatPrint (
 | |
|   IN OUT POOL_PRINT   *Str,
 | |
|   IN CHAR16           *Fmt,
 | |
|   ...
 | |
|   )
 | |
| {
 | |
|   UINT16  *AppendStr;
 | |
|   VA_LIST Args;
 | |
|   UINTN   Size;
 | |
| 
 | |
|   AppendStr = AllocateZeroPool (0x1000);
 | |
|   if (AppendStr == NULL) {
 | |
|     return Str->Str;
 | |
|   }
 | |
| 
 | |
|   VA_START (Args, Fmt);
 | |
|   UnicodeVSPrint (AppendStr, 0x1000, Fmt, Args);
 | |
|   VA_END (Args);
 | |
|   if (NULL == Str->Str) {
 | |
|     Size   = StrSize (AppendStr);
 | |
|     Str->Str  = AllocateZeroPool (Size);
 | |
|     ASSERT (Str->Str != NULL);
 | |
|   } else {
 | |
|     Size = StrSize (AppendStr) - sizeof (UINT16);
 | |
|     Size = Size + StrSize (Str->Str);
 | |
|     Str->Str = ReallocatePool (
 | |
|                 Str->Str,
 | |
|                 StrSize (Str->Str),
 | |
|                 Size
 | |
|                 );
 | |
|     ASSERT (Str->Str != NULL);
 | |
|   }
 | |
| 
 | |
|   Str->MaxLen = MAX_CHAR * sizeof (UINT16);
 | |
|   if (Size < Str->MaxLen) {
 | |
|     StrCat (Str->Str, AppendStr);
 | |
|     Str->Len = Size - sizeof (UINT16);
 | |
|   }
 | |
| 
 | |
|   FreePool (AppendStr);
 | |
|   return Str->Str;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a PCI device path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToTextPci (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   PCI_DEVICE_PATH *Pci;
 | |
| 
 | |
|   Pci = DevPath;
 | |
|   CatPrint (Str, L"Pci(0x%x,0x%x)", Pci->Device, Pci->Function);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a PC Card device path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToTextPccard (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   PCCARD_DEVICE_PATH  *Pccard;
 | |
| 
 | |
|   Pccard = DevPath;
 | |
|   CatPrint (Str, L"PcCard(0x%x)", Pccard->FunctionNumber);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a Memory Map device path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToTextMemMap (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   MEMMAP_DEVICE_PATH  *MemMap;
 | |
| 
 | |
|   MemMap = DevPath;
 | |
|   CatPrint (
 | |
|     Str,
 | |
|     L"MemoryMapped(0x%x,0x%lx,0x%lx)",
 | |
|     MemMap->MemoryType,
 | |
|     MemMap->StartingAddress,
 | |
|     MemMap->EndingAddress
 | |
|     );
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a Vendor device path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToTextVendor (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   VENDOR_DEVICE_PATH  *Vendor;
 | |
|   CHAR16              *Type;
 | |
|   UINTN               Index;
 | |
|   UINTN               DataLength;
 | |
|   UINT32              FlowControlMap;
 | |
|   UINT16              Info;
 | |
| 
 | |
|   Vendor = (VENDOR_DEVICE_PATH *) DevPath;
 | |
|   switch (DevicePathType (&Vendor->Header)) {
 | |
|   case HARDWARE_DEVICE_PATH:
 | |
|     Type = L"Hw";
 | |
|     break;
 | |
| 
 | |
|   case MESSAGING_DEVICE_PATH:
 | |
|     Type = L"Msg";
 | |
|     if (AllowShortcuts) {
 | |
|       if (CompareGuid (&Vendor->Guid, &gEfiPcAnsiGuid)) {
 | |
|         CatPrint (Str, L"VenPcAnsi()");
 | |
|         return ;
 | |
|       } else if (CompareGuid (&Vendor->Guid, &gEfiVT100Guid)) {
 | |
|         CatPrint (Str, L"VenVt100()");
 | |
|         return ;
 | |
|       } else if (CompareGuid (&Vendor->Guid, &gEfiVT100PlusGuid)) {
 | |
|         CatPrint (Str, L"VenVt100Plus()");
 | |
|         return ;
 | |
|       } else if (CompareGuid (&Vendor->Guid, &gEfiVTUTF8Guid)) {
 | |
|         CatPrint (Str, L"VenUft8()");
 | |
|         return ;
 | |
|       } else if (CompareGuid (&Vendor->Guid, &mEfiDevicePathMessagingUartFlowControlGuid)) {
 | |
|         FlowControlMap = (((UART_FLOW_CONTROL_DEVICE_PATH *) Vendor)->FlowControlMap);
 | |
|         switch (FlowControlMap & 0x00000003) {
 | |
|         case 0:
 | |
|           CatPrint (Str, L"UartFlowCtrl(%s)", L"None");
 | |
|           break;
 | |
| 
 | |
|         case 1:
 | |
|           CatPrint (Str, L"UartFlowCtrl(%s)", L"Hardware");
 | |
|           break;
 | |
| 
 | |
|         case 2:
 | |
|           CatPrint (Str, L"UartFlowCtrl(%s)", L"XonXoff");
 | |
|           break;
 | |
| 
 | |
|         default:
 | |
|           break;
 | |
|         }
 | |
| 
 | |
|         return ;
 | |
|       } else if (CompareGuid (&Vendor->Guid, &mEfiDevicePathMessagingSASGuid)) {
 | |
|         CatPrint (
 | |
|           Str,
 | |
|           L"SAS(0x%lx,0x%lx,0x%x,",
 | |
|           ((SAS_DEVICE_PATH *) Vendor)->SasAddress,
 | |
|           ((SAS_DEVICE_PATH *) Vendor)->Lun,
 | |
|           ((SAS_DEVICE_PATH *) Vendor)->RelativeTargetPort
 | |
|           );
 | |
|         Info = (((SAS_DEVICE_PATH *) Vendor)->DeviceTopology);
 | |
|         if ((Info & 0x0f) == 0) {
 | |
|           CatPrint (Str, L"NoTopology,0,0,0,");
 | |
|         } else if (((Info & 0x0f) == 1) || ((Info & 0x0f) == 2)) {
 | |
|           CatPrint (
 | |
|             Str,
 | |
|             L"%s,%s,%s,",
 | |
|             ((Info & (0x1 << 4)) != 0) ? L"SATA" : L"SAS",
 | |
|             ((Info & (0x1 << 5)) != 0) ? L"External" : L"Internal",
 | |
|             ((Info & (0x1 << 6)) != 0) ? L"Expanded" : L"Direct"
 | |
|             );
 | |
|           if ((Info & 0x0f) == 1) {
 | |
|             CatPrint (Str, L"0,");
 | |
|           } else {
 | |
|             CatPrint (Str, L"0x%x,", (Info >> 8) & 0xff);
 | |
|           }
 | |
|         } else {
 | |
|           CatPrint (Str, L"0,0,0,0,");
 | |
|         }
 | |
| 
 | |
|         CatPrint (Str, L"0x%x)", ((SAS_DEVICE_PATH *) Vendor)->Reserved);
 | |
|         return ;
 | |
|       } else if (CompareGuid (&Vendor->Guid, &gEfiDebugPortProtocolGuid)) {
 | |
|         CatPrint (Str, L"DebugPort()");
 | |
|         return ;
 | |
|       }
 | |
|     }
 | |
|     break;
 | |
| 
 | |
|   case MEDIA_DEVICE_PATH:
 | |
|     Type = L"Media";
 | |
|     break;
 | |
| 
 | |
|   default:
 | |
|     Type = L"?";
 | |
|     break;
 | |
|   }
 | |
| 
 | |
|   DataLength = DevicePathNodeLength (&Vendor->Header) - sizeof (VENDOR_DEVICE_PATH);
 | |
|   CatPrint (Str, L"Ven%s(%g", Type, &Vendor->Guid);
 | |
|   if (DataLength != 0) {
 | |
|     CatPrint (Str, L",");
 | |
|     for (Index = 0; Index < DataLength; Index++) {
 | |
|       CatPrint (Str, L"%02x", ((VENDOR_DEVICE_PATH_WITH_DATA *) Vendor)->VendorDefinedData[Index]);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   CatPrint (Str, L")");
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a Controller device path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToTextController (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   CONTROLLER_DEVICE_PATH  *Controller;
 | |
| 
 | |
|   Controller = DevPath;
 | |
|   CatPrint (
 | |
|     Str,
 | |
|     L"Ctrl(0x%x)",
 | |
|     Controller->ControllerNumber
 | |
|     );
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a ACPI device path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToTextAcpi (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   ACPI_HID_DEVICE_PATH  *Acpi;
 | |
| 
 | |
|   Acpi = DevPath;
 | |
|   if ((Acpi->HID & PNP_EISA_ID_MASK) == PNP_EISA_ID_CONST) {
 | |
|     switch (EISA_ID_TO_NUM (Acpi->HID)) {
 | |
|     case 0x0a03:
 | |
|       CatPrint (Str, L"PciRoot(0x%x)", Acpi->UID);
 | |
|       break;
 | |
| 
 | |
|     case 0x0604:
 | |
|       CatPrint (Str, L"Floppy(0x%x)", Acpi->UID);
 | |
|       break;
 | |
| 
 | |
|     case 0x0301:
 | |
|       CatPrint (Str, L"Keyboard(0x%x)", Acpi->UID);
 | |
|       break;
 | |
| 
 | |
|     case 0x0501:
 | |
|       CatPrint (Str, L"Serial(0x%x)", Acpi->UID);
 | |
|       break;
 | |
| 
 | |
|     case 0x0401:
 | |
|       CatPrint (Str, L"ParallelPort(0x%x)", Acpi->UID);
 | |
|       break;
 | |
| 
 | |
|     default:
 | |
|       CatPrint (Str, L"Acpi(PNP%04x,0x%x)", EISA_ID_TO_NUM (Acpi->HID), Acpi->UID);
 | |
|       break;
 | |
|     }
 | |
|   } else {
 | |
|     CatPrint (Str, L"Acpi(0x%08x,0x%x)", Acpi->HID, Acpi->UID);
 | |
|   }
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts EISA identification to string.
 | |
| 
 | |
|   @param EisaId        The input EISA identification.
 | |
|   @param Text          A pointer to the output string.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| EisaIdToText (
 | |
|   IN UINT32         EisaId,
 | |
|   IN OUT CHAR16     *Text
 | |
|   )
 | |
| {
 | |
|   CHAR16 PnpIdStr[17];
 | |
| 
 | |
|   //
 | |
|   //UnicodeSPrint ("%X", 0x0a03) => "0000000000000A03"
 | |
|   //
 | |
|   UnicodeSPrint (PnpIdStr, 17 * 2, L"%16X", EisaId >> 16);
 | |
| 
 | |
|   UnicodeSPrint (
 | |
|     Text,
 | |
|     sizeof (CHAR16) + sizeof (CHAR16) + sizeof (CHAR16) + sizeof (PnpIdStr),
 | |
|     L"%c%c%c%s",
 | |
|     '@' + ((EisaId >> 10) & 0x1f),
 | |
|     '@' + ((EisaId >>  5) & 0x1f),
 | |
|     '@' + ((EisaId >>  0) & 0x1f),
 | |
|     PnpIdStr + (16 - 4)
 | |
|     );
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a ACPI extended HID device path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToTextAcpiEx (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   ACPI_EXTENDED_HID_DEVICE_PATH  *AcpiEx;
 | |
|   CHAR8                          *HIDStr;
 | |
|   CHAR8                          *UIDStr;
 | |
|   CHAR8                          *CIDStr;
 | |
|   CHAR16                         HIDText[11];
 | |
|   CHAR16                         CIDText[11];
 | |
| 
 | |
|   AcpiEx = DevPath;
 | |
|   HIDStr = (CHAR8 *) (((UINT8 *) AcpiEx) + sizeof (ACPI_EXTENDED_HID_DEVICE_PATH));
 | |
|   UIDStr = HIDStr + AsciiStrLen (HIDStr) + 1;
 | |
|   CIDStr = UIDStr + AsciiStrLen (UIDStr) + 1;
 | |
| 
 | |
|   EisaIdToText (AcpiEx->HID, HIDText);
 | |
|   EisaIdToText (AcpiEx->CID, CIDText);
 | |
| 
 | |
|   if ((*HIDStr == '\0') && (*CIDStr == '\0') && (AcpiEx->UID == 0)) {
 | |
|     //
 | |
|     // use AcpiExp()
 | |
|     //
 | |
|     CatPrint (
 | |
|       Str,
 | |
|       L"AcpiExp(%s,%s,%a)",
 | |
|       HIDText,
 | |
|       CIDText,
 | |
|       UIDStr
 | |
|       );
 | |
|   } else {
 | |
|     if (AllowShortcuts) {
 | |
|       //
 | |
|       // display only
 | |
|       //
 | |
|       if (AcpiEx->HID == 0) {
 | |
|         CatPrint (Str, L"AcpiEx(%a,", HIDStr);
 | |
|       } else {
 | |
|         CatPrint (Str, L"AcpiEx(%s,", HIDText);
 | |
|       }
 | |
| 
 | |
|       if (AcpiEx->UID == 0) {
 | |
|         CatPrint (Str, L"%a,", UIDStr);
 | |
|       } else {
 | |
|         CatPrint (Str, L"0x%x,", AcpiEx->UID);
 | |
|       }
 | |
| 
 | |
|       if (AcpiEx->CID == 0) {
 | |
|         CatPrint (Str, L"%a)", CIDStr);
 | |
|       } else {
 | |
|         CatPrint (Str, L"%s)", CIDText);
 | |
|       }
 | |
|     } else {
 | |
|       CatPrint (
 | |
|         Str,
 | |
|         L"AcpiEx(%s,%s,0x%x,%a,%a,%a)",
 | |
|         HIDText,
 | |
|         CIDText,
 | |
|         AcpiEx->UID,
 | |
|         HIDStr,
 | |
|         CIDStr,
 | |
|         UIDStr
 | |
|         );
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a ACPI address device path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToTextAcpiAdr (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   ACPI_ADR_DEVICE_PATH    *AcpiAdr;
 | |
|   UINT16                  Index;
 | |
|   UINT16                  Length;
 | |
|   UINT16                  AdditionalAdrCount;
 | |
| 
 | |
|   AcpiAdr            = DevPath;
 | |
|   Length             = (UINT16) DevicePathNodeLength ((EFI_DEVICE_PATH_PROTOCOL *) AcpiAdr);
 | |
|   AdditionalAdrCount = (UINT16) ((Length - 8) / 4);
 | |
| 
 | |
|   CatPrint (Str, L"AcpiAdr(0x%x", AcpiAdr->ADR);
 | |
|   for (Index = 0; Index < AdditionalAdrCount; Index++) {
 | |
|     CatPrint (Str, L",0x%x", *(UINT32 *) ((UINT8 *) AcpiAdr + 8 + Index * 4));
 | |
|   }
 | |
|   CatPrint (Str, L")");
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a ATAPI device path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToTextAtapi (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   ATAPI_DEVICE_PATH *Atapi;
 | |
| 
 | |
|   Atapi = DevPath;
 | |
| 
 | |
|   if (DisplayOnly) {
 | |
|     CatPrint (Str, L"Ata(0x%x)", Atapi->Lun);
 | |
|   } else {
 | |
|     CatPrint (
 | |
|       Str,
 | |
|       L"Ata(%s,%s,0x%x)",
 | |
|       Atapi->PrimarySecondary ? L"Secondary" : L"Primary",
 | |
|       Atapi->SlaveMaster ? L"Slave" : L"Master",
 | |
|       Atapi->Lun
 | |
|       );
 | |
|   }
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a SCSI device path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToTextScsi (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   SCSI_DEVICE_PATH  *Scsi;
 | |
| 
 | |
|   Scsi = DevPath;
 | |
|   CatPrint (Str, L"Scsi(0x%x,0x%x)", Scsi->Pun, Scsi->Lun);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a Fibre device path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToTextFibre (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   FIBRECHANNEL_DEVICE_PATH  *Fibre;
 | |
| 
 | |
|   Fibre = DevPath;
 | |
|   CatPrint (Str, L"Fibre(0x%lx,0x%lx)", Fibre->WWN, Fibre->Lun);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a 1394 device path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToText1394 (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   F1394_DEVICE_PATH *F1394DevPath;
 | |
| 
 | |
|   F1394DevPath = DevPath;
 | |
|   //
 | |
|   // Guid has format of IEEE-EUI64
 | |
|   //
 | |
|   CatPrint (Str, L"I1394(%016lx)", F1394DevPath->Guid);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a USB device path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToTextUsb (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   USB_DEVICE_PATH *Usb;
 | |
| 
 | |
|   Usb = DevPath;
 | |
|   CatPrint (Str, L"USB(0x%x,0x%x)", Usb->ParentPortNumber, Usb->InterfaceNumber);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a USB WWID device path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToTextUsbWWID (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   USB_WWID_DEVICE_PATH  *UsbWWId;
 | |
|   CHAR16                *SerialNumberStr;
 | |
|   CHAR16                *NewStr;
 | |
|   UINT16                Length;
 | |
| 
 | |
|   UsbWWId = DevPath;
 | |
| 
 | |
|   SerialNumberStr = (CHAR16 *) ((UINT8 *) UsbWWId + sizeof (USB_WWID_DEVICE_PATH));
 | |
|   Length = (UINT16) ((DevicePathNodeLength ((EFI_DEVICE_PATH_PROTOCOL *) UsbWWId) - sizeof (USB_WWID_DEVICE_PATH)) / sizeof (CHAR16));
 | |
|   if (SerialNumberStr [Length - 1] != 0) {
 | |
|     //
 | |
|     // In case no NULL terminator in SerialNumber, create a new one with NULL terminator
 | |
|     //
 | |
|     NewStr = AllocateCopyPool ((Length + 1) * sizeof (CHAR16), SerialNumberStr);
 | |
|     NewStr [Length] = 0;
 | |
|     SerialNumberStr = NewStr;
 | |
|   }
 | |
| 
 | |
|   CatPrint (
 | |
|     Str,
 | |
|     L"UsbWwid(0x%x,0x%x,0x%x,\"%s\")",
 | |
|     UsbWWId->VendorId,
 | |
|     UsbWWId->ProductId,
 | |
|     UsbWWId->InterfaceNumber,
 | |
|     SerialNumberStr
 | |
|     );
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a Logic Unit device path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToTextLogicalUnit (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   DEVICE_LOGICAL_UNIT_DEVICE_PATH *LogicalUnit;
 | |
| 
 | |
|   LogicalUnit = DevPath;
 | |
|   CatPrint (Str, L"Unit(0x%x)", LogicalUnit->Lun);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a USB class device path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToTextUsbClass (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   USB_CLASS_DEVICE_PATH *UsbClass;
 | |
|   BOOLEAN               IsKnownSubClass;
 | |
| 
 | |
| 
 | |
|   UsbClass = DevPath;
 | |
| 
 | |
|   IsKnownSubClass = TRUE;
 | |
|   switch (UsbClass->DeviceClass) {
 | |
|   case USB_CLASS_AUDIO:
 | |
|     CatPrint (Str, L"UsbAudio");
 | |
|     break;
 | |
| 
 | |
|   case USB_CLASS_CDCCONTROL:
 | |
|     CatPrint (Str, L"UsbCDCControl");
 | |
|     break;
 | |
| 
 | |
|   case USB_CLASS_HID:
 | |
|     CatPrint (Str, L"UsbHID");
 | |
|     break;
 | |
| 
 | |
|   case USB_CLASS_IMAGE:
 | |
|     CatPrint (Str, L"UsbImage");
 | |
|     break;
 | |
| 
 | |
|   case USB_CLASS_PRINTER:
 | |
|     CatPrint (Str, L"UsbPrinter");
 | |
|     break;
 | |
| 
 | |
|   case USB_CLASS_MASS_STORAGE:
 | |
|     CatPrint (Str, L"UsbMassStorage");
 | |
|     break;
 | |
| 
 | |
|   case USB_CLASS_HUB:
 | |
|     CatPrint (Str, L"UsbHub");
 | |
|     break;
 | |
| 
 | |
|   case USB_CLASS_CDCDATA:
 | |
|     CatPrint (Str, L"UsbCDCData");
 | |
|     break;
 | |
| 
 | |
|   case USB_CLASS_SMART_CARD:
 | |
|     CatPrint (Str, L"UsbSmartCard");
 | |
|     break;
 | |
| 
 | |
|   case USB_CLASS_VIDEO:
 | |
|     CatPrint (Str, L"UsbVideo");
 | |
|     break;
 | |
| 
 | |
|   case USB_CLASS_DIAGNOSTIC:
 | |
|     CatPrint (Str, L"UsbDiagnostic");
 | |
|     break;
 | |
| 
 | |
|   case USB_CLASS_WIRELESS:
 | |
|     CatPrint (Str, L"UsbWireless");
 | |
|     break;
 | |
| 
 | |
|   default:
 | |
|     IsKnownSubClass = FALSE;
 | |
|     break;
 | |
|   }
 | |
| 
 | |
|   if (IsKnownSubClass) {
 | |
|     CatPrint (
 | |
|       Str,
 | |
|       L"(0x%x,0x%x,0x%x,0x%x)",
 | |
|       UsbClass->VendorId,
 | |
|       UsbClass->ProductId,
 | |
|       UsbClass->DeviceSubClass,
 | |
|       UsbClass->DeviceProtocol
 | |
|       );
 | |
|     return;
 | |
|   }
 | |
| 
 | |
|   if (UsbClass->DeviceClass == USB_CLASS_RESERVE) {
 | |
|     if (UsbClass->DeviceSubClass == USB_SUBCLASS_FW_UPDATE) {
 | |
|       CatPrint (
 | |
|         Str,
 | |
|         L"UsbDeviceFirmwareUpdate(0x%x,0x%x,0x%x)",
 | |
|         UsbClass->VendorId,
 | |
|         UsbClass->ProductId,
 | |
|         UsbClass->DeviceProtocol
 | |
|         );
 | |
|       return;
 | |
|     } else if (UsbClass->DeviceSubClass == USB_SUBCLASS_IRDA_BRIDGE) {
 | |
|       CatPrint (
 | |
|         Str,
 | |
|         L"UsbIrdaBridge(0x%x,0x%x,0x%x)",
 | |
|         UsbClass->VendorId,
 | |
|         UsbClass->ProductId,
 | |
|         UsbClass->DeviceProtocol
 | |
|         );
 | |
|       return;
 | |
|     } else if (UsbClass->DeviceSubClass == USB_SUBCLASS_TEST) {
 | |
|       CatPrint (
 | |
|         Str,
 | |
|         L"UsbTestAndMeasurement(0x%x,0x%x,0x%x)",
 | |
|         UsbClass->VendorId,
 | |
|         UsbClass->ProductId,
 | |
|         UsbClass->DeviceProtocol
 | |
|         );
 | |
|       return;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   CatPrint (
 | |
|     Str,
 | |
|     L"UsbClass(0x%x,0x%x,0x%x,0x%x,0x%x)",
 | |
|     UsbClass->VendorId,
 | |
|     UsbClass->ProductId,
 | |
|     UsbClass->DeviceClass,
 | |
|     UsbClass->DeviceSubClass,
 | |
|     UsbClass->DeviceProtocol
 | |
|     );
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a SATA device path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToTextSata (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   SATA_DEVICE_PATH *Sata;
 | |
| 
 | |
|   Sata = DevPath;
 | |
|   CatPrint (
 | |
|     Str,
 | |
|     L"Sata(0x%x,0x%x,0x%x)",
 | |
|     (UINTN) Sata->HBAPortNumber,
 | |
|     (UINTN) Sata->PortMultiplierPortNumber,
 | |
|     (UINTN) Sata->Lun
 | |
|     );
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a I20 device path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToTextI2O (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   I2O_DEVICE_PATH *I2ODevPath;
 | |
| 
 | |
|   I2ODevPath = DevPath;
 | |
|   CatPrint (Str, L"I2O(0x%x)", I2ODevPath->Tid);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a MAC address device path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToTextMacAddr (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   MAC_ADDR_DEVICE_PATH  *MacDevPath;
 | |
|   UINTN                 HwAddressSize;
 | |
|   UINTN                 Index;
 | |
| 
 | |
|   MacDevPath = DevPath;
 | |
| 
 | |
|   HwAddressSize = sizeof (EFI_MAC_ADDRESS);
 | |
|   if (MacDevPath->IfType == 0x01 || MacDevPath->IfType == 0x00) {
 | |
|     HwAddressSize = 6;
 | |
|   }
 | |
| 
 | |
|   CatPrint (Str, L"MAC(");
 | |
| 
 | |
|   for (Index = 0; Index < HwAddressSize; Index++) {
 | |
|     CatPrint (Str, L"%02x", MacDevPath->MacAddress.Addr[Index]);
 | |
|   }
 | |
| 
 | |
|   CatPrint (Str, L",0x%x)", MacDevPath->IfType);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a IPv4 device path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToTextIPv4 (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   IPv4_DEVICE_PATH  *IPDevPath;
 | |
| 
 | |
|   IPDevPath = DevPath;
 | |
|   if (DisplayOnly) {
 | |
|     CatPrint (
 | |
|       Str,
 | |
|       L"IPv4(%d.%d.%d.%d)",
 | |
|       IPDevPath->RemoteIpAddress.Addr[0],
 | |
|       IPDevPath->RemoteIpAddress.Addr[1],
 | |
|       IPDevPath->RemoteIpAddress.Addr[2],
 | |
|       IPDevPath->RemoteIpAddress.Addr[3]
 | |
|       );
 | |
|     return ;
 | |
|   }
 | |
| 
 | |
|   CatPrint (
 | |
|     Str,
 | |
|     L"IPv4(%d.%d.%d.%d,%s,%s,%d.%d.%d.%d)",
 | |
|     IPDevPath->RemoteIpAddress.Addr[0],
 | |
|     IPDevPath->RemoteIpAddress.Addr[1],
 | |
|     IPDevPath->RemoteIpAddress.Addr[2],
 | |
|     IPDevPath->RemoteIpAddress.Addr[3],
 | |
|     IPDevPath->Protocol ? L"TCP" : L"UDP",
 | |
|     (IPDevPath->StaticIpAddress == TRUE) ? L"Static" : L"DHCP",
 | |
|     IPDevPath->LocalIpAddress.Addr[0],
 | |
|     IPDevPath->LocalIpAddress.Addr[1],
 | |
|     IPDevPath->LocalIpAddress.Addr[2],
 | |
|     IPDevPath->LocalIpAddress.Addr[3]
 | |
|     );
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a IPv6 device path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToTextIPv6 (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   IPv6_DEVICE_PATH  *IPDevPath;
 | |
| 
 | |
|   IPDevPath = DevPath;
 | |
|   if (DisplayOnly) {
 | |
|     CatPrint (
 | |
|       Str,
 | |
|       L"IPv6(%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x)",
 | |
|       IPDevPath->RemoteIpAddress.Addr[0],
 | |
|       IPDevPath->RemoteIpAddress.Addr[1],
 | |
|       IPDevPath->RemoteIpAddress.Addr[2],
 | |
|       IPDevPath->RemoteIpAddress.Addr[3],
 | |
|       IPDevPath->RemoteIpAddress.Addr[4],
 | |
|       IPDevPath->RemoteIpAddress.Addr[5],
 | |
|       IPDevPath->RemoteIpAddress.Addr[6],
 | |
|       IPDevPath->RemoteIpAddress.Addr[7],
 | |
|       IPDevPath->RemoteIpAddress.Addr[8],
 | |
|       IPDevPath->RemoteIpAddress.Addr[9],
 | |
|       IPDevPath->RemoteIpAddress.Addr[10],
 | |
|       IPDevPath->RemoteIpAddress.Addr[11],
 | |
|       IPDevPath->RemoteIpAddress.Addr[12],
 | |
|       IPDevPath->RemoteIpAddress.Addr[13],
 | |
|       IPDevPath->RemoteIpAddress.Addr[14],
 | |
|       IPDevPath->RemoteIpAddress.Addr[15]
 | |
|       );
 | |
|     return ;
 | |
|   }
 | |
| 
 | |
|   CatPrint (
 | |
|     Str,
 | |
|     L"IPv6(%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x,%s,%s,%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x)",
 | |
|     IPDevPath->RemoteIpAddress.Addr[0],
 | |
|     IPDevPath->RemoteIpAddress.Addr[1],
 | |
|     IPDevPath->RemoteIpAddress.Addr[2],
 | |
|     IPDevPath->RemoteIpAddress.Addr[3],
 | |
|     IPDevPath->RemoteIpAddress.Addr[4],
 | |
|     IPDevPath->RemoteIpAddress.Addr[5],
 | |
|     IPDevPath->RemoteIpAddress.Addr[6],
 | |
|     IPDevPath->RemoteIpAddress.Addr[7],
 | |
|     IPDevPath->RemoteIpAddress.Addr[8],
 | |
|     IPDevPath->RemoteIpAddress.Addr[9],
 | |
|     IPDevPath->RemoteIpAddress.Addr[10],
 | |
|     IPDevPath->RemoteIpAddress.Addr[11],
 | |
|     IPDevPath->RemoteIpAddress.Addr[12],
 | |
|     IPDevPath->RemoteIpAddress.Addr[13],
 | |
|     IPDevPath->RemoteIpAddress.Addr[14],
 | |
|     IPDevPath->RemoteIpAddress.Addr[15],
 | |
|     IPDevPath->Protocol ? L"TCP" : L"UDP",
 | |
|     (IPDevPath->StaticIpAddress == TRUE) ? L"Static" : L"DHCP",
 | |
|     IPDevPath->LocalIpAddress.Addr[0],
 | |
|     IPDevPath->LocalIpAddress.Addr[1],
 | |
|     IPDevPath->LocalIpAddress.Addr[2],
 | |
|     IPDevPath->LocalIpAddress.Addr[3],
 | |
|     IPDevPath->LocalIpAddress.Addr[4],
 | |
|     IPDevPath->LocalIpAddress.Addr[5],
 | |
|     IPDevPath->LocalIpAddress.Addr[6],
 | |
|     IPDevPath->LocalIpAddress.Addr[7],
 | |
|     IPDevPath->LocalIpAddress.Addr[8],
 | |
|     IPDevPath->LocalIpAddress.Addr[9],
 | |
|     IPDevPath->LocalIpAddress.Addr[10],
 | |
|     IPDevPath->LocalIpAddress.Addr[11],
 | |
|     IPDevPath->LocalIpAddress.Addr[12],
 | |
|     IPDevPath->LocalIpAddress.Addr[13],
 | |
|     IPDevPath->LocalIpAddress.Addr[14],
 | |
|     IPDevPath->LocalIpAddress.Addr[15]
 | |
|     );
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts an Infini Band device path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToTextInfiniBand (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   INFINIBAND_DEVICE_PATH  *InfiniBand;
 | |
| 
 | |
|   InfiniBand = DevPath;
 | |
|   CatPrint (
 | |
|     Str,
 | |
|     L"Infiniband(0x%x,%g,0x%lx,0x%lx,0x%lx)",
 | |
|     InfiniBand->ResourceFlags,
 | |
|     InfiniBand->PortGid,
 | |
|     InfiniBand->ServiceId,
 | |
|     InfiniBand->TargetPortId,
 | |
|     InfiniBand->DeviceId
 | |
|     );
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a UART device path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToTextUart (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   UART_DEVICE_PATH  *Uart;
 | |
|   CHAR8             Parity;
 | |
| 
 | |
|   Uart = DevPath;
 | |
|   switch (Uart->Parity) {
 | |
|   case 0:
 | |
|     Parity = 'D';
 | |
|     break;
 | |
| 
 | |
|   case 1:
 | |
|     Parity = 'N';
 | |
|     break;
 | |
| 
 | |
|   case 2:
 | |
|     Parity = 'E';
 | |
|     break;
 | |
| 
 | |
|   case 3:
 | |
|     Parity = 'O';
 | |
|     break;
 | |
| 
 | |
|   case 4:
 | |
|     Parity = 'M';
 | |
|     break;
 | |
| 
 | |
|   case 5:
 | |
|     Parity = 'S';
 | |
|     break;
 | |
| 
 | |
|   default:
 | |
|     Parity = 'x';
 | |
|     break;
 | |
|   }
 | |
| 
 | |
|   if (Uart->BaudRate == 0) {
 | |
|     CatPrint (Str, L"Uart(DEFAULT,");
 | |
|   } else {
 | |
|     CatPrint (Str, L"Uart(%ld,", Uart->BaudRate);
 | |
|   }
 | |
| 
 | |
|   if (Uart->DataBits == 0) {
 | |
|     CatPrint (Str, L"DEFAULT,");
 | |
|   } else {
 | |
|     CatPrint (Str, L"%d,", Uart->DataBits);
 | |
|   }
 | |
| 
 | |
|   CatPrint (Str, L"%c,", Parity);
 | |
| 
 | |
|   switch (Uart->StopBits) {
 | |
|   case 0:
 | |
|     CatPrint (Str, L"D)");
 | |
|     break;
 | |
| 
 | |
|   case 1:
 | |
|     CatPrint (Str, L"1)");
 | |
|     break;
 | |
| 
 | |
|   case 2:
 | |
|     CatPrint (Str, L"1.5)");
 | |
|     break;
 | |
| 
 | |
|   case 3:
 | |
|     CatPrint (Str, L"2)");
 | |
|     break;
 | |
| 
 | |
|   default:
 | |
|     CatPrint (Str, L"x)");
 | |
|     break;
 | |
|   }
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts an iSCSI device path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToTextiSCSI (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   ISCSI_DEVICE_PATH_WITH_NAME *ISCSIDevPath;
 | |
|   UINT16                      Options;
 | |
| 
 | |
|   ISCSIDevPath = DevPath;
 | |
|   CatPrint (
 | |
|     Str,
 | |
|     L"iSCSI(%a,0x%x,0x%lx,",
 | |
|     ISCSIDevPath->iSCSITargetName,
 | |
|     ISCSIDevPath->TargetPortalGroupTag,
 | |
|     ISCSIDevPath->Lun
 | |
|     );
 | |
| 
 | |
|   Options = ISCSIDevPath->LoginOption;
 | |
|   CatPrint (Str, L"%s,", (((Options >> 1) & 0x0001) != 0) ? L"CRC32C" : L"None");
 | |
|   CatPrint (Str, L"%s,", (((Options >> 3) & 0x0001) != 0) ? L"CRC32C" : L"None");
 | |
|   if (((Options >> 11) & 0x0001) != 0) {
 | |
|     CatPrint (Str, L"%s,", L"None");
 | |
|   } else if (((Options >> 12) & 0x0001) != 0) {
 | |
|     CatPrint (Str, L"%s,", L"CHAP_UNI");
 | |
|   } else {
 | |
|     CatPrint (Str, L"%s,", L"CHAP_BI");
 | |
| 
 | |
|   }
 | |
| 
 | |
|   CatPrint (Str, L"%s)", (ISCSIDevPath->NetworkProtocol == 0) ? L"TCP" : L"reserved");
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a Hard drive device path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToTextHardDrive (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   HARDDRIVE_DEVICE_PATH *Hd;
 | |
| 
 | |
|   Hd = DevPath;
 | |
|   switch (Hd->SignatureType) {
 | |
|   case SIGNATURE_TYPE_MBR:
 | |
|     CatPrint (
 | |
|       Str,
 | |
|       L"HD(%d,%s,0x%08x,",
 | |
|       Hd->PartitionNumber,
 | |
|       L"MBR",
 | |
|       *((UINT32 *) (&(Hd->Signature[0])))
 | |
|       );
 | |
|     break;
 | |
| 
 | |
|   case SIGNATURE_TYPE_GUID:
 | |
|     CatPrint (
 | |
|       Str,
 | |
|       L"HD(%d,%s,%g,",
 | |
|       Hd->PartitionNumber,
 | |
|       L"GPT",
 | |
|       (EFI_GUID *) &(Hd->Signature[0])
 | |
|       );
 | |
|     break;
 | |
| 
 | |
|   default:
 | |
|     CatPrint (
 | |
|       Str,
 | |
|       L"HD(%d,%d,0,",
 | |
|       Hd->PartitionNumber,
 | |
|       Hd->SignatureType
 | |
|       );
 | |
|     break;
 | |
|   }
 | |
| 
 | |
|   CatPrint (Str, L"0x%lx,0x%lx)", Hd->PartitionStart, Hd->PartitionSize);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a CDROM device path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToTextCDROM (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   CDROM_DEVICE_PATH *Cd;
 | |
| 
 | |
|   Cd = DevPath;
 | |
|   if (DisplayOnly) {
 | |
|     CatPrint (Str, L"CDROM(0x%x)", Cd->BootEntry);
 | |
|     return ;
 | |
|   }
 | |
| 
 | |
|   CatPrint (Str, L"CDROM(0x%x,0x%lx,0x%lx)", Cd->BootEntry, Cd->PartitionStart, Cd->PartitionSize);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a File device path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToTextFilePath (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   FILEPATH_DEVICE_PATH  *Fp;
 | |
| 
 | |
|   Fp = DevPath;
 | |
|   CatPrint (Str, L"%s", Fp->PathName);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a Media protocol device path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToTextMediaProtocol (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   MEDIA_PROTOCOL_DEVICE_PATH  *MediaProt;
 | |
| 
 | |
|   MediaProt = DevPath;
 | |
|   CatPrint (Str, L"Media(%g)", &MediaProt->Protocol);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a Firmware Volume device path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToTextFv (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   MEDIA_FW_VOL_DEVICE_PATH  *Fv;
 | |
| 
 | |
|   Fv = DevPath;
 | |
|   CatPrint (Str, L"Fv(%g)", &Fv->FvName);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a Firmware Volume File device path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToTextFvFile (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   MEDIA_FW_VOL_FILEPATH_DEVICE_PATH  *FvFile;
 | |
| 
 | |
|   FvFile = DevPath;
 | |
|   CatPrint (Str, L"FvFile(%g)", &FvFile->FvFileName);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a BIOS Boot Specification device path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToTextBBS (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   BBS_BBS_DEVICE_PATH *Bbs;
 | |
|   CHAR16              *Type;
 | |
| 
 | |
|   Bbs = DevPath;
 | |
|   switch (Bbs->DeviceType) {
 | |
|   case BBS_TYPE_FLOPPY:
 | |
|     Type = L"Floppy";
 | |
|     break;
 | |
| 
 | |
|   case BBS_TYPE_HARDDRIVE:
 | |
|     Type = L"HD";
 | |
|     break;
 | |
| 
 | |
|   case BBS_TYPE_CDROM:
 | |
|     Type = L"CDROM";
 | |
|     break;
 | |
| 
 | |
|   case BBS_TYPE_PCMCIA:
 | |
|     Type = L"PCMCIA";
 | |
|     break;
 | |
| 
 | |
|   case BBS_TYPE_USB:
 | |
|     Type = L"USB";
 | |
|     break;
 | |
| 
 | |
|   case BBS_TYPE_EMBEDDED_NETWORK:
 | |
|     Type = L"Network";
 | |
|     break;
 | |
| 
 | |
|   default:
 | |
|     Type = NULL;
 | |
|     break;
 | |
|   }
 | |
| 
 | |
|   if (Type != NULL) {
 | |
|     CatPrint (Str, L"BBS(%s,%a", Type, Bbs->String);
 | |
|   } else {
 | |
|     CatPrint (Str, L"BBS(0x%x,%a", Bbs->DeviceType, Bbs->String);
 | |
|   }
 | |
| 
 | |
|   if (DisplayOnly) {
 | |
|     CatPrint (Str, L")");
 | |
|     return ;
 | |
|   }
 | |
| 
 | |
|   CatPrint (Str, L",0x%x)", Bbs->StatusFlag);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts an End-of-Device-Path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToTextEndInstance (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   CatPrint (Str, L",");
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts an unknown device path structure to its string representive.
 | |
| 
 | |
|   @param Str             The string representive of input device.
 | |
|   @param DevPath         The input device path structure.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| DevPathToTextNodeUnknown (
 | |
|   IN OUT POOL_PRINT  *Str,
 | |
|   IN VOID            *DevPath,
 | |
|   IN BOOLEAN         DisplayOnly,
 | |
|   IN BOOLEAN         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   CatPrint (Str, L"?");
 | |
| }
 | |
| 
 | |
| GLOBAL_REMOVE_IF_UNREFERENCED const DEVICE_PATH_TO_TEXT_TABLE DevPathToTextTable[] = {
 | |
|   {HARDWARE_DEVICE_PATH, HW_PCI_DP, DevPathToTextPci},
 | |
|   {HARDWARE_DEVICE_PATH, HW_PCCARD_DP, DevPathToTextPccard},
 | |
|   {HARDWARE_DEVICE_PATH, HW_MEMMAP_DP, DevPathToTextMemMap},
 | |
|   {HARDWARE_DEVICE_PATH, HW_VENDOR_DP, DevPathToTextVendor},
 | |
|   {HARDWARE_DEVICE_PATH, HW_CONTROLLER_DP, DevPathToTextController},
 | |
|   {ACPI_DEVICE_PATH, ACPI_DP, DevPathToTextAcpi},
 | |
|   {ACPI_DEVICE_PATH, ACPI_EXTENDED_DP, DevPathToTextAcpiEx},
 | |
|   {ACPI_DEVICE_PATH, ACPI_ADR_DP, DevPathToTextAcpiAdr},
 | |
|   {MESSAGING_DEVICE_PATH, MSG_ATAPI_DP, DevPathToTextAtapi},
 | |
|   {MESSAGING_DEVICE_PATH, MSG_SCSI_DP, DevPathToTextScsi},
 | |
|   {MESSAGING_DEVICE_PATH, MSG_FIBRECHANNEL_DP, DevPathToTextFibre},
 | |
|   {MESSAGING_DEVICE_PATH, MSG_1394_DP, DevPathToText1394},
 | |
|   {MESSAGING_DEVICE_PATH, MSG_USB_DP, DevPathToTextUsb},
 | |
|   {MESSAGING_DEVICE_PATH, MSG_USB_WWID_DP, DevPathToTextUsbWWID},
 | |
|   {MESSAGING_DEVICE_PATH, MSG_DEVICE_LOGICAL_UNIT_DP, DevPathToTextLogicalUnit},
 | |
|   {MESSAGING_DEVICE_PATH, MSG_USB_CLASS_DP, DevPathToTextUsbClass},
 | |
|   {MESSAGING_DEVICE_PATH, MSG_SATA_DP, DevPathToTextSata},
 | |
|   {MESSAGING_DEVICE_PATH, MSG_I2O_DP, DevPathToTextI2O},
 | |
|   {MESSAGING_DEVICE_PATH, MSG_MAC_ADDR_DP, DevPathToTextMacAddr},
 | |
|   {MESSAGING_DEVICE_PATH, MSG_IPv4_DP, DevPathToTextIPv4},
 | |
|   {MESSAGING_DEVICE_PATH, MSG_IPv6_DP, DevPathToTextIPv6},
 | |
|   {MESSAGING_DEVICE_PATH, MSG_INFINIBAND_DP, DevPathToTextInfiniBand},
 | |
|   {MESSAGING_DEVICE_PATH, MSG_UART_DP, DevPathToTextUart},
 | |
|   {MESSAGING_DEVICE_PATH, MSG_VENDOR_DP, DevPathToTextVendor},
 | |
|   {MESSAGING_DEVICE_PATH, MSG_ISCSI_DP, DevPathToTextiSCSI},
 | |
|   {MEDIA_DEVICE_PATH, MEDIA_HARDDRIVE_DP, DevPathToTextHardDrive},
 | |
|   {MEDIA_DEVICE_PATH, MEDIA_CDROM_DP, DevPathToTextCDROM},
 | |
|   {MEDIA_DEVICE_PATH, MEDIA_VENDOR_DP, DevPathToTextVendor},
 | |
|   {MEDIA_DEVICE_PATH, MEDIA_FILEPATH_DP, DevPathToTextFilePath},
 | |
|   {MEDIA_DEVICE_PATH, MEDIA_PROTOCOL_DP, DevPathToTextMediaProtocol},
 | |
|   {MEDIA_DEVICE_PATH, MEDIA_FILEPATH_DP, DevPathToTextFilePath},
 | |
|   {MEDIA_DEVICE_PATH, MEDIA_PIWG_FW_VOL_DP, DevPathToTextFv},
 | |
|   {MEDIA_DEVICE_PATH, MEDIA_PIWG_FW_FILE_DP, DevPathToTextFvFile},
 | |
|   {BBS_DEVICE_PATH, BBS_BBS_DP, DevPathToTextBBS},
 | |
|   {END_DEVICE_PATH_TYPE, END_INSTANCE_DEVICE_PATH_SUBTYPE, DevPathToTextEndInstance},
 | |
|   {0, 0, NULL}
 | |
| };
 | |
| 
 | |
| /**
 | |
|   Converts a device node to its string representation.
 | |
| 
 | |
|   @param DeviceNode        A Pointer to the device node to be converted.
 | |
|   @param DisplayOnly       If DisplayOnly is TRUE, then the shorter text representation
 | |
|                            of the display node is used, where applicable. If DisplayOnly
 | |
|                            is FALSE, then the longer text representation of the display node
 | |
|                            is used.
 | |
|   @param AllowShortcuts    If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                            representation for a device node can be used, where applicable.
 | |
| 
 | |
|   @return A pointer to the allocated text representation of the device node or NULL if DeviceNode
 | |
|           is NULL or there was insufficient memory.
 | |
| 
 | |
| **/
 | |
| CHAR16 *
 | |
| EFIAPI
 | |
| ConvertDeviceNodeToText (
 | |
|   IN CONST EFI_DEVICE_PATH_PROTOCOL  *DeviceNode,
 | |
|   IN BOOLEAN                         DisplayOnly,
 | |
|   IN BOOLEAN                         AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   POOL_PRINT  Str;
 | |
|   UINTN       Index;
 | |
|   UINTN       NewSize;
 | |
|   VOID        (*DumpNode)(POOL_PRINT *, VOID *, BOOLEAN, BOOLEAN);
 | |
| 
 | |
|   if (DeviceNode == NULL) {
 | |
|     return NULL;
 | |
|   }
 | |
| 
 | |
|   ZeroMem (&Str, sizeof (Str));
 | |
| 
 | |
|   //
 | |
|   // Process the device path node
 | |
|   //
 | |
|   DumpNode = NULL;
 | |
|   for (Index = 0; DevPathToTextTable[Index].Function != NULL; Index++) {
 | |
|     if (DevicePathType (DeviceNode) == DevPathToTextTable[Index].Type &&
 | |
|         DevicePathSubType (DeviceNode) == DevPathToTextTable[Index].SubType
 | |
|         ) {
 | |
|       DumpNode = DevPathToTextTable[Index].Function;
 | |
|       break;
 | |
|     }
 | |
|   }
 | |
|   //
 | |
|   // If not found, use a generic function
 | |
|   //
 | |
|   if (DumpNode == NULL) {
 | |
|     DumpNode = DevPathToTextNodeUnknown;
 | |
|   }
 | |
| 
 | |
|   //
 | |
|   // Print this node
 | |
|   //
 | |
|   DumpNode (&Str, (VOID *) DeviceNode, DisplayOnly, AllowShortcuts);
 | |
| 
 | |
|   //
 | |
|   // Shrink pool used for string allocation
 | |
|   //
 | |
|   NewSize = (Str.Len + 1) * sizeof (CHAR16);
 | |
|   Str.Str = ReallocatePool (Str.Str, NewSize, NewSize);
 | |
|   ASSERT (Str.Str != NULL);
 | |
|   Str.Str[Str.Len] = 0;
 | |
|   return Str.Str;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Converts a device path to its text representation.
 | |
| 
 | |
|   @param DevicePath      A Pointer to the device to be converted.
 | |
|   @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text representation
 | |
|                          of the display node is used, where applicable. If DisplayOnly
 | |
|                          is FALSE, then the longer text representation of the display node
 | |
|                          is used.
 | |
|   @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms of text
 | |
|                          representation for a device node can be used, where applicable.
 | |
| 
 | |
|   @return A pointer to the allocated text representation of the device path or
 | |
|           NULL if DeviceNode is NULL or there was insufficient memory.
 | |
| 
 | |
| **/
 | |
| CHAR16 *
 | |
| EFIAPI
 | |
| ConvertDevicePathToText (
 | |
|   IN CONST EFI_DEVICE_PATH_PROTOCOL   *DevicePath,
 | |
|   IN BOOLEAN                          DisplayOnly,
 | |
|   IN BOOLEAN                          AllowShortcuts
 | |
|   )
 | |
| {
 | |
|   POOL_PRINT                Str;
 | |
|   EFI_DEVICE_PATH_PROTOCOL  *DevPathNode;
 | |
|   EFI_DEVICE_PATH_PROTOCOL  *UnpackDevPath;
 | |
|   UINTN                     Index;
 | |
|   UINTN                     NewSize;
 | |
|   VOID                      (*DumpNode) (POOL_PRINT *, VOID *, BOOLEAN, BOOLEAN);
 | |
| 
 | |
|   if (DevicePath == NULL) {
 | |
|     return NULL;
 | |
|   }
 | |
| 
 | |
|   ZeroMem (&Str, sizeof (Str));
 | |
| 
 | |
|   //
 | |
|   // Unpacked the device path
 | |
|   //
 | |
|   UnpackDevPath = UnpackDevicePath ((EFI_DEVICE_PATH_PROTOCOL *) DevicePath);
 | |
|   ASSERT (UnpackDevPath != NULL);
 | |
| 
 | |
|   //
 | |
|   // Process each device path node
 | |
|   //
 | |
|   DevPathNode = UnpackDevPath;
 | |
|   while (!IsDevicePathEnd (DevPathNode)) {
 | |
|     //
 | |
|     // Find the handler to dump this device path node
 | |
|     //
 | |
|     DumpNode = NULL;
 | |
|     for (Index = 0; DevPathToTextTable[Index].Function; Index += 1) {
 | |
| 
 | |
|       if (DevicePathType (DevPathNode) == DevPathToTextTable[Index].Type &&
 | |
|           DevicePathSubType (DevPathNode) == DevPathToTextTable[Index].SubType
 | |
|           ) {
 | |
|         DumpNode = DevPathToTextTable[Index].Function;
 | |
|         break;
 | |
|       }
 | |
|     }
 | |
|     //
 | |
|     // If not found, use a generic function
 | |
|     //
 | |
|     if (!DumpNode) {
 | |
|       DumpNode = DevPathToTextNodeUnknown;
 | |
|     }
 | |
|     //
 | |
|     //  Put a path seperator in if needed
 | |
|     //
 | |
|     if ((Str.Len != 0) && DumpNode != DevPathToTextEndInstance) {
 | |
|       if (*(Str.Str + Str.Len / sizeof (CHAR16) - 1) != L',') {
 | |
|         CatPrint (&Str, L"/");
 | |
|       }
 | |
|     }
 | |
|     //
 | |
|     // Print this node of the device path
 | |
|     //
 | |
|     DumpNode (&Str, DevPathNode, DisplayOnly, AllowShortcuts);
 | |
| 
 | |
|     //
 | |
|     // Next device path node
 | |
|     //
 | |
|     DevPathNode = NextDevicePathNode (DevPathNode);
 | |
|   }
 | |
|   //
 | |
|   // Shrink pool used for string allocation
 | |
|   //
 | |
|   FreePool (UnpackDevPath);
 | |
| 
 | |
|   NewSize = (Str.Len + 1) * sizeof (CHAR16);
 | |
|   Str.Str = ReallocatePool (Str.Str, NewSize, NewSize);
 | |
|   ASSERT (Str.Str != NULL);
 | |
|   Str.Str[Str.Len] = 0;
 | |
|   return Str.Str;
 | |
| }
 |