From: Michael Paquier Date: Thu, 30 Apr 2026 09:44:38 +0000 (+0900) Subject: Fix errno check based on EINTR in pg_flush_data() X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=5941e7f092233adb5415b2a12addea48a97a6618;p=thirdparty%2Fpostgresql.git Fix errno check based on EINTR in pg_flush_data() Upon a failure of sync_file_range(), EINTR was checked based on the returned result of the routine rather than its errno. sync_file_range() returns -1 on failure, making the check a no-op, invalidating the retry attempt in this case. Oversight in 0d369ac65004. Author: DaeMyung Kang Discussion: https://postgr.es/m/20260429151811.1810874-1-charsyam@gmail.com Backpatch-through: 16 --- diff --git a/src/backend/storage/file/fd.c b/src/backend/storage/file/fd.c index a8be066afe0..817855e2720 100644 --- a/src/backend/storage/file/fd.c +++ b/src/backend/storage/file/fd.c @@ -563,7 +563,7 @@ retry: { int elevel; - if (rc == EINTR) + if (errno == EINTR) goto retry; /*