Lines Matching refs:region
492 static void store_slot_info(struct mem_vector *region, unsigned long image_size) in store_slot_info() argument
499 slot_area.addr = region->start; in store_slot_info()
500 slot_area.num = 1 + (region->size - image_size) / CONFIG_PHYSICAL_ALIGN; in store_slot_info()
511 process_gb_huge_pages(struct mem_vector *region, unsigned long image_size) in process_gb_huge_pages() argument
518 store_slot_info(region, image_size); in process_gb_huge_pages()
523 pud_start = ALIGN(region->start, PUD_SIZE); in process_gb_huge_pages()
524 pud_end = ALIGN_DOWN(region->start + region->size, PUD_SIZE); in process_gb_huge_pages()
528 store_slot_info(region, image_size); in process_gb_huge_pages()
533 if (pud_start >= region->start + image_size) { in process_gb_huge_pages()
534 tmp.start = region->start; in process_gb_huge_pages()
535 tmp.size = pud_start - region->start; in process_gb_huge_pages()
549 if (region->start + region->size >= pud_end + image_size) { in process_gb_huge_pages()
551 tmp.size = region->start + region->size - pud_end; in process_gb_huge_pages()
584 struct mem_vector region, overlap; in __process_mem_region() local
588 region.start = max_t(u64, entry->start, minimum); in __process_mem_region()
594 region.start = ALIGN(region.start, CONFIG_PHYSICAL_ALIGN); in __process_mem_region()
597 if (region.start > region_end) in __process_mem_region()
601 region.size = region_end - region.start; in __process_mem_region()
604 if (region.size < image_size) in __process_mem_region()
608 if (!mem_avoid_overlap(®ion, &overlap)) { in __process_mem_region()
609 process_gb_huge_pages(®ion, image_size); in __process_mem_region()
614 if (overlap.start >= region.start + image_size) { in __process_mem_region()
615 region.size = overlap.start - region.start; in __process_mem_region()
616 process_gb_huge_pages(®ion, image_size); in __process_mem_region()
620 region.start = overlap.start + overlap.size; in __process_mem_region()
624 static bool process_mem_region(struct mem_vector *region, in process_mem_region() argument
634 __process_mem_region(region, minimum, image_size); in process_mem_region()
652 if (!mem_overlaps(region, &immovable_mem[i])) in process_mem_region()
657 region_end = region->start + region->size; in process_mem_region()
659 entry.start = clamp(region->start, start, end); in process_mem_region()
684 struct mem_vector region; in process_efi_entries() local
741 region.start = md->phys_addr; in process_efi_entries()
742 region.size = md->num_pages << EFI_PAGE_SHIFT; in process_efi_entries()
743 if (process_mem_region(®ion, minimum, image_size)) in process_efi_entries()
760 struct mem_vector region; in process_e820_entries() local
769 region.start = entry->addr; in process_e820_entries()
770 region.size = entry->size; in process_e820_entries()
771 if (process_mem_region(®ion, minimum, image_size)) in process_e820_entries()