]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/commit
amd64: Avoid copying td_frame from kernel procs
authorMark Johnston <markj@FreeBSD.org>
Sat, 25 Sep 2021 14:15:31 +0000 (10:15 -0400)
committerEd Maste <emaste@FreeBSD.org>
Thu, 2 Mar 2023 03:11:16 +0000 (22:11 -0500)
commitcf25fa7f31e7bda9b8aa20757659524db9c4ef97
treeaf11343e11c2cd1dc87b14c7e10dd456fd23bbc8
parent43fd77233cd49061839cfdd936cfeba53e9855c3
amd64: Avoid copying td_frame from kernel procs

When creating a new thread, we unconditionally copy td_frame from the
creating thread.  For threads which never return to user mode, this is
unnecessary since td_frame just points to the base of the stack or a
random interrupt frame.

If KASAN is configured this copying may also trigger false positives
since the td_frame region may contain poisoned stack regions.  It was
not noticed before since thread0 used a dummy proc0_tf trapframe, and
kernel procs are generally created by thread0.  Since commit
df8dd6025af88a99d34f549fa9591a9b8f9b75b1, though, we call
cpu_thread_alloc(&thread0) when initializing FPU state, which
reinitializes thread0.td_frame.

Work around the problem by not copying the frame unless the copying
thread came from user mode.  While here, de-duplicate the copying and
remove redundant re(initialization) of td_frame.

Reported by: syzbot+2ec89312bffbf38d9aec@syzkaller.appspotmail.com
Reviewed by: kib
Fixes: df8dd6025af8
MFC after: 2 weeks
Sponsored by: The FreeBSD Foundation
Differential Revision: https://reviews.freebsd.org/D32057

(cherry picked from commit ca1e447b1048b26b855d7f7fbcdad78309e4d741)
sys/amd64/amd64/vm_machdep.c