84 lines
3.1 KiB
Diff
84 lines
3.1 KiB
Diff
From ac14e901f5d4d496a16402571bd4166b1a75996e Mon Sep 17 00:00:00 2001
|
|
Message-Id: <ac14e901f5d4d496a16402571bd4166b1a75996e.1599166691.git.zanussi@kernel.org>
|
|
In-Reply-To: <56457dc415803c8abc5acb513ada877a79596f05.1599166690.git.zanussi@kernel.org>
|
|
References: <56457dc415803c8abc5acb513ada877a79596f05.1599166690.git.zanussi@kernel.org>
|
|
From: Sebastian Andrzej Siewior <bigeasy@linutronix.de>
|
|
Date: Wed, 18 Dec 2019 12:25:09 +0100
|
|
Subject: [PATCH 315/333] userfaultfd: Use a seqlock instead of seqcount
|
|
Origin: https://www.kernel.org/pub/linux/kernel/projects/rt/4.19/older/patches-4.19.142-rt63.tar.xz
|
|
|
|
[ Upstream commit dc952a564d02997330654be9628bbe97ba2a05d3 ]
|
|
|
|
On RT write_seqcount_begin() disables preemption which leads to warning
|
|
in add_wait_queue() while the spinlock_t is acquired.
|
|
The waitqueue can't be converted to swait_queue because
|
|
userfaultfd_wake_function() is used as a custom wake function.
|
|
|
|
Use seqlock instead seqcount to avoid the preempt_disable() section
|
|
during add_wait_queue().
|
|
|
|
Cc: stable-rt@vger.kernel.org
|
|
Signed-off-by: Sebastian Andrzej Siewior <bigeasy@linutronix.de>
|
|
Signed-off-by: Steven Rostedt (VMware) <rostedt@goodmis.org>
|
|
---
|
|
fs/userfaultfd.c | 12 ++++++------
|
|
1 file changed, 6 insertions(+), 6 deletions(-)
|
|
|
|
diff --git a/fs/userfaultfd.c b/fs/userfaultfd.c
|
|
index d269d1139f7f..ff6be687f68e 100644
|
|
--- a/fs/userfaultfd.c
|
|
+++ b/fs/userfaultfd.c
|
|
@@ -61,7 +61,7 @@ struct userfaultfd_ctx {
|
|
/* waitqueue head for events */
|
|
wait_queue_head_t event_wqh;
|
|
/* a refile sequence protected by fault_pending_wqh lock */
|
|
- struct seqcount refile_seq;
|
|
+ seqlock_t refile_seq;
|
|
/* pseudo fd refcounting */
|
|
atomic_t refcount;
|
|
/* userfaultfd syscall flags */
|
|
@@ -1064,7 +1064,7 @@ static ssize_t userfaultfd_ctx_read(struct userfaultfd_ctx *ctx, int no_wait,
|
|
* waitqueue could become empty if this is the
|
|
* only userfault.
|
|
*/
|
|
- write_seqcount_begin(&ctx->refile_seq);
|
|
+ write_seqlock(&ctx->refile_seq);
|
|
|
|
/*
|
|
* The fault_pending_wqh.lock prevents the uwq
|
|
@@ -1090,7 +1090,7 @@ static ssize_t userfaultfd_ctx_read(struct userfaultfd_ctx *ctx, int no_wait,
|
|
list_del(&uwq->wq.entry);
|
|
add_wait_queue(&ctx->fault_wqh, &uwq->wq);
|
|
|
|
- write_seqcount_end(&ctx->refile_seq);
|
|
+ write_sequnlock(&ctx->refile_seq);
|
|
|
|
/* careful to always initialize msg if ret == 0 */
|
|
*msg = uwq->msg;
|
|
@@ -1263,11 +1263,11 @@ static __always_inline void wake_userfault(struct userfaultfd_ctx *ctx,
|
|
* sure we've userfaults to wake.
|
|
*/
|
|
do {
|
|
- seq = read_seqcount_begin(&ctx->refile_seq);
|
|
+ seq = read_seqbegin(&ctx->refile_seq);
|
|
need_wakeup = waitqueue_active(&ctx->fault_pending_wqh) ||
|
|
waitqueue_active(&ctx->fault_wqh);
|
|
cond_resched();
|
|
- } while (read_seqcount_retry(&ctx->refile_seq, seq));
|
|
+ } while (read_seqretry(&ctx->refile_seq, seq));
|
|
if (need_wakeup)
|
|
__wake_userfault(ctx, range);
|
|
}
|
|
@@ -1938,7 +1938,7 @@ static void init_once_userfaultfd_ctx(void *mem)
|
|
init_waitqueue_head(&ctx->fault_wqh);
|
|
init_waitqueue_head(&ctx->event_wqh);
|
|
init_waitqueue_head(&ctx->fd_wqh);
|
|
- seqcount_init(&ctx->refile_seq);
|
|
+ seqlock_init(&ctx->refile_seq);
|
|
}
|
|
|
|
SYSCALL_DEFINE1(userfaultfd, int, flags)
|
|
--
|
|
2.17.1
|
|
|