sunxi.c 2.1 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12
/*
 * Device Tree support for Allwinner A1X SoCs
 *
 * Copyright (C) 2012 Maxime Ripard
 *
 * Maxime Ripard <maxime.ripard@free-electrons.com>
 *
 * This file is licensed under the terms of the GNU General Public
 * License version 2.  This program is licensed "as is" without any
 * warranty of any kind, whether express or implied.
 */

13 14
#include <linux/clk-provider.h>
#include <linux/clocksource.h>
15
#include <linux/init.h>
16
#include <linux/platform_device.h>
17 18

#include <asm/mach/arch.h>
19

20 21 22 23 24
static void __init sunxi_dt_cpufreq_init(void)
{
	platform_device_register_simple("cpufreq-dt", -1, NULL, 0);
}

25
static const char * const sunxi_board_dt_compat[] = {
26
	"allwinner,sun4i-a10",
27
	"allwinner,sun5i-a10s",
28
	"allwinner,sun5i-a13",
29 30 31 32 33
	NULL,
};

DT_MACHINE_START(SUNXI_DT, "Allwinner A1X (Device Tree)")
	.dt_compat	= sunxi_board_dt_compat,
34
	.init_late	= sunxi_dt_cpufreq_init,
35
MACHINE_END
36 37 38

static const char * const sun6i_board_dt_compat[] = {
	"allwinner,sun6i-a31",
39
	"allwinner,sun6i-a31s",
40 41 42
	NULL,
};

43 44 45 46
extern void __init sun6i_reset_init(void);
static void __init sun6i_timer_init(void)
{
	of_clk_init(NULL);
47 48
	if (IS_ENABLED(CONFIG_RESET_CONTROLLER))
		sun6i_reset_init();
49 50 51
	clocksource_of_init();
}

52
DT_MACHINE_START(SUN6I_DT, "Allwinner sun6i (A31) Family")
53
	.init_time	= sun6i_timer_init,
54
	.dt_compat	= sun6i_board_dt_compat,
55
	.init_late	= sunxi_dt_cpufreq_init,
56 57 58 59 60 61 62 63 64
MACHINE_END

static const char * const sun7i_board_dt_compat[] = {
	"allwinner,sun7i-a20",
	NULL,
};

DT_MACHINE_START(SUN7I_DT, "Allwinner sun7i (A20) Family")
	.dt_compat	= sun7i_board_dt_compat,
65
	.init_late	= sunxi_dt_cpufreq_init,
66
MACHINE_END
67 68 69

static const char * const sun8i_board_dt_compat[] = {
	"allwinner,sun8i-a23",
70
	"allwinner,sun8i-a33",
71
	"allwinner,sun8i-h3",
72 73 74
	NULL,
};

75 76
DT_MACHINE_START(SUN8I_DT, "Allwinner sun8i Family")
	.init_time	= sun6i_timer_init,
77
	.dt_compat	= sun8i_board_dt_compat,
78
	.init_late	= sunxi_dt_cpufreq_init,
79
MACHINE_END
80 81 82 83 84 85 86 87 88

static const char * const sun9i_board_dt_compat[] = {
	"allwinner,sun9i-a80",
	NULL,
};

DT_MACHINE_START(SUN9I_DT, "Allwinner sun9i Family")
	.dt_compat	= sun9i_board_dt_compat,
MACHINE_END