Function report |
Source Code:mm\madvise.c |
Create Date:2022-07-28 15:12:13 |
Last Modify:2020-03-12 14:18:49 | Copyright©Brick |
home page | Tree |
Annotation kernel can get tool activity | Download SCCT | Chinese |
Name:madvise_cold_or_pageout_pte_range
Proto:static int madvise_cold_or_pageout_pte_range(pmd_t *pmd, unsigned long addr, unsigned long end, struct mm_walk *walk)
Type:int
Parameter:
Type | Parameter | Name |
---|---|---|
pmd_t * | pmd | |
unsigned long | addr | |
unsigned long | end | |
struct mm_walk * | walk |
314 | If fatal_signal_pending(current process) Then Return -EINTR |
318 | If pmd_trans_huge( * pmd) Then |
320 | next = pmd_addr_end(addr, end) |
324 | If Not ptl Then Return 0 |
328 | If is_huge_zero_pmd(orig_pmd) Then Go to huge_unlock |
334 | Go to huge_unlock |
337 | page = Currently stuck as a macro due to indirect forward reference to* linux/mmzone.h's __section_mem_map_addr() definition:(orig_pmd) |
338 | If next - addr != HPAGE_PMD_SIZE Then |
341 | If page_mapcount(page) != 1 Then Go to huge_unlock |
345 | spin_unlock(ptl) |
347 | err = split_huge_page(page) |
350 | If Not err Then Go to regular_page |
352 | Return 0 |
356 | pmdp_invalidate(vma, addr, pmd) |
359 | set_pmd_at(mm, addr, pmd, orig_pmd) |
360 | tlb_remove_pmd_tlb_entry(tlb, pmd, addr) |
363 | ClearPageReferenced(page) |
365 | If pageout Then |
374 | huge_unlock : |
375 | spin_unlock(ptl) |
376 | If pageout Then reclaim_pages( & page_list) |
378 | Return 0 |
381 | If This is a noop if Transparent Hugepage Support is not built into* the kernel Then Return 0 |
383 | regular_page : |
385 | tlb_change_page_size(tlb, PAGE_SIZE) |
386 | orig_pte = pte = pte_offset_map_lock(The address space we belong to. , pmd, addr, & ptl) |
395 | If Not pte_present(ptent) Then Continue |
399 | If Not page Then Continue |
407 | If page_mapcount(page) != 1 Then Break |
410 | If Not Return true if the page was successfully locked Then |
414 | pte_unmap_unlock(orig_pte, ptl) |
415 | If split_huge_page(page) Then |
418 | pte_offset_map_lock(mm, pmd, addr, & ptl) |
419 | Break |
424 | pte-- |
426 | Continue |
429 | VM_BUG_ON_PAGE(PageTransCompound returns true for both transparent huge pages* and hugetlbfs pages, so it should only be called when it's known* that hugetlbfs pages aren't involved., page) |
432 | ptent = ptep_get_and_clear_full(mm, addr, pte, we are in the middle of an operation to clear* a full mm and can make some optimizations) |
435 | set_pte_at(mm, addr, pte, ptent) |
445 | ClearPageReferenced(page) |
447 | If pageout Then |
458 | arch_leave_lazy_mmu_mode() |
459 | pte_unmap_unlock(orig_pte, ptl) |
460 | If pageout Then reclaim_pages( & page_list) |
462 | cond_resched() |
464 | Return 0 |
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 |