提交 5fc3c6db 编写于 作者: I igerasim

8055421: (fs) bad error handling in java.base/unix/native/libnio/fs/UnixNativeDispatcher.c

Reviewed-by: martin, alanb
上级 85b14a0c
......@@ -315,7 +315,7 @@ Java_sun_nio_fs_UnixNativeDispatcher_dup(JNIEnv* env, jclass this, jint fd) {
int res = -1;
RESTARTABLE(dup((int)fd), res);
if (fd == -1) {
if (res == -1) {
throwUnixException(env, errno);
}
return (jint)res;
......@@ -343,13 +343,14 @@ Java_sun_nio_fs_UnixNativeDispatcher_fopen0(JNIEnv* env, jclass this,
JNIEXPORT void JNICALL
Java_sun_nio_fs_UnixNativeDispatcher_fclose(JNIEnv* env, jclass this, jlong stream)
{
int res;
FILE* fp = jlong_to_ptr(stream);
do {
res = fclose(fp);
} while (res == EOF && errno == EINTR);
if (res == EOF) {
/* NOTE: fclose() wrapper is only used with read-only streams.
* If it ever is used with write streams, it might be better to add
* RESTARTABLE(fflush(fp)) before closing, to make sure the stream
* is completely written even if fclose() failed.
*/
if (fclose(fp) == EOF && errno != EINTR) {
throwUnixException(env, errno);
}
}
......@@ -657,11 +658,9 @@ Java_sun_nio_fs_UnixNativeDispatcher_fdopendir(JNIEnv* env, jclass this, int dfd
JNIEXPORT void JNICALL
Java_sun_nio_fs_UnixNativeDispatcher_closedir(JNIEnv* env, jclass this, jlong dir) {
int err;
DIR* dirp = jlong_to_ptr(dir);
RESTARTABLE(closedir(dirp), err);
if (errno == -1) {
if (closedir(dirp) == -1 && errno != EINTR) {
throwUnixException(env, errno);
}
}
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册