]> sourceware.org Git - glibc.git/commitdiff
Consolidate rename Linux implementation
authorAdhemerval Zanella <adhemerval.zanella@linaro.org>
Fri, 11 Nov 2016 11:02:46 +0000 (09:02 -0200)
committerAdhemerval Zanella <adhemerval.zanella@linaro.org>
Wed, 14 Dec 2016 17:31:24 +0000 (15:31 -0200)
This patch consolidates the Linux rename implementation on
sysdeps/unix/sysv/linux/rename.c.  Current code try to use
__NR_rename if is defined and apply the same strategy for
__NR_renameat and __NR_renameat2.

Check on x86_64 and aarch64.

* sysdeps/unix/sysv/linux/rename.c: New file.
* sysdeps/unix/sysv/linux/generic/rename.c: Remove file.

ChangeLog
sysdeps/unix/sysv/linux/rename.c [moved from sysdeps/unix/sysv/linux/generic/rename.c with 69% similarity]

index 90dad728332b4e49d0331e0b6e93c89067b70c0f..a9e69a33645edd270aa6e203e8aa240325bb9a61 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+2016-12-14  Adhemerval Zanella  <adhemerval.zanella@linaro.org>
+
+       * sysdeps/unix/sysv/linux/rename.c: New file.
+       * sysdeps/unix/sysv/linux/generic/rename.c: Remove file.
+
 2015-12-14  Wilco Dijkstra  <wdijkstr@arm.com>
 
        * benchtests/bench-strtok.c (oldstrtok): Add old implementation.
similarity index 69%
rename from sysdeps/unix/sysv/linux/generic/rename.c
rename to sysdeps/unix/sysv/linux/rename.c
index 174c147eb4aaa92e6ea65605820c95c42df0a550..73f0ae43bd2e3b42eacae82252a16b23352734ab 100644 (file)
@@ -1,6 +1,6 @@
-/* Copyright (C) 2011-2016 Free Software Foundation, Inc.
+/* Linux implementation for rename function.
+   Copyright (C) 2016 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
-   Contributed by Chris Metcalf <cmetcalf@tilera.com>, 2011.
 
    The GNU C Library is free software; you can redistribute it and/or
    modify it under the terms of the GNU Lesser General Public
    <http://www.gnu.org/licenses/>.  */
 
 #include <stdio.h>
-#include <unistd.h>
 #include <fcntl.h>
 #include <sysdep.h>
+#include <errno.h>
 
 /* Rename the file OLD to NEW.  */
 int
 rename (const char *old, const char *new)
 {
-  return INLINE_SYSCALL (renameat, 4, AT_FDCWD, old, AT_FDCWD, new);
+#if defined (__NR_rename)
+  return INLINE_SYSCALL_CALL (rename, old, new);
+#elif defined (__NR_renameat)
+  return INLINE_SYSCALL_CALL (renameat, AT_FDCWD, old, AT_FDCWD, new);
+#else
+  return INLINE_SYSCALL_CALL (renameat2, AT_FDCWD, old, AT_FDCWD, new, 0);
+#endif
 }
This page took 0.173235 seconds and 5 git commands to generate.