From b05b7d84d6bd29dd07d0b493dad8d4d48493db3e Mon Sep 17 00:00:00 2001 From: Christopher Faylor Date: Fri, 17 May 2002 19:30:52 +0000 Subject: * fhandler.cc (fhandler_base::lseek): Avoid calling SetFilePointer with high order part of 64 bit address on OS's which do not support that kind of operation. Otherwise Windows 95 will become confused. --- winsup/cygwin/fhandler.cc | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) (limited to 'winsup/cygwin/fhandler.cc') diff --git a/winsup/cygwin/fhandler.cc b/winsup/cygwin/fhandler.cc index dd7aeb2e7..d1b0a4afc 100644 --- a/winsup/cygwin/fhandler.cc +++ b/winsup/cygwin/fhandler.cc @@ -732,9 +732,17 @@ fhandler_base::lseek (__off64_t offset, int whence) : (whence == SEEK_CUR ? FILE_CURRENT : FILE_END); LONG off_low = offset & 0xffffffff; - LONG off_high = wincap.has_64bit_file_access () ? offset >> 32 : 0; + LONG *poff_high, off_high; + if (!wincap.has_64bit_file_access ()) + poff_high = NULL; + else + { + off_high = offset >> 32; + poff_high = &off_high; + } - res = SetFilePointer (get_handle(), off_low, &off_high, win32_whence); + debug_printf ("setting file pointer to %u (high), %u (low)", off_high, off_low); + res = SetFilePointer (get_handle(), off_low, poff_high, win32_whence); if (res == INVALID_SET_FILE_POINTER && GetLastError ()) { __seterrno (); -- cgit v1.2.3