X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/2e21eb2f39dd80aa166216381d5d402be943686e..ab281459f86543c6b8c11ecccc3e743c3d69577e:/lunaix-os/kernel/mm/cow.c diff --git a/lunaix-os/kernel/mm/cow.c b/lunaix-os/kernel/mm/cow.c index 85dcd49..81e0648 100644 --- a/lunaix-os/kernel/mm/cow.c +++ b/lunaix-os/kernel/mm/cow.c @@ -1,19 +1,21 @@ #include -void* vmm_dup_page(pid_t pid, void* pa) { +void* +vmm_dup_page(pid_t pid, void* pa) +{ void* new_ppg = pmm_alloc_page(pid, 0); - vmm_fmap_page(pid, PG_MOUNT_3, new_ppg, PG_PREM_RW); - vmm_fmap_page(pid, PG_MOUNT_4, pa, PG_PREM_RW); + vmm_set_mapping(PD_REFERENCED, PG_MOUNT_3, new_ppg, PG_PREM_RW, VMAP_NULL); + vmm_set_mapping(PD_REFERENCED, PG_MOUNT_4, pa, PG_PREM_RW, VMAP_NULL); - asm volatile ( - "movl %1, %%edi\n" - "movl %2, %%esi\n" - "rep movsl\n" - :: "c"(1024), "r"(PG_MOUNT_3), "r"(PG_MOUNT_4) - : "memory", "%edi", "%esi"); + asm volatile("movl %1, %%edi\n" + "movl %2, %%esi\n" + "rep movsl\n" ::"c"(1024), + "r"(PG_MOUNT_3), + "r"(PG_MOUNT_4) + : "memory", "%edi", "%esi"); - vmm_unset_mapping(PG_MOUNT_3); - vmm_unset_mapping(PG_MOUNT_4); + vmm_del_mapping(PD_REFERENCED, PG_MOUNT_3); + vmm_del_mapping(PD_REFERENCED, PG_MOUNT_4); return new_ppg; } \ No newline at end of file