Lines Matching refs:mm
86 static int slice_area_is_free(struct mm_struct *mm, unsigned long addr, in slice_area_is_free() argument
91 if ((mm_ctx_slb_addr_limit(&mm->context) - len) < addr) in slice_area_is_free()
93 vma = find_vma(mm, addr); in slice_area_is_free()
97 static int slice_low_has_vma(struct mm_struct *mm, unsigned long slice) in slice_low_has_vma() argument
99 return !slice_area_is_free(mm, slice << SLICE_LOW_SHIFT, in slice_low_has_vma()
103 static int slice_high_has_vma(struct mm_struct *mm, unsigned long slice) in slice_high_has_vma() argument
114 return !slice_area_is_free(mm, start, end - start); in slice_high_has_vma()
117 static void slice_mask_for_free(struct mm_struct *mm, struct slice_mask *ret, in slice_mask_for_free() argument
127 if (!slice_low_has_vma(mm, i)) in slice_mask_for_free()
134 if (!slice_high_has_vma(mm, i)) in slice_mask_for_free()
138 static bool slice_check_range_fits(struct mm_struct *mm, in slice_check_range_fits() argument
173 struct mm_struct *mm = parm; in slice_flush_segments() local
176 if (mm != current->active_mm) in slice_flush_segments()
187 static void slice_convert(struct mm_struct *mm, in slice_convert() argument
197 slice_dbg("slice_convert(mm=%p, psize=%d)\n", mm, psize); in slice_convert()
200 psize_mask = slice_mask_for_size(&mm->context, psize); in slice_convert()
207 lpsizes = mm_ctx_low_slices(&mm->context); in slice_convert()
217 old_mask = slice_mask_for_size(&mm->context, old_psize); in slice_convert()
226 hpsizes = mm_ctx_high_slices(&mm->context); in slice_convert()
227 for (i = 0; i < GET_HIGH_SLICE_INDEX(mm_ctx_slb_addr_limit(&mm->context)); i++) { in slice_convert()
236 old_mask = slice_mask_for_size(&mm->context, old_psize); in slice_convert()
246 (unsigned long)mm_ctx_low_slices(&mm->context), in slice_convert()
247 (unsigned long)mm_ctx_high_slices(&mm->context)); in slice_convert()
251 copro_flush_all_slbs(mm); in slice_convert()
278 static unsigned long slice_find_area_bottomup(struct mm_struct *mm, in slice_find_area_bottomup() argument
324 static unsigned long slice_find_area_topdown(struct mm_struct *mm, in slice_find_area_topdown() argument
339 addr = mm->mmap_base; in slice_find_area_topdown()
347 addr += mm_ctx_slb_addr_limit(&mm->context) - DEFAULT_MAP_WINDOW; in slice_find_area_topdown()
380 return slice_find_area_bottomup(mm, len, available, psize, high_limit); in slice_find_area_topdown()
384 static unsigned long slice_find_area(struct mm_struct *mm, unsigned long len, in slice_find_area() argument
389 return slice_find_area_topdown(mm, len, mask, psize, high_limit); in slice_find_area()
391 return slice_find_area_bottomup(mm, len, mask, psize, high_limit); in slice_find_area()
440 struct mm_struct *mm = current->mm; in slice_get_unmapped_area() local
459 if (high_limit > mm_ctx_slb_addr_limit(&mm->context)) { in slice_get_unmapped_area()
465 mm_ctx_set_slb_addr_limit(&mm->context, high_limit); in slice_get_unmapped_area()
467 on_each_cpu(slice_flush_segments, mm, 1); in slice_get_unmapped_area()
471 BUG_ON(mm->task_size == 0); in slice_get_unmapped_area()
472 BUG_ON(mm_ctx_slb_addr_limit(&mm->context) == 0); in slice_get_unmapped_area()
475 slice_dbg("slice_get_unmapped_area(mm=%p, psize=%d...\n", mm, psize); in slice_get_unmapped_area()
485 !slice_area_is_free(mm, addr, len)) in slice_get_unmapped_area()
492 maskp = slice_mask_for_size(&mm->context, psize); in slice_get_unmapped_area()
519 compat_maskp = slice_mask_for_size(&mm->context, MMU_PAGE_4K); in slice_get_unmapped_area()
537 if (slice_check_range_fits(mm, &good_mask, addr, len)) { in slice_get_unmapped_area()
546 newaddr = slice_find_area(mm, len, &good_mask, in slice_get_unmapped_area()
560 slice_mask_for_free(mm, &potential_mask, high_limit); in slice_get_unmapped_area()
565 if (slice_check_range_fits(mm, &potential_mask, addr, len)) { in slice_get_unmapped_area()
582 newaddr = slice_find_area(mm, len, &good_mask, in slice_get_unmapped_area()
593 newaddr = slice_find_area(mm, len, &potential_mask, in slice_get_unmapped_area()
600 newaddr = slice_find_area(mm, len, &potential_mask, in slice_get_unmapped_area()
616 if (need_extra_context(mm, newaddr)) { in slice_get_unmapped_area()
617 if (alloc_extended_context(mm, newaddr) < 0) in slice_get_unmapped_area()
627 slice_convert(mm, &potential_mask, psize); in slice_get_unmapped_area()
629 on_each_cpu(slice_flush_segments, mm, 1); in slice_get_unmapped_area()
634 if (need_extra_context(mm, newaddr)) { in slice_get_unmapped_area()
635 if (alloc_extended_context(mm, newaddr) < 0) in slice_get_unmapped_area()
649 mm_ctx_user_psize(¤t->mm->context), 0); in arch_get_unmapped_area()
659 mm_ctx_user_psize(¤t->mm->context), 1); in arch_get_unmapped_area_topdown()
662 unsigned int notrace get_slice_psize(struct mm_struct *mm, unsigned long addr) in get_slice_psize() argument
670 psizes = mm_ctx_low_slices(&mm->context); in get_slice_psize()
673 psizes = mm_ctx_high_slices(&mm->context); in get_slice_psize()
681 void slice_init_new_context_exec(struct mm_struct *mm) in slice_init_new_context_exec() argument
687 slice_dbg("slice_init_new_context_exec(mm=%p)\n", mm); in slice_init_new_context_exec()
694 mm_ctx_set_slb_addr_limit(&mm->context, SLB_ADDR_LIMIT_DEFAULT); in slice_init_new_context_exec()
695 mm_ctx_set_user_psize(&mm->context, psize); in slice_init_new_context_exec()
700 lpsizes = mm_ctx_low_slices(&mm->context); in slice_init_new_context_exec()
703 hpsizes = mm_ctx_high_slices(&mm->context); in slice_init_new_context_exec()
709 mask = slice_mask_for_size(&mm->context, psize); in slice_init_new_context_exec()
718 struct mm_struct *mm = current->mm; in slice_setup_new_exec() local
720 slice_dbg("slice_setup_new_exec(mm=%p)\n", mm); in slice_setup_new_exec()
725 mm_ctx_set_slb_addr_limit(&mm->context, DEFAULT_MAP_WINDOW); in slice_setup_new_exec()
729 void slice_set_range_psize(struct mm_struct *mm, unsigned long start, in slice_set_range_psize() argument
737 slice_convert(mm, &mask, psize); in slice_set_range_psize()
760 int slice_is_hugepage_only_range(struct mm_struct *mm, unsigned long addr, in slice_is_hugepage_only_range() argument
764 unsigned int psize = mm_ctx_user_psize(&mm->context); in slice_is_hugepage_only_range()
768 maskp = slice_mask_for_size(&mm->context, psize); in slice_is_hugepage_only_range()
775 compat_maskp = slice_mask_for_size(&mm->context, MMU_PAGE_4K); in slice_is_hugepage_only_range()
777 return !slice_check_range_fits(mm, &available, addr, len); in slice_is_hugepage_only_range()
780 return !slice_check_range_fits(mm, maskp, addr, len); in slice_is_hugepage_only_range()