blob: 922b85f07cd273d35daab8e3ff52b74f751f571d [file] [log] [blame]
Ludovic Desroches8f4b4792013-03-22 13:24:12 +00001/*
Nicolas Ferrecac01722015-01-27 16:41:55 +01002 * Setup code for SAMA5
Ludovic Desroches8f4b4792013-03-22 13:24:12 +00003 *
4 * Copyright (C) 2013 Atmel,
5 * 2013 Ludovic Desroches <ludovic.desroches@atmel.com>
6 *
7 * Licensed under GPLv2 or later.
8 */
9
Ludovic Desroches8f4b4792013-03-22 13:24:12 +000010#include <linux/of.h>
Ludovic Desroches8f4b4792013-03-22 13:24:12 +000011#include <linux/of_platform.h>
Alexandre Bellonie7336082015-03-12 15:54:30 +010012
13#include <asm/mach/arch.h>
14#include <asm/mach/map.h>
15#include <asm/system_misc.h>
Ludovic Desroches8f4b4792013-03-22 13:24:12 +000016
Ludovic Desroches8f4b4792013-03-22 13:24:12 +000017#include "generic.h"
Alexandre Bellonie7336082015-03-12 15:54:30 +010018#include "soc.h"
19
20static const struct at91_soc sama5_socs[] = {
Ludovic Desrochesc07f98a2016-03-18 08:21:20 +010021 AT91_SOC(SAMA5D2_CIDR_MATCH, SAMA5D21CU_EXID_MATCH,
22 "sama5d21", "sama5d2"),
23 AT91_SOC(SAMA5D2_CIDR_MATCH, SAMA5D22CU_EXID_MATCH,
24 "sama5d22", "sama5d2"),
25 AT91_SOC(SAMA5D2_CIDR_MATCH, SAMA5D23CU_EXID_MATCH,
26 "sama5d23", "sama5d2"),
27 AT91_SOC(SAMA5D2_CIDR_MATCH, SAMA5D24CX_EXID_MATCH,
28 "sama5d24", "sama5d2"),
29 AT91_SOC(SAMA5D2_CIDR_MATCH, SAMA5D24CU_EXID_MATCH,
30 "sama5d24", "sama5d2"),
31 AT91_SOC(SAMA5D2_CIDR_MATCH, SAMA5D26CU_EXID_MATCH,
32 "sama5d26", "sama5d2"),
33 AT91_SOC(SAMA5D2_CIDR_MATCH, SAMA5D27CU_EXID_MATCH,
Nicolas Ferrec268a742015-07-30 19:12:12 +020034 "sama5d27", "sama5d2"),
Ludovic Desrochesc07f98a2016-03-18 08:21:20 +010035 AT91_SOC(SAMA5D2_CIDR_MATCH, SAMA5D27CN_EXID_MATCH,
36 "sama5d27", "sama5d2"),
37 AT91_SOC(SAMA5D2_CIDR_MATCH, SAMA5D28CU_EXID_MATCH,
38 "sama5d28", "sama5d2"),
39 AT91_SOC(SAMA5D2_CIDR_MATCH, SAMA5D28CN_EXID_MATCH,
40 "sama5d28", "sama5d2"),
Alexandre Bellonie7336082015-03-12 15:54:30 +010041 AT91_SOC(SAMA5D3_CIDR_MATCH, SAMA5D31_EXID_MATCH,
42 "sama5d31", "sama5d3"),
43 AT91_SOC(SAMA5D3_CIDR_MATCH, SAMA5D33_EXID_MATCH,
44 "sama5d33", "sama5d3"),
45 AT91_SOC(SAMA5D3_CIDR_MATCH, SAMA5D34_EXID_MATCH,
46 "sama5d34", "sama5d3"),
47 AT91_SOC(SAMA5D3_CIDR_MATCH, SAMA5D35_EXID_MATCH,
48 "sama5d35", "sama5d3"),
49 AT91_SOC(SAMA5D3_CIDR_MATCH, SAMA5D36_EXID_MATCH,
50 "sama5d36", "sama5d3"),
51 AT91_SOC(SAMA5D4_CIDR_MATCH, SAMA5D41_EXID_MATCH,
52 "sama5d41", "sama5d4"),
53 AT91_SOC(SAMA5D4_CIDR_MATCH, SAMA5D42_EXID_MATCH,
54 "sama5d42", "sama5d4"),
55 AT91_SOC(SAMA5D4_CIDR_MATCH, SAMA5D43_EXID_MATCH,
56 "sama5d43", "sama5d4"),
57 AT91_SOC(SAMA5D4_CIDR_MATCH, SAMA5D44_EXID_MATCH,
58 "sama5d44", "sama5d4"),
59 { /* sentinel */ },
60};
Ludovic Desroches8f4b4792013-03-22 13:24:12 +000061
Ludovic Desroches8f4b4792013-03-22 13:24:12 +000062static void __init sama5_dt_device_init(void)
63{
Alexandre Bellonie7336082015-03-12 15:54:30 +010064 struct soc_device *soc;
65 struct device *soc_dev = NULL;
66
67 soc = at91_soc_init(sama5_socs);
68 if (soc != NULL)
69 soc_dev = soc_device_to_device(soc);
70
71 of_platform_populate(NULL, of_default_bus_match_table, NULL, soc_dev);
Alexandre Bellonifbc7edc2015-09-30 01:58:40 +020072 sama5_pm_init();
Ludovic Desroches8f4b4792013-03-22 13:24:12 +000073}
74
Nicolas Pitre19c233b2015-07-27 18:27:52 -040075static const char *const sama5_dt_board_compat[] __initconst = {
Ludovic Desroches8f4b4792013-03-22 13:24:12 +000076 "atmel,sama5",
77 NULL
78};
79
Nicolas Ferread3fc3e2015-01-27 18:41:33 +010080DT_MACHINE_START(sama5_dt, "Atmel SAMA5")
Ludovic Desroches8f4b4792013-03-22 13:24:12 +000081 /* Maintainer: Atmel */
Ludovic Desroches8f4b4792013-03-22 13:24:12 +000082 .init_machine = sama5_dt_device_init,
83 .dt_compat = sama5_dt_board_compat,
84MACHINE_END
Nicolas Ferre726d32b2014-09-15 18:15:55 +020085
Nicolas Pitre19c233b2015-07-27 18:27:52 -040086static const char *const sama5_alt_dt_board_compat[] __initconst = {
Nicolas Ferrec268a742015-07-30 19:12:12 +020087 "atmel,sama5d2",
Nicolas Ferre726d32b2014-09-15 18:15:55 +020088 "atmel,sama5d4",
89 NULL
90};
91
Nicolas Ferread3fc3e2015-01-27 18:41:33 +010092DT_MACHINE_START(sama5_alt_dt, "Atmel SAMA5")
Nicolas Ferre726d32b2014-09-15 18:15:55 +020093 /* Maintainer: Atmel */
Nicolas Ferre726d32b2014-09-15 18:15:55 +020094 .init_machine = sama5_dt_device_init,
95 .dt_compat = sama5_alt_dt_board_compat,
96 .l2c_aux_mask = ~0UL,
97MACHINE_END