1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-11 05:18:09 +03:00

vfs_ceph_new: proper error handling to readdir

Error handling in the case of 'ceph_readdir' is done by setting 'errno'
deep within libcephfs code. In case of error, emit proper debug message
and re-update errno to avoid possible over-write by logging mechanism.

BUG: https://bugzilla.samba.org/show_bug.cgi?id=15686

Signed-off-by: Shachar Sharon <ssharon@redhat.com>
Reviewed-by: Guenther Deschner <gd@samba.org>
Reviewed-by: Anoop C S <anoopcs@samba.org>
This commit is contained in:
Shachar Sharon 2024-07-17 11:41:13 +03:00 committed by Günther Deschner
parent 99c7179e5d
commit 24a3423949

View File

@ -985,11 +985,19 @@ static struct dirent *vfs_ceph_readdir(struct vfs_handle_struct *handle,
{ {
const struct vfs_ceph_fh *dircfh = (const struct vfs_ceph_fh *)dirp; const struct vfs_ceph_fh *dircfh = (const struct vfs_ceph_fh *)dirp;
struct dirent *result = NULL; struct dirent *result = NULL;
int errval = 0;
DBG_DEBUG("[CEPH] readdir(%p, %p)\n", handle, dirp); DBG_DEBUG("[CEPH] readdir(%p, %p)\n", handle, dirp);
errno = 0;
result = vfs_ceph_ll_readdir(handle, dircfh); result = vfs_ceph_ll_readdir(handle, dircfh);
DBG_DEBUG("[CEPH] readdir(...) = %p\n", result); errval = errno;
if ((result == NULL) && (errval != 0)) {
DBG_DEBUG("[CEPH] readdir(...) = %d\n", errval);
} else {
DBG_DEBUG("[CEPH] readdir(...) = %p\n", result);
}
/* re-assign errno to avoid possible over-write by DBG_DEBUG */
errno = errval;
return result; return result;
} }