Page MenuHomeFreeBSD

powerpc/spe: Implement SPE exception handling
ClosedPublic

Authored by jhibbits on Oct 6 2018, 12:37 AM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Nov 2, 11:49 PM
Unknown Object (File)
Oct 18 2024, 8:19 PM
Unknown Object (File)
Oct 18 2024, 8:19 PM
Unknown Object (File)
Oct 18 2024, 8:18 PM
Unknown Object (File)
Oct 18 2024, 7:55 PM
Unknown Object (File)
Sep 24 2024, 10:12 AM
Unknown Object (File)
Sep 24 2024, 6:15 AM
Unknown Object (File)
Sep 24 2024, 3:12 AM
Subscribers

Details

Summary

The Signal Processing Engine (SPE) found in Freescale e500 cores (and
others) offloads IEEE-754 compliance (NaN, Inf handling, overflow,
underflow) to software, most likely as a means of simplifying the APU
silicon. Some software, like AbiWord, needs full IEEE-754 compliance,
including NaN handling. Implement the necessary bits to enable it.

Test Plan

Tested on a P1022, both a simple floating point program and polkitd.
polkitd uses spidermonkey, and is a great test for FPU conformance.

Diff Detail

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

Event Timeline

Aside from one inline note, this looks OK for non-SPE.

sys/powerpc/booke/spe.c
126 ↗(On Diff #48817)

Doesn't this break on non-SPE systems?

jhibbits added inline comments.
sys/powerpc/booke/spe.c
126 ↗(On Diff #48817)

spe.c is only built for powerpcspe, so no :)

This revision was not accepted when it landed; it landed in state Needs Review.Oct 21 2018, 12:43 AM
This revision was automatically updated to reflect the committed changes.