]> git.ipfire.org Git - thirdparty/postgresql.git/commitdiff
Fix errno check based on EINTR in pg_flush_data()
authorMichael Paquier <michael@paquier.xyz>
Thu, 30 Apr 2026 09:44:38 +0000 (18:44 +0900)
committerMichael Paquier <michael@paquier.xyz>
Thu, 30 Apr 2026 09:44:38 +0000 (18:44 +0900)
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 <charsyam@gmail.com>
Discussion: https://postgr.es/m/20260429151811.1810874-1-charsyam@gmail.com
Backpatch-through: 16

src/backend/storage/file/fd.c

index a8be066afe0d69dbd7114fb7d2ab728ad6c45ddf..817855e2720f7c957a3d8f225176767c861af4ad 100644 (file)
@@ -563,7 +563,7 @@ retry:
                {
                        int                     elevel;
 
-                       if (rc == EINTR)
+                       if (errno == EINTR)
                                goto retry;
 
                        /*