X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/61a1daa59589212608039e2734009870818bacd3..f69a7227ff3ad84af3651fe36162e131d4f2b323:/lunaix-os/kernel/process/sched.c?ds=sidebyside diff --git a/lunaix-os/kernel/process/sched.c b/lunaix-os/kernel/process/sched.c index f58710e..4e3f290 100644 --- a/lunaix-os/kernel/process/sched.c +++ b/lunaix-os/kernel/process/sched.c @@ -4,6 +4,7 @@ #include #include +#include #include #include #include @@ -281,6 +282,8 @@ alloc_process() proc->created = clock_systime(); proc->pgid = proc->pid; proc->fdtable = vzalloc(sizeof(struct v_fdtable)); + proc->fxstate = + vzalloc_dma(512); // FXSAVE需要十六位对齐地址,使用DMA块(128位对齐) llist_init_head(&proc->mm.regions.head); llist_init_head(&proc->tasks); @@ -331,14 +334,24 @@ destroy_process(pid_t pid) sched_ctx._procs[index] = 0; llist_delete(&proc->siblings); + llist_delete(&proc->grp_member); + llist_delete(&proc->tasks); + llist_delete(&proc->sleep.sleepers); + + taskfs_invalidate(pid); + + if (proc->cwd) { + vfs_unref_dnode(proc->cwd); + } for (size_t i = 0; i < VFS_MAX_FD; i++) { struct v_fd* fd = proc->fdtable->fds[i]; if (fd) - vfs_close(fd->file); + vfs_pclose(fd->file, pid); } vfree(proc->fdtable); + vfree_dma(proc->fxstate); struct mm_region *pos, *n; llist_for_each(pos, n, &proc->mm.regions.head, head)