summaryrefslogtreecommitdiffstats
path: root/fs/dlm
diff options
context:
space:
mode:
authorAlexander Aring <aahringo@redhat.com>2021-11-30 20:47:15 +0100
committerDavid Teigland <teigland@redhat.com>2021-12-07 19:42:26 +0100
commitbcbfea41e1f9d516faed1faf0f2d390c000bf0d9 (patch)
treebf03db700022fd8737bb5045009800ccd47894f9 /fs/dlm
parentfs: dlm: use list_empty() to check last iteration (diff)
downloadlinux-bcbfea41e1f9d516faed1faf0f2d390c000bf0d9.tar.xz
linux-bcbfea41e1f9d516faed1faf0f2d390c000bf0d9.zip
fs: dlm: check for pending users filling buffers
Currently we don't care if the DLM application stack is filling buffers (not committed yet) while we transmit some already committed buffers. By checking on active writequeue users before dequeue a writequeue entry we know there is coming more data and do nothing. We wait until the send worker will be triggered again if the writequeue entry users hit zero. Signed-off-by: Alexander Aring <aahringo@redhat.com> Signed-off-by: David Teigland <teigland@redhat.com>
Diffstat (limited to 'fs/dlm')
-rw-r--r--fs/dlm/lowcomms.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/fs/dlm/lowcomms.c b/fs/dlm/lowcomms.c
index f7fc1ac76ce8..6d500ebc6145 100644
--- a/fs/dlm/lowcomms.c
+++ b/fs/dlm/lowcomms.c
@@ -201,7 +201,10 @@ static struct writequeue_entry *con_next_wq(struct connection *con)
e = list_first_entry(&con->writequeue, struct writequeue_entry,
list);
- if (e->len == 0)
+ /* if len is zero nothing is to send, if there are users filling
+ * buffers we wait until the users are done so we can send more.
+ */
+ if (e->users || e->len == 0)
return NULL;
return e;