Am 20.08.2011 12:10, schrieb Stefan Weil:
SetFilePointer returns INVALID_SET_FILE_POINTER when it fails.
In addition, GetLastError must be checked.

The first call of SetFilePointer did not use INVALID_SET_FILE_POINTER,
the second call used wrong error handling.

Signed-off-by: Stefan Weil<w...@mail.berlios.de>
---
  block/raw-win32.c |    8 ++++++--
  1 files changed, 6 insertions(+), 2 deletions(-)

diff --git a/block/raw-win32.c b/block/raw-win32.c
index e47cfe0..b7dd357 100644
--- a/block/raw-win32.c
+++ b/block/raw-win32.c
@@ -41,6 +41,7 @@ typedef struct BDRVRawState {
  int qemu_ftruncate64(int fd, int64_t length)
  {
      LARGE_INTEGER li;
+    DWORD dw;
      LONG high;
      HANDLE h;
      BOOL res;
@@ -53,12 +54,15 @@ int qemu_ftruncate64(int fd, int64_t length)
      /* get current position, ftruncate do not change position */
      li.HighPart = 0;
      li.LowPart = SetFilePointer (h, 0,&li.HighPart, FILE_CURRENT);
-    if (li.LowPart == 0xffffffffUL&&  GetLastError() != NO_ERROR)
+    if (li.LowPart == INVALID_SET_FILE_POINTER&&  GetLastError() != NO_ERROR) {
        return -1;
+    }

      high = length>>  32;
-    if (!SetFilePointer(h, (DWORD) length,&high, FILE_BEGIN))
+    dw = SetFilePointer(h, (DWORD) length,&high, FILE_BEGIN);
+    if (dw == INVALID_SET_FILE_POINTER&&  GetLastError() != NO_ERROR) {
        return -1;
+    }
      res = SetEndOfFile(h);

      /* back to old position */

This is a bug fix, please apply it to git master and stable-0.15.

Thanks,
Stefan W.


Reply via email to