Hi:
I am working on a project to copy (page aligned) the buffer content of one process to the buffer of other process. Now I resolved this issue using copy_page() but, analizing performance with different buffer sizes, the "copy_page" becames the critical time component and limiting factor. I read some articles about, COW, zero copy and page flipping and I wrote a kernel code to implement page "transfer" (only copy page references), but that code fail and hang. The kernel I use is 2.6.32. The pseudocode I think is: pte_t *src_pte, *dst_pte; src_pte = getpte(src_task);
And here is code added to the kernel: ------------------------------------------------------------------------------------------------------------- len = PAGE_SIZE; src_vma=find_vma_intersection(src_proc->p_task->mm,src_addr,src_addr+len); dst_vma=find_vma_intersection(dst_proc->p_task->mm,dst_addr,dst_addr+len); src_pgd=pgd_offset(src_proc->p_task->mm, (unsigned long) src_addr); src_pud=pud_offset(src_pgd,(unsigned long) src_addr); src_pmd=pmd_offset(src_pud,(unsigned long) src_addr); src_pte=pte_offset_map_lock(src_proc->p_task->mm, src_pmd,(unsigned long) src_addr, &src_ptl); dst_pgd=pgd_offset(dst_proc->p_task->mm, (unsigned long) dst_addr); dst_pud=pud_offset(dst_pgd,(unsigned long) dst_addr); dst_pmd=pmd_offset(dst_pud,(unsigned long) dst_addr); dst_pte=pte_offset_map_lock(dst_proc->p_task->mm, dst_pmd,(unsigned long) dst_addr, &dst_ptl); pte_free(dst_proc->p_task->mm, dst_pte); copy_pte_range(dst_proc->p_task->mm, src_proc->p_task->mm, dst_pmd, src_pmd, dst_vma, (unsigned long) dst_addr, ((unsigned long)dst_addr+PAGE_SIZE)); spin_unlock(src_ptl); spin_unlock(dst_ptl); ------------------------------------------------------------------------------------------------------------- There are a lots of kernel functions that are not well documented or they have been changed. Can anybody help me with this issue? Does COW (Copy On Write) will make the copy when the processes will modify their buffers? I am not suscribed to the mailing list, please CC: the answers to this email account. Thanks in Advance. I apologize for my basic English. Pablo Pessolani PD: once finishing with that code, some issues about page protection will be considered. |
_______________________________________________ Kernelnewbies mailing list Kernelnewbies@xxxxxxxxxxxxxxxxx http://lists.kernelnewbies.org/mailman/listinfo/kernelnewbies