nfs: avoid double fd unref in opendir

Noticed that the fd_unref was called on the fd regardless of the return
value at nfs3svc_opendir_readdir_cbk(), hence removing an extra unref in
the negative case in nfs_inode_opendir_cbk, which fixes the spurious
fd_unref().

Change-Id: I2bf68410dd86cdf9cfe8a3d43adc27497d8bb36f
BUG: 959190
Signed-off-by: Rajesh Amaravathi <rajesh@redhat.com>
Reviewed-on: http://review.gluster.org/4943
Reviewed-by: Amar Tumballi <amarts@redhat.com>
Tested-by: Amar Tumballi <amarts@redhat.com>
Reviewed-by: Anand Avati <avati@redhat.com>
This commit is contained in:
Rajesh Amaravathi 2013-05-06 17:00:57 +05:30 committed by Anand Avati
parent 760d4e1d58
commit d3e3a849dd

View File

@ -572,9 +572,7 @@ nfs_inode_opendir_cbk (call_frame_t *frame, void *cookie, xlator_t *this,
struct nfs_fop_local *nfl = NULL; struct nfs_fop_local *nfl = NULL;
fop_open_cbk_t progcbk = NULL; fop_open_cbk_t progcbk = NULL;
if ((op_ret == -1) && (fd)) if (op_ret != -1)
fd_unref (fd);
else
fd_bind (fd); fd_bind (fd);
inodes_nfl_to_prog_data (nfl, progcbk, frame); inodes_nfl_to_prog_data (nfl, progcbk, frame);