devicepathtotext.c
来自「EFI BIOS是Intel提出的下一代的BIOS标准。这里上传的Edk源代码是」· C语言 代码 · 共 1,553 行 · 第 1/3 页
C
1,553 行
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;
}
}
VOID
DevPathToTextiSCSI (
IN OUT POOL_PRINT *Str,
IN VOID *DevPath,
IN BOOLEAN DisplayOnly,
IN BOOLEAN AllowShortcuts
)
{
ISCSI_DEVICE_PATH_WITH_NAME *iSCSI;
UINT16 Options;
iSCSI = DevPath;
CatPrint (
Str,
L"iSCSI(%s,%x,%lx,",
iSCSI->iSCSITargetName,
iSCSI->TargetPortalGroupTag,
iSCSI->Lun
);
Options = iSCSI->LoginOption;
CatPrint (Str, L"%s,", ((Options >> 1) & 0x0001) ? L"CRC32C" : L"None");
CatPrint (Str, L"%s,", ((Options >> 3) & 0x0001) ? L"CRC32C" : L"None");
if ((Options >> 11) & 0x0001) {
CatPrint (Str, L"%s,", L"None");
} else if ((Options >> 12) & 0x0001) {
CatPrint (Str, L"%s,", L"CHAP_UNI");
} else {
CatPrint (Str, L"%s,", L"CHAP_BI");
}
CatPrint (Str, L"%s)", (iSCSI->NetworkProtocol == 0) ? L"TCP" : L"reserved");
}
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 0:
CatPrint (
Str,
L"HD(%d,%s,0,",
Hd->PartitionNumber,
L"None"
);
break;
case SIGNATURE_TYPE_MBR:
CatPrint (
Str,
L"HD(%d,%s,%08x,",
Hd->PartitionNumber,
L"MBR",
*((UINT32 *) (&(Hd->Signature[0])))
);
break;
case SIGNATURE_TYPE_GUID:
CatPrint (
Str,
L"HD(%d,%s,%g,",
Hd->PartitionNumber,
L"GUID",
(EFI_GUID *) &(Hd->Signature[0])
);
break;
default:
break;
}
CatPrint (Str, L"%lx,%lx)", Hd->PartitionStart, Hd->PartitionSize);
}
VOID
DevPathToTextCDROM (
IN OUT POOL_PRINT *Str,
IN VOID *DevPath,
IN BOOLEAN DisplayOnly,
IN BOOLEAN AllowShortcuts
)
{
CDROM_DEVICE_PATH *Cd;
Cd = DevPath;
if (DisplayOnly == TRUE) {
CatPrint (Str, L"CDROM(%x)", Cd->BootEntry);
return ;
}
CatPrint (Str, L"CDROM(%x,%lx,%lx)", Cd->BootEntry, Cd->PartitionStart, Cd->PartitionSize);
}
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);
}
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);
}
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 = L"?";
break;
}
CatPrint (Str, L"BBS(%s,%a", Type, Bbs->String);
if (DisplayOnly == TRUE) {
CatPrint (Str, L")");
return ;
}
CatPrint (Str, L",%x)", Bbs->StatusFlag);
}
VOID
DevPathToTextEndInstance (
IN OUT POOL_PRINT *Str,
IN VOID *DevPath,
IN BOOLEAN DisplayOnly,
IN BOOLEAN AllowShortcuts
)
{
CatPrint (Str, L",");
}
VOID
DevPathToTextNodeUnknown (
IN OUT POOL_PRINT *Str,
IN VOID *DevPath,
IN BOOLEAN DisplayOnly,
IN BOOLEAN AllowShortcuts
)
{
CatPrint (Str, L"?");
}
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,
DevPathToTextExtAcpi,
ACPI_DEVICE_PATH,
ACPI_ADR_DP,
DevPathToTextAdrAcpi,
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_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,
BBS_DEVICE_PATH,
BBS_BBS_DP,
DevPathToTextBBS,
END_DEVICE_PATH_TYPE,
END_INSTANCE_DEVICE_PATH_SUBTYPE,
DevPathToTextEndInstance,
0,
0,
NULL
};
CHAR16 *
ConvertDeviceNodeToText (
IN CONST EFI_DEVICE_PATH_PROTOCOL *DeviceNode,
IN BOOLEAN DisplayOnly,
IN BOOLEAN AllowShortcuts
)
/*++
Routine Description:
Convert a device node to its text representation.
Arguments:
DeviceNode - Points to the device node to be converted.
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.
AllowShortcuts - If AllowShortcuts is TRUE, then the shortcut forms of text
representation for a device node can be used, where applicable.
Returns:
A pointer - a pointer to the allocated text representation of the device node.
NULL - if DeviceNode is NULL or there was insufficient memory.
--*/
{
POOL_PRINT Str;
UINTN Index;
UINTN NewSize;
VOID (*DumpNode)(POOL_PRINT *, VOID *, BOOLEAN, BOOLEAN);
if (DeviceNode == NULL) {
return NULL;
}
EfiZeroMem (&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;
}
CHAR16 *
ConvertDevicePathToText (
IN CONST EFI_DEVICE_PATH_PROTOCOL *DevicePath,
IN BOOLEAN DisplayOnly,
IN BOOLEAN AllowShortcuts
)
/*++
Routine Description:
Convert a device path to its text representation.
Arguments:
DeviceNode - Points to the device path to be converted.
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.
AllowShortcuts - If AllowShortcuts is TRUE, then the shortcut forms of text
representation for a device node can be used, where applicable.
Returns:
A pointer - a pointer to the allocated text representation of the device path.
NULL - if DeviceNode is NULL or there was insufficient memory.
--*/
{
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;
}
EfiZeroMem (&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 && 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
//
gBS->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;
}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?