From 61598093bbdd283a7edc367d900f223070ead8d2 Mon Sep 17 00:00:00 2001
From: hc <hc@nodka.com>
Date: Fri, 10 May 2024 07:43:03 +0000
Subject: [PATCH] add ax88772C AX88772C_eeprom_tools

---
 kernel/kernel/sched/swait.c |   27 ++++++++++-----------------
 1 files changed, 10 insertions(+), 17 deletions(-)

diff --git a/kernel/kernel/sched/swait.c b/kernel/kernel/sched/swait.c
index 119a56d..e1c655f 100644
--- a/kernel/kernel/sched/swait.c
+++ b/kernel/kernel/sched/swait.c
@@ -32,24 +32,18 @@
 }
 EXPORT_SYMBOL(swake_up_locked);
 
+/*
+ * Wake up all waiters. This is an interface which is solely exposed for
+ * completions and not for general usage.
+ *
+ * It is intentionally different from swake_up_all() to allow usage from
+ * hard interrupt context and interrupt disabled regions.
+ */
 void swake_up_all_locked(struct swait_queue_head *q)
 {
-	struct swait_queue *curr;
-	int wakes = 0;
-
-	while (!list_empty(&q->task_list)) {
-
-		curr = list_first_entry(&q->task_list, typeof(*curr),
-					task_list);
-		wake_up_process(curr->task);
-		list_del_init(&curr->task_list);
-		wakes++;
-	}
-	if (pm_in_action)
-		return;
-	WARN(wakes > 2, "complete_all() with %d waiters\n", wakes);
+	while (!list_empty(&q->task_list))
+		swake_up_locked(q);
 }
-EXPORT_SYMBOL(swake_up_all_locked);
 
 void swake_up_one(struct swait_queue_head *q)
 {
@@ -70,7 +64,6 @@
 	struct swait_queue *curr;
 	LIST_HEAD(tmp);
 
-	WARN_ON(irqs_disabled());
 	raw_spin_lock_irq(&q->lock);
 	list_splice_init(&q->task_list, &tmp);
 	while (!list_empty(&tmp)) {
@@ -113,7 +106,7 @@
 	long ret = 0;
 
 	raw_spin_lock_irqsave(&q->lock, flags);
-	if (unlikely(signal_pending_state(state, current))) {
+	if (signal_pending_state(state, current)) {
 		/*
 		 * See prepare_to_wait_event(). TL;DR, subsequent swake_up_one()
 		 * must not see us.

--
Gitblit v1.6.2