summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorIan Moffett <ian@osmora.org>2025-06-09 01:53:56 -0400
committerIan Moffett <ian@osmora.org>2025-06-09 01:53:56 -0400
commitc31bc1b4132d12d5cfb144419f83f480ee4e7b88 (patch)
tree8aa0e4d1b8c4a8043755ad62a620fa976fbcd257
parentb27538ea39d8065eb26f36853fc5d1fa24a126b3 (diff)
kernel: spawn: Improve wait sleep handlingexpt
Signed-off-by: Ian Moffett <ian@osmora.org>
-rw-r--r--sys/kern/kern_exit.c5
-rw-r--r--sys/kern/kern_spawn.c5
2 files changed, 2 insertions, 8 deletions
diff --git a/sys/kern/kern_exit.c b/sys/kern/kern_exit.c
index 0f90365..53dc166 100644
--- a/sys/kern/kern_exit.c
+++ b/sys/kern/kern_exit.c
@@ -159,10 +159,7 @@ exit1(struct proc *td, int flags)
if (td->data == NULL)
sched_enter();
- if (ISSET(parent->flags, PROC_SLEEP)) {
- sched_enqueue_td(parent);
- parent->flags &= ~PROC_SLEEP;
- }
+ parent->flags &= ~PROC_SLEEP;
sched_enter();
}
diff --git a/sys/kern/kern_spawn.c b/sys/kern/kern_spawn.c
index 4ec1bfb..42e558a 100644
--- a/sys/kern/kern_spawn.c
+++ b/sys/kern/kern_spawn.c
@@ -168,10 +168,7 @@ spawn(struct proc *cur, void(*func)(void), void *p, int flags, struct proc **new
if (ISSET(flags, SPAWN_WAIT)) {
newproc->flags |= PROC_WAITED;
cur->flags |= PROC_SLEEP;
-
- while (ISSET(cur->flags, PROC_SLEEP)) {
- sched_yield();
- }
+ sched_yield();
if (!ISSET(newproc->flags, PROC_ZOMB)) {
pr_error("spawn: fatal: %d not zombie\n", newproc->pid);