aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm/mach-ux500/board-mop500.c
diff options
context:
space:
mode:
Diffstat (limited to 'arch/arm/mach-ux500/board-mop500.c')
-rw-r--r--arch/arm/mach-ux500/board-mop500.c173
1 files changed, 160 insertions, 13 deletions
diff --git a/arch/arm/mach-ux500/board-mop500.c b/arch/arm/mach-ux500/board-mop500.c
index 0e8fd135a57..cac83a69488 100644
--- a/arch/arm/mach-ux500/board-mop500.c
+++ b/arch/arm/mach-ux500/board-mop500.c
@@ -18,18 +18,22 @@
18#include <linux/amba/pl022.h> 18#include <linux/amba/pl022.h>
19#include <linux/spi/spi.h> 19#include <linux/spi/spi.h>
20#include <linux/mfd/ab8500.h> 20#include <linux/mfd/ab8500.h>
21#include <linux/input/matrix_keypad.h>
21 22
22#include <asm/mach-types.h> 23#include <asm/mach-types.h>
23#include <asm/mach/arch.h> 24#include <asm/mach/arch.h>
24 25
25#include <plat/pincfg.h> 26#include <plat/pincfg.h>
26#include <plat/i2c.h> 27#include <plat/i2c.h>
28#include <plat/ske.h>
27 29
28#include <mach/hardware.h> 30#include <mach/hardware.h>
29#include <mach/setup.h> 31#include <mach/setup.h>
30#include <mach/devices.h> 32#include <mach/devices.h>
33#include <mach/irqs.h>
31 34
32#include "pins-db8500.h" 35#include "pins-db8500.h"
36#include "board-mop500.h"
33 37
34static pin_cfg_t mop500_pins[] = { 38static pin_cfg_t mop500_pins[] = {
35 /* SSP0 */ 39 /* SSP0 */
@@ -47,6 +51,24 @@ static pin_cfg_t mop500_pins[] = {
47 GPIO11_I2C2_SCL, 51 GPIO11_I2C2_SCL,
48 GPIO229_I2C3_SDA, 52 GPIO229_I2C3_SDA,
49 GPIO230_I2C3_SCL, 53 GPIO230_I2C3_SCL,
54
55 /* SKE keypad */
56 GPIO153_KP_I7,
57 GPIO154_KP_I6,
58 GPIO155_KP_I5,
59 GPIO156_KP_I4,
60 GPIO157_KP_O7,
61 GPIO158_KP_O6,
62 GPIO159_KP_O5,
63 GPIO160_KP_O4,
64 GPIO161_KP_I3,
65 GPIO162_KP_I2,
66 GPIO163_KP_I1,
67 GPIO164_KP_I0,
68 GPIO165_KP_O3,
69 GPIO166_KP_O2,
70 GPIO167_KP_O1,
71 GPIO168_KP_O0,
50}; 72};
51 73
52static void ab4500_spi_cs_control(u32 command) 74static void ab4500_spi_cs_control(u32 command)
@@ -55,19 +77,13 @@ static void ab4500_spi_cs_control(u32 command)
55} 77}
56 78
57struct pl022_config_chip ab4500_chip_info = { 79struct pl022_config_chip ab4500_chip_info = {
58 .lbm = LOOPBACK_DISABLED,
59 .com_mode = INTERRUPT_TRANSFER, 80 .com_mode = INTERRUPT_TRANSFER,
60 .iface = SSP_INTERFACE_MOTOROLA_SPI, 81 .iface = SSP_INTERFACE_MOTOROLA_SPI,
61 /* we can act as master only */ 82 /* we can act as master only */
62 .hierarchy = SSP_MASTER, 83 .hierarchy = SSP_MASTER,
63 .slave_tx_disable = 0, 84 .slave_tx_disable = 0,
64 .endian_rx = SSP_RX_MSB,
65 .endian_tx = SSP_TX_MSB,
66 .data_size = SSP_DATA_BITS_24,
67 .rx_lev_trig = SSP_RX_1_OR_MORE_ELEM, 85 .rx_lev_trig = SSP_RX_1_OR_MORE_ELEM,
68 .tx_lev_trig = SSP_TX_1_OR_MORE_EMPTY_LOC, 86 .tx_lev_trig = SSP_TX_1_OR_MORE_EMPTY_LOC,
69 .clk_phase = SSP_CLK_SECOND_EDGE,
70 .clk_pol = SSP_CLK_POL_IDLE_HIGH,
71 .cs_control = ab4500_spi_cs_control, 87 .cs_control = ab4500_spi_cs_control,
72}; 88};
73 89
@@ -75,15 +91,33 @@ static struct ab8500_platform_data ab8500_platdata = {
75 .irq_base = MOP500_AB8500_IRQ_BASE, 91 .irq_base = MOP500_AB8500_IRQ_BASE,
76}; 92};
77 93
78static struct spi_board_info u8500_spi_devices[] = { 94static struct resource ab8500_resources[] = {
95 [0] = {
96 .start = IRQ_AB8500,
97 .end = IRQ_AB8500,
98 .flags = IORESOURCE_IRQ
99 }
100};
101
102struct platform_device ab8500_device = {
103 .name = "ab8500-i2c",
104 .id = 0,
105 .dev = {
106 .platform_data = &ab8500_platdata,
107 },
108 .num_resources = 1,
109 .resource = ab8500_resources,
110};
111
112static struct spi_board_info ab8500_spi_devices[] = {
79 { 113 {
80 .modalias = "ab8500", 114 .modalias = "ab8500-spi",
81 .controller_data = &ab4500_chip_info, 115 .controller_data = &ab4500_chip_info,
82 .platform_data = &ab8500_platdata, 116 .platform_data = &ab8500_platdata,
83 .max_speed_hz = 12000000, 117 .max_speed_hz = 12000000,
84 .bus_num = 0, 118 .bus_num = 0,
85 .chip_select = 0, 119 .chip_select = 0,
86 .mode = SPI_MODE_0, 120 .mode = SPI_MODE_3,
87 .irq = IRQ_DB8500_AB8500, 121 .irq = IRQ_DB8500_AB8500,
88 }, 122 },
89}; 123};
@@ -134,12 +168,120 @@ static struct amba_device *amba_devs[] __initdata = {
134 &u8500_ssp0_device, 168 &u8500_ssp0_device,
135}; 169};
136 170
171static const unsigned int ux500_keymap[] = {
172 KEY(2, 5, KEY_END),
173 KEY(4, 1, KEY_POWER),
174 KEY(3, 5, KEY_VOLUMEDOWN),
175 KEY(1, 3, KEY_3),
176 KEY(5, 2, KEY_RIGHT),
177 KEY(5, 0, KEY_9),
178
179 KEY(0, 5, KEY_MENU),
180 KEY(7, 6, KEY_ENTER),
181 KEY(4, 5, KEY_0),
182 KEY(6, 7, KEY_2),
183 KEY(3, 4, KEY_UP),
184 KEY(3, 3, KEY_DOWN),
185
186 KEY(6, 4, KEY_SEND),
187 KEY(6, 2, KEY_BACK),
188 KEY(4, 2, KEY_VOLUMEUP),
189 KEY(5, 5, KEY_1),
190 KEY(4, 3, KEY_LEFT),
191 KEY(3, 2, KEY_7),
192};
193
194static const struct matrix_keymap_data ux500_keymap_data = {
195 .keymap = ux500_keymap,
196 .keymap_size = ARRAY_SIZE(ux500_keymap),
197};
198
199/*
200 * Nomadik SKE keypad
201 */
202#define ROW_PIN_I0 164
203#define ROW_PIN_I1 163
204#define ROW_PIN_I2 162
205#define ROW_PIN_I3 161
206#define ROW_PIN_I4 156
207#define ROW_PIN_I5 155
208#define ROW_PIN_I6 154
209#define ROW_PIN_I7 153
210#define COL_PIN_O0 168
211#define COL_PIN_O1 167
212#define COL_PIN_O2 166
213#define COL_PIN_O3 165
214#define COL_PIN_O4 160
215#define COL_PIN_O5 159
216#define COL_PIN_O6 158
217#define COL_PIN_O7 157
218
219#define SKE_KPD_MAX_ROWS 8
220#define SKE_KPD_MAX_COLS 8
221
222static int ske_kp_rows[] = {
223 ROW_PIN_I0, ROW_PIN_I1, ROW_PIN_I2, ROW_PIN_I3,
224 ROW_PIN_I4, ROW_PIN_I5, ROW_PIN_I6, ROW_PIN_I7,
225};
226
227/*
228 * ske_set_gpio_row: request and set gpio rows
229 */
230static int ske_set_gpio_row(int gpio)
231{
232 int ret;
233
234 ret = gpio_request(gpio, "ske-kp");
235 if (ret < 0) {
236 pr_err("ske_set_gpio_row: gpio request failed\n");
237 return ret;
238 }
239
240 ret = gpio_direction_output(gpio, 1);
241 if (ret < 0) {
242 pr_err("ske_set_gpio_row: gpio direction failed\n");
243 gpio_free(gpio);
244 }
245
246 return ret;
247}
248
249/*
250 * ske_kp_init - enable the gpio configuration
251 */
252static int ske_kp_init(void)
253{
254 int ret, i;
255
256 for (i = 0; i < SKE_KPD_MAX_ROWS; i++) {
257 ret = ske_set_gpio_row(ske_kp_rows[i]);
258 if (ret < 0) {
259 pr_err("ske_kp_init: failed init\n");
260 return ret;
261 }
262 }
263
264 return 0;
265}
266
267static struct ske_keypad_platform_data ske_keypad_board = {
268 .init = ske_kp_init,
269 .keymap_data = &ux500_keymap_data,
270 .no_autorepeat = true,
271 .krow = SKE_KPD_MAX_ROWS, /* 8x8 matrix */
272 .kcol = SKE_KPD_MAX_COLS,
273 .debounce_ms = 40, /* in millsecs */
274};
275
276
277
137/* add any platform devices here - TODO */ 278/* add any platform devices here - TODO */
138static struct platform_device *platform_devs[] __initdata = { 279static struct platform_device *platform_devs[] __initdata = {
139 &u8500_i2c0_device, 280 &u8500_i2c0_device,
140 &ux500_i2c1_device, 281 &ux500_i2c1_device,
141 &ux500_i2c2_device, 282 &ux500_i2c2_device,
142 &ux500_i2c3_device, 283 &ux500_i2c3_device,
284 &ux500_ske_keypad_device,
143}; 285};
144 286
145static void __init u8500_init_machine(void) 287static void __init u8500_init_machine(void)
@@ -154,6 +296,7 @@ static void __init u8500_init_machine(void)
154 ux500_i2c1_device.dev.platform_data = &u8500_i2c1_data; 296 ux500_i2c1_device.dev.platform_data = &u8500_i2c1_data;
155 ux500_i2c2_device.dev.platform_data = &u8500_i2c2_data; 297 ux500_i2c2_device.dev.platform_data = &u8500_i2c2_data;
156 ux500_i2c3_device.dev.platform_data = &u8500_i2c3_data; 298 ux500_i2c3_device.dev.platform_data = &u8500_i2c3_data;
299 ux500_ske_keypad_device.dev.platform_data = &ske_keypad_board;
157 300
158 u8500_ssp0_device.dev.platform_data = &ssp0_platform_data; 301 u8500_ssp0_device.dev.platform_data = &ssp0_platform_data;
159 302
@@ -163,14 +306,18 @@ static void __init u8500_init_machine(void)
163 306
164 platform_add_devices(platform_devs, ARRAY_SIZE(platform_devs)); 307 platform_add_devices(platform_devs, ARRAY_SIZE(platform_devs));
165 308
166 spi_register_board_info(u8500_spi_devices, 309 mop500_sdi_init();
167 ARRAY_SIZE(u8500_spi_devices)); 310
311 /* If HW is early drop (ED) or V1.0 then use SPI to access AB8500 */
312 if (cpu_is_u8500ed() || cpu_is_u8500v10())
313 spi_register_board_info(ab8500_spi_devices,
314 ARRAY_SIZE(ab8500_spi_devices));
315 else /* If HW is v.1.1 or later use I2C to access AB8500 */
316 platform_device_register(&ab8500_device);
168} 317}
169 318
170MACHINE_START(U8500, "ST-Ericsson MOP500 platform") 319MACHINE_START(U8500, "ST-Ericsson MOP500 platform")
171 /* Maintainer: Srinidhi Kasagar <srinidhi.kasagar@stericsson.com> */ 320 /* Maintainer: Srinidhi Kasagar <srinidhi.kasagar@stericsson.com> */
172 .phys_io = U8500_UART2_BASE,
173 .io_pg_offst = (IO_ADDRESS(U8500_UART2_BASE) >> 18) & 0xfffc,
174 .boot_params = 0x100, 321 .boot_params = 0x100,
175 .map_io = u8500_map_io, 322 .map_io = u8500_map_io,
176 .init_irq = ux500_init_irq, 323 .init_irq = ux500_init_irq,