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

Commit 4691b271 authored by Kinglong Mee's avatar Kinglong Mee Committed by J. Bruce Fields
Browse files

nfsd: Fix a memory leak in nfsd4_list_rec_dir()



If lookup_one_len() failed, nfsd should free those memory allocated for fname.

Signed-off-by: default avatarKinglong Mee <kinglongmee@gmail.com>
Signed-off-by: default avatarJ. Bruce Fields <bfields@redhat.com>
parent 1ca4b88e
Loading
Loading
Loading
Loading
+9 −3
Original line number Diff line number Diff line
@@ -272,6 +272,7 @@ nfsd4_list_rec_dir(recdir_func *f, struct nfsd_net *nn)
		.ctx.actor = nfsd4_build_namelist,
		.names = LIST_HEAD_INIT(ctx.names)
	};
	struct name_list *entry, *tmp;
	int status;

	status = nfs4_save_creds(&original_cred);
@@ -286,9 +287,8 @@ nfsd4_list_rec_dir(recdir_func *f, struct nfsd_net *nn)

	status = iterate_dir(nn->rec_file, &ctx.ctx);
	mutex_lock_nested(&d_inode(dir)->i_mutex, I_MUTEX_PARENT);
	while (!list_empty(&ctx.names)) {
		struct name_list *entry;
		entry = list_entry(ctx.names.next, struct name_list, list);

	list_for_each_entry_safe(entry, tmp, &ctx.names, list) {
		if (!status) {
			struct dentry *dentry;
			dentry = lookup_one_len(entry->name, dir, HEXDIR_LEN-1);
@@ -304,6 +304,12 @@ nfsd4_list_rec_dir(recdir_func *f, struct nfsd_net *nn)
	}
	mutex_unlock(&d_inode(dir)->i_mutex);
	nfs4_reset_creds(original_cred);

	list_for_each_entry_safe(entry, tmp, &ctx.names, list) {
		dprintk("NFSD: %s. Left entry %s\n", __func__, entry->name);
		list_del(&entry->list);
		kfree(entry);
	}
	return status;
}