mirror of https://github.com/acidanthera/audk.git
MdePkg/DevicePathLib: Fix FromText bug for multi-instance devicepath
UefiDevicePathLibConvertTextToDevicePath correctly detects when it has hit a ',' splicing together multiple paths. However, the code that tries to cope with it: {code} if (IsInstanceEnd) { DeviceNode = (EFI_DEVICE_PATH_PROTOCOL *) AllocatePool ( END_DEVICE_PATH_LENGTH); ASSERT (DeviceNode != NULL); SetDevicePathEndNode (DeviceNode); NewDevicePath = AppendDevicePathNode (DevicePath, DeviceNode); FreePool (DevicePath); FreePool (DeviceNode); DevicePath = NewDevicePath; } {code} causes a problem. The END node that's appended it the node for the entire list. So when the node is appended in AppendDevicePathNode, it winds up disappearing. This leads to the path 'PciRoot(0x0),PciRoot(0x0)' parsing as if 'PciRoot(0x0)/PciRoot(0x0)' were specified. These are two very different things. Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Warner Losh <imp@bsdimp.com> Reviewed-by: Ruiyu Ni <ruiyu.ni@intel.com>
This commit is contained in:
parent
6ca29fa310
commit
647636e175
|
@ -3500,6 +3500,7 @@ UefiDevicePathLibConvertTextToDevicePath (
|
||||||
DeviceNode = (EFI_DEVICE_PATH_PROTOCOL *) AllocatePool (END_DEVICE_PATH_LENGTH);
|
DeviceNode = (EFI_DEVICE_PATH_PROTOCOL *) AllocatePool (END_DEVICE_PATH_LENGTH);
|
||||||
ASSERT (DeviceNode != NULL);
|
ASSERT (DeviceNode != NULL);
|
||||||
SetDevicePathEndNode (DeviceNode);
|
SetDevicePathEndNode (DeviceNode);
|
||||||
|
DeviceNode->SubType = END_INSTANCE_DEVICE_PATH_SUBTYPE;
|
||||||
|
|
||||||
NewDevicePath = AppendDevicePathNode (DevicePath, DeviceNode);
|
NewDevicePath = AppendDevicePathNode (DevicePath, DeviceNode);
|
||||||
FreePool (DevicePath);
|
FreePool (DevicePath);
|
||||||
|
|
Loading…
Reference in New Issue