Browse Source

arm64: Move unflatten_device_tree() call earlier.

In order to extract NUMA information from the device tree, we need to
have the tree in its unflattened form.

Move the call to bootmem_init() in the tail of paging_init() into
setup_arch, and adjust header files so that its declaration is
visible.

Move the unflatten_device_tree() call between the calls to
paging_init() and bootmem_init().  Follow on patches add NUMA handling
to bootmem_init().

Signed-off-by: David Daney <david.daney@cavium.com>
Signed-off-by: Will Deacon <will.deacon@arm.com>
David Daney 9 years ago
parent
commit
3194ac6e66
4 changed files with 9 additions and 7 deletions
  1. 1 0
      arch/arm64/include/asm/mmu.h
  2. 8 4
      arch/arm64/kernel/setup.c
  3. 0 1
      arch/arm64/mm/mm.h
  4. 0 2
      arch/arm64/mm/mmu.c

+ 1 - 0
arch/arm64/include/asm/mmu.h

@@ -29,6 +29,7 @@ typedef struct {
 #define ASID(mm)	((mm)->context.id.counter & 0xffff)
 #define ASID(mm)	((mm)->context.id.counter & 0xffff)
 
 
 extern void paging_init(void);
 extern void paging_init(void);
+extern void bootmem_init(void);
 extern void __iomem *early_io_map(phys_addr_t phys, unsigned long virt);
 extern void __iomem *early_io_map(phys_addr_t phys, unsigned long virt);
 extern void init_mem_pgprot(void);
 extern void init_mem_pgprot(void);
 extern void create_pgd_mapping(struct mm_struct *mm, phys_addr_t phys,
 extern void create_pgd_mapping(struct mm_struct *mm, phys_addr_t phys,

+ 8 - 4
arch/arm64/kernel/setup.c

@@ -265,18 +265,22 @@ void __init setup_arch(char **cmdline_p)
 
 
 	paging_init();
 	paging_init();
 
 
+	if (acpi_disabled)
+		unflatten_device_tree();
+
+	bootmem_init();
+
 	kasan_init();
 	kasan_init();
 
 
 	request_standard_resources();
 	request_standard_resources();
 
 
 	early_ioremap_reset();
 	early_ioremap_reset();
 
 
-	if (acpi_disabled) {
-		unflatten_device_tree();
+	if (acpi_disabled)
 		psci_dt_init();
 		psci_dt_init();
-	} else {
+	else
 		psci_acpi_init();
 		psci_acpi_init();
-	}
+
 	xen_early_init();
 	xen_early_init();
 
 
 	cpu_read_bootcpu_ops();
 	cpu_read_bootcpu_ops();

+ 0 - 1
arch/arm64/mm/mm.h

@@ -1,3 +1,2 @@
-extern void __init bootmem_init(void);
 
 
 void fixup_init(void);
 void fixup_init(void);

+ 0 - 2
arch/arm64/mm/mmu.c

@@ -564,8 +564,6 @@ void __init paging_init(void)
 	 */
 	 */
 	memblock_free(__pa(swapper_pg_dir) + PAGE_SIZE,
 	memblock_free(__pa(swapper_pg_dir) + PAGE_SIZE,
 		      SWAPPER_DIR_SIZE - PAGE_SIZE);
 		      SWAPPER_DIR_SIZE - PAGE_SIZE);
-
-	bootmem_init();
 }
 }
 
 
 /*
 /*