of.c 2.0 KB
Newer Older
J
John Crispin 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13
/*
 * 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>
 * Copyright (C) 2013 John Crispin <blogic@openwrt.org>
 */

#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
}

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
	 */
64
	__dt_setup_arch(__dtb_start);
65 66

	if (soc_info.mem_size)
67
		add_memory_region(soc_info.mem_base, soc_info.mem_size * SZ_1M,
68 69 70 71 72
				  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 已提交
73 74 75 76
}

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

79
	/* make sure that the reset controller is setup early */
80 81
	ralink_rst_init();

J
John Crispin 已提交
82 83 84 85
	return 0;
}

arch_initcall(plat_of_setup);