diff --git a/src/hotspot/os/aix/os_aix.cpp b/src/hotspot/os/aix/os_aix.cpp index 346afa7f6c4..d6133f2a664 100644 --- a/src/hotspot/os/aix/os_aix.cpp +++ b/src/hotspot/os/aix/os_aix.cpp @@ -2603,35 +2603,6 @@ jlong os::seek_to_file_offset(int fd, jlong offset) { return (jlong)::lseek64(fd, (off64_t)offset, SEEK_SET); } -// This code originates from JDK's sysAvailable -// from src/solaris/hpi/src/native_threads/src/sys_api_td.c - -int os::available(int fd, jlong *bytes) { - jlong cur, end; - int mode; - struct stat64 buf64; - - if (::fstat64(fd, &buf64) >= 0) { - mode = buf64.st_mode; - if (S_ISCHR(mode) || S_ISFIFO(mode) || S_ISSOCK(mode)) { - int n; - if (::ioctl(fd, FIONREAD, &n) >= 0) { - *bytes = n; - return 1; - } - } - } - if ((cur = ::lseek64(fd, 0L, SEEK_CUR)) == -1) { - return 0; - } else if ((end = ::lseek64(fd, 0L, SEEK_END)) == -1) { - return 0; - } else if (::lseek64(fd, cur, SEEK_SET) == -1) { - return 0; - } - *bytes = end - cur; - return 1; -} - // Map a block of memory. char* os::pd_map_memory(int fd, const char* file_name, size_t file_offset, char *addr, size_t bytes, bool read_only, diff --git a/src/hotspot/os/bsd/os_bsd.cpp b/src/hotspot/os/bsd/os_bsd.cpp index c26544be82c..55c792f24f1 100644 --- a/src/hotspot/os/bsd/os_bsd.cpp +++ b/src/hotspot/os/bsd/os_bsd.cpp @@ -2308,35 +2308,6 @@ jlong os::seek_to_file_offset(int fd, jlong offset) { return (jlong)::lseek(fd, (off_t)offset, SEEK_SET); } -// This code originates from JDK's sysAvailable -// from src/solaris/hpi/src/native_threads/src/sys_api_td.c - -int os::available(int fd, jlong *bytes) { - jlong cur, end; - int mode; - struct stat buf; - - if (::fstat(fd, &buf) >= 0) { - mode = buf.st_mode; - if (S_ISCHR(mode) || S_ISFIFO(mode) || S_ISSOCK(mode)) { - int n; - if (::ioctl(fd, FIONREAD, &n) >= 0) { - *bytes = n; - return 1; - } - } - } - if ((cur = ::lseek(fd, 0L, SEEK_CUR)) == -1) { - return 0; - } else if ((end = ::lseek(fd, 0L, SEEK_END)) == -1) { - return 0; - } else if (::lseek(fd, cur, SEEK_SET) == -1) { - return 0; - } - *bytes = end - cur; - return 1; -} - // Map a block of memory. char* os::pd_map_memory(int fd, const char* file_name, size_t file_offset, char *addr, size_t bytes, bool read_only, diff --git a/src/hotspot/os/linux/os_linux.cpp b/src/hotspot/os/linux/os_linux.cpp index e96ff835000..9a5707bee17 100644 --- a/src/hotspot/os/linux/os_linux.cpp +++ b/src/hotspot/os/linux/os_linux.cpp @@ -4944,35 +4944,6 @@ jlong os::seek_to_file_offset(int fd, jlong offset) { return (jlong)::lseek64(fd, (off64_t)offset, SEEK_SET); } -// This code originates from JDK's sysAvailable -// from src/solaris/hpi/src/native_threads/src/sys_api_td.c - -int os::available(int fd, jlong *bytes) { - jlong cur, end; - int mode; - struct stat64 buf64; - - if (::fstat64(fd, &buf64) >= 0) { - mode = buf64.st_mode; - if (S_ISCHR(mode) || S_ISFIFO(mode) || S_ISSOCK(mode)) { - int n; - if (::ioctl(fd, FIONREAD, &n) >= 0) { - *bytes = n; - return 1; - } - } - } - if ((cur = ::lseek64(fd, 0L, SEEK_CUR)) == -1) { - return 0; - } else if ((end = ::lseek64(fd, 0L, SEEK_END)) == -1) { - return 0; - } else if (::lseek64(fd, cur, SEEK_SET) == -1) { - return 0; - } - *bytes = end - cur; - return 1; -} - // Map a block of memory. char* os::pd_map_memory(int fd, const char* file_name, size_t file_offset, char *addr, size_t bytes, bool read_only, diff --git a/src/hotspot/os/windows/os_windows.cpp b/src/hotspot/os/windows/os_windows.cpp index 5b4ef70cc0e..ce4136fce72 100644 --- a/src/hotspot/os/windows/os_windows.cpp +++ b/src/hotspot/os/windows/os_windows.cpp @@ -4992,43 +4992,6 @@ int os::fsync(int fd) { return 0; } -static int nonSeekAvailable(int, long *); -static int stdinAvailable(int, long *); - -// This code is a copy of JDK's sysAvailable -// from src/windows/hpi/src/sys_api_md.c - -int os::available(int fd, jlong *bytes) { - jlong cur, end; - struct _stati64 stbuf64; - - if (::_fstati64(fd, &stbuf64) >= 0) { - int mode = stbuf64.st_mode; - if (S_ISCHR(mode) || S_ISFIFO(mode)) { - int ret; - long lpbytes; - if (fd == 0) { - ret = stdinAvailable(fd, &lpbytes); - } else { - ret = nonSeekAvailable(fd, &lpbytes); - } - (*bytes) = (jlong)(lpbytes); - return ret; - } - if ((cur = ::_lseeki64(fd, 0L, SEEK_CUR)) == -1) { - return FALSE; - } else if ((end = ::_lseeki64(fd, 0L, SEEK_END)) == -1) { - return FALSE; - } else if (::_lseeki64(fd, cur, SEEK_SET) == -1) { - return FALSE; - } - *bytes = end - cur; - return TRUE; - } else { - return FALSE; - } -} - void os::flockfile(FILE* fp) { _lock_file(fp); } @@ -5037,100 +5000,6 @@ void os::funlockfile(FILE* fp) { _unlock_file(fp); } -// This code is a copy of JDK's nonSeekAvailable -// from src/windows/hpi/src/sys_api_md.c - -static int nonSeekAvailable(int fd, long *pbytes) { - // This is used for available on non-seekable devices - // (like both named and anonymous pipes, such as pipes - // connected to an exec'd process). - // Standard Input is a special case. - HANDLE han; - - if ((han = (HANDLE) ::_get_osfhandle(fd)) == (HANDLE)(-1)) { - return FALSE; - } - - if (! ::PeekNamedPipe(han, NULL, 0, NULL, (LPDWORD)pbytes, NULL)) { - // PeekNamedPipe fails when at EOF. In that case we - // simply make *pbytes = 0 which is consistent with the - // behavior we get on Solaris when an fd is at EOF. - // The only alternative is to raise an Exception, - // which isn't really warranted. - // - if (::GetLastError() != ERROR_BROKEN_PIPE) { - return FALSE; - } - *pbytes = 0; - } - return TRUE; -} - -#define MAX_INPUT_EVENTS 2000 - -// This code is a copy of JDK's stdinAvailable -// from src/windows/hpi/src/sys_api_md.c - -static int stdinAvailable(int fd, long *pbytes) { - HANDLE han; - DWORD numEventsRead = 0; // Number of events read from buffer - DWORD numEvents = 0; // Number of events in buffer - DWORD i = 0; // Loop index - DWORD curLength = 0; // Position marker - DWORD actualLength = 0; // Number of bytes readable - BOOL error = FALSE; // Error holder - INPUT_RECORD *lpBuffer; // Pointer to records of input events - - if ((han = ::GetStdHandle(STD_INPUT_HANDLE)) == INVALID_HANDLE_VALUE) { - return FALSE; - } - - // Construct an array of input records in the console buffer - error = ::GetNumberOfConsoleInputEvents(han, &numEvents); - if (error == 0) { - return nonSeekAvailable(fd, pbytes); - } - - // lpBuffer must fit into 64K or else PeekConsoleInput fails - if (numEvents > MAX_INPUT_EVENTS) { - numEvents = MAX_INPUT_EVENTS; - } - - lpBuffer = (INPUT_RECORD *)os::malloc(numEvents * sizeof(INPUT_RECORD), mtInternal); - if (lpBuffer == NULL) { - return FALSE; - } - - error = ::PeekConsoleInput(han, lpBuffer, numEvents, &numEventsRead); - if (error == 0) { - os::free(lpBuffer); - return FALSE; - } - - // Examine input records for the number of bytes available - for (i=0; ibKeyDown == TRUE) { - CHAR *keyPressed = (CHAR *) &(keyRecord->uChar); - curLength++; - if (*keyPressed == '\r') { - actualLength = curLength; - } - } - } - } - - if (lpBuffer != NULL) { - os::free(lpBuffer); - } - - *pbytes = (long) actualLength; - return TRUE; -} - // Map a block of memory. char* os::pd_map_memory(int fd, const char* file_name, size_t file_offset, char *addr, size_t bytes, bool read_only, diff --git a/src/hotspot/share/runtime/os.hpp b/src/hotspot/share/runtime/os.hpp index 48d78a0fa33..ed20a29c4f7 100644 --- a/src/hotspot/share/runtime/os.hpp +++ b/src/hotspot/share/runtime/os.hpp @@ -550,7 +550,6 @@ class os: AllStatic { static char* native_path(char *path); static int ftruncate(int fd, jlong length); static int fsync(int fd); - static int available(int fd, jlong *bytes); static int get_fileno(FILE* fp); static void flockfile(FILE* fp); static void funlockfile(FILE* fp);