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:
parent
760d4e1d58
commit
d3e3a849dd
@ -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);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user