| Function report | 
| Source Code: mm\huge_memory.c | Create Date:2022-07-28 16:02:06 | 
| Last Modify:2020-03-12 14:18:49 | Copyright©Brick | 
| home page | Tree | 
| Annotation kernel can get tool activity | Download SCCT | Chinese | 
Name:Return true if we do MADV_FREE successfully on entire pmd page.* Otherwise, return false.
Proto:bool madvise_free_huge_pmd(struct mmu_gather *tlb, struct vm_area_struct *vma, pmd_t *pmd, unsigned long addr, unsigned long next)
Type:bool
Parameter:
| Type | Parameter | Name | 
|---|---|---|
| struct mmu_gather * | tlb | |
| struct vm_area_struct * | vma | |
| pmd_t * | pmd | |
| unsigned long | addr | |
| unsigned long | next | 
| 1702 | bool ret = false | 
| 1707 | If Not ptl Then Go to out_unlocked | 
| 1711 | If is_huge_zero_pmd(orig_pmd) Then Go to out | 
| 1715 | VM_BUG_ON(thp_migration_supported() && !is_pmd_migration_entry(orig_pmd)) | 
| 1717 | Go to out | 
| 1720 | page = Currently stuck as a macro due to indirect forward reference to* linux/mmzone.h's __section_mem_map_addr() definition:(orig_pmd) | 
| 1725 | If page_mapcount(page) != 1 Then Go to out | 
| 1728 | If Not Return true if the page was successfully locked Then Go to out | 
| 1735 | If next - addr != HPAGE_PMD_SIZE Then | 
| 1744 | If PageDirty(page) Then ClearPageDirty(page) | 
| 1749 | pmdp_invalidate(vma, addr, pmd) | 
| 1751 | orig_pmd = pmd_mkclean(orig_pmd) | 
| 1753 | set_pmd_at(mm, addr, pmd, orig_pmd) | 
| 1754 | tlb_remove_pmd_tlb_entry(tlb, pmd, addr) | 
| 1758 | ret = true | 
| 1759 | out : | 
| 1760 | spin_unlock(ptl) | 
| 1761 | out_unlocked : | 
| 1762 | Return ret | 
| Name | Describe | 
|---|---|
| madvise_free_pte_range | 
| 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 |