Blame SOURCES/coreutils-8.30-renameatu.patch

8d0e4d
From 57ee8db4fee8eb6772df1ff18d275594c0b034d4 Mon Sep 17 00:00:00 2001
8d0e4d
From: Paul Eggert <eggert@cs.ucla.edu>
8d0e4d
Date: Thu, 5 Jul 2018 09:22:09 -0700
8d0e4d
Subject: [PATCH 1/2] renameatu: rename from renameat2
8d0e4d
8d0e4d
It's looking like Glibc will add a renameat2 function
8d0e4d
that is incompatible with Gnulib renameat2; see:
8d0e4d
https://sourceware.org/ml/libc-alpha/2018-07/msg00064.html
8d0e4d
To help avoid future confusion, rename renameat2 to something else.
8d0e4d
Use the name 'renameatu', as the Gnulib function is close to the
8d0e4d
Glibc function.  Perhaps someday there will also be a renameat2
8d0e4d
Gnulib module, which mimicks the future glibc renameat2, but that
8d0e4d
can wait as nobody seems to need such a module now.
8d0e4d
* NEWS: Mention this.
8d0e4d
* lib/renameatu.c: Rename from lib/renameat2.c.
8d0e4d
* lib/renameatu.h: Rename from lib/renameat2.h.
8d0e4d
* modules/renameatu: Rename from modules/renameat2.
8d0e4d
* modules/renameatu-tests: Rename from modules/renameat2-tests.
8d0e4d
All uses of "renameat2" in identifiers or file name
8d0e4d
changed to "renameatu", except for two instances in
8d0e4d
lib/renameatu.c that deal with the Linux kernel's
8d0e4d
renameat2 syscall.
8d0e4d
8d0e4d
Upstream-commit: 2522322e5304e7d86c63e607e2bc83c8d8b0a889
8d0e4d
Signed-off-by: Kamil Dudka <kdudka@redhat.com>
8d0e4d
---
8d0e4d
 gnulib-tests/gnulib.mk                             | 12 +++---
8d0e4d
 .../{test-renameat2.c => test-renameatu.c}         | 48 +++++++++++-----------
8d0e4d
 lib/backupfile.c                                   |  4 +-
8d0e4d
 lib/gnulib.mk                                      | 10 ++---
8d0e4d
 lib/renameat.c                                     |  4 +-
8d0e4d
 lib/{renameat2.c => renameatu.c}                   |  9 ++--
8d0e4d
 lib/{renameat2.h => renameatu.h}                   |  8 ++--
8d0e4d
 7 files changed, 48 insertions(+), 47 deletions(-)
8d0e4d
 rename gnulib-tests/{test-renameat2.c => test-renameatu.c} (80%)
8d0e4d
 rename lib/{renameat2.c => renameatu.c} (94%)
8d0e4d
 rename lib/{renameat2.h => renameatu.h} (84%)
8d0e4d
8d0e4d
diff --git a/gnulib-tests/gnulib.mk b/gnulib-tests/gnulib.mk
8d0e4d
index be2b99e..891425b 100644
8d0e4d
--- a/gnulib-tests/gnulib.mk
8d0e4d
+++ b/gnulib-tests/gnulib.mk
8d0e4d
@@ -1750,14 +1750,14 @@ EXTRA_DIST += test-rename.h test-renameat.c signature.h macros.h
8d0e4d
 
8d0e4d
 ## end   gnulib module renameat-tests
8d0e4d
 
8d0e4d
-## begin gnulib module renameat2-tests
8d0e4d
+## begin gnulib module renameatu-tests
8d0e4d
 
8d0e4d
-TESTS += test-renameat2
8d0e4d
-check_PROGRAMS += test-renameat2
8d0e4d
-test_renameat2_LDADD = $(LDADD) @LIBINTL@
8d0e4d
-EXTRA_DIST += test-rename.h test-renameat2.c signature.h macros.h
8d0e4d
+TESTS += test-renameatu
8d0e4d
+check_PROGRAMS += test-renameatu
8d0e4d
+test_renameatu_LDADD = $(LDADD) @LIBINTL@
8d0e4d
+EXTRA_DIST += test-rename.h test-renameatu.c signature.h macros.h
8d0e4d
 
8d0e4d
-## end   gnulib module renameat2-tests
8d0e4d
+## end   gnulib module renameatu-tests
8d0e4d
 
8d0e4d
 ## begin gnulib module rmdir-tests
8d0e4d
 
8d0e4d
diff --git a/gnulib-tests/test-renameat2.c b/gnulib-tests/test-renameatu.c
8d0e4d
similarity index 80%
8d0e4d
rename from gnulib-tests/test-renameat2.c
8d0e4d
rename to gnulib-tests/test-renameatu.c
8d0e4d
index 0104890..988428b 100644
8d0e4d
--- a/gnulib-tests/test-renameat2.c
8d0e4d
+++ b/gnulib-tests/test-renameatu.c
8d0e4d
@@ -1,4 +1,4 @@
8d0e4d
-/* Test renameat2.
8d0e4d
+/* Test renameatu.
8d0e4d
    Copyright (C) 2009-2018 Free Software Foundation, Inc.
8d0e4d
 
8d0e4d
    This program is free software: you can redistribute it and/or modify
8d0e4d
@@ -18,12 +18,12 @@
8d0e4d
 
8d0e4d
 #include <config.h>
8d0e4d
 
8d0e4d
-#include <renameat2.h>
8d0e4d
+#include <renameatu.h>
8d0e4d
 
8d0e4d
 #include <stdio.h>
8d0e4d
 
8d0e4d
 #include "signature.h"
8d0e4d
-SIGNATURE_CHECK (renameat2, int,
8d0e4d
+SIGNATURE_CHECK (renameatu, int,
8d0e4d
                  (int, char const *, int, char const *, unsigned int));
8d0e4d
 
8d0e4d
 #include <dirent.h>
8d0e4d
@@ -39,18 +39,18 @@ SIGNATURE_CHECK (renameat2, int,
8d0e4d
 #include "ignore-value.h"
8d0e4d
 #include "macros.h"
8d0e4d
 
8d0e4d
-#define BASE "test-renameat2.t"
8d0e4d
+#define BASE "test-renameatu.t"
8d0e4d
 
8d0e4d
 #include "test-rename.h"
8d0e4d
 
8d0e4d
 static int dfd1 = AT_FDCWD;
8d0e4d
 static int dfd2 = AT_FDCWD;
8d0e4d
 
8d0e4d
-/* Wrapper to test renameat2 like rename.  */
8d0e4d
+/* Wrapper to test renameatu like rename.  */
8d0e4d
 static int
8d0e4d
 do_rename (char const *name1, char const *name2)
8d0e4d
 {
8d0e4d
-  return renameat2 (dfd1, name1, dfd2, name2, 0);
8d0e4d
+  return renameatu (dfd1, name1, dfd2, name2, 0);
8d0e4d
 }
8d0e4d
 
8d0e4d
 int
8d0e4d
@@ -67,24 +67,24 @@ main (void)
8d0e4d
   /* Test behaviour for invalid file descriptors.  */
8d0e4d
   {
8d0e4d
     errno = 0;
8d0e4d
-    ASSERT (renameat2 (-1, "foo", AT_FDCWD, "bar", 0) == -1);
8d0e4d
+    ASSERT (renameatu (-1, "foo", AT_FDCWD, "bar", 0) == -1);
8d0e4d
     ASSERT (errno == EBADF);
8d0e4d
   }
8d0e4d
   {
8d0e4d
     close (99);
8d0e4d
     errno = 0;
8d0e4d
-    ASSERT (renameat2 (99, "foo", AT_FDCWD, "bar", 0) == -1);
8d0e4d
+    ASSERT (renameatu (99, "foo", AT_FDCWD, "bar", 0) == -1);
8d0e4d
     ASSERT (errno == EBADF);
8d0e4d
   }
8d0e4d
   ASSERT (close (creat (BASE "oo", 0600)) == 0);
8d0e4d
   {
8d0e4d
     errno = 0;
8d0e4d
-    ASSERT (renameat2 (AT_FDCWD, BASE "oo", -1, "bar", 0) == -1);
8d0e4d
+    ASSERT (renameatu (AT_FDCWD, BASE "oo", -1, "bar", 0) == -1);
8d0e4d
     ASSERT (errno == EBADF);
8d0e4d
   }
8d0e4d
   {
8d0e4d
     errno = 0;
8d0e4d
-    ASSERT (renameat2 (AT_FDCWD, BASE "oo", 99, "bar", 0) == -1);
8d0e4d
+    ASSERT (renameatu (AT_FDCWD, BASE "oo", 99, "bar", 0) == -1);
8d0e4d
     ASSERT (errno == EBADF);
8d0e4d
   }
8d0e4d
   ASSERT (unlink (BASE "oo") == 0);
8d0e4d
@@ -133,13 +133,13 @@ main (void)
8d0e4d
 
8d0e4d
       ASSERT (sprintf (strchr (file1, '\0') - 2, "%02d", i) == 2);
8d0e4d
       ASSERT (sprintf (strchr (file2, '\0') - 2, "%02d", i + 1) == 2);
8d0e4d
-      ASSERT (renameat2 (fd1, file1, fd2, file2, 0) == 0);
8d0e4d
+      ASSERT (renameatu (fd1, file1, fd2, file2, 0) == 0);
8d0e4d
       free (file1);
8d0e4d
       free (file2);
8d0e4d
     }
8d0e4d
   dfd2 = open ("..", O_RDONLY);
8d0e4d
   ASSERT (0 <= dfd2);
8d0e4d
-  ASSERT (renameat2 (dfd, "../" BASE "16", dfd2, BASE "17", 0) == 0);
8d0e4d
+  ASSERT (renameatu (dfd, "../" BASE "16", dfd2, BASE "17", 0) == 0);
8d0e4d
   ASSERT (close (dfd2) == 0);
8d0e4d
 
8d0e4d
   /* Now we change back to the parent directory, and set dfd to ".";
8d0e4d
@@ -152,47 +152,47 @@ main (void)
8d0e4d
 
8d0e4d
   ASSERT (close (creat (BASE "sub2/file", 0600)) == 0);
8d0e4d
   errno = 0;
8d0e4d
-  ASSERT (renameat2 (dfd, BASE "sub1", dfd, BASE "sub2", 0) == -1);
8d0e4d
+  ASSERT (renameatu (dfd, BASE "sub1", dfd, BASE "sub2", 0) == -1);
8d0e4d
   ASSERT (errno == EEXIST || errno == ENOTEMPTY);
8d0e4d
   ASSERT (unlink (BASE "sub2/file") == 0);
8d0e4d
   errno = 0;
8d0e4d
-  ASSERT (renameat2 (dfd, BASE "sub2", dfd, BASE "sub1/.", 0) == -1);
8d0e4d
+  ASSERT (renameatu (dfd, BASE "sub2", dfd, BASE "sub1/.", 0) == -1);
8d0e4d
   ASSERT (errno == EINVAL || errno == EISDIR || errno == EBUSY
8d0e4d
           || errno == ENOTEMPTY || errno == EEXIST
8d0e4d
           || errno == ENOENT /* WSL */);
8d0e4d
   errno = 0;
8d0e4d
-  ASSERT (renameat2 (dfd, BASE "sub2/.", dfd, BASE "sub1", 0) == -1);
8d0e4d
+  ASSERT (renameatu (dfd, BASE "sub2/.", dfd, BASE "sub1", 0) == -1);
8d0e4d
   ASSERT (errno == EINVAL || errno == EBUSY || errno == EEXIST
8d0e4d
           || errno == ENOENT /* WSL */);
8d0e4d
   errno = 0;
8d0e4d
-  ASSERT (renameat2 (dfd, BASE "17", dfd, BASE "sub1", 0) == -1);
8d0e4d
+  ASSERT (renameatu (dfd, BASE "17", dfd, BASE "sub1", 0) == -1);
8d0e4d
   ASSERT (errno == EISDIR);
8d0e4d
   errno = 0;
8d0e4d
-  ASSERT (renameat2 (dfd, BASE "nosuch", dfd, BASE "18", 0) == -1);
8d0e4d
+  ASSERT (renameatu (dfd, BASE "nosuch", dfd, BASE "18", 0) == -1);
8d0e4d
   ASSERT (errno == ENOENT);
8d0e4d
   errno = 0;
8d0e4d
-  ASSERT (renameat2 (dfd, "", dfd, BASE "17", 0) == -1);
8d0e4d
+  ASSERT (renameatu (dfd, "", dfd, BASE "17", 0) == -1);
8d0e4d
   ASSERT (errno == ENOENT);
8d0e4d
   errno = 0;
8d0e4d
-  ASSERT (renameat2 (dfd, BASE "17", dfd, "", 0) == -1);
8d0e4d
+  ASSERT (renameatu (dfd, BASE "17", dfd, "", 0) == -1);
8d0e4d
   ASSERT (errno == ENOENT);
8d0e4d
   errno = 0;
8d0e4d
-  ASSERT (renameat2 (dfd, BASE "sub2", dfd, BASE "17", 0) == -1);
8d0e4d
+  ASSERT (renameatu (dfd, BASE "sub2", dfd, BASE "17", 0) == -1);
8d0e4d
   ASSERT (errno == ENOTDIR);
8d0e4d
   errno = 0;
8d0e4d
-  ASSERT (renameat2 (dfd, BASE "17/", dfd, BASE "18", 0) == -1);
8d0e4d
+  ASSERT (renameatu (dfd, BASE "17/", dfd, BASE "18", 0) == -1);
8d0e4d
   ASSERT (errno == ENOTDIR);
8d0e4d
   errno = 0;
8d0e4d
-  ASSERT (renameat2 (dfd, BASE "17", dfd, BASE "18/", 0) == -1);
8d0e4d
+  ASSERT (renameatu (dfd, BASE "17", dfd, BASE "18/", 0) == -1);
8d0e4d
   ASSERT (errno == ENOTDIR || errno == ENOENT);
8d0e4d
 
8d0e4d
   /* Finally, make sure we cannot overwrite existing files.  */
8d0e4d
   ASSERT (close (creat (BASE "sub2/file", 0600)) == 0);
8d0e4d
   errno = 0;
8d0e4d
-  ASSERT ((renameat2 (dfd, BASE "sub2", dfd, BASE "sub1", RENAME_NOREPLACE)
8d0e4d
+  ASSERT ((renameatu (dfd, BASE "sub2", dfd, BASE "sub1", RENAME_NOREPLACE)
8d0e4d
            == -1)
8d0e4d
           && errno == EEXIST);
8d0e4d
-  ASSERT ((renameat2 (dfd, BASE "sub2/file", dfd, BASE "17", RENAME_NOREPLACE)
8d0e4d
+  ASSERT ((renameatu (dfd, BASE "sub2/file", dfd, BASE "17", RENAME_NOREPLACE)
8d0e4d
            == -1)
8d0e4d
           && errno == EEXIST);
8d0e4d
 
8d0e4d
diff --git a/lib/backupfile.c b/lib/backupfile.c
8d0e4d
index d438455..637be6c 100644
8d0e4d
--- a/lib/backupfile.c
8d0e4d
+++ b/lib/backupfile.c
8d0e4d
@@ -23,7 +23,7 @@
8d0e4d
 #include "backup-internal.h"
8d0e4d
 
8d0e4d
 #include "dirname.h"
8d0e4d
-#include "renameat2.h"
8d0e4d
+#include "renameatu.h"
8d0e4d
 #include "xalloc-oversized.h"
8d0e4d
 
8d0e4d
 #include <fcntl.h>
8d0e4d
@@ -353,7 +353,7 @@ backupfile_internal (char const *file, enum backup_type backup_type, bool rename
8d0e4d
           base_offset = 0;
8d0e4d
         }
8d0e4d
       unsigned flags = backup_type == simple_backups ? 0 : RENAME_NOREPLACE;
8d0e4d
-      if (renameat2 (AT_FDCWD, file, sdir, s + base_offset, flags) == 0)
8d0e4d
+      if (renameatu (AT_FDCWD, file, sdir, s + base_offset, flags) == 0)
8d0e4d
         break;
8d0e4d
       int e = errno;
8d0e4d
       if (e != EEXIST)
8d0e4d
diff --git a/lib/gnulib.mk b/lib/gnulib.mk
8d0e4d
index 04473d5..0b747e3 100644
8d0e4d
--- a/lib/gnulib.mk
8d0e4d
+++ b/lib/gnulib.mk
8d0e4d
@@ -21,7 +21,7 @@
8d0e4d
 # the same distribution terms as the rest of that program.
8d0e4d
 #
8d0e4d
 # Generated by gnulib-tool.
8d0e4d
-# Reproduce by: gnulib-tool --import --local-dir=gl --lib=libcoreutils --source-base=lib --m4-base=m4 --doc-base=doc --tests-base=gnulib-tests --aux-dir=build-aux --with-tests --avoid=canonicalize-lgpl --avoid=dummy --makefile-name=gnulib.mk --no-conditional-dependencies --no-libtool --macro-prefix=gl acl alignof alloca announce-gen areadlink-with-size argmatch argv-iter assert autobuild backup-rename backupfile base32 base64 buffer-lcm c-strcase c-strtod c-strtold calloc-gnu canon-host canonicalize chown cloexec closein closeout config-h configmake crypto/md5 crypto/sha1 crypto/sha256 crypto/sha512 cycle-check d-ino d-type di-set diacrit dirfd dirname do-release-commit-and-tag dtoastr dup2 environ error euidaccess exclude exitfail explicit_bzero faccessat fadvise fchdir fchmodat fchownat fclose fcntl fcntl-safer fd-reopen fdatasync fdl fdopen fdutimensat file-has-acl file-type fileblocks filemode filenamecat filevercmp flexmember fnmatch-gnu fopen-safer fprintftime freopen freopen-safer fseeko fstatat fsusage fsync ftoastr ftruncate fts full-read full-write getgroups gethrxtime getline getloadavg getlogin getndelim2 getopt-gnu getpagesize getpass-gnu gettext-h gettime gettimeofday getugroups getusershell git-version-gen gitlog-to-changelog gnu-make gnu-web-doc-update gnumakefile gnupload group-member hard-locale hash hash-pjw heap host-os human idcache ignore-value inttostr inttypes isapipe isatty isblank largefile lchmod lchown ldtoastr lib-ignore linebuffer link link-follow linkat long-options lstat maintainer-makefile malloc-gnu manywarnings mbrlen mbrtowc mbsalign mbschr mbslen mbswidth memcasecmp memchr memcmp2 mempcpy memrchr mgetgroups mkancesdirs mkdir mkdir-p mkfifo mknod mkostemp mkstemp mktime modechange mountlist mpsort netinet_in non-recursive-gnulib-prefix-hack nproc nstrftime obstack open parse-datetime pathmax perl physmem pipe-posix pipe2 posix-shell posixtm posixver priv-set progname propername pthread putenv quote quotearg randint randperm read-file readlink readtokens readtokens0 readutmp realloc-gnu regex remove rename renameat renameat2 rmdir root-dev-ino rpmatch safe-read same save-cwd savedir savewd selinux-at setenv settime sig2str sigaction smack ssize_t stat-macros stat-size stat-time statat stdbool stdlib-safer stpcpy stpncpy strdup-posix strncat strnumcmp strsignal strtod strtoimax strtoumax symlinkat sys_ioctl sys_resource sys_stat sys_wait tempname termios time_rz timer-time timespec tzset uname unicodeio unistd-safer unlink-busy unlinkat unlocked-io unsetenv update-copyright uptime useless-if-before-free userspec utimecmp utimens vasprintf-posix vc-list-files verify verror version-etc-fsf wchar-single wcswidth wcwidth winsz-ioctl winsz-termios write-any-file xalloc xbinary-io xdectoint xfts xgetcwd xgetgroups xgethostname xmemcoll xnanosleep xprintf xprintf-posix xreadlink xstrtod xstrtoimax xstrtol xstrtold xstrtoumax year2038 yesno
8d0e4d
+# Reproduce by: gnulib-tool --import --local-dir=gl --lib=libcoreutils --source-base=lib --m4-base=m4 --doc-base=doc --tests-base=gnulib-tests --aux-dir=build-aux --with-tests --avoid=canonicalize-lgpl --avoid=dummy --makefile-name=gnulib.mk --no-conditional-dependencies --no-libtool --macro-prefix=gl acl alignof alloca announce-gen areadlink-with-size argmatch argv-iter assert autobuild backup-rename backupfile base32 base64 buffer-lcm c-strcase c-strtod c-strtold calloc-gnu canon-host canonicalize chown cloexec closein closeout config-h configmake crypto/md5 crypto/sha1 crypto/sha256 crypto/sha512 cycle-check d-ino d-type di-set diacrit dirfd dirname do-release-commit-and-tag dtoastr dup2 environ error euidaccess exclude exitfail explicit_bzero faccessat fadvise fchdir fchmodat fchownat fclose fcntl fcntl-safer fd-reopen fdatasync fdl fdopen fdutimensat file-has-acl file-type fileblocks filemode filenamecat filevercmp flexmember fnmatch-gnu fopen-safer fprintftime freopen freopen-safer fseeko fstatat fsusage fsync ftoastr ftruncate fts full-read full-write getgroups gethrxtime getline getloadavg getlogin getndelim2 getopt-gnu getpagesize getpass-gnu gettext-h gettime gettimeofday getugroups getusershell git-version-gen gitlog-to-changelog gnu-make gnu-web-doc-update gnumakefile gnupload group-member hard-locale hash hash-pjw heap host-os human idcache ignore-value inttostr inttypes isapipe isatty isblank largefile lchmod lchown ldtoastr lib-ignore linebuffer link link-follow linkat long-options lstat maintainer-makefile malloc-gnu manywarnings mbrlen mbrtowc mbsalign mbschr mbslen mbswidth memcasecmp memchr memcmp2 mempcpy memrchr mgetgroups mkancesdirs mkdir mkdir-p mkfifo mknod mkostemp mkstemp mktime modechange mountlist mpsort netinet_in non-recursive-gnulib-prefix-hack nproc nstrftime obstack open parse-datetime pathmax perl physmem pipe-posix pipe2 posix-shell posixtm posixver priv-set progname propername pthread putenv quote quotearg randint randperm read-file readlink readtokens readtokens0 readutmp realloc-gnu regex remove rename renameat renameatu rmdir root-dev-ino rpmatch safe-read same save-cwd savedir savewd selinux-at setenv settime sig2str sigaction smack ssize_t stat-macros stat-size stat-time statat stdbool stdlib-safer stpcpy stpncpy strdup-posix strncat strnumcmp strsignal strtod strtoimax strtoumax symlinkat sys_ioctl sys_resource sys_stat sys_wait tempname termios time_rz timer-time timespec tzset uname unicodeio unistd-safer unlink-busy unlinkat unlocked-io unsetenv update-copyright uptime useless-if-before-free userspec utimecmp utimens vasprintf-posix vc-list-files verify verror version-etc-fsf wchar-single wcswidth wcwidth winsz-ioctl winsz-termios write-any-file xalloc xbinary-io xdectoint xfts xgetcwd xgetgroups xgethostname xmemcoll xnanosleep xprintf xprintf-posix xreadlink xstrtod xstrtoimax xstrtol xstrtold xstrtoumax year2038 yesno
8d0e4d
 
8d0e4d
 
8d0e4d
 MOSTLYCLEANFILES += lib/core lib/*.stackdump
8d0e4d
@@ -3218,15 +3218,15 @@ EXTRA_lib_libcoreutils_a_SOURCES += lib/renameat.c
8d0e4d
 
8d0e4d
 ## end   gnulib module renameat
8d0e4d
 
8d0e4d
-## begin gnulib module renameat2
8d0e4d
+## begin gnulib module renameatu
8d0e4d
 
8d0e4d
-lib_libcoreutils_a_SOURCES += lib/renameat2.c
8d0e4d
+lib_libcoreutils_a_SOURCES += lib/renameatu.c
8d0e4d
 
8d0e4d
-EXTRA_DIST += lib/at-func2.c lib/renameat2.h
8d0e4d
+EXTRA_DIST += lib/at-func2.c lib/renameatu.h
8d0e4d
 
8d0e4d
 EXTRA_lib_libcoreutils_a_SOURCES += lib/at-func2.c
8d0e4d
 
8d0e4d
-## end   gnulib module renameat2
8d0e4d
+## end   gnulib module renameatu
8d0e4d
 
8d0e4d
 ## begin gnulib module rewinddir
8d0e4d
 
8d0e4d
diff --git a/lib/renameat.c b/lib/renameat.c
8d0e4d
index 0cb7d33..67be22b 100644
8d0e4d
--- a/lib/renameat.c
8d0e4d
+++ b/lib/renameat.c
8d0e4d
@@ -16,10 +16,10 @@
8d0e4d
 
8d0e4d
 #include <config.h>
8d0e4d
 #include <stdio.h>
8d0e4d
-#include "renameat2.h"
8d0e4d
+#include "renameatu.h"
8d0e4d
 
8d0e4d
 int
8d0e4d
 renameat (int fd1, char const *src, int fd2, char const *dst)
8d0e4d
 {
8d0e4d
-  return renameat2 (fd1, src, fd2, dst, 0);
8d0e4d
+  return renameatu (fd1, src, fd2, dst, 0);
8d0e4d
 }
8d0e4d
diff --git a/lib/renameat2.c b/lib/renameatu.c
8d0e4d
similarity index 94%
8d0e4d
rename from lib/renameat2.c
8d0e4d
rename to lib/renameatu.c
8d0e4d
index a295ec3..b013ad6 100644
8d0e4d
--- a/lib/renameat2.c
8d0e4d
+++ b/lib/renameatu.c
8d0e4d
@@ -18,7 +18,7 @@
8d0e4d
 
8d0e4d
 #include <config.h>
8d0e4d
 
8d0e4d
-#include "renameat2.h"
8d0e4d
+#include "renameatu.h"
8d0e4d
 
8d0e4d
 #include <errno.h>
8d0e4d
 #include <stdio.h>
8d0e4d
@@ -68,10 +68,13 @@ rename_noreplace (char const *src, char const *dst)
8d0e4d
    the restore_cwd fails, then give a diagnostic and exit nonzero.
8d0e4d
 
8d0e4d
    Obey FLAGS when doing the renaming.  If FLAGS is zero, this
8d0e4d
-   function is equivalent to renameat (FD1, SRC, FD2, DST).  */
8d0e4d
+   function is equivalent to renameat (FD1, SRC, FD2, DST).
8d0e4d
+   Otherwise, attempt to implement FLAGS even if the implementation is
8d0e4d
+   not atomic; this differs from the GNU/Linux native renameat2,
8d0e4d
+   which fails if it cannot guarantee atomicity.  */
8d0e4d
 
8d0e4d
 int
8d0e4d
-renameat2 (int fd1, char const *src, int fd2, char const *dst,
8d0e4d
+renameatu (int fd1, char const *src, int fd2, char const *dst,
8d0e4d
            unsigned int flags)
8d0e4d
 {
8d0e4d
   int ret_val = -1;
8d0e4d
diff --git a/lib/renameat2.h b/lib/renameatu.h
8d0e4d
similarity index 84%
8d0e4d
rename from lib/renameat2.h
8d0e4d
rename to lib/renameatu.h
8d0e4d
index aba7966..7d79775 100644
8d0e4d
--- a/lib/renameat2.h
8d0e4d
+++ b/lib/renameatu.h
8d0e4d
@@ -16,15 +16,13 @@
8d0e4d
 
8d0e4d
 /* written by Paul Eggert */
8d0e4d
 
8d0e4d
-/* Get RENAME_* macros from linux/fs.h if present, otherwise supply
8d0e4d
+/* Get RENAME_* macros from <stdio.h> if present, otherwise supply
8d0e4d
    the traditional Linux values.  */
8d0e4d
-#if HAVE_LINUX_FS_H
8d0e4d
-# include <linux/fs.h>
8d0e4d
-#endif
8d0e4d
+#include <stdio.h>
8d0e4d
 #ifndef RENAME_NOREPLACE
8d0e4d
 # define RENAME_NOREPLACE  (1 << 0)
8d0e4d
 # define RENAME_EXCHANGE   (1 << 1)
8d0e4d
 # define RENAME_WHITEOUT   (1 << 2)
8d0e4d
 #endif
8d0e4d
 
8d0e4d
-extern int renameat2 (int, char const *, int, char const *, unsigned int);
8d0e4d
+extern int renameatu (int, char const *, int, char const *, unsigned int);
8d0e4d
-- 
8d0e4d
2.14.4
8d0e4d
8d0e4d
8d0e4d
From a6b7ff5ef538bbdff4550a56fed878e9cd951d6d Mon Sep 17 00:00:00 2001
8d0e4d
From: Paul Eggert <eggert@cs.ucla.edu>
8d0e4d
Date: Thu, 5 Jul 2018 09:33:48 -0700
8d0e4d
Subject: [PATCH 2/2] build: update gnulib submodule to latest
8d0e4d
8d0e4d
* bootstrap.conf, src/copy.c, src/mv.c, src/shred.c:
8d0e4d
Adjust to renaming of renameat2 to renameatu.
8d0e4d
8d0e4d
Upstream-commit: 439741053256618eb651e6d43919df29625b8714
8d0e4d
Signed-off-by: Kamil Dudka <kdudka@redhat.com>
8d0e4d
---
8d0e4d
 bootstrap.conf | 2 +-
8d0e4d
 src/copy.c     | 4 ++--
8d0e4d
 src/mv.c       | 4 ++--
8d0e4d
 src/shred.c    | 4 ++--
8d0e4d
 4 files changed, 7 insertions(+), 7 deletions(-)
8d0e4d
8d0e4d
diff --git a/bootstrap.conf b/bootstrap.conf
8d0e4d
index 4da4f94..fcf29dc 100644
8d0e4d
--- a/bootstrap.conf
8d0e4d
+++ b/bootstrap.conf
8d0e4d
@@ -210,7 +210,7 @@ gnulib_modules="
8d0e4d
   remove
8d0e4d
   rename
8d0e4d
   renameat
8d0e4d
-  renameat2
8d0e4d
+  renameatu
8d0e4d
   rmdir
8d0e4d
   root-dev-ino
8d0e4d
   rpmatch
8d0e4d
diff --git a/src/copy.c b/src/copy.c
8d0e4d
index 58d2f6e..1a9cdd1 100644
8d0e4d
--- a/src/copy.c
8d0e4d
+++ b/src/copy.c
8d0e4d
@@ -53,7 +53,7 @@
8d0e4d
 #include "ignore-value.h"
8d0e4d
 #include "ioblksize.h"
8d0e4d
 #include "quote.h"
8d0e4d
-#include "renameat2.h"
8d0e4d
+#include "renameatu.h"
8d0e4d
 #include "root-uid.h"
8d0e4d
 #include "same.h"
8d0e4d
 #include "savedir.h"
8d0e4d
@@ -1873,7 +1873,7 @@ copy_internal (char const *src_name, char const *dst_name,
8d0e4d
   if (x->move_mode)
8d0e4d
     {
8d0e4d
       if (rename_errno < 0)
8d0e4d
-        rename_errno = (renameat2 (AT_FDCWD, src_name, AT_FDCWD, dst_name,
8d0e4d
+        rename_errno = (renameatu (AT_FDCWD, src_name, AT_FDCWD, dst_name,
8d0e4d
                                    RENAME_NOREPLACE)
8d0e4d
                         ? errno : 0);
8d0e4d
       new_dst = rename_errno == 0;
8d0e4d
diff --git a/src/mv.c b/src/mv.c
8d0e4d
index b6dd72d..36fd1af 100644
8d0e4d
--- a/src/mv.c
8d0e4d
+++ b/src/mv.c
8d0e4d
@@ -31,7 +31,7 @@
8d0e4d
 #include "error.h"
8d0e4d
 #include "filenamecat.h"
8d0e4d
 #include "remove.h"
8d0e4d
-#include "renameat2.h"
8d0e4d
+#include "renameatu.h"
8d0e4d
 #include "root-dev-ino.h"
8d0e4d
 #include "priv-set.h"
8d0e4d
 
8d0e4d
@@ -456,7 +456,7 @@ main (int argc, char **argv)
8d0e4d
     {
8d0e4d
       assert (2 <= n_files);
8d0e4d
       if (n_files == 2)
8d0e4d
-        x.rename_errno = (renameat2 (AT_FDCWD, file[0], AT_FDCWD, file[1],
8d0e4d
+        x.rename_errno = (renameatu (AT_FDCWD, file[0], AT_FDCWD, file[1],
8d0e4d
                                      RENAME_NOREPLACE)
8d0e4d
                           ? errno : 0);
8d0e4d
       if (x.rename_errno != 0 && target_directory_operand (file[n_files - 1]))
8d0e4d
diff --git a/src/shred.c b/src/shred.c
8d0e4d
index 2ddaadd..270b1e9 100644
8d0e4d
--- a/src/shred.c
8d0e4d
+++ b/src/shred.c
8d0e4d
@@ -93,7 +93,7 @@
8d0e4d
 #include "human.h"
8d0e4d
 #include "randint.h"
8d0e4d
 #include "randread.h"
8d0e4d
-#include "renameat2.h"
8d0e4d
+#include "renameatu.h"
8d0e4d
 #include "stat-size.h"
8d0e4d
 
8d0e4d
 /* Default number of times to overwrite.  */
8d0e4d
@@ -1096,7 +1096,7 @@ wipename (char *oldname, char const *qoldname, struct Options const *flags)
8d0e4d
         memset (base, nameset[0], len);
8d0e4d
         base[len] = 0;
8d0e4d
         bool rename_ok;
8d0e4d
-        while (! (rename_ok = (renameat2 (AT_FDCWD, oldname, AT_FDCWD, newname,
8d0e4d
+        while (! (rename_ok = (renameatu (AT_FDCWD, oldname, AT_FDCWD, newname,
8d0e4d
                                           RENAME_NOREPLACE)
8d0e4d
                                == 0))
8d0e4d
                && errno == EEXIST && incname (base, len))
8d0e4d
-- 
8d0e4d
2.14.4
8d0e4d