Page MenuHomeFreeBSD

x86: Restore the critical section around whole ipi_bitmap_handler() if hardclock IPI is delivered.
ClosedPublic

Authored by kib on Dec 6 2019, 11:45 PM.
Tags
None
Referenced Files
Unknown Object (File)
Dec 30 2023, 1:18 AM
Unknown Object (File)
Dec 20 2023, 3:30 AM
Unknown Object (File)
Sep 11 2023, 4:33 PM
Unknown Object (File)
Aug 10 2023, 2:15 PM
Unknown Object (File)
Aug 10 2023, 2:14 PM
Unknown Object (File)
Aug 10 2023, 2:13 PM
Unknown Object (File)
Aug 10 2023, 2:13 PM
Unknown Object (File)
Aug 7 2023, 10:58 AM
Subscribers

Details

Summary

In the current code after r355311, critical section is taken only around hardclockintr() call, and sched_preempt() is called after the section is exited. If we reschedule after exit, as we typically would due to conditions that caused IPI, in ULE the runq tdq_ipipending is not cleared, which blocks generation of further preempt IPIs.

Since all relatively modern (10 years) hardware has per-cpu event timers, restoring the critical section conditionally does not affect it.

Diagnosed and reviewed by: jeff
Reported and tested by: cy

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

kib edited the summary of this revision. (Show Details)

thank you.

sys/x86/x86/mp_x86.c
1267 ↗(On Diff #65343)

Comment something like:

sched_preempt() must be called to clear the pending IPI. However, the critical section will cause extra scheduler lock thrashing when used unconditionally. Only critical_enter() if hardclock must also run.

This revision is now accepted and ready to land.Dec 6 2019, 11:57 PM