Merge branch 'for-next' of git://git.kernel.org/pub/scm/linux/kernel/git/gerg/m68knommu
[cascardo/linux.git] / arch / arm / mach-shmobile / board-genmai.c
1 /*
2  * Genmai board support
3  *
4  * Copyright (C) 2013-2014  Renesas Solutions Corp.
5  * Copyright (C) 2013  Magnus Damm
6  * Copyright (C) 2014  Cogent Embedded, Inc.
7  *
8  * This program is free software; you can redistribute it and/or modify
9  * it under the terms of the GNU General Public License as published by
10  * the Free Software Foundation; version 2 of the License.
11  *
12  * This program is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15  * GNU General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License
18  * along with this program; if not, write to the Free Software
19  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
20  */
21
22 #include <linux/kernel.h>
23 #include <linux/platform_device.h>
24 #include <linux/serial_sci.h>
25 #include <linux/sh_eth.h>
26 #include <linux/spi/rspi.h>
27 #include <linux/spi/spi.h>
28 #include <mach/common.h>
29 #include <mach/irqs.h>
30 #include <mach/r7s72100.h>
31 #include <asm/mach-types.h>
32 #include <asm/mach/arch.h>
33
34 /* Ether */
35 static const struct sh_eth_plat_data ether_pdata __initconst = {
36         .phy                    = 0x00, /* PD60610 */
37         .edmac_endian           = EDMAC_LITTLE_ENDIAN,
38         .phy_interface          = PHY_INTERFACE_MODE_MII,
39         .no_ether_link          = 1
40 };
41
42 static const struct resource ether_resources[] __initconst = {
43         DEFINE_RES_MEM(0xe8203000, 0x800),
44         DEFINE_RES_MEM(0xe8204800, 0x200),
45         DEFINE_RES_IRQ(gic_iid(359)),
46 };
47
48 static const struct platform_device_info ether_info __initconst = {
49         .name           = "r7s72100-ether",
50         .id             = -1,
51         .res            = ether_resources,
52         .num_res        = ARRAY_SIZE(ether_resources),
53         .data           = &ether_pdata,
54         .size_data      = sizeof(ether_pdata),
55         .dma_mask       = DMA_BIT_MASK(32),
56 };
57
58 /* RSPI */
59 #define RSPI_RESOURCE(idx, baseaddr, irq)                               \
60 static const struct resource rspi##idx##_resources[] __initconst = {    \
61         DEFINE_RES_MEM(baseaddr, 0x24),                                 \
62         DEFINE_RES_IRQ_NAMED(irq, "error"),                             \
63         DEFINE_RES_IRQ_NAMED(irq + 1, "rx"),                            \
64         DEFINE_RES_IRQ_NAMED(irq + 2, "tx"),                            \
65 }
66
67 RSPI_RESOURCE(0, 0xe800c800, gic_iid(270));
68 RSPI_RESOURCE(1, 0xe800d000, gic_iid(273));
69 RSPI_RESOURCE(2, 0xe800d800, gic_iid(276));
70 RSPI_RESOURCE(3, 0xe800e000, gic_iid(279));
71 RSPI_RESOURCE(4, 0xe800e800, gic_iid(282));
72
73 static const struct rspi_plat_data rspi_pdata __initconst = {
74         .num_chipselect = 1,
75 };
76
77 #define r7s72100_register_rspi(idx)                                        \
78         platform_device_register_resndata(NULL, "rspi-rz", idx,            \
79                                         rspi##idx##_resources,             \
80                                         ARRAY_SIZE(rspi##idx##_resources), \
81                                         &rspi_pdata, sizeof(rspi_pdata))
82
83 static const struct spi_board_info spi_info[] __initconst = {
84         {
85                 .modalias               = "wm8978",
86                 .max_speed_hz           = 5000000,
87                 .bus_num                = 4,
88                 .chip_select            = 0,
89         },
90 };
91
92 /* SCIF */
93 #define R7S72100_SCIF(index, baseaddr, irq)                             \
94 static const struct plat_sci_port scif##index##_platform_data = {       \
95         .type           = PORT_SCIF,                                    \
96         .regtype        = SCIx_SH2_SCIF_FIFODATA_REGTYPE,               \
97         .flags          = UPF_BOOT_AUTOCONF | UPF_IOREMAP,              \
98         .scscr          = SCSCR_RIE | SCSCR_TIE | SCSCR_RE | SCSCR_TE | \
99                           SCSCR_REIE,                                   \
100 };                                                                      \
101                                                                         \
102 static struct resource scif##index##_resources[] = {                    \
103         DEFINE_RES_MEM(baseaddr, 0x100),                                \
104         DEFINE_RES_IRQ(irq + 1),                                        \
105         DEFINE_RES_IRQ(irq + 2),                                        \
106         DEFINE_RES_IRQ(irq + 3),                                        \
107         DEFINE_RES_IRQ(irq),                                            \
108 }                                                                       \
109
110 R7S72100_SCIF(0, 0xe8007000, gic_iid(221));
111 R7S72100_SCIF(1, 0xe8007800, gic_iid(225));
112 R7S72100_SCIF(2, 0xe8008000, gic_iid(229));
113 R7S72100_SCIF(3, 0xe8008800, gic_iid(233));
114 R7S72100_SCIF(4, 0xe8009000, gic_iid(237));
115 R7S72100_SCIF(5, 0xe8009800, gic_iid(241));
116 R7S72100_SCIF(6, 0xe800a000, gic_iid(245));
117 R7S72100_SCIF(7, 0xe800a800, gic_iid(249));
118
119 #define r7s72100_register_scif(index)                                          \
120         platform_device_register_resndata(NULL, "sh-sci", index,               \
121                                           scif##index##_resources,             \
122                                           ARRAY_SIZE(scif##index##_resources), \
123                                           &scif##index##_platform_data,        \
124                                           sizeof(scif##index##_platform_data))
125
126 static void __init genmai_add_standard_devices(void)
127 {
128         r7s72100_clock_init();
129         r7s72100_add_dt_devices();
130
131         platform_device_register_full(&ether_info);
132
133         r7s72100_register_rspi(0);
134         r7s72100_register_rspi(1);
135         r7s72100_register_rspi(2);
136         r7s72100_register_rspi(3);
137         r7s72100_register_rspi(4);
138         spi_register_board_info(spi_info, ARRAY_SIZE(spi_info));
139
140         r7s72100_register_scif(0);
141         r7s72100_register_scif(1);
142         r7s72100_register_scif(2);
143         r7s72100_register_scif(3);
144         r7s72100_register_scif(4);
145         r7s72100_register_scif(5);
146         r7s72100_register_scif(6);
147         r7s72100_register_scif(7);
148 }
149
150 static const char * const genmai_boards_compat_dt[] __initconst = {
151         "renesas,genmai",
152         NULL,
153 };
154
155 DT_MACHINE_START(GENMAI_DT, "genmai")
156         .init_early     = r7s72100_init_early,
157         .init_machine   = genmai_add_standard_devices,
158         .dt_compat      = genmai_boards_compat_dt,
159 MACHINE_END