diff options
-rw-r--r-- | source3/modules/vfs_posix_eadb.c | 5 | ||||
-rw-r--r-- | source3/modules/vfs_xattr_tdb.c | 2 |
2 files changed, 7 insertions, 0 deletions
diff --git a/source3/modules/vfs_posix_eadb.c b/source3/modules/vfs_posix_eadb.c index c8bebc4c0f..fff7c11dce 100644 --- a/source3/modules/vfs_posix_eadb.c +++ b/source3/modules/vfs_posix_eadb.c @@ -52,6 +52,11 @@ static ssize_t posix_eadb_getattr(struct tdb_wrap *db_ctx, status = pull_xattr_blob_tdb_raw(db_ctx, talloc_tos(), name, fname, fd, size, &blob); + if (NT_STATUS_EQUAL(status, NT_STATUS_NOT_FOUND)) { + errno = ENOATTR; + return -1; + } + if (!NT_STATUS_IS_OK(status)) { DEBUG(10, ("posix_eadb_fetch_attrs failed: %s\n", nt_errstr(status))); diff --git a/source3/modules/vfs_xattr_tdb.c b/source3/modules/vfs_xattr_tdb.c index 80db90441d..719ac0c84d 100644 --- a/source3/modules/vfs_xattr_tdb.c +++ b/source3/modules/vfs_xattr_tdb.c @@ -50,6 +50,7 @@ static ssize_t xattr_tdb_getxattr(struct vfs_handle_struct *handle, xattr_size = xattr_tdb_getattr(db, frame, &id, name, &blob); if (xattr_size < 0) { + errno = ENOATTR; TALLOC_FREE(frame); return -1; } @@ -85,6 +86,7 @@ static ssize_t xattr_tdb_fgetxattr(struct vfs_handle_struct *handle, xattr_size = xattr_tdb_getattr(db, frame, &id, name, &blob); if (xattr_size < 0) { + errno = ENOATTR; TALLOC_FREE(frame); return -1; } |