ac3a84
From 62686ccc4631b6a5f73722fd7f1dcaca8782431c Mon Sep 17 00:00:00 2001
ac3a84
From: Lennart Poettering <lennart@poettering.net>
ac3a84
Date: Tue, 22 Nov 2022 12:56:55 +0100
ac3a84
Subject: [PATCH] utmp-wtmp: handle EINTR gracefully when waiting to write to
ac3a84
 tty
ac3a84
ac3a84
(cherry picked from commit 22ecfa83123dbfa2322346ac4e25ad2193a3b10c)
ac3a84
ac3a84
Related: #2137584
ac3a84
---
ac3a84
 src/shared/utmp-wtmp.c | 11 +++++++----
ac3a84
 1 file changed, 7 insertions(+), 4 deletions(-)
ac3a84
ac3a84
diff --git a/src/shared/utmp-wtmp.c b/src/shared/utmp-wtmp.c
ac3a84
index 20add0e81b..37a5bf7990 100644
ac3a84
--- a/src/shared/utmp-wtmp.c
ac3a84
+++ b/src/shared/utmp-wtmp.c
ac3a84
@@ -12,6 +12,7 @@
ac3a84
 #include <utmpx.h>
ac3a84
 
ac3a84
 #include "alloc-util.h"
ac3a84
+#include "errno-util.h"
ac3a84
 #include "fd-util.h"
ac3a84
 #include "hostname-util.h"
ac3a84
 #include "io-util.h"
ac3a84
@@ -300,7 +301,7 @@ static int write_to_terminal(const char *tty, const char *message) {
ac3a84
         p = message;
ac3a84
         left = strlen(message);
ac3a84
 
ac3a84
-        end = now(CLOCK_MONOTONIC) + TIMEOUT_USEC;
ac3a84
+        end = usec_add(now(CLOCK_MONOTONIC), TIMEOUT_USEC);
ac3a84
 
ac3a84
         while (left > 0) {
ac3a84
                 ssize_t n;
ac3a84
@@ -308,19 +309,21 @@ static int write_to_terminal(const char *tty, const char *message) {
ac3a84
                 int k;
ac3a84
 
ac3a84
                 t = now(CLOCK_MONOTONIC);
ac3a84
-
ac3a84
                 if (t >= end)
ac3a84
                         return -ETIME;
ac3a84
 
ac3a84
                 k = fd_wait_for_event(fd, POLLOUT, end - t);
ac3a84
-                if (k < 0)
ac3a84
+                if (k < 0) {
ac3a84
+                        if (ERRNO_IS_TRANSIENT(k))
ac3a84
+                                continue;
ac3a84
                         return k;
ac3a84
+                }
ac3a84
                 if (k == 0)
ac3a84
                         return -ETIME;
ac3a84
 
ac3a84
                 n = write(fd, p, left);
ac3a84
                 if (n < 0) {
ac3a84
-                        if (errno == EAGAIN)
ac3a84
+                        if (ERRNO_IS_TRANSIENT(errno))
ac3a84
                                 continue;
ac3a84
 
ac3a84
                         return -errno;