diff options
author | dzwdz | 2023-01-08 00:28:24 +0100 |
---|---|---|
committer | dzwdz | 2023-01-08 00:28:24 +0100 |
commit | 50723d19f972b7a50e3165620e57cb261c28056f (patch) | |
tree | 2d4ee4f6d9c5a09382697cafea419dc94de06a60 /src/kernel/proc.h | |
parent | a1a4ab33cd75f0bc1d5e71989b01ba3446c998ae (diff) |
kernel/proc: don't kill children when parent dies
Diffstat (limited to 'src/kernel/proc.h')
-rw-r--r-- | src/kernel/proc.h | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/src/kernel/proc.h b/src/kernel/proc.h index 07cba28..135baad 100644 --- a/src/kernel/proc.h +++ b/src/kernel/proc.h @@ -6,9 +6,12 @@ struct vfs_mount; #define HANDLE_MAX 16 +/* legal transitions described by process_transition */ enum process_state { PS_RUNNING, - PS_DEAD, // return message not collected + PS_TOREAP, /* return message not collected */ + PS_TOMBSTONE, /* fully dead, supports alive children */ + PS_WAITS4CHILDDEATH, PS_WAITS4FS, PS_WAITS4REQUEST, @@ -18,6 +21,8 @@ enum process_state { PS_LAST, }; +#define proc_alive(p) (p && p->state != PS_TOREAP && p->state != PS_TOMBSTONE) + struct process { struct pagedir *pages; /* if NULL, refcount == 1. kmalloc'd */ @@ -80,8 +85,8 @@ struct process *process_seed(void *data, size_t datalen); struct process *process_fork(struct process *parent, int flags); void process_kill(struct process *proc, int ret); -/** Tries to free a process / collect its return value. */ -void process_try2collect(struct process *dead); +/** Tries to reap a dead process / free a tombstone. */ +void process_tryreap(struct process *dead); /** Switches execution to any running process. */ _Noreturn void process_switch_any(void); |