* Fixed reversed handling of O_NOTRAVERSE in attr_open(), and attr_create().
* Added support for O_NOFOLLOW for those two as well. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@42619 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
3d01f69f9e
commit
33272012fb
@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright 2005-2011, Ingo Weinhold, ingo_weinhold@gmx.de.
|
* Copyright 2005-2011, Ingo Weinhold, ingo_weinhold@gmx.de.
|
||||||
* Copyright 2002-2010, Axel Dörfler, axeld@pinc-software.de.
|
* Copyright 2002-2011, Axel Dörfler, axeld@pinc-software.de.
|
||||||
* Distributed under the terms of the MIT License.
|
* Distributed under the terms of the MIT License.
|
||||||
*
|
*
|
||||||
* Copyright 2001-2002, Travis Geiselbrecht. All rights reserved.
|
* Copyright 2001-2002, Travis Geiselbrecht. All rights reserved.
|
||||||
@ -5308,7 +5308,7 @@ file_open_entry_ref(dev_t mountID, ino_t directoryID, const char* name,
|
|||||||
FUNCTION(("file_open_entry_ref(ref = (%ld, %Ld, %s), openMode = %d)\n",
|
FUNCTION(("file_open_entry_ref(ref = (%ld, %Ld, %s), openMode = %d)\n",
|
||||||
mountID, directoryID, name, openMode));
|
mountID, directoryID, name, openMode));
|
||||||
|
|
||||||
bool traverse = ((openMode & (O_NOTRAVERSE | O_NOFOLLOW)) == 0);
|
bool traverse = (openMode & (O_NOTRAVERSE | O_NOFOLLOW)) == 0;
|
||||||
|
|
||||||
// get the vnode matching the entry_ref
|
// get the vnode matching the entry_ref
|
||||||
struct vnode* vnode;
|
struct vnode* vnode;
|
||||||
@ -5337,7 +5337,7 @@ file_open_entry_ref(dev_t mountID, ino_t directoryID, const char* name,
|
|||||||
static int
|
static int
|
||||||
file_open(int fd, char* path, int openMode, bool kernel)
|
file_open(int fd, char* path, int openMode, bool kernel)
|
||||||
{
|
{
|
||||||
bool traverse = ((openMode & (O_NOTRAVERSE | O_NOFOLLOW)) == 0);
|
bool traverse = (openMode & (O_NOTRAVERSE | O_NOFOLLOW)) == 0;
|
||||||
|
|
||||||
FUNCTION(("file_open: fd: %d, entry path = '%s', omode %d, kernel %d\n",
|
FUNCTION(("file_open: fd: %d, entry path = '%s', omode %d, kernel %d\n",
|
||||||
fd, path, openMode, kernel));
|
fd, path, openMode, kernel));
|
||||||
@ -6396,12 +6396,18 @@ attr_create(int fd, char* path, const char* name, uint32 type,
|
|||||||
if (name == NULL || *name == '\0')
|
if (name == NULL || *name == '\0')
|
||||||
return B_BAD_VALUE;
|
return B_BAD_VALUE;
|
||||||
|
|
||||||
|
bool traverse = (openMode & (O_NOTRAVERSE | O_NOFOLLOW)) == 0;
|
||||||
struct vnode* vnode;
|
struct vnode* vnode;
|
||||||
status_t status = fd_and_path_to_vnode(fd, path,
|
status_t status = fd_and_path_to_vnode(fd, path, traverse, &vnode, NULL,
|
||||||
(openMode & O_NOTRAVERSE) != 0, &vnode, NULL, kernel);
|
kernel);
|
||||||
if (status != B_OK)
|
if (status != B_OK)
|
||||||
return status;
|
return status;
|
||||||
|
|
||||||
|
if ((openMode & O_NOFOLLOW) != 0 && S_ISLNK(vnode->Type())) {
|
||||||
|
status = B_LINK_LIMIT;
|
||||||
|
goto err;
|
||||||
|
}
|
||||||
|
|
||||||
if (!HAS_FS_CALL(vnode, create_attr)) {
|
if (!HAS_FS_CALL(vnode, create_attr)) {
|
||||||
status = B_READ_ONLY_DEVICE;
|
status = B_READ_ONLY_DEVICE;
|
||||||
goto err;
|
goto err;
|
||||||
@ -6436,12 +6442,18 @@ attr_open(int fd, char* path, const char* name, int openMode, bool kernel)
|
|||||||
if (name == NULL || *name == '\0')
|
if (name == NULL || *name == '\0')
|
||||||
return B_BAD_VALUE;
|
return B_BAD_VALUE;
|
||||||
|
|
||||||
|
bool traverse = (openMode & (O_NOTRAVERSE | O_NOFOLLOW)) == 0;
|
||||||
struct vnode* vnode;
|
struct vnode* vnode;
|
||||||
status_t status = fd_and_path_to_vnode(fd, path,
|
status_t status = fd_and_path_to_vnode(fd, path, traverse, &vnode, NULL,
|
||||||
(openMode & O_NOTRAVERSE) != 0, &vnode, NULL, kernel);
|
kernel);
|
||||||
if (status != B_OK)
|
if (status != B_OK)
|
||||||
return status;
|
return status;
|
||||||
|
|
||||||
|
if ((openMode & O_NOFOLLOW) != 0 && S_ISLNK(vnode->Type())) {
|
||||||
|
status = B_LINK_LIMIT;
|
||||||
|
goto err;
|
||||||
|
}
|
||||||
|
|
||||||
if (!HAS_FS_CALL(vnode, open_attr)) {
|
if (!HAS_FS_CALL(vnode, open_attr)) {
|
||||||
status = B_NOT_SUPPORTED;
|
status = B_NOT_SUPPORTED;
|
||||||
goto err;
|
goto err;
|
||||||
|
Loading…
Reference in New Issue
Block a user