of/flattree: merge early_init_dt_scan_memory() common code
Merge common code between PowerPC and Microblaze architectures. Signed-off-by: Grant Likely <grant.likely@secretlab.ca> Acked-by: Michal Simek <monstr@monstr.eu>
This commit is contained in:
parent
71a157e8ed
commit
51975db0b7
|
@ -45,61 +45,14 @@
|
||||||
/* export that to outside world */
|
/* export that to outside world */
|
||||||
struct device_node *of_chosen;
|
struct device_node *of_chosen;
|
||||||
|
|
||||||
#define early_init_dt_scan_drconf_memory(node) 0
|
|
||||||
|
|
||||||
void __init early_init_dt_scan_chosen_arch(unsigned long node)
|
void __init early_init_dt_scan_chosen_arch(unsigned long node)
|
||||||
{
|
{
|
||||||
/* No Microblaze specific code here */
|
/* No Microblaze specific code here */
|
||||||
}
|
}
|
||||||
|
|
||||||
static int __init early_init_dt_scan_memory(unsigned long node,
|
void __init early_init_dt_add_memory_arch(u64 base, u64 size)
|
||||||
const char *uname, int depth, void *data)
|
|
||||||
{
|
{
|
||||||
char *type = of_get_flat_dt_prop(node, "device_type", NULL);
|
lmb_add(base, size);
|
||||||
__be32 *reg, *endp;
|
|
||||||
unsigned long l;
|
|
||||||
|
|
||||||
/* Look for the ibm,dynamic-reconfiguration-memory node */
|
|
||||||
/* if (depth == 1 &&
|
|
||||||
strcmp(uname, "ibm,dynamic-reconfiguration-memory") == 0)
|
|
||||||
return early_init_dt_scan_drconf_memory(node);
|
|
||||||
*/
|
|
||||||
/* We are scanning "memory" nodes only */
|
|
||||||
if (type == NULL) {
|
|
||||||
/*
|
|
||||||
* The longtrail doesn't have a device_type on the
|
|
||||||
* /memory node, so look for the node called /memory@0.
|
|
||||||
*/
|
|
||||||
if (depth != 1 || strcmp(uname, "memory@0") != 0)
|
|
||||||
return 0;
|
|
||||||
} else if (strcmp(type, "memory") != 0)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
reg = (__be32 *)of_get_flat_dt_prop(node, "linux,usable-memory", &l);
|
|
||||||
if (reg == NULL)
|
|
||||||
reg = (__be32 *)of_get_flat_dt_prop(node, "reg", &l);
|
|
||||||
if (reg == NULL)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
endp = reg + (l / sizeof(__be32));
|
|
||||||
|
|
||||||
pr_debug("memory scan node %s, reg size %ld, data: %x %x %x %x,\n",
|
|
||||||
uname, l, reg[0], reg[1], reg[2], reg[3]);
|
|
||||||
|
|
||||||
while ((endp - reg) >= (dt_root_addr_cells + dt_root_size_cells)) {
|
|
||||||
u64 base, size;
|
|
||||||
|
|
||||||
base = dt_mem_next_cell(dt_root_addr_cells, ®);
|
|
||||||
size = dt_mem_next_cell(dt_root_size_cells, ®);
|
|
||||||
|
|
||||||
if (size == 0)
|
|
||||||
continue;
|
|
||||||
pr_debug(" - %llx , %llx\n", (unsigned long long)base,
|
|
||||||
(unsigned long long)size);
|
|
||||||
|
|
||||||
lmb_add(base, size);
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef CONFIG_EARLY_PRINTK
|
#ifdef CONFIG_EARLY_PRINTK
|
||||||
|
|
|
@ -483,64 +483,31 @@ static int __init early_init_dt_scan_drconf_memory(unsigned long node)
|
||||||
#define early_init_dt_scan_drconf_memory(node) 0
|
#define early_init_dt_scan_drconf_memory(node) 0
|
||||||
#endif /* CONFIG_PPC_PSERIES */
|
#endif /* CONFIG_PPC_PSERIES */
|
||||||
|
|
||||||
static int __init early_init_dt_scan_memory(unsigned long node,
|
static int __init early_init_dt_scan_memory_ppc(unsigned long node,
|
||||||
const char *uname, int depth, void *data)
|
const char *uname,
|
||||||
|
int depth, void *data)
|
||||||
{
|
{
|
||||||
char *type = of_get_flat_dt_prop(node, "device_type", NULL);
|
|
||||||
__be32 *reg, *endp;
|
|
||||||
unsigned long l;
|
|
||||||
|
|
||||||
/* Look for the ibm,dynamic-reconfiguration-memory node */
|
|
||||||
if (depth == 1 &&
|
if (depth == 1 &&
|
||||||
strcmp(uname, "ibm,dynamic-reconfiguration-memory") == 0)
|
strcmp(uname, "ibm,dynamic-reconfiguration-memory") == 0)
|
||||||
return early_init_dt_scan_drconf_memory(node);
|
return early_init_dt_scan_drconf_memory(node);
|
||||||
|
|
||||||
|
return early_init_dt_scan_memory(node, uname, depth, data);
|
||||||
|
}
|
||||||
|
|
||||||
/* We are scanning "memory" nodes only */
|
void __init early_init_dt_add_memory_arch(u64 base, u64 size)
|
||||||
if (type == NULL) {
|
{
|
||||||
/*
|
#if defined(CONFIG_PPC64)
|
||||||
* The longtrail doesn't have a device_type on the
|
if (iommu_is_off) {
|
||||||
* /memory node, so look for the node called /memory@0.
|
if (base >= 0x80000000ul)
|
||||||
*/
|
return;
|
||||||
if (depth != 1 || strcmp(uname, "memory@0") != 0)
|
if ((base + size) > 0x80000000ul)
|
||||||
return 0;
|
size = 0x80000000ul - base;
|
||||||
} else if (strcmp(type, "memory") != 0)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
reg = of_get_flat_dt_prop(node, "linux,usable-memory", &l);
|
|
||||||
if (reg == NULL)
|
|
||||||
reg = of_get_flat_dt_prop(node, "reg", &l);
|
|
||||||
if (reg == NULL)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
endp = reg + (l / sizeof(__be32));
|
|
||||||
|
|
||||||
DBG("memory scan node %s, reg size %ld, data: %x %x %x %x,\n",
|
|
||||||
uname, l, reg[0], reg[1], reg[2], reg[3]);
|
|
||||||
|
|
||||||
while ((endp - reg) >= (dt_root_addr_cells + dt_root_size_cells)) {
|
|
||||||
u64 base, size;
|
|
||||||
|
|
||||||
base = dt_mem_next_cell(dt_root_addr_cells, ®);
|
|
||||||
size = dt_mem_next_cell(dt_root_size_cells, ®);
|
|
||||||
|
|
||||||
if (size == 0)
|
|
||||||
continue;
|
|
||||||
DBG(" - %llx , %llx\n", (unsigned long long)base,
|
|
||||||
(unsigned long long)size);
|
|
||||||
#ifdef CONFIG_PPC64
|
|
||||||
if (iommu_is_off) {
|
|
||||||
if (base >= 0x80000000ul)
|
|
||||||
continue;
|
|
||||||
if ((base + size) > 0x80000000ul)
|
|
||||||
size = 0x80000000ul - base;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
lmb_add(base, size);
|
|
||||||
|
|
||||||
memstart_addr = min((u64)memstart_addr, base);
|
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
return 0;
|
lmb_add(base, size);
|
||||||
|
|
||||||
|
memstart_addr = min((u64)memstart_addr, base);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void __init early_reserve_mem(void)
|
static void __init early_reserve_mem(void)
|
||||||
|
@ -706,7 +673,7 @@ void __init early_init_devtree(void *params)
|
||||||
/* Scan memory nodes and rebuild LMBs */
|
/* Scan memory nodes and rebuild LMBs */
|
||||||
lmb_init();
|
lmb_init();
|
||||||
of_scan_flat_dt(early_init_dt_scan_root, NULL);
|
of_scan_flat_dt(early_init_dt_scan_root, NULL);
|
||||||
of_scan_flat_dt(early_init_dt_scan_memory, NULL);
|
of_scan_flat_dt(early_init_dt_scan_memory_ppc, NULL);
|
||||||
|
|
||||||
/* Save command line for /proc/cmdline and then parse parameters */
|
/* Save command line for /proc/cmdline and then parse parameters */
|
||||||
strlcpy(boot_command_line, cmd_line, COMMAND_LINE_SIZE);
|
strlcpy(boot_command_line, cmd_line, COMMAND_LINE_SIZE);
|
||||||
|
|
|
@ -15,6 +15,7 @@
|
||||||
#include <linux/of.h>
|
#include <linux/of.h>
|
||||||
#include <linux/of_fdt.h>
|
#include <linux/of_fdt.h>
|
||||||
|
|
||||||
|
|
||||||
#ifdef CONFIG_PPC
|
#ifdef CONFIG_PPC
|
||||||
#include <asm/machdep.h>
|
#include <asm/machdep.h>
|
||||||
#endif /* CONFIG_PPC */
|
#endif /* CONFIG_PPC */
|
||||||
|
@ -443,6 +444,55 @@ u64 __init dt_mem_next_cell(int s, u32 **cellp)
|
||||||
return of_read_number(p, s);
|
return of_read_number(p, s);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* early_init_dt_scan_memory - Look for an parse memory nodes
|
||||||
|
*/
|
||||||
|
int __init early_init_dt_scan_memory(unsigned long node, const char *uname,
|
||||||
|
int depth, void *data)
|
||||||
|
{
|
||||||
|
char *type = of_get_flat_dt_prop(node, "device_type", NULL);
|
||||||
|
__be32 *reg, *endp;
|
||||||
|
unsigned long l;
|
||||||
|
|
||||||
|
/* We are scanning "memory" nodes only */
|
||||||
|
if (type == NULL) {
|
||||||
|
/*
|
||||||
|
* The longtrail doesn't have a device_type on the
|
||||||
|
* /memory node, so look for the node called /memory@0.
|
||||||
|
*/
|
||||||
|
if (depth != 1 || strcmp(uname, "memory@0") != 0)
|
||||||
|
return 0;
|
||||||
|
} else if (strcmp(type, "memory") != 0)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
reg = of_get_flat_dt_prop(node, "linux,usable-memory", &l);
|
||||||
|
if (reg == NULL)
|
||||||
|
reg = of_get_flat_dt_prop(node, "reg", &l);
|
||||||
|
if (reg == NULL)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
endp = reg + (l / sizeof(__be32));
|
||||||
|
|
||||||
|
pr_debug("memory scan node %s, reg size %ld, data: %x %x %x %x,\n",
|
||||||
|
uname, l, reg[0], reg[1], reg[2], reg[3]);
|
||||||
|
|
||||||
|
while ((endp - reg) >= (dt_root_addr_cells + dt_root_size_cells)) {
|
||||||
|
u64 base, size;
|
||||||
|
|
||||||
|
base = dt_mem_next_cell(dt_root_addr_cells, ®);
|
||||||
|
size = dt_mem_next_cell(dt_root_size_cells, ®);
|
||||||
|
|
||||||
|
if (size == 0)
|
||||||
|
continue;
|
||||||
|
pr_debug(" - %llx , %llx\n", (unsigned long long)base,
|
||||||
|
(unsigned long long)size);
|
||||||
|
|
||||||
|
early_init_dt_add_memory_arch(base, size);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
int __init early_init_dt_scan_chosen(unsigned long node, const char *uname,
|
int __init early_init_dt_scan_chosen(unsigned long node, const char *uname,
|
||||||
int depth, void *data)
|
int depth, void *data)
|
||||||
{
|
{
|
||||||
|
|
|
@ -75,6 +75,9 @@ extern void early_init_dt_scan_chosen_arch(unsigned long node);
|
||||||
extern int early_init_dt_scan_chosen(unsigned long node, const char *uname,
|
extern int early_init_dt_scan_chosen(unsigned long node, const char *uname,
|
||||||
int depth, void *data);
|
int depth, void *data);
|
||||||
extern void early_init_dt_check_for_initrd(unsigned long node);
|
extern void early_init_dt_check_for_initrd(unsigned long node);
|
||||||
|
extern int early_init_dt_scan_memory(unsigned long node, const char *uname,
|
||||||
|
int depth, void *data);
|
||||||
|
extern void early_init_dt_add_memory_arch(u64 base, u64 size);
|
||||||
extern u64 dt_mem_next_cell(int s, u32 **cellp);
|
extern u64 dt_mem_next_cell(int s, u32 **cellp);
|
||||||
|
|
||||||
/* Early flat tree scan hooks */
|
/* Early flat tree scan hooks */
|
||||||
|
|
Loading…
Reference in New Issue