Fix error reporting after ioctl() call with pg_upgrade --clone
authorMichael Paquier
Mon, 1 Aug 2022 07:39:30 +0000 (16:39 +0900)
committerMichael Paquier
Mon, 1 Aug 2022 07:39:30 +0000 (16:39 +0900)
errno was not reported correctly after attempting to clone a file,
leading to incorrect error reports.  While scanning through the code, I
have not noticed any similar mistakes.

Error introduced in 3a769d8.

Author: Justin Pryzby
Discussion: https://postgr.es/m/20220731134135[email protected]
Backpatch-through: 12

src/bin/pg_upgrade/file.c

index 395e53791b6f3953d9db19ed897b51d836596134..2bc0f440b6f6a7646c5aac6f74c6420940d10aab 100644 (file)
@@ -57,9 +57,11 @@ cloneFile(const char *src, const char *dst,
 
    if (ioctl(dest_fd, FICLONE, src_fd) < 0)
    {
+       int         save_errno = errno;
+
        unlink(dst);
        pg_fatal("error while cloning relation \"%s.%s\" (\"%s\" to \"%s\"): %s\n",
-                schemaName, relName, src, dst, strerror(errno));
+                schemaName, relName, src, dst, strerror(save_errno));
    }
 
    close(src_fd);