Page MenuHomeFreeBSD

powerpc64: Optimize radix trap handling a little more
ClosedPublic

Authored by jhibbits on Apr 27 2021, 2:21 AM.
Tags
None
Referenced Files
Unknown Object (File)
Dec 9 2024, 6:37 AM
Unknown Object (File)
Dec 6 2024, 6:07 PM
Unknown Object (File)
Nov 26 2024, 12:57 PM
Unknown Object (File)
Nov 11 2024, 6:57 PM
Unknown Object (File)
Nov 11 2024, 6:41 PM
Unknown Object (File)
Nov 7 2024, 10:43 PM
Unknown Object (File)
Nov 7 2024, 8:54 PM
Unknown Object (File)
Sep 27 2024, 3:52 AM
Subscribers

Details

Summary

Since PCPU can live in a GPR for a while longer, let it, rather than
re-getting it in yet another register. MFSPR is an expensive operation,
12 clock latency on POWER9, so the fewer operations we need, the better.

Since the check is tightly coupled to the fetch, by reducing the number
of fetch+check, we reduce the stalls, and improve the performance
marginally. Buildworld was measured at a ~5-7% improvement on a single
run.

Test Plan

Boot on radix and HPT

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 38879
Build 35768: arc lint + arc unit

Event Timeline

Looks good to me. Thanks! There are probably more instances of this kind of thing lying around.

This revision is now accepted and ready to land.Apr 29 2021, 12:29 PM