From b895a333562e5ada8d1e30af0bdcbfe537d74e0f Mon Sep 17 00:00:00 2001 From: GNU Libc Maintainers Date: Wed, 5 Dec 2018 18:50:21 +0000 Subject: [PATCH] tg-eintr commit 230b85f414291ac955827aba15cfbd103ab6ebdd Author: Samuel Thibault Date: Thu Jun 9 01:15:10 2016 +0200 Fix pipe() call returning EINTR sometimes because it uses a critical section Gbp-Pq: Topic hurd-i386 Gbp-Pq: Name tg-eintr.diff --- hurd/hurdsock.c | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/hurd/hurdsock.c b/hurd/hurdsock.c index bb98a6b74..e9334ba78 100644 --- a/hurd/hurdsock.c +++ b/hurd/hurdsock.c @@ -52,6 +52,7 @@ _hurd_socket_server (int domain, int dead) return MACH_PORT_NULL; } +retry: HURD_CRITICAL_BEGIN; __mutex_lock (&lock); @@ -102,6 +103,10 @@ _hurd_socket_server (int domain, int dead) __mutex_unlock (&lock); HURD_CRITICAL_END; + if (!server && errno == EINTR) + /* Got a signal while inside an RPC of the critical section, retry again */ + goto retry; + return server; } -- 2.30.2