staging/lustre: Always return EEXIST on mkdir for existing names
if the name already exists, but we don't have write permissions in the parent, force talking to the MDS to determine what more sensical error code to return. This also happens to fix matlab and other such programs that assume that EEXIST is the only valid error code for mkdir of an existing directory. Signed-off-by: Oleg Drokin <green@linuxhacker.ru> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
4cae780e54
commit
3a77df1180
@ -606,8 +606,12 @@ static struct dentry *ll_lookup_nd(struct inode *parent, struct dentry *dentry,
|
|||||||
CDEBUG(D_VFSTRACE, "VFS Op:name=%pd, dir="DFID"(%p),flags=%u\n",
|
CDEBUG(D_VFSTRACE, "VFS Op:name=%pd, dir="DFID"(%p),flags=%u\n",
|
||||||
dentry, PFID(ll_inode2fid(parent)), parent, flags);
|
dentry, PFID(ll_inode2fid(parent)), parent, flags);
|
||||||
|
|
||||||
/* Optimize away (CREATE && !OPEN). Let .create handle the race. */
|
/* Optimize away (CREATE && !OPEN). Let .create handle the race.
|
||||||
if ((flags & LOOKUP_CREATE) && !(flags & LOOKUP_OPEN))
|
* but only if we have write permissions there, otherwise we need
|
||||||
|
* to proceed with lookup. LU-4185
|
||||||
|
*/
|
||||||
|
if ((flags & LOOKUP_CREATE) && !(flags & LOOKUP_OPEN) &&
|
||||||
|
(inode_permission(parent, MAY_WRITE | MAY_EXEC) == 0))
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
if (flags & (LOOKUP_PARENT|LOOKUP_OPEN|LOOKUP_CREATE))
|
if (flags & (LOOKUP_PARENT|LOOKUP_OPEN|LOOKUP_CREATE))
|
||||||
|
Loading…
x
Reference in New Issue
Block a user