linux-fsdevel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [RFC PATCH] epoll: Add synchronous wakeup support for ep_poll_callback
@ 2024-04-26  8:05 Xuewen Yan
  2024-04-26  8:31 ` Christian Brauner
  2024-10-16 13:10 ` Christian Brauner
  0 siblings, 2 replies; 11+ messages in thread
From: Xuewen Yan @ 2024-04-26  8:05 UTC (permalink / raw)
  To: viro, brauner, mingo, peterz, juri.lelli, vincent.guittot
  Cc: jack, dietmar.eggemann, rostedt, bsegall, mgorman, bristot,
	vschneid, cmllamas, linux-fsdevel, linux-kernel, ke.wang,
	jing.xia, xuewen.yan94

Now, the epoll only use wake_up() interface to wake up task.
However, sometimes, there are epoll users which want to use
the synchronous wakeup flag to hint the scheduler, such as
Android binder driver.
So add a wake_up_sync() define, and use the wake_up_sync()
when the sync is true in ep_poll_callback().

Co-developed-by: Jing Xia <jing.xia@unisoc.com>
Signed-off-by: Jing Xia <jing.xia@unisoc.com>
Signed-off-by: Xuewen Yan <xuewen.yan@unisoc.com>
---
 fs/eventpoll.c       | 5 ++++-
 include/linux/wait.h | 1 +
 2 files changed, 5 insertions(+), 1 deletion(-)

diff --git a/fs/eventpoll.c b/fs/eventpoll.c
index 882b89edc52a..9b815e0a1ac5 100644
--- a/fs/eventpoll.c
+++ b/fs/eventpoll.c
@@ -1336,7 +1336,10 @@ static int ep_poll_callback(wait_queue_entry_t *wait, unsigned mode, int sync, v
 				break;
 			}
 		}
-		wake_up(&ep->wq);
+		if (sync)
+			wake_up_sync(&ep->wq);
+		else
+			wake_up(&ep->wq);
 	}
 	if (waitqueue_active(&ep->poll_wait))
 		pwake++;
diff --git a/include/linux/wait.h b/include/linux/wait.h
index 8aa3372f21a0..2b322a9b88a2 100644
--- a/include/linux/wait.h
+++ b/include/linux/wait.h
@@ -221,6 +221,7 @@ void __wake_up_pollfree(struct wait_queue_head *wq_head);
 #define wake_up_all(x)			__wake_up(x, TASK_NORMAL, 0, NULL)
 #define wake_up_locked(x)		__wake_up_locked((x), TASK_NORMAL, 1)
 #define wake_up_all_locked(x)		__wake_up_locked((x), TASK_NORMAL, 0)
+#define wake_up_sync(x)			__wake_up_sync(x, TASK_NORMAL)
 
 #define wake_up_interruptible(x)	__wake_up(x, TASK_INTERRUPTIBLE, 1, NULL)
 #define wake_up_interruptible_nr(x, nr)	__wake_up(x, TASK_INTERRUPTIBLE, nr, NULL)
-- 
2.25.1


^ permalink raw reply related	[flat|nested] 11+ messages in thread

end of thread, other threads:[~2024-12-17 16:31 UTC | newest]

Thread overview: 11+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-04-26  8:05 [RFC PATCH] epoll: Add synchronous wakeup support for ep_poll_callback Xuewen Yan
2024-04-26  8:31 ` Christian Brauner
2024-09-19 12:36   ` Brian Geffon
2024-09-25 18:38     ` Brian Geffon
2024-10-15 20:46       ` Brian Geffon
2024-10-16 13:10 ` Christian Brauner
2024-10-16 19:05   ` Brian Geffon
2024-12-12 17:14     ` Brian Geffon
2024-12-17 14:30       ` Brian Geffon
2024-12-17 15:34         ` Greg KH
2024-12-17 16:31           ` Brian Geffon

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).