X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/48b4a227035048fdebcd32532deb7a857c6199ac..bb793d5c6918efee6a86de442463a7c9aaa4ecdd:/lunaix-os/kernel/mm/cow.c?ds=sidebyside diff --git a/lunaix-os/kernel/mm/cow.c b/lunaix-os/kernel/mm/cow.c index 30cead9..6b46e48 100644 --- a/lunaix-os/kernel/mm/cow.c +++ b/lunaix-os/kernel/mm/cow.c @@ -1,16 +1,22 @@ +#include #include -void* vmm_dup_page(void* va) { - void* new_ppg = pmm_alloc_page(KERNEL_PID, 0); - vmm_fmap_page(KERNEL_PID, PG_MOUNT_3, new_ppg, PG_PREM_RW); +ptr_t +vmm_dup_page(pid_t pid, ptr_t pa) +{ + ptr_t new_ppg = pmm_alloc_page(pid, 0); + vmm_set_mapping(VMS_SELF, PG_MOUNT_3, new_ppg, PG_PREM_RW, VMAP_NULL); + vmm_set_mapping(VMS_SELF, PG_MOUNT_4, pa, PG_PREM_RW, VMAP_NULL); - asm volatile ( - "movl %1, %%edi\n" - "rep movsl\n" - :: "c"(1024), "r"(PG_MOUNT_3), "S"((uintptr_t)va) - : "memory", "%edi"); + 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_del_mapping(VMS_SELF, PG_MOUNT_3); + vmm_del_mapping(VMS_SELF, PG_MOUNT_4); return new_ppg; } \ No newline at end of file