usb: phy: rcar-gen2-usb: always use 'dev' variable in probe() method
[platform/adaptation/renesas_rcar/renesas_kernel.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
29 #include <asm/mach-types.h>
30 #include <asm/mach/arch.h>
31
32 #include "common.h"
33 #include "irqs.h"
34 #include "r7s72100.h"
35
36 /* Ether */
37 static const struct sh_eth_plat_data ether_pdata __initconst = {
38         .phy                    = 0x00, /* PD60610 */
39         .edmac_endian           = EDMAC_LITTLE_ENDIAN,
40         .phy_interface          = PHY_INTERFACE_MODE_MII,
41         .no_ether_link          = 1
42 };
43
44 static const struct resource ether_resources[] __initconst = {
45         DEFINE_RES_MEM(0xe8203000, 0x800),
46         DEFINE_RES_MEM(0xe8204800, 0x200),
47         DEFINE_RES_IRQ(gic_iid(359)),
48 };
49
50 static const struct platform_device_info ether_info __initconst = {
51         .parent         = &platform_bus,
52         .name           = "r7s72100-ether",
53         .id             = -1,
54         .res            = ether_resources,
55         .num_res        = ARRAY_SIZE(ether_resources),
56         .data           = &ether_pdata,
57         .size_data      = sizeof(ether_pdata),
58         .dma_mask       = DMA_BIT_MASK(32),
59 };
60
61 /* RSPI */
62 #define RSPI_RESOURCE(idx, baseaddr, irq)                               \
63 static const struct resource rspi##idx##_resources[] __initconst = {    \
64         DEFINE_RES_MEM(baseaddr, 0x24),                                 \
65         DEFINE_RES_IRQ_NAMED(irq, "error"),                             \
66         DEFINE_RES_IRQ_NAMED(irq + 1, "rx"),                            \
67         DEFINE_RES_IRQ_NAMED(irq + 2, "tx"),                            \
68 }
69
70 RSPI_RESOURCE(0, 0xe800c800, gic_iid(270));
71 RSPI_RESOURCE(1, 0xe800d000, gic_iid(273));
72 RSPI_RESOURCE(2, 0xe800d800, gic_iid(276));
73 RSPI_RESOURCE(3, 0xe800e000, gic_iid(279));
74 RSPI_RESOURCE(4, 0xe800e800, gic_iid(282));
75
76 static const struct rspi_plat_data rspi_pdata __initconst = {
77         .num_chipselect = 1,
78 };
79
80 #define r7s72100_register_rspi(idx)                                        \
81         platform_device_register_resndata(&platform_bus, "rspi-rz", idx,   \
82                                         rspi##idx##_resources,             \
83                                         ARRAY_SIZE(rspi##idx##_resources), \
84                                         &rspi_pdata, sizeof(rspi_pdata))
85
86 static const struct spi_board_info spi_info[] __initconst = {
87         {
88                 .modalias               = "wm8978",
89                 .max_speed_hz           = 5000000,
90                 .bus_num                = 4,
91                 .chip_select            = 0,
92         },
93 };
94
95 /* SCIF */
96 #define R7S72100_SCIF(index, baseaddr, irq)                             \
97 static const struct plat_sci_port scif##index##_platform_data = {       \
98         .type           = PORT_SCIF,                                    \
99         .regtype        = SCIx_SH2_SCIF_FIFODATA_REGTYPE,               \
100         .flags          = UPF_BOOT_AUTOCONF | UPF_IOREMAP,              \
101         .scscr          = SCSCR_RIE | SCSCR_TIE | SCSCR_RE | SCSCR_TE | \
102                           SCSCR_REIE,                                   \
103 };                                                                      \
104                                                                         \
105 static struct resource scif##index##_resources[] = {                    \
106         DEFINE_RES_MEM(baseaddr, 0x100),                                \
107         DEFINE_RES_IRQ(irq + 1),                                        \
108         DEFINE_RES_IRQ(irq + 2),                                        \
109         DEFINE_RES_IRQ(irq + 3),                                        \
110         DEFINE_RES_IRQ(irq),                                            \
111 }                                                                       \
112
113 R7S72100_SCIF(0, 0xe8007000, gic_iid(221));
114 R7S72100_SCIF(1, 0xe8007800, gic_iid(225));
115 R7S72100_SCIF(2, 0xe8008000, gic_iid(229));
116 R7S72100_SCIF(3, 0xe8008800, gic_iid(233));
117 R7S72100_SCIF(4, 0xe8009000, gic_iid(237));
118 R7S72100_SCIF(5, 0xe8009800, gic_iid(241));
119 R7S72100_SCIF(6, 0xe800a000, gic_iid(245));
120 R7S72100_SCIF(7, 0xe800a800, gic_iid(249));
121
122 #define r7s72100_register_scif(index)                                          \
123         platform_device_register_resndata(&platform_bus, "sh-sci", index,      \
124                                           scif##index##_resources,             \
125                                           ARRAY_SIZE(scif##index##_resources), \
126                                           &scif##index##_platform_data,        \
127                                           sizeof(scif##index##_platform_data))
128
129 static void __init genmai_add_standard_devices(void)
130 {
131         r7s72100_clock_init();
132         r7s72100_add_dt_devices();
133
134         platform_device_register_full(&ether_info);
135
136         r7s72100_register_rspi(0);
137         r7s72100_register_rspi(1);
138         r7s72100_register_rspi(2);
139         r7s72100_register_rspi(3);
140         r7s72100_register_rspi(4);
141         spi_register_board_info(spi_info, ARRAY_SIZE(spi_info));
142
143         r7s72100_register_scif(0);
144         r7s72100_register_scif(1);
145         r7s72100_register_scif(2);
146         r7s72100_register_scif(3);
147         r7s72100_register_scif(4);
148         r7s72100_register_scif(5);
149         r7s72100_register_scif(6);
150         r7s72100_register_scif(7);
151 }
152
153 static const char * const genmai_boards_compat_dt[] __initconst = {
154         "renesas,genmai",
155         NULL,
156 };
157
158 DT_MACHINE_START(GENMAI_DT, "genmai")
159         .init_early     = shmobile_init_delay,
160         .init_machine   = genmai_add_standard_devices,
161         .dt_compat      = genmai_boards_compat_dt,
162 MACHINE_END