Page MenuHomeFreeBSD

amd64: Clear the local TSS when creating a new thread
ClosedPublic

Authored by markj on Jun 1 2021, 10:27 PM.
Tags
None
Referenced Files
F159347590: D30607.id90293.diff
Sat, Jun 13, 3:23 AM
Unknown Object (File)
Fri, Jun 12, 7:51 AM
Unknown Object (File)
Mon, May 18, 3:08 AM
Unknown Object (File)
Mon, May 18, 3:08 AM
Unknown Object (File)
Mon, May 18, 3:08 AM
Unknown Object (File)
Sun, May 17, 4:36 PM
Unknown Object (File)
Sun, May 17, 4:28 PM
Unknown Object (File)
Sat, May 16, 11:34 AM
Subscribers

Details

Summary

Otherwise it is copied from the creating thread. Then, if either thread
exits, the other is left with a dangling pointer, typically resulting in
a page fault upon the next context switch. This is equivalent to our
behaviour on i386.

Reported by: syzkaller

Test Plan

syzkaller generated a test case where a thread

  • calls sysarch(AMD64_SET_IOPERM)
  • creates a new thread

when the new thread exits, the current thread triggers
a page fault when reloading the TSS during a context switch.

Diff Detail

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