Function report |
Source Code:mm\userfaultfd.c |
Create Date:2022-07-28 16:33:53 |
| Last Modify:2020-03-12 14:18:49 | Copyright©Brick |
| home page | Tree |
| Annotation kernel can get tool activity | Download SCCT | Chinese |
Name:__mcopy_atomic processing for HUGETLB vmas. Note that this routine is* called with mmap_sem held, it will release mmap_sem before returning.
Proto:static __always_inline ssize_t __mcopy_atomic_hugetlb(struct mm_struct *dst_mm, struct vm_area_struct *dst_vma, unsigned long dst_start, unsigned long src_start, unsigned long len, bool zeropage)
Type:ssize_t
Parameter:
| Type | Parameter | Name |
|---|---|---|
| struct mm_struct * | dst_mm | |
| struct vm_area_struct * | dst_vma | |
| unsigned long | dst_start | |
| unsigned long | src_start | |
| unsigned long | len | |
| bool | zeropage |
| 210 | vm_alloc_shared = Flags, see mm.h. & VM_SHARED |
| 211 | vm_shared = Flags, see mm.h. & VM_SHARED |
| 228 | If zeropage Then |
| 230 | Return -EINVAL |
| 235 | copied = 0 |
| 236 | page = NULL |
| 237 | vma_hpagesize = Return the size of the pages allocated when backing a VMA. In the majority* cases this will be same size as used by the page table entries. |
| 243 | If dst_start & vma_hpagesize - 1 || len & vma_hpagesize - 1 Then Go to out_unlock |
| 246 | retry : |
| 251 | If Not dst_vma Then |
| 253 | dst_vma = find_dst_vma(dst_mm, dst_start, len) |
| 254 | If Not dst_vma || Not is_vm_hugetlb_page(dst_vma) Then Go to out_unlock |
| 258 | If vma_hpagesize != Return the size of the pages allocated when backing a VMA. In the majority* cases this will be same size as used by the page table entries. Then Go to out_unlock |
| 261 | vm_shared = Flags, see mm.h. & VM_SHARED |
| 268 | If Not vm_shared Then |
| 269 | If Value for the false possibility is greater at compile time(anon_vma_prepare(dst_vma)) Then Go to out_unlock |
| 281 | idx = linear_page_index(dst_vma, dst_addr) |
| 283 | hash = For uniprocesor systems we always use a single mutex, so just* return 0 and avoid the hashing overhead. |
| 284 | mutex_lock( & hugetlb_fault_mutex_table[hash]) |
| 287 | dst_pte = arch callbacks |
| 288 | If Not dst_pte Then |
| 290 | Go to out_unlock |
| 294 | dst_pteval = huge_ptep_get(dst_pte) |
| 295 | If Not huge_pte_none(dst_pteval) Then |
| 297 | Go to out_unlock |
| 300 | err = Used by userfaultfd UFFDIO_COPY. Based on mcopy_atomic_pte with* modifications for huge pages. |
| 304 | vm_alloc_shared = vm_shared |
| 306 | cond_resched() |
| 308 | If Value for the false possibility is greater at compile time(err == - ENOENT) Then |
| 312 | err = copy_huge_page_from_user(page, (constvoid__user * )src_addr, vma_hpagesize / PAGE_SIZE, true) |
| 320 | lock for reading |
| 322 | dst_vma = NULL |
| 323 | Go to retry |
| 327 | If Not err Then |
| 328 | dst_addr += vma_hpagesize |
| 329 | src_addr += vma_hpagesize |
| 330 | copied += vma_hpagesize |
| 332 | If fatal_signal_pending(current process) Then err = -EINTR |
| 335 | If err Then Break |
| 339 | out_unlock : |
| 341 | out : |
| 342 | If page Then |
| Name | Describe |
|---|---|
| __mcopy_atomic |
| Source code conversion tool public plug-in interface | X |
|---|---|
| Support c/c++/esqlc/java Oracle/Informix/Mysql Plug-in can realize: logical Report Code generation and batch code conversion |