mirror of https://github.com/xemu-project/xemu.git
Fix error code checking for SetFilePointer() call
An error has occurred if the return value is invalid_set_file_pointer and getlasterror doesn't return no_error. Signed-off-by: Fabien Chouteau <chouteau@adacore.com> Acked-by: Stefan Hajnoczi <stefanha@redhat.com>
This commit is contained in:
parent
473c7f0255
commit
fbcad04d6b
|
@ -303,13 +303,24 @@ static int raw_truncate(BlockDriverState *bs, int64_t offset)
|
||||||
{
|
{
|
||||||
BDRVRawState *s = bs->opaque;
|
BDRVRawState *s = bs->opaque;
|
||||||
LONG low, high;
|
LONG low, high;
|
||||||
|
DWORD dwPtrLow;
|
||||||
|
|
||||||
low = offset;
|
low = offset;
|
||||||
high = offset >> 32;
|
high = offset >> 32;
|
||||||
if (!SetFilePointer(s->hfile, low, &high, FILE_BEGIN))
|
|
||||||
|
/*
|
||||||
|
* An error has occurred if the return value is INVALID_SET_FILE_POINTER
|
||||||
|
* and GetLastError doesn't return NO_ERROR.
|
||||||
|
*/
|
||||||
|
dwPtrLow = SetFilePointer(s->hfile, low, &high, FILE_BEGIN);
|
||||||
|
if (dwPtrLow == INVALID_SET_FILE_POINTER && GetLastError() != NO_ERROR) {
|
||||||
|
fprintf(stderr, "SetFilePointer error: %d\n", GetLastError());
|
||||||
return -EIO;
|
return -EIO;
|
||||||
if (!SetEndOfFile(s->hfile))
|
}
|
||||||
|
if (SetEndOfFile(s->hfile) == 0) {
|
||||||
|
fprintf(stderr, "SetEndOfFile error: %d\n", GetLastError());
|
||||||
return -EIO;
|
return -EIO;
|
||||||
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue