[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20140116105406.GF24171@tucsk.piliscsaba.szeredi.hu>
Date: Thu, 16 Jan 2014 11:54:06 +0100
From: Miklos Szeredi <miklos@...redi.hu>
To: Michael Kerrisk <mtk.manpages@...il.com>
Cc: "J. Bruce Fields" <bfields@...ldses.org>, Jan Kara <jack@...e.cz>,
Al Viro <viro@...iv.linux.org.uk>,
Linus Torvalds <torvalds@...ux-foundation.org>,
Linux-Fsdevel <linux-fsdevel@...r.kernel.org>,
Kernel Mailing List <linux-kernel@...r.kernel.org>,
Christoph Hellwig <hch@...radead.org>,
Andrew Morton <akpm@...ux-foundation.org>,
David Howells <dhowells@...hat.com>,
Zach Brown <zab@...hat.com>,
Andy Lutomirski <luto@...capital.net>,
"mszeredi@...e.cz" <mszeredi@...e.cz>
Subject: Re: [PATCH 11/11] ext4: add cross rename support
> On Wed, Jan 15, 2014 at 7:23 PM, J. Bruce Fields <bfields@...ldses.org> wrote:
> > Do you have a man page update somewhere for the two new flags?
Here's the updated man page (and attached the patch)
Michael, could you please review the interface?
I forgot to CC you when posing the patch series. I can resend it if you want,
or you can fetch the latest version of the cross-rename series from:
git://git.kernel.org/pub/scm/linux/kernel/git/mszeredi/vfs.git cross-rename
Thanks,
Miklos
----
RENAMEAT(2) Linux Programmer's Manual RENAMEAT(2)
NAME
renameat, renameat2 - rename a file relative to directory file descrip-
tors
SYNOPSIS
#include <fcntl.h> /* Definition of AT_* constants */
#include <stdio.h>
int renameat(int olddirfd, const char *oldpath,
int newdirfd, const char *newpath);
int renameat2(int olddirfd, const char *oldpath,
int newdirfd, const char *newpath, unsigned int flags);
Feature Test Macro Requirements for glibc (see feature_test_macros(7)):
renameat():
Since glibc 2.10:
_XOPEN_SOURCE >= 700 || _POSIX_C_SOURCE >= 200809L
Before glibc 2.10:
_ATFILE_SOURCE
DESCRIPTION
The renameat() and renameat2() system calls operate in exactly the same
way as rename(2), except for the differences described in this manual
page.
If the pathname given in oldpath is relative, then it is interpreted
relative to the directory referred to by the file descriptor olddirfd
(rather than relative to the current working directory of the calling
process, as is done by rename(2) for a relative pathname).
If oldpath is relative and olddirfd is the special value AT_FDCWD, then
oldpath is interpreted relative to the current working directory of the
calling process (like rename(2)).
If oldpath is absolute, then olddirfd is ignored.
The interpretation of newpath is as for oldpath, except that a relative
pathname is interpreted relative to the directory referred to by the
file descriptor newdirfd.
renameat2() has an additional flags argument. renameat2() call with a
zero flags argument is equivalent to renameat().
The flags argument is a bitfield consisting of zero or more of the fol-
lowing constants defined in <linux/fs.h>:
RENAME_NOREPLACE
Don't overwrite the target of the rename. Return an error if
the target would be overwritten.
RENAME_EXCHANGE
Atomically exchange the source and destination. Both must exist
but may be of a different type (e.g. one a non-empty directory
and the other a symbolic link).
RETURN VALUE
On success, renameat() and renameat2() return 0. On error, -1 is
returned and errno is set to indicate the error.
ERRORS
The same errors that occur for rename(2) can also occur for renameat()
and renameat2(). The following additional errors can occur for
renameat() and renameat2():
EBADF olddirfd or newdirfd is not a valid file descriptor.
ENOTDIR
oldpath is relative and olddirfd is a file descriptor referring
to a file other than a directory; or similar for newpath and
newdirfd
The following additional errors are defined for renameat2():
EOPNOTSUPP
The filesystem does not support a flag in flags
EINVAL Invalid combination of flags
EEXIST flags contain RENAME_NOREPLACE and the target of the rename
exists
ENOENT flags contain RENAME_EXCHANGE and the target of the rename does
not exist
VERSIONS
renameat() was added to Linux in kernel 2.6.16; library support was
added to glibc in version 2.4.
CONFORMING TO
renameat() is specified in POSIX.1-2008.
NOTES
See openat(2) for an explanation of the need for renameat().
SEE ALSO
openat(2), rename(2), path_resolution(7)
Linux 2012-05-04 RENAMEAT(2)
View attachment "renameat.2.patch" of type "text/x-patch" (3020 bytes)
Powered by blists - more mailing lists