Lines Matching refs:mr

327 static int __meminit save_mr(struct map_range *mr, int nr_range,  in save_mr()  argument
334 mr[nr_range].start = start_pfn<<PAGE_SHIFT; in save_mr()
335 mr[nr_range].end = end_pfn<<PAGE_SHIFT; in save_mr()
336 mr[nr_range].page_size_mask = page_size_mask; in save_mr()
347 static void __ref adjust_range_page_size_mask(struct map_range *mr, in adjust_range_page_size_mask() argument
354 !(mr[i].page_size_mask & (1<<PG_LEVEL_2M))) { in adjust_range_page_size_mask()
355 unsigned long start = round_down(mr[i].start, PMD_SIZE); in adjust_range_page_size_mask()
356 unsigned long end = round_up(mr[i].end, PMD_SIZE); in adjust_range_page_size_mask()
364 mr[i].page_size_mask |= 1<<PG_LEVEL_2M; in adjust_range_page_size_mask()
367 !(mr[i].page_size_mask & (1<<PG_LEVEL_1G))) { in adjust_range_page_size_mask()
368 unsigned long start = round_down(mr[i].start, PUD_SIZE); in adjust_range_page_size_mask()
369 unsigned long end = round_up(mr[i].end, PUD_SIZE); in adjust_range_page_size_mask()
372 mr[i].page_size_mask |= 1<<PG_LEVEL_1G; in adjust_range_page_size_mask()
377 static const char *page_size_string(struct map_range *mr) in page_size_string() argument
384 if (mr->page_size_mask & (1<<PG_LEVEL_1G)) in page_size_string()
393 mr->page_size_mask & (1<<PG_LEVEL_2M)) in page_size_string()
396 if (mr->page_size_mask & (1<<PG_LEVEL_2M)) in page_size_string()
402 static int __meminit split_mem_range(struct map_range *mr, int nr_range, in split_mem_range() argument
431 nr_range = save_mr(mr, nr_range, start_pfn, end_pfn, 0); in split_mem_range()
446 nr_range = save_mr(mr, nr_range, start_pfn, end_pfn, in split_mem_range()
456 nr_range = save_mr(mr, nr_range, start_pfn, end_pfn, in split_mem_range()
466 nr_range = save_mr(mr, nr_range, start_pfn, end_pfn, in split_mem_range()
475 nr_range = save_mr(mr, nr_range, start_pfn, end_pfn, 0); in split_mem_range()
478 adjust_range_page_size_mask(mr, nr_range); in split_mem_range()
483 if (mr[i].end != mr[i+1].start || in split_mem_range()
484 mr[i].page_size_mask != mr[i+1].page_size_mask) in split_mem_range()
487 old_start = mr[i].start; in split_mem_range()
488 memmove(&mr[i], &mr[i+1], in split_mem_range()
490 mr[i--].start = old_start; in split_mem_range()
496 mr[i].start, mr[i].end - 1, in split_mem_range()
497 page_size_string(&mr[i])); in split_mem_range()
538 struct map_range mr[NR_RANGE_MR]; in init_memory_mapping() local
545 memset(mr, 0, sizeof(mr)); in init_memory_mapping()
546 nr_range = split_mem_range(mr, 0, start, end); in init_memory_mapping()
549 ret = kernel_physical_mapping_init(mr[i].start, mr[i].end, in init_memory_mapping()
550 mr[i].page_size_mask, in init_memory_mapping()