On 3/10/21 4:45 AM, Alex Richardson wrote:
The branch main has been updated by arichardson:

URL: 
https://cgit.FreeBSD.org/src/commit/?id=953a7d7c61f3b2f5351dfe668510ec782ae282e8

commit 953a7d7c61f3b2f5351dfe668510ec782ae282e8
Author:     Alex Richardson <arichard...@freebsd.org>
AuthorDate: 2021-03-09 19:11:40 +0000
Commit:     Alex Richardson <arichard...@freebsd.org>
CommitDate: 2021-03-10 12:44:42 +0000

     Arch64: Clear VFP state on execve()
I noticed that many of the math-related tests were failing on AArch64.
     After a lot of debugging, I noticed that the floating point exception flags
     were not being reset when starting a new process. This change resets the
     VFP inside exec_setregs() to ensure no VFP register state is leaked from
     parent processes to children.
This commit also moves the clearing of fpcr that was added in 65618fdda0f27
     from fork() to execve() since that makes more sense: fork() can retain
     current register values, but execve() should result in a well-defined
     clean state.
Reviewed By: andrew
     MFC after:      1 week
     Differential Revision: https://reviews.freebsd.org/D29060

FYI, cpu_thread_copy() should copy the creating thread's state to the new 
thread,
not reset it.  POSIX actually says that new threads inherit the "floating point
environment" from the creating thread for pthread_create().  I have a patch I'm
testing to fix thix for x86.

--
John Baldwin
_______________________________________________
dev-commits-src-main@freebsd.org mailing list
https://lists.freebsd.org/mailman/listinfo/dev-commits-src-main
To unsubscribe, send any mail to "dev-commits-src-main-unsubscr...@freebsd.org"

Reply via email to