Page MenuHomeFreeBSD

Ensure the boot CPU is CPU 0 on arm64
ClosedPublic

Authored by andrew on Dec 7 2020, 1:05 PM.
Tags
None
Referenced Files
Unknown Object (File)
Tue, Apr 7, 11:29 AM
Unknown Object (File)
Tue, Apr 7, 3:33 AM
Unknown Object (File)
Mon, Apr 6, 8:44 AM
Unknown Object (File)
Sun, Apr 5, 1:30 PM
Unknown Object (File)
Sun, Apr 5, 11:29 AM
Unknown Object (File)
Sun, Apr 5, 5:35 AM
Unknown Object (File)
Sat, Apr 4, 7:21 AM
Unknown Object (File)
Sat, Apr 4, 12:17 AM
Subscribers

Details

Summary

We assume the boot CPU is always CPU 0 on arm64. To allow for this reserve
cpuid 0 for the boot CPU in the ACPI and FDT cases but otherwise start the
CPU as normal. We then check for the boot CPU in start_cpu and return as if
it was started.

While here extract the FDT CPU init code into a new function to simplify
cpu_mp_start and return FALSE from start_cpu when the CPU fails to start.

Diff Detail

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

Event Timeline

andrew requested review of this revision.Dec 7 2020, 1:05 PM

Simplify by only iterating once with CPU 0 being reserved

  • Use the correct ID in cpu_init_fdt
  • Copy a comment explaining why we don't increment the CPU ID to teh FDT code
  • Fix a typo in said comment
mmel added a subscriber: mmel.

Works for me and it's much better than my initial proposal.

This revision is now accepted and ready to land.Dec 7 2020, 4:37 PM
This revision was automatically updated to reflect the committed changes.