Commit 6ad5f024 authored by Vasily Gorbik's avatar Vasily Gorbik Committed by Heiko Carstens

s390/setup: re-arrange memblock setup

- Avoid using ULONG_MAX in memblock_remove, it has no functional change
  but makes memblock_dbg output a range which makes sense.

- Actually finish memblock memory setup before doing amode31/cr/uv
  setup.

- Move memblock_dump_all() debug output after memblock memory setup is
  complete. This gives us final "memory" regions if they were trimmed
  due to addressing limits and still "physmem" regions as original info
  which came from mem_detect.
Reviewed-by: default avatarHeiko Carstens <hca@linux.ibm.com>
Signed-off-by: default avatarVasily Gorbik <gor@linux.ibm.com>
Signed-off-by: default avatarHeiko Carstens <hca@linux.ibm.com>
parent 5dbc4cb4
...@@ -606,7 +606,7 @@ static void __init setup_resources(void) ...@@ -606,7 +606,7 @@ static void __init setup_resources(void)
static void __init setup_memory_end(void) static void __init setup_memory_end(void)
{ {
memblock_remove(ident_map_size, ULONG_MAX); memblock_remove(ident_map_size, PHYS_ADDR_MAX - ident_map_size);
max_pfn = max_low_pfn = PFN_DOWN(ident_map_size); max_pfn = max_low_pfn = PFN_DOWN(ident_map_size);
pr_notice("The maximum memory size is %luMB\n", ident_map_size >> 20); pr_notice("The maximum memory size is %luMB\n", ident_map_size >> 20);
} }
...@@ -777,7 +777,6 @@ static void __init memblock_add_mem_detect_info(void) ...@@ -777,7 +777,6 @@ static void __init memblock_add_mem_detect_info(void)
} }
memblock_set_bottom_up(false); memblock_set_bottom_up(false);
memblock_set_node(0, ULONG_MAX, &memblock.memory, 0); memblock_set_node(0, ULONG_MAX, &memblock.memory, 0);
memblock_dump_all();
} }
/* /*
...@@ -999,13 +998,13 @@ void __init setup_arch(char **cmdline_p) ...@@ -999,13 +998,13 @@ void __init setup_arch(char **cmdline_p)
memblock_add_mem_detect_info(); memblock_add_mem_detect_info();
free_mem_detect_info(); free_mem_detect_info();
setup_memory_end();
memblock_dump_all();
setup_memory();
relocate_amode31_section(); relocate_amode31_section();
setup_cr(); setup_cr();
setup_uv(); setup_uv();
setup_memory_end();
setup_memory();
dma_contiguous_reserve(ident_map_size); dma_contiguous_reserve(ident_map_size);
vmcp_cma_reserve(); vmcp_cma_reserve();
if (MACHINE_HAS_EDAT2) if (MACHINE_HAS_EDAT2)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment