sched/irq: remove scheduling check in csection

1. The critical section does not prevent task scheduling
2. If the critical section is in sched_lock, there is no need to check,
   scheduling is not going to happen
3. If sched_lock is in the critical section, sched_unlock will also
   trigger scheduling without waiting for the exit of the critical section
4. After exiting the critical section, if there is an interrupt,
   the scheduling will be automatically triggered

Signed-off-by: hujun5 <hujun5@xiaomi.com>
This commit is contained in:
hujun5 2024-04-10 10:06:27 +08:00 committed by archer
parent e543a8086e
commit 1b068b0d4b

View File

@ -550,35 +550,6 @@ void leave_critical_section(irqstate_t flags)
DEBUGASSERT(spin_is_locked(&g_cpu_irqlock) && DEBUGASSERT(spin_is_locked(&g_cpu_irqlock) &&
(g_cpu_irqset & (1 << cpu)) != 0); (g_cpu_irqset & (1 << cpu)) != 0);
/* Check if releasing the lock held by this CPU will unlock the
* critical section.
*/
if ((g_cpu_irqset & ~(1 << cpu)) == 0)
{
/* Yes.. Check if there are pending tasks and that pre-
* emption is also enabled. This is necessary because we
* may have deferred the nxsched_merge_pending() call in
* sched_unlock() because we were within a critical
* section then.
*/
if (list_pendingtasks()->head != NULL &&
!nxsched_islocked_global())
{
/* Release any ready-to-run tasks that have collected
* in g_pendingtasks. NOTE: This operation has a very
* high likelihood of causing this task to be switched
* out!
*/
if (nxsched_merge_pending())
{
up_switch_context(this_task(), rtcb);
}
}
}
/* Now, possibly on return from a context switch, clear our /* Now, possibly on return from a context switch, clear our
* count on the lock. If all CPUs have released the lock, * count on the lock. If all CPUs have released the lock,
* then unlock the global IRQ spinlock. * then unlock the global IRQ spinlock.