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)
Wed, Jul 2, 1:49 AM
Unknown Object (File)
Mon, Jun 30, 8:24 PM
Unknown Object (File)
Thu, Jun 26, 3:18 AM
Unknown Object (File)
Mon, Jun 23, 2:38 PM
Unknown Object (File)
Sat, Jun 21, 1:14 AM
Unknown Object (File)
Fri, Jun 20, 1:10 PM
Unknown Object (File)
Wed, Jun 18, 2:41 AM
Unknown Object (File)
Sun, Jun 15, 7:07 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