Page MenuHomeFreeBSD

arm64: Add a new CPU feature framework
Needs ReviewPublic

Authored by andrew on Nov 27 2024, 6:11 PM.
Tags
None
Referenced Files
F108301246: D47812.diff
Thu, Jan 23, 4:44 PM
Unknown Object (File)
Wed, Jan 15, 8:07 PM
Unknown Object (File)
Sun, Jan 12, 3:41 PM
Unknown Object (File)
Tue, Jan 7, 3:15 PM
Unknown Object (File)
Tue, Jan 7, 3:12 AM
Unknown Object (File)
Mon, Jan 6, 9:08 AM
Unknown Object (File)
Mon, Jan 6, 7:28 AM
Unknown Object (File)
Mon, Jan 6, 2:17 AM
Subscribers

Details

Reviewers
manu
Group Reviewers
ARM
Summary

This will be used to enable features that are discoverable on boot. It
has support to check if a feature needs to be enabled, and if there is
any errata associated with the feature that mean it shouldn't be
enabled. It can also be used to enable errata workarounds that aren't
associated with a specific feature, e.g. where we need to trap access
to a register in userspace to emulate it.

As some features need to be enabled early, while others can wait there
are two options for when to enable a feature:

  • CPU_FEAT_EARLY_BOOT: The feature will be enabled early in the boot. On the boot CPU this is in initarm, while on secondary CPUs this is before signalling the CPU has started.
  • CPU_FEAT_AFTER_DEV: The feature will be enabled after devices have attached but before interrupts are enabled.

There are also two scopes for where to enable the feature:

  • CPU_FEAT_PER_CPU: The feature will be checked and enabled on all CPU cores.
  • CPU_FEAT_SYSTEM: The feature will only be checked and enabled on a single core.

It is expected the former will be used for most features, while the
latter is for features that set a global variable to be checked.

Sponsored by: Arm Ltd

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 61113
Build 57997: arc lint + arc unit

Event Timeline

Create an enum to describe the status of a workaround

Allow multiple errata to be returned from feat_has_errata.