diff options
| author | Konstantin Belousov <kib@FreeBSD.org> | 2025-09-08 03:43:09 +0000 |
|---|---|---|
| committer | Konstantin Belousov <kib@FreeBSD.org> | 2025-09-09 02:51:08 +0000 |
| commit | f51d7d5139a76d225c9f537bd948525ababdef0c (patch) | |
| tree | 6d41aec06de1ee4faf600231573bcc957c3c1261 | |
| parent | c745a6818bcbf33cf7f59641c925d19b3f98cea8 (diff) | |
kern_thr_exit(): clear kASTs in advance
PR: 289204
Reviewed by: markj
Sponsored by: The FreeBSD Foundation
MFC after: 1 week
Differential revision: https://reviews.freebsd.org/D52421
| -rw-r--r-- | sys/kern/kern_thr.c | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/sys/kern/kern_thr.c b/sys/kern/kern_thr.c index 0e8c2b9f362e..4329959a2ef4 100644 --- a/sys/kern/kern_thr.c +++ b/sys/kern/kern_thr.c @@ -347,6 +347,17 @@ kern_thr_exit(struct thread *td) p = td->td_proc; /* + * Clear kernel ASTs in advance of selecting the last exiting + * thread and acquiring schedulers locks. It is fine to + * clear the ASTs here even if we are not going to exit after + * all. On the other hand, leaving them pending could trigger + * execution in subsystems in a context where they are not + * prepared to handle top kernel actions, even in execution of + * an unrelated thread. + */ + ast_kclear(td); + + /* * If all of the threads in a process call this routine to * exit (e.g. all threads call pthread_exit()), exactly one * thread should return to the caller to terminate the process |
