瀏覽代碼

nfsd: don't leak dentry count on mnt_want_write failure

The exit cleanup isn't quite right here.

Signed-off-by: J. Bruce Fields <bfields@redhat.com>
J. Bruce Fields 14 年之前
父節點
當前提交
541ce98c10
共有 1 個文件被更改,包括 6 次插入6 次删除
  1. 6 6
      fs/nfsd/vfs.c

+ 6 - 6
fs/nfsd/vfs.c

@@ -1812,22 +1812,22 @@ nfsd_unlink(struct svc_rqst *rqstp, struct svc_fh *fhp, int type,
 
 
 	host_err = mnt_want_write(fhp->fh_export->ex_path.mnt);
 	host_err = mnt_want_write(fhp->fh_export->ex_path.mnt);
 	if (host_err)
 	if (host_err)
-		goto out_nfserr;
+		goto out_put;
 
 
 	host_err = nfsd_break_lease(rdentry->d_inode);
 	host_err = nfsd_break_lease(rdentry->d_inode);
 	if (host_err)
 	if (host_err)
-		goto out_put;
+		goto out_drop_write;
 	if (type != S_IFDIR)
 	if (type != S_IFDIR)
 		host_err = vfs_unlink(dirp, rdentry);
 		host_err = vfs_unlink(dirp, rdentry);
 	else
 	else
 		host_err = vfs_rmdir(dirp, rdentry);
 		host_err = vfs_rmdir(dirp, rdentry);
-out_put:
-	dput(rdentry);
-
 	if (!host_err)
 	if (!host_err)
 		host_err = commit_metadata(fhp);
 		host_err = commit_metadata(fhp);
-
+out_drop_write:
 	mnt_drop_write(fhp->fh_export->ex_path.mnt);
 	mnt_drop_write(fhp->fh_export->ex_path.mnt);
+out_put:
+	dput(rdentry);
+
 out_nfserr:
 out_nfserr:
 	err = nfserrno(host_err);
 	err = nfserrno(host_err);
 out:
 out: