mirror of https://github.com/acidanthera/audk.git
Nt32Pkg/FvbServicesRuntimeDxe: correct NumOfLba vararg type in EraseBlocks()
According to the PI spec, Volume 3, EFI_FIRMWARE_VOLUME_BLOCK2_PROTOCOL.EraseBlocks(): > The variable argument list is a list of tuples. Each tuple describes a > range of LBAs to erase and consists of the following: > * An EFI_LBA that indicates the starting LBA > * A UINTN that indicates the number of blocks to erase (NB, in edk2, EFI_FIRMWARE_VOLUME_BLOCK_PROTOCOL is a typedef to EFI_FIRMWARE_VOLUME_BLOCK2_PROTOCOL.) In this driver, the NumOfLba local variable is defined with type UINTN, but the TYPE argument passed to VA_ARG() is UINT32. Fix the mismatch. Cc: Jordan Justen <jordan.l.justen@intel.com> Cc: Ruiyu Ni <ruiyu.ni@intel.com> Reported-by: Jordan Justen <jordan.l.justen@intel.com> Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Laszlo Ersek <lersek@redhat.com> Reviewed-by: Jordan Justen <jordan.l.justen@intel.com> Reviewed-by: Hao Wu <hao.a.wu@intel.com>
This commit is contained in:
parent
d98e939f4f
commit
d0d7289cce
|
@ -945,7 +945,7 @@ Returns:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
NumOfLba = VA_ARG (args, UINT32);
|
NumOfLba = VA_ARG (args, UINTN);
|
||||||
|
|
||||||
//
|
//
|
||||||
// Check input parameters
|
// Check input parameters
|
||||||
|
@ -965,7 +965,7 @@ Returns:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
NumOfLba = VA_ARG (args, UINT32);
|
NumOfLba = VA_ARG (args, UINTN);
|
||||||
|
|
||||||
while (NumOfLba > 0) {
|
while (NumOfLba > 0) {
|
||||||
Status = FvbEraseBlock (FvbDevice->Instance, StartingLba, mFvbModuleGlobal, EfiGoneVirtual ());
|
Status = FvbEraseBlock (FvbDevice->Instance, StartingLba, mFvbModuleGlobal, EfiGoneVirtual ());
|
||||||
|
|
Loading…
Reference in New Issue