From 45c5c6fda477c04eca1c8fdf9bdff7eab0535751 Mon Sep 17 00:00:00 2001 From: Ivan Gerasimov Date: Thu, 28 Jun 2018 01:10:09 -0700 Subject: [PATCH] 8205959: Do not restart close if errno is EINTR Reviewed-by: alanb, vtewari --- src/java.base/linux/native/libnet/linux_close.c | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/src/java.base/linux/native/libnet/linux_close.c b/src/java.base/linux/native/libnet/linux_close.c index 3b1efa3592f..960b71966e9 100644 --- a/src/java.base/linux/native/libnet/linux_close.c +++ b/src/java.base/linux/native/libnet/linux_close.c @@ -1,5 +1,5 @@ /* - * Copyright (c) 2001, 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2001, 2018, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -290,13 +290,13 @@ static int closefd(int fd1, int fd2) { * And close/dup the file descriptor * (restart if interrupted by signal) */ - do { - if (fd1 < 0) { - rv = close(fd2); - } else { + if (fd1 < 0) { + rv = close(fd2); + } else { + do { rv = dup2(fd1, fd2); - } - } while (rv == -1 && errno == EINTR); + } while (rv == -1 && errno == EINTR); + } /* * Send a wakeup signal to all threads blocked on this