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)
Mon, May 25, 6:27 AM
Unknown Object (File)
Wed, May 13, 2:23 AM
Unknown Object (File)
Apr 24 2026, 10:12 AM
Unknown Object (File)
Apr 16 2026, 12:10 AM
Unknown Object (File)
Apr 15 2026, 6:41 PM
Unknown Object (File)
Apr 6 2026, 10:57 AM
Unknown Object (File)
Apr 2 2026, 8:42 AM
Unknown Object (File)
Apr 1 2026, 11:08 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 Skipped
Unit
Tests Skipped
Build Status
Buildable 28022

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