Page MenuHomeFreeBSD

cpu_auxmsr: assert caller is preventing CPU migration
ClosedPublic

Authored by adam_fenn.io on Aug 23 2020, 9:27 PM.
Tags
None
Referenced Files
F108836314: D26166.id76129.diff
Tue, Jan 28, 12:15 PM
Unknown Object (File)
Sat, Jan 25, 7:52 PM
Unknown Object (File)
Sat, Jan 25, 7:44 PM
Unknown Object (File)
Sat, Jan 25, 7:39 PM
Unknown Object (File)
Tue, Jan 14, 9:03 PM
Unknown Object (File)
Tue, Jan 14, 3:26 PM
Unknown Object (File)
Sun, Dec 29, 4:19 PM
Unknown Object (File)
Dec 23 2024, 5:24 AM
Subscribers

Details

Test Plan

Peformed the following sanity-checks:

  • i386
    • Confirmed assertion is not triggered during boot of a 4-CPU system (a bhyve VM).
  • amd64
    • Confirmed assertion is not triggered during boot of a 4-CPU system (a VMWare VM).
    • Confirmed assertion is not triggered in the VM entry/exit code path (used an invocation of dtrace -f fbt:kernel:cpu_auxmsr to confirm this routine was, as expected, being called while a bhyve VM was running).

The resume codepaths were not sanity-checked, but, by inspection, these appear equally clear as contexts with interrupts disabled as the cases that were sanity-checked.

Diff Detail

Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 33123
Build 30488: arc lint + arc unit

Event Timeline

adam_fenn.io held this revision as a draft.
sys/amd64/amd64/initcpu.c
224

I suggest to trim this sentence to just

Caller should prevent CPU migration.
235

I am not sure the comment is useful. If somebody is using this in context that only prevents scheduling, e.g. in critical section, he should be qualified enough to change assert to accommodate new situation. Comment above the function gives enough clue, if needed.

237

Indent of contig lines should be +4 spaces, no alignment to opening braces. Also I believe the message could be made much shorter without loosing the information.

adam_fenn.io marked an inline comment as done.

Incorporate @kib's review feedback.

sys/amd64/amd64/initcpu.c
230

I suggest to write the message Context switch possible instead of interrupts enabled which just repeats the assert code. It is more to the point IMO.

231

Remove blank line.

This revision is now accepted and ready to land.Aug 23 2020, 11:44 PM

Thanks kib@, I can commit this.