a3470f
From d4a387d3e419f4b15a5fc98a9ee7af4644b05ffe Mon Sep 17 00:00:00 2001
a3470f
From: Poornima G <pgurusid@redhat.com>
a3470f
Date: Wed, 16 May 2018 11:00:32 +0530
a3470f
Subject: [PATCH 272/274] readdir-ahead: Fix an issue with parallel-readdir and
a3470f
 readdir-optimize
a3470f
a3470f
Issue: When parallel-readdir is enabled, readdir-optimize automatically
a3470f
stops working because of a bug in rda_opendir.
a3470f
a3470f
RCA: In rda_opendir, the xattrs that indicate readdir-optimize or not
a3470f
is sent in xdata. This xdata is sent to all the readdirp prefetch
a3470f
calls. A dict_ref is taken on xdata and kept in rda_opendir to be
a3470f
used by rda_fill_fd, but dht_opendir deletes some elements in xdata
a3470f
after calling rda_opendir. Hence dict_ref is not a right choice here,
a3470f
dict_copy needs to used.
a3470f
a3470f
Backport of https://review.gluster.org/#/c/20026/
a3470f
a3470f
>Change-Id: Ie7cc7ceb03117dd4179ef7905647f2f123f94966
a3470f
>fixes: bz#1578650
a3470f
>Signed-off-by: Poornima G <pgurusid@redhat.com>
a3470f
a3470f
Bug: 1578647
a3470f
Change-Id: Ia710b39ad2fe9e71df17ae13c3281526f382004b
a3470f
Signed-off-by: Poornima G <pgurusid@redhat.com>
a3470f
Reviewed-on: https://code.engineering.redhat.com/gerrit/139040
a3470f
Tested-by: RHGS Build Bot <nigelb@redhat.com>
a3470f
Reviewed-by: Sunil Kumar Heggodu Gopala Acharya <sheggodu@redhat.com>
a3470f
---
a3470f
 xlators/performance/readdir-ahead/src/readdir-ahead.c | 2 +-
a3470f
 1 file changed, 1 insertion(+), 1 deletion(-)
a3470f
a3470f
diff --git a/xlators/performance/readdir-ahead/src/readdir-ahead.c b/xlators/performance/readdir-ahead/src/readdir-ahead.c
a3470f
index 0d3bdbd..6501a6b 100644
a3470f
--- a/xlators/performance/readdir-ahead/src/readdir-ahead.c
a3470f
+++ b/xlators/performance/readdir-ahead/src/readdir-ahead.c
a3470f
@@ -525,7 +525,7 @@ rda_opendir(call_frame_t *frame, xlator_t *this, loc_t *loc, fd_t *fd,
a3470f
                  * Retrieve list of keys set by md-cache xlator and store it
a3470f
                  * in local to be consumed in rda_opendir_cbk
a3470f
                  */
a3470f
-                local->xattrs = dict_ref (xdata);
a3470f
+                local->xattrs = dict_copy_with_ref (xdata, NULL);
a3470f
                 frame->local = local;
a3470f
         }
a3470f
 
a3470f
-- 
a3470f
1.8.3.1
a3470f