Page MenuHomeFreeBSD

x86: Copy the FPU/XSAVE state from the creating thread to new threads.
ClosedPublic

Authored by jhb on Mar 10 2021, 10:13 PM.
Tags
None
Referenced Files
Unknown Object (File)
Fri, Jan 3, 9:54 AM
Unknown Object (File)
Wed, Jan 1, 8:03 AM
Unknown Object (File)
Tue, Dec 31, 8:04 AM
Unknown Object (File)
Mon, Dec 30, 8:14 AM
Unknown Object (File)
Mon, Dec 30, 7:45 AM
Unknown Object (File)
Sun, Dec 29, 7:14 AM
Unknown Object (File)
Sat, Dec 28, 8:14 PM
Unknown Object (File)
Sat, Dec 28, 7:19 AM
Subscribers

Details

Summary

POSIX states that new threads created via pthread_create() should
inherit the "floating point environment" from the creating thread.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 37749
Build 34638: arc lint + arc unit

Event Timeline

I tested this on amd64 using kib@'s test program from D29024.

sys/i386/i386/vm_machdep.c
434

Why not call npxexit() there, same as for amd64?

466

This should be fine but unrelated?

sys/i386/i386/vm_machdep.c
434

Why not call npxexit() there, same as for amd64?

This matches cpu_fork() for i386 which does not use npxexit(). If we'd rather fix i386 to use npxexit() can I throw that into this series.

466

This should be fine but unrelated?

It's just part of the 'update pcb before copy logic' which now matches cpu_fork(). Since I had to add the FPU save, I figured this should mirror cpu_fork() at the same time.

This revision was not accepted when it landed; it landed in state Needs Review.Mar 12 2021, 5:50 PM
This revision was automatically updated to reflect the committed changes.