On Thu 14-12-17 16:44:26, Anshuman Khandual wrote:
> diff --git a/mm/mprotect.c b/mm/mprotect.c
> index ec39f73..43c29fa 100644
> --- a/mm/mprotect.c
> +++ b/mm/mprotect.c
> @@ -196,6 +196,7 @@ static inline unsigned long change_pmd_range(struct 
> vm_area_struct *vma,
>               this_pages = change_pte_range(vma, pmd, addr, next, newprot,
>                                dirty_accountable, prot_numa);
>               pages += this_pages;
> +             cond_resched();
>       } while (pmd++, addr = next, addr != end);
>  
>       if (mni_start)

this is not exactly what I meant. See how change_huge_pmd does continue.
That's why I mentioned zap_pmd_range which does goto next...
-- 
Michal Hocko
SUSE Labs

Reply via email to