mirror of https://github.com/acidanthera/audk.git
Fix the BdsExpandPartitionPartialDevicePathToFull() hang issue by duplicates BlockIoDevicePath when the CachedDevicePath returned from BdsLibDelPartMatchInstance() is NULL.
Signed-off-by: Ruiyu Ni <ruiyu.ni@intel.com> Reviewed-by: Chao B Zhang <chao.b.zhang@intel.com> git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@14733 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
parent
798e4d22c4
commit
e5a9b63cdf
|
@ -2637,17 +2637,16 @@ BdsExpandPartitionPartialDevicePathToFull (
|
||||||
TempNewDevicePath = CachedDevicePath;
|
TempNewDevicePath = CachedDevicePath;
|
||||||
CachedDevicePath = BdsLibDelPartMatchInstance (CachedDevicePath, BlockIoDevicePath);
|
CachedDevicePath = BdsLibDelPartMatchInstance (CachedDevicePath, BlockIoDevicePath);
|
||||||
FreePool(TempNewDevicePath);
|
FreePool(TempNewDevicePath);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (CachedDevicePath != NULL) {
|
||||||
TempNewDevicePath = CachedDevicePath;
|
TempNewDevicePath = CachedDevicePath;
|
||||||
CachedDevicePath = AppendDevicePathInstance (BlockIoDevicePath, CachedDevicePath);
|
CachedDevicePath = AppendDevicePathInstance (BlockIoDevicePath, CachedDevicePath);
|
||||||
if (TempNewDevicePath != NULL) {
|
|
||||||
FreePool(TempNewDevicePath);
|
FreePool(TempNewDevicePath);
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
TempNewDevicePath = CachedDevicePath;
|
CachedDevicePath = DuplicateDevicePath (BlockIoDevicePath);
|
||||||
CachedDevicePath = AppendDevicePathInstance (BlockIoDevicePath, CachedDevicePath);
|
|
||||||
FreePool(TempNewDevicePath);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
// Here limit the device path instance number to 12, which is max number for a system support 3 IDE controller
|
// Here limit the device path instance number to 12, which is max number for a system support 3 IDE controller
|
||||||
// If the user try to boot many OS in different HDs or partitions, in theory,
|
// If the user try to boot many OS in different HDs or partitions, in theory,
|
||||||
|
|
Loading…
Reference in New Issue