21ab4e
From c925baf1c95d876b867d9b44a4d6af908e3f7af3 Mon Sep 17 00:00:00 2001
21ab4e
From: Poornima G <pgurusid@redhat.com>
21ab4e
Date: Tue, 6 Dec 2016 16:31:51 +0530
21ab4e
Subject: [PATCH 355/361] readdir-ahead: Enhance EOD detection logic
21ab4e
21ab4e
Issue:
21ab4e
Currently end of directory is identified on obtaining a
21ab4e
readdirp_cbk with op_ret = 0 (i.e. 0 entries fetched in
21ab4e
readdirp). Thus an extra readdirp is required for every
21ab4e
directory just to identify EOD. Consider a case of listing
21ab4e
large number of small directories. The readdirp fops required
21ab4e
are doubled in that case.
21ab4e
21ab4e
Solution:
21ab4e
On reaching the EOD, posix sets the op_errno to ENOENT,
21ab4e
hence along with looking for 'op_ret == 0' we also
21ab4e
look for 'operrno == ENOENT' ehile checking for EOD condition
21ab4e
21ab4e
mainline:
21ab4e
> BUG: 1401812
21ab4e
> Reviewed-on: http://review.gluster.org/16042
21ab4e
> Smoke: Gluster Build System <jenkins@build.gluster.org>
21ab4e
> NetBSD-regression: NetBSD Build System <jenkins@build.gluster.org>
21ab4e
> CentOS-regression: Gluster Build System <jenkins@build.gluster.org>
21ab4e
> Reviewed-by: Raghavendra G <rgowdapp@redhat.com>
21ab4e
(cherry picked from commit f60631904defdaec2f1bae84b3cfd6a3e083cf09)
21ab4e
21ab4e
BUG: 1427096
21ab4e
Change-Id: I7a5b52e7b98f5dc236c387635fcc651dac0171b3
21ab4e
Signed-off-by: Poornima G <pgurusid@redhat.com>
21ab4e
Reviewed-on: https://code.engineering.redhat.com/gerrit/101415
21ab4e
Tested-by: Milind Changire <mchangir@redhat.com>
21ab4e
Reviewed-by: Atin Mukherjee <amukherj@redhat.com>
21ab4e
---
21ab4e
 xlators/performance/readdir-ahead/src/readdir-ahead.c | 2 +-
21ab4e
 1 file changed, 1 insertion(+), 1 deletion(-)
21ab4e
21ab4e
diff --git a/xlators/performance/readdir-ahead/src/readdir-ahead.c b/xlators/performance/readdir-ahead/src/readdir-ahead.c
21ab4e
index 4b57a8b..38507a1 100644
21ab4e
--- a/xlators/performance/readdir-ahead/src/readdir-ahead.c
21ab4e
+++ b/xlators/performance/readdir-ahead/src/readdir-ahead.c
21ab4e
@@ -322,7 +322,7 @@ rda_fill_fd_cbk(call_frame_t *frame, void *cookie, xlator_t *this,
21ab4e
 	if (ctx->cur_size >= priv->rda_high_wmark)
21ab4e
 		ctx->state &= ~RDA_FD_PLUGGED;
21ab4e
 
21ab4e
-	if (!op_ret) {
21ab4e
+	if (!op_ret || op_errno == ENOENT) {
21ab4e
 		/* we've hit eod */
21ab4e
 		ctx->state &= ~RDA_FD_RUNNING;
21ab4e
 		ctx->state |= RDA_FD_EOD;
21ab4e
-- 
21ab4e
1.8.3.1
21ab4e