blob: 3f81e357affba85b27a95863582c08de5f020533 [file] [log] [blame]
Guennadi Liakhovetski574ec542009-06-23 13:26:23 +02001/*
2 * Copyright (C) 2009
3 * Guennadi Liakhovetski, DENX Software Engineering, <lg@denx.de>
4 *
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License version 2 as
7 * published by the Free Software Foundation.
8 */
9#include <linux/gpio.h>
Guennadi Liakhovetski574ec542009-06-23 13:26:23 +020010#include <linux/input.h>
11#include <linux/platform_device.h>
12#include <linux/spi/spi.h>
13
14#include <mach/common.h>
Guennadi Liakhovetski574ec542009-06-23 13:26:23 +020015#include <mach/iomux-mx3.h>
Sascha Hauer8cad8fa2010-08-09 09:45:09 +020016#include <mach/spi.h>
Guennadi Liakhovetski574ec542009-06-23 13:26:23 +020017
18#include <asm/mach-types.h>
19
20#include "pcm037.h"
21#include "devices.h"
Eric Bénardc0f832b2010-10-15 01:00:01 +020022#include "devices-imx31.h"
Guennadi Liakhovetski574ec542009-06-23 13:26:23 +020023
24static unsigned int pcm037_eet_pins[] = {
Guennadi Liakhovetski574ec542009-06-23 13:26:23 +020025 /* Reserve and hardwire GPIO 57 high - S6E63D6 chipselect */
26 IOMUX_MODE(MX31_PIN_KEY_COL7, IOMUX_CONFIG_GPIO),
27 /* GPIO keys */
28 IOMUX_MODE(MX31_PIN_GPIO1_0, IOMUX_CONFIG_GPIO), /* 0 */
29 IOMUX_MODE(MX31_PIN_GPIO1_1, IOMUX_CONFIG_GPIO), /* 1 */
30 IOMUX_MODE(MX31_PIN_GPIO1_2, IOMUX_CONFIG_GPIO), /* 2 */
31 IOMUX_MODE(MX31_PIN_GPIO1_3, IOMUX_CONFIG_GPIO), /* 3 */
32 IOMUX_MODE(MX31_PIN_SVEN0, IOMUX_CONFIG_GPIO), /* 32 */
33 IOMUX_MODE(MX31_PIN_STX0, IOMUX_CONFIG_GPIO), /* 33 */
34 IOMUX_MODE(MX31_PIN_SRX0, IOMUX_CONFIG_GPIO), /* 34 */
35 IOMUX_MODE(MX31_PIN_SIMPD0, IOMUX_CONFIG_GPIO), /* 35 */
36 IOMUX_MODE(MX31_PIN_RTS1, IOMUX_CONFIG_GPIO), /* 38 */
37 IOMUX_MODE(MX31_PIN_CTS1, IOMUX_CONFIG_GPIO), /* 39 */
38 IOMUX_MODE(MX31_PIN_KEY_ROW4, IOMUX_CONFIG_GPIO), /* 50 */
39 IOMUX_MODE(MX31_PIN_KEY_ROW5, IOMUX_CONFIG_GPIO), /* 51 */
40 IOMUX_MODE(MX31_PIN_KEY_ROW6, IOMUX_CONFIG_GPIO), /* 52 */
41 IOMUX_MODE(MX31_PIN_KEY_ROW7, IOMUX_CONFIG_GPIO), /* 53 */
42
43 /* LEDs */
44 IOMUX_MODE(MX31_PIN_DTR_DTE1, IOMUX_CONFIG_GPIO), /* 44 */
45 IOMUX_MODE(MX31_PIN_DSR_DTE1, IOMUX_CONFIG_GPIO), /* 45 */
46 IOMUX_MODE(MX31_PIN_KEY_COL5, IOMUX_CONFIG_GPIO), /* 55 */
47 IOMUX_MODE(MX31_PIN_KEY_COL6, IOMUX_CONFIG_GPIO), /* 56 */
48};
49
50/* SPI */
51static struct spi_board_info pcm037_spi_dev[] = {
52 {
53 .modalias = "dac124s085",
54 .max_speed_hz = 400000,
55 .bus_num = 0,
56 .chip_select = 0, /* Index in pcm037_spi1_cs[] */
57 .mode = SPI_CPHA,
58 },
59};
60
61/* Platform Data for MXC CSPI */
Guennadi Liakhovetski574ec542009-06-23 13:26:23 +020062static int pcm037_spi1_cs[] = {MXC_SPI_CS(1), IOMUX_TO_GPIO(MX31_PIN_KEY_COL7)};
63
Uwe Kleine-Königa4dc0132010-06-22 10:14:15 +020064static const struct spi_imx_master pcm037_spi1_pdata __initconst = {
Guennadi Liakhovetski574ec542009-06-23 13:26:23 +020065 .chipselect = pcm037_spi1_cs,
66 .num_chipselect = ARRAY_SIZE(pcm037_spi1_cs),
67};
Guennadi Liakhovetski574ec542009-06-23 13:26:23 +020068
69/* GPIO-keys input device */
70static struct gpio_keys_button pcm037_gpio_keys[] = {
71 {
72 .type = EV_KEY,
73 .code = KEY_L,
74 .gpio = 0,
75 .desc = "Wheel Manual",
76 .wakeup = 0,
77 }, {
78 .type = EV_KEY,
79 .code = KEY_A,
80 .gpio = 1,
81 .desc = "Wheel AF",
82 .wakeup = 0,
83 }, {
84 .type = EV_KEY,
85 .code = KEY_V,
86 .gpio = 2,
87 .desc = "Wheel View",
88 .wakeup = 0,
89 }, {
90 .type = EV_KEY,
91 .code = KEY_M,
92 .gpio = 3,
93 .desc = "Wheel Menu",
94 .wakeup = 0,
95 }, {
96 .type = EV_KEY,
97 .code = KEY_UP,
98 .gpio = 32,
99 .desc = "Nav Pad Up",
100 .wakeup = 0,
101 }, {
102 .type = EV_KEY,
103 .code = KEY_RIGHT,
104 .gpio = 33,
105 .desc = "Nav Pad Right",
106 .wakeup = 0,
107 }, {
108 .type = EV_KEY,
109 .code = KEY_DOWN,
110 .gpio = 34,
111 .desc = "Nav Pad Down",
112 .wakeup = 0,
113 }, {
114 .type = EV_KEY,
115 .code = KEY_LEFT,
116 .gpio = 35,
117 .desc = "Nav Pad Left",
118 .wakeup = 0,
119 }, {
120 .type = EV_KEY,
121 .code = KEY_ENTER,
122 .gpio = 38,
123 .desc = "Nav Pad Ok",
124 .wakeup = 0,
125 }, {
126 .type = EV_KEY,
127 .code = KEY_O,
128 .gpio = 39,
129 .desc = "Wheel Off",
130 .wakeup = 0,
131 }, {
132 .type = EV_KEY,
133 .code = BTN_FORWARD,
134 .gpio = 50,
135 .desc = "Focus Forward",
136 .wakeup = 0,
137 }, {
138 .type = EV_KEY,
139 .code = BTN_BACK,
140 .gpio = 51,
141 .desc = "Focus Backward",
142 .wakeup = 0,
143 }, {
144 .type = EV_KEY,
145 .code = BTN_MIDDLE,
146 .gpio = 52,
147 .desc = "Release Half",
148 .wakeup = 0,
149 }, {
150 .type = EV_KEY,
151 .code = BTN_EXTRA,
152 .gpio = 53,
153 .desc = "Release Full",
154 .wakeup = 0,
155 },
156};
157
Uwe Kleine-König53094982011-02-28 18:04:33 +0100158static const struct gpio_keys_platform_data
159 pcm037_gpio_keys_platform_data __initconst = {
Guennadi Liakhovetski574ec542009-06-23 13:26:23 +0200160 .buttons = pcm037_gpio_keys,
161 .nbuttons = ARRAY_SIZE(pcm037_gpio_keys),
162 .rep = 0, /* No auto-repeat */
163};
164
Alberto Panizzof0573e62010-11-01 18:00:03 +0100165static int __init eet_init_devices(void)
Guennadi Liakhovetski574ec542009-06-23 13:26:23 +0200166{
167 if (!machine_is_pcm037() || pcm037_variant() != PCM037_EET)
168 return 0;
169
170 mxc_iomux_setup_multiple_pins(pcm037_eet_pins,
171 ARRAY_SIZE(pcm037_eet_pins), "pcm037_eet");
172
173 /* SPI */
174 spi_register_board_info(pcm037_spi_dev, ARRAY_SIZE(pcm037_spi_dev));
Eric Bénardc0f832b2010-10-15 01:00:01 +0200175 imx31_add_spi_imx0(&pcm037_spi1_pdata);
Guennadi Liakhovetski574ec542009-06-23 13:26:23 +0200176
Uwe Kleine-König53094982011-02-28 18:04:33 +0100177 imx_add_gpio_keys(&pcm037_gpio_keys_platform_data);
Guennadi Liakhovetski574ec542009-06-23 13:26:23 +0200178
179 return 0;
180}
Guennadi Liakhovetski574ec542009-06-23 13:26:23 +0200181late_initcall(eet_init_devices);