X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/20097445f742afff2c263431efcb1c8b596076a8..58bc147210ab1363ee9ddc169a8e1c46ce24cf29:/lunaix-os/kernel/process.c diff --git a/lunaix-os/kernel/process.c b/lunaix-os/kernel/process.c index 87a7413..020dfb4 100644 --- a/lunaix-os/kernel/process.c +++ b/lunaix-os/kernel/process.c @@ -5,6 +5,7 @@ #include #include #include +#include #include #include @@ -90,6 +91,36 @@ __DEFINE_LXSYSCALL(pid_t, getppid) return __current->parent->pid; } +__DEFINE_LXSYSCALL(pid_t, getpgid) +{ + return __current->pgid; +} + +__DEFINE_LXSYSCALL2(int, setpgid, pid_t, pid, pid_t, pgid) +{ + struct proc_info* proc = pid ? get_process(pid) : __current; + + if (!proc) { + __current->k_status = LXINVL; + return -1; + } + + pgid = pgid ? pgid : proc->pid; + + struct proc_info* gruppenfuhrer = get_process(pgid); + + if (!gruppenfuhrer || proc->pgid == proc->pid) { + __current->k_status = LXINVL; + return -1; + } + + llist_delete(&proc->grp_member); + llist_append(&gruppenfuhrer->grp_member, &proc->grp_member); + + proc->pgid = pgid; + return 0; +} + void init_proc(struct proc_info* pcb) { @@ -98,6 +129,7 @@ init_proc(struct proc_info* pcb) pcb->pid = alloc_pid(); pcb->created = clock_systime(); pcb->state = PROC_CREATED; + pcb->pgid = pcb->pid; } pid_t