git://scm.lunaixsky.com
/
lunaix-os.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
feat: msync(2)
[lunaix-os.git]
/
lunaix-os
/
kernel
/
process
/
sched.c
diff --git
a/lunaix-os/kernel/process/sched.c
b/lunaix-os/kernel/process/sched.c
index 46500608a3da9a913dd459e16f4b8ab8ca37d9eb..1c6bd977833145e61061d124eda41c96a7532818 100644
(file)
--- a/
lunaix-os/kernel/process/sched.c
+++ b/
lunaix-os/kernel/process/sched.c
@@
-7,6
+7,7
@@
#include <lunaix/fs/taskfs.h>
#include <lunaix/mm/cake.h>
#include <lunaix/mm/kalloc.h>
#include <lunaix/fs/taskfs.h>
#include <lunaix/mm/cake.h>
#include <lunaix/mm/kalloc.h>
+#include <lunaix/mm/mmap.h>
#include <lunaix/mm/pmm.h>
#include <lunaix/mm/valloc.h>
#include <lunaix/mm/vmm.h>
#include <lunaix/mm/pmm.h>
#include <lunaix/mm/valloc.h>
#include <lunaix/mm/vmm.h>
@@
-400,18
+401,18
@@
destroy_process(pid_t pid)
vfree(proc->fdtable);
vfree_dma(proc->fxstate);
vfree(proc->fdtable);
vfree_dma(proc->fxstate);
- // TODO unmap all regions
+ vmm_mount_pd(VMS_MOUNT_1, proc->page_table);
+
struct mm_region *pos, *n;
llist_for_each(pos, n, &proc->mm.regions, head)
{
struct mm_region *pos, *n;
llist_for_each(pos, n, &proc->mm.regions, head)
{
+ mem_sync_pages(VMS_MOUNT_1, pos, pos->start, pos->end - pos->start, 0);
vfree(pos);
}
vfree(pos);
}
- vmm_mount_pd(PD_MOUNT_1, proc->page_table);
-
- __del_pagetable(pid, PD_MOUNT_1);
+ __del_pagetable(pid, VMS_MOUNT_1);
- vmm_unmount_pd(
PD
_MOUNT_1);
+ vmm_unmount_pd(
VMS
_MOUNT_1);
cake_release(proc_pile, proc);
cake_release(proc_pile, proc);