of.c 2.3 KB
Newer Older
J
John Crispin 已提交
1 2 3 4 5 6 7
/*
 * This program is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License version 2 as published
 * by the Free Software Foundation.
 *
 * Copyright (C) 2008 Imre Kaloz <kaloz@openwrt.org>
 * Copyright (C) 2008-2009 Gabor Juhos <juhosg@openwrt.org>
J
John Crispin 已提交
8
 * Copyright (C) 2013 John Crispin <john@phrozen.org>
J
John Crispin 已提交
9 10 11 12 13
 */

#include <linux/io.h>
#include <linux/clk.h>
#include <linux/init.h>
14
#include <linux/sizes.h>
J
John Crispin 已提交
15 16 17 18 19 20 21 22 23
#include <linux/of_fdt.h>
#include <linux/kernel.h>
#include <linux/bootmem.h>
#include <linux/of_platform.h>
#include <linux/of_address.h>

#include <asm/reboot.h>
#include <asm/bootinfo.h>
#include <asm/addrspace.h>
24
#include <asm/prom.h>
J
John Crispin 已提交
25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52

#include "common.h"

__iomem void *rt_sysc_membase;
__iomem void *rt_memc_membase;

__iomem void *plat_of_remap_node(const char *node)
{
	struct resource res;
	struct device_node *np;

	np = of_find_compatible_node(NULL, NULL, node);
	if (!np)
		panic("Failed to find %s node", node);

	if (of_address_to_resource(np, 0, &res))
		panic("Failed to get resource for %s", node);

	if ((request_mem_region(res.start,
				resource_size(&res),
				res.name) < 0))
		panic("Failed to request resources for %s", node);

	return ioremap_nocache(res.start, resource_size(&res));
}

void __init device_tree_init(void)
{
53
	unflatten_and_copy_device_tree();
J
John Crispin 已提交
54 55
}

56 57 58 59 60 61 62 63 64 65 66
static int memory_dtb;

static int __init early_init_dt_find_memory(unsigned long node,
				const char *uname, int depth, void *data)
{
	if (depth == 1 && !strcmp(uname, "memory@0"))
		memory_dtb = 1;

	return 0;
}

J
John Crispin 已提交
67 68 69 70 71 72 73 74
void __init plat_mem_setup(void)
{
	set_io_port_base(KSEG1);

	/*
	 * Load the builtin devicetree. This causes the chosen node to be
	 * parsed resulting in our memory appearing
	 */
75
	__dt_setup_arch(__dtb_start);
76

77 78 79 80
	of_scan_flat_dt(early_init_dt_find_memory, NULL);
	if (memory_dtb)
		of_scan_flat_dt(early_init_dt_scan_memory, NULL);
	else if (soc_info.mem_size)
81
		add_memory_region(soc_info.mem_base, soc_info.mem_size * SZ_1M,
82 83 84 85 86
				  BOOT_MEM_RAM);
	else
		detect_memory_region(soc_info.mem_base,
				     soc_info.mem_size_min * SZ_1M,
				     soc_info.mem_size_max * SZ_1M);
J
John Crispin 已提交
87 88 89 90
}

static int __init plat_of_setup(void)
{
91
	__dt_register_buses(soc_info.compatible, "palmbus");
J
John Crispin 已提交
92

93
	/* make sure that the reset controller is setup early */
94 95
	ralink_rst_init();

J
John Crispin 已提交
96 97 98 99
	return 0;
}

arch_initcall(plat_of_setup);