Page MenuHomeFreeBSD

[PowerPC64LE] Fix LE VSX/fpr interop
ClosedPublic

Authored by bdragon on Dec 1 2020, 1:11 AM.
Referenced Files
Unknown Object (File)
Fri, Dec 13, 12:48 PM
Unknown Object (File)
Fri, Nov 29, 10:45 AM
Unknown Object (File)
Oct 3 2024, 1:06 PM
Unknown Object (File)
Oct 1 2024, 7:30 AM
Unknown Object (File)
Sep 26 2024, 1:55 PM
Unknown Object (File)
Sep 25 2024, 6:22 PM
Unknown Object (File)
Sep 24 2024, 7:53 AM
Unknown Object (File)
Sep 22 2024, 6:55 PM
Subscribers

Details

Summary

In the PCB struct, we need to match the VSX register file layout correctly, as the VSRs shadow the FPRs.

In LE, we need to have a dword of padding before the fprs so they end up on the correct side, as the struct may be manipulated by either the FP routines or the VSX routines.

Additionally, when saving and restoring fprs, we need to explicitly target the fpr union member so it gets offset correctly on LE.

Fixes weirdness with FP registers in VSX-using programs (A fpr that was saved by the FP routines but restored by the VSX routines was becoming 0 due to being loaded to the wrong side of the vsr.)

Original patch by jhibbits.

Diff Detail

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