blob: e3cef503cd8f3e16d958b3dd82dd2efc92af869a [file] [log] [blame]
Sekhar Nori689e3312012-08-28 15:27:52 +05301/*
2 * Copyright (C) 2012 Texas Instruments Incorporated - http://www.ti.com/
3 *
4 * Modified from mach-omap/omap2/board-generic.c
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License version 2 as
8 * published by the Free Software Foundation.
9 */
10#include <linux/io.h>
11#include <linux/of_irq.h>
12#include <linux/of_platform.h>
13#include <linux/irqdomain.h>
Bartosz Golaszewskid8e22fb2017-01-13 11:00:26 +010014#include <linux/platform_data/ti-aemif.h>
Sekhar Nori689e3312012-08-28 15:27:52 +053015
16#include <asm/mach/arch.h>
17
18#include <mach/common.h>
Arnd Bergmann3acf7312015-01-30 10:45:33 +010019#include "cp_intc.h"
Sekhar Nori689e3312012-08-28 15:27:52 +053020#include <mach/da8xx.h>
21
Bartosz Golaszewskid8e22fb2017-01-13 11:00:26 +010022static struct of_dev_auxdata da850_aemif_auxdata_lookup[] = {
23 OF_DEV_AUXDATA("ti,davinci-nand", 0x62000000, "davinci-nand.0", NULL),
24 {}
25};
26
27static struct aemif_platform_data aemif_data = {
28 .dev_lookup = da850_aemif_auxdata_lookup,
29};
30
Sekhar Nori267f3c02013-04-10 14:57:13 +053031static struct of_dev_auxdata da850_auxdata_lookup[] __initdata = {
Vishwanathrao Badarkhe, Manish01729cc2013-02-06 15:06:22 +053032 OF_DEV_AUXDATA("ti,davinci-i2c", 0x01c22000, "i2c_davinci.1", NULL),
Petr Kulhavy6c8f7352016-04-01 17:42:05 +020033 OF_DEV_AUXDATA("ti,davinci-i2c", 0x01e28000, "i2c_davinci.2", NULL),
Ivan Khoronzhuk84374812013-11-27 15:31:53 +020034 OF_DEV_AUXDATA("ti,davinci-wdt", 0x01c21000, "davinci-wdt", NULL),
Manjunathappa, Prakashdb4c8fa2013-03-28 18:42:02 +053035 OF_DEV_AUXDATA("ti,da830-mmc", 0x01c40000, "da830-mmc.0", NULL),
David Lechner36173c22016-10-31 15:04:24 -050036 OF_DEV_AUXDATA("ti,da850-ehrpwm", 0x01f00000, "ehrpwm.0", NULL),
37 OF_DEV_AUXDATA("ti,da850-ehrpwm", 0x01f02000, "ehrpwm.1", NULL),
38 OF_DEV_AUXDATA("ti,da850-ecap", 0x01f06000, "ecap.0", NULL),
39 OF_DEV_AUXDATA("ti,da850-ecap", 0x01f07000, "ecap.1", NULL),
40 OF_DEV_AUXDATA("ti,da850-ecap", 0x01f08000, "ecap.2", NULL),
David Lechner801a6aa9aa2016-04-16 12:00:18 -050041 OF_DEV_AUXDATA("ti,da830-spi", 0x01c41000, "spi_davinci.0", NULL),
Manjunathappa, Prakash414d6e52013-04-03 19:39:09 +053042 OF_DEV_AUXDATA("ti,da830-spi", 0x01f0e000, "spi_davinci.1", NULL),
Manjunathappa, Prakash19955c32013-06-19 14:45:38 +053043 OF_DEV_AUXDATA("ns16550a", 0x01c42000, "serial8250.0", NULL),
44 OF_DEV_AUXDATA("ns16550a", 0x01d0c000, "serial8250.1", NULL),
45 OF_DEV_AUXDATA("ns16550a", 0x01d0d000, "serial8250.2", NULL),
Lad, Prabhakar73db59512013-08-15 11:31:35 +053046 OF_DEV_AUXDATA("ti,davinci_mdio", 0x01e24000, "davinci_mdio.0", NULL),
Lad, Prabhakar235d8cd2013-08-16 19:41:02 +053047 OF_DEV_AUXDATA("ti,davinci-dm6467-emac", 0x01e20000, "davinci_emac.1",
48 NULL),
Peter Ujfalusi06b57f12014-08-01 09:13:25 +030049 OF_DEV_AUXDATA("ti,da830-mcasp-audio", 0x01d00000, "davinci-mcasp.0", NULL),
Bartosz Golaszewskid8e22fb2017-01-13 11:00:26 +010050 OF_DEV_AUXDATA("ti,da850-aemif", 0x68000000, "ti-aemif", &aemif_data),
Karl Beldanec7cc272016-10-05 15:05:31 +020051 OF_DEV_AUXDATA("ti,da850-tilcdc", 0x01e13000, "da8xx_lcdc.0", NULL),
Axel Haslam8439a1d2016-11-03 17:03:06 +010052 OF_DEV_AUXDATA("ti,da830-ohci", 0x01e25000, "ohci-da8xx", NULL),
David Lechnerb08157a2016-10-26 19:18:16 -050053 OF_DEV_AUXDATA("ti,da830-musb", 0x01e00000, "musb-da8xx", NULL),
David Lechner3b996e52016-10-31 15:47:19 -050054 OF_DEV_AUXDATA("ti,da830-usb-phy", 0x01c1417c, "da8xx-usb-phy", NULL),
Bartosz Golaszewski57a66aa2017-01-30 11:02:00 +010055 OF_DEV_AUXDATA("ti,da850-ahci", 0x01e18000, "ahci_da850", NULL),
Vishwanathrao Badarkhe, Manish01729cc2013-02-06 15:06:22 +053056 {}
57};
58
Sekhar Nori689e3312012-08-28 15:27:52 +053059#ifdef CONFIG_ARCH_DAVINCI_DA850
60
61static void __init da850_init_machine(void)
62{
Bartosz Golaszewski00bacfb2017-01-30 11:02:03 +010063 /* All existing boards use 100MHz SATA refclkpn */
64 static const unsigned long sata_refclkpn = 100 * 1000 * 1000;
65
Axel Haslamced95ac2016-10-31 15:47:21 -050066 int ret;
67
68 ret = da8xx_register_usb20_phy_clk(false);
69 if (ret)
70 pr_warn("%s: registering USB 2.0 PHY clock failed: %d",
71 __func__, ret);
72 ret = da8xx_register_usb11_phy_clk(false);
73 if (ret)
74 pr_warn("%s: registering USB 1.1 PHY clock failed: %d",
75 __func__, ret);
76
Bartosz Golaszewski00bacfb2017-01-30 11:02:03 +010077 ret = da850_register_sata_refclk(sata_refclkpn);
78 if (ret)
79 pr_warn("%s: registering SATA REFCLK failed: %d",
80 __func__, ret);
81
David Lechner2f44a8d2016-02-29 16:33:24 -060082 of_platform_default_populate(NULL, da850_auxdata_lookup, NULL);
Kevin Hilman7e431af2016-11-15 11:54:21 -080083 davinci_pm_init();
Kevin Hilman9c9b1bc2017-01-09 12:55:29 -080084 pdata_quirks_init();
Sekhar Nori689e3312012-08-28 15:27:52 +053085}
86
Nicolas Pitre19c233b2015-07-27 18:27:52 -040087static const char *const da850_boards_compat[] __initconst = {
Heiko Schocher3015fb32012-05-30 12:19:03 +020088 "enbw,cmc",
Karl Beldan44524a02016-08-05 20:29:49 +000089 "ti,da850-lcdk",
Sekhar Nori27e6e0d2012-08-29 23:25:27 +053090 "ti,da850-evm",
Sekhar Nori689e3312012-08-28 15:27:52 +053091 "ti,da850",
92 NULL,
93};
94
95DT_MACHINE_START(DA850_DT, "Generic DA850/OMAP-L138/AM18x")
96 .map_io = da850_init,
Stephen Warren6bb27d72012-11-08 12:40:59 -070097 .init_time = davinci_timer_init,
Sekhar Nori689e3312012-08-28 15:27:52 +053098 .init_machine = da850_init_machine,
99 .dt_compat = da850_boards_compat,
100 .init_late = davinci_init_late,
101 .restart = da8xx_restart,
102MACHINE_END
103
104#endif