Page MenuHomeFreeBSD

kern_reboot(): don't clear kdb_active
ClosedPublic

Authored by mhorne on Nov 20 2023, 6:00 PM.
Tags
None
Referenced Files
Unknown Object (File)
Nov 18 2024, 2:16 AM
Unknown Object (File)
Sep 30 2024, 9:37 AM
Unknown Object (File)
Sep 30 2024, 9:26 AM
Unknown Object (File)
Sep 18 2024, 12:30 PM
Unknown Object (File)
Sep 17 2024, 2:07 PM
Unknown Object (File)
Sep 16 2024, 10:00 PM
Unknown Object (File)
Sep 16 2024, 1:03 AM
Unknown Object (File)
Aug 13 2024, 5:12 PM
Subscribers
None

Details

Summary

It is possible to reach this function from ddb via the "reset" command.
When this happens, we don't actually exit kdb, meaning we never execute
the latter steps of kdb_break() to restore the system state (e.g.
re-enable scheduler).

Therefore, we should not clear the kdb_active flag in this function, as
the debugger is still active. Put differently, kern_reboot() is not an
authority on kdb state, and should not touch it. The original motivation
for this assignment is not clear; I have checked thoroughly and I am
convinced it is not required by any reset code.

This fixes an edge case where a panic can be triggered during reset from
ddb:

  1. Enter ddb via keyboard break sequence (KERNEL_PANICKED() == false && td->td_critnest > 0)
  2. Execute the "reset" command
  3. kern_reboot() sets kdb_active = false
  4. A witness_checkorder() call via shutdown handler sees !kdb_active and panics

This is my preferred alternative to the initial fix I proposed in D38656.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable