of.c 2.5 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
void __init plat_mem_setup(void)
{
69 70
	void *dtb = NULL;

J
John Crispin 已提交
71 72 73 74
	set_io_port_base(KSEG1);

	/*
	 * Load the builtin devicetree. This causes the chosen node to be
75 76
	 * parsed resulting in our memory appearing. fw_passed_dtb is used
	 * by CONFIG_MIPS_APPENDED_RAW_DTB as well.
J
John Crispin 已提交
77
	 */
78 79 80 81 82 83
	if (fw_passed_dtb)
		dtb = (void *)fw_passed_dtb;
	else if (__dtb_start != __dtb_end)
		dtb = (void *)__dtb_start;

	__dt_setup_arch(dtb);
84

85 86 87 88
	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)
89
		add_memory_region(soc_info.mem_base, soc_info.mem_size * SZ_1M,
90 91 92 93 94
				  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 已提交
95 96 97 98
}

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

101
	/* make sure that the reset controller is setup early */
102 103
	ralink_rst_init();

J
John Crispin 已提交
104 105 106 107
	return 0;
}

arch_initcall(plat_of_setup);