Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 99424380 authored by Bryan Schumaker's avatar Bryan Schumaker Committed by Trond Myklebust
Browse files

NFS: check xdr_decode for errors



Check if the decoded entry has the eof bit set when returning from xdr_decode
with an error.  If it does, we should set the eof bits in the array before
returning.  This should keep us from looping when we expect more data but the
server doesn't give us anything new.

Signed-off-by: default avatarBryan Schumaker <bjschuma@netapp.com>
Signed-off-by: default avatarTrond Myklebust <Trond.Myklebust@netapp.com>
parent 3c8a1aee
Loading
Loading
Loading
Loading
+15 −1
Original line number Diff line number Diff line
@@ -442,6 +442,8 @@ void nfs_readdir_page_filler(nfs_readdir_descriptor_t *desc, struct nfs_entry *e
	struct xdr_stream stream;
	struct xdr_buf buf;
	__be32 *ptr = xdr_page;
	int status;
	struct nfs_cache_array *array;

	buf.head->iov_base = xdr_page;
	buf.head->iov_len = buflen;
@@ -453,11 +455,23 @@ void nfs_readdir_page_filler(nfs_readdir_descriptor_t *desc, struct nfs_entry *e

	xdr_init_decode(&stream, &buf, ptr);

	while (xdr_decode(desc, entry, &stream) == 0) {

	do {
		status = xdr_decode(desc, entry, &stream);
		if (status != 0)
			break;

		if (nfs_readdir_add_to_array(entry, page) == -1)
			break;
		if (desc->plus == 1)
			nfs_prime_dcache(desc->file->f_path.dentry, entry);
	} while (!entry->eof);

	if (status == -EBADCOOKIE && entry->eof) {
		array = nfs_readdir_get_array(page);
		array->eof_index = array->size - 1;
		status = 0;
		nfs_readdir_release_array(page);
	}
}