Blame view

arch/arm/mach-pxa/spitz.c 25 KB
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
  /*
   * Support for Sharp SL-Cxx00 Series of PDAs
   * Models: SL-C3000 (Spitz), SL-C1000 (Akita) and SL-C3100 (Borzoi)
   *
   * Copyright (c) 2005 Richard Purdie
   *
   * Based on Sharp's 2.4 kernel patches/lubbock.c
   *
   * This program is free software; you can redistribute it and/or modify
   * it under the terms of the GNU General Public License version 2 as
   * published by the Free Software Foundation.
   *
   */
  
  #include <linux/kernel.h>
d052d1bef   Russell King   Create platform_d...
16
  #include <linux/platform_device.h>
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
17
  #include <linux/delay.h>
f6919eb41   Stanislav Brabec   [ARM] pxa/spitz: ...
18
  #include <linux/gpio_keys.h>
dd5980d68   Eric Miao   [ARM] pxa/spitz: ...
19
  #include <linux/gpio.h>
4fe3224ff   Eric Miao   [ARM] pxa/spitz: ...
20
  #include <linux/leds.h>
f72de6638   Eric Miao   [ARM] pxa/akita: ...
21
  #include <linux/i2c.h>
b459396ee   Sebastian Andrzej Siewior   ARM: pxa2xx: reor...
22
  #include <linux/i2c/pxa-i2c.h>
f72de6638   Eric Miao   [ARM] pxa/akita: ...
23
  #include <linux/i2c/pca953x.h>
859b79634   Eric Miao   [ARM] pxa/spitz: ...
24
25
26
  #include <linux/spi/spi.h>
  #include <linux/spi/ads7846.h>
  #include <linux/spi/corgi_lcd.h>
8348c259d   Sebastian Andrzej Siewior   arm/pxa2xx: reorg...
27
  #include <linux/spi/pxa2xx_spi.h>
6af7a8eb1   Dmitry Eremin-Solenikov   [MTD] sharpsl-nan...
28
  #include <linux/mtd/sharpsl.h>
ea0c4f3ca   Eric Miao   ARM: pxa: fix bui...
29
  #include <linux/mtd/physmap.h>
93dd29a81   Eric Miao   [ARM] pxa/spitz: ...
30
  #include <linux/input/matrix_keypad.h>
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
31
  #include <linux/regulator/machine.h>
851982c1b   Marek Vasut   ARM: pxa: Introdu...
32
  #include <linux/io.h>
73017a542   Paul Gortmaker   arm: fix implicit...
33
  #include <linux/module.h>
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
34
35
  
  #include <asm/setup.h>
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
36
  #include <asm/mach-types.h>
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
37
  #include <asm/mach/arch.h>
f0ba40176   Dmitry Eremin-Solenikov   [ARM] pxa/spitz: ...
38
39
  #include <asm/mach/sharpsl_param.h>
  #include <asm/hardware/scoop.h>
51c62982a   Eric Miao   [ARM] pxa: introd...
40
  #include <mach/pxa27x.h>
a09e64fbc   Russell King   [ARM] Move includ...
41
  #include <mach/pxa27x-udc.h>
afd2fc02a   Russell King   Merge branch 'for...
42
  #include <mach/reset.h>
a09e64fbc   Russell King   [ARM] Move includ...
43
44
45
  #include <mach/irda.h>
  #include <mach/mmc.h>
  #include <mach/ohci.h>
a09e64fbc   Russell King   [ARM] Move includ...
46
  #include <mach/pxafb.h>
a09e64fbc   Russell King   [ARM] Move includ...
47
  #include <mach/spitz.h>
04e4ad235   Eric Miao   [ARM] pxa: remove...
48
  #include <mach/sharpsl_pm.h>
ad68bb9f7   Marek Vasut   ARM: pxa: Access ...
49
  #include <mach/smemc.h>
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
50
51
  
  #include "generic.h"
46c41e62a   Russell King   [ARM] pxa: move p...
52
  #include "devices.h"
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
53

2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
54
55
56
  /******************************************************************************
   * Pin configuration
   ******************************************************************************/
5e96adec6   Eric Miao   [ARM] pxa/spitz: ...
57
58
59
  static unsigned long spitz_pin_config[] __initdata = {
  	/* Chip Selects */
  	GPIO78_nCS_2,	/* SCOOP #2 */
faf2f0ab1   Eric Miao   [ARM] pxa: fix in...
60
  	GPIO79_nCS_3,	/* NAND */
5e96adec6   Eric Miao   [ARM] pxa/spitz: ...
61
62
63
  	GPIO80_nCS_4,	/* SCOOP #1 */
  
  	/* LCD - 16bpp Active TFT */
bedbda971   Eric Miao   [ARM] pxa: simpli...
64
  	GPIOxx_LCD_TFT_16BPP,
5e96adec6   Eric Miao   [ARM] pxa/spitz: ...
65
66
67
68
69
70
71
72
  
  	/* PC Card */
  	GPIO48_nPOE,
  	GPIO49_nPWE,
  	GPIO50_nPIOR,
  	GPIO51_nPIOW,
  	GPIO85_nPCE_1,
  	GPIO54_nPCE_2,
5e96adec6   Eric Miao   [ARM] pxa/spitz: ...
73
74
75
  	GPIO55_nPREG,
  	GPIO56_nPWAIT,
  	GPIO57_nIOIS16,
faf2f0ab1   Eric Miao   [ARM] pxa: fix in...
76
  	GPIO104_PSKTSEL,
5e96adec6   Eric Miao   [ARM] pxa/spitz: ...
77

772885c1d   Philipp Zabel   pxa/spitz: Setup ...
78
79
80
81
82
  	/* I2S */
  	GPIO28_I2S_BITCLK_OUT,
  	GPIO29_I2S_SDATA_IN,
  	GPIO30_I2S_SDATA_OUT,
  	GPIO31_I2S_SYNC,
5e96adec6   Eric Miao   [ARM] pxa/spitz: ...
83
84
85
86
87
88
89
90
91
92
  	/* MMC */
  	GPIO32_MMC_CLK,
  	GPIO112_MMC_CMD,
  	GPIO92_MMC_DAT_0,
  	GPIO109_MMC_DAT_1,
  	GPIO110_MMC_DAT_2,
  	GPIO111_MMC_DAT_3,
  
  	/* GPIOs */
  	GPIO9_GPIO,	/* SPITZ_GPIO_nSD_DETECT */
b6eede112   Eric Miao   [ARM] pxa/spitz: ...
93
  	GPIO16_GPIO,	/* SPITZ_GPIO_SYNC */
5e96adec6   Eric Miao   [ARM] pxa/spitz: ...
94
95
96
97
98
99
100
101
  	GPIO81_GPIO,	/* SPITZ_GPIO_nSD_WP */
  	GPIO41_GPIO,	/* SPITZ_GPIO_USB_CONNECT */
  	GPIO37_GPIO,	/* SPITZ_GPIO_USB_HOST */
  	GPIO35_GPIO,	/* SPITZ_GPIO_USB_DEVICE */
  	GPIO22_GPIO,	/* SPITZ_GPIO_HSYNC */
  	GPIO94_GPIO,	/* SPITZ_GPIO_CF_CD */
  	GPIO105_GPIO,	/* SPITZ_GPIO_CF_IRQ */
  	GPIO106_GPIO,	/* SPITZ_GPIO_CF2_IRQ */
93dd29a81   Eric Miao   [ARM] pxa/spitz: ...
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
  	/* GPIO matrix keypad */
  	GPIO88_GPIO,	/* column 0 */
  	GPIO23_GPIO,	/* column 1 */
  	GPIO24_GPIO,	/* column 2 */
  	GPIO25_GPIO,	/* column 3 */
  	GPIO26_GPIO,	/* column 4 */
  	GPIO27_GPIO,	/* column 5 */
  	GPIO52_GPIO,	/* column 6 */
  	GPIO103_GPIO,	/* column 7 */
  	GPIO107_GPIO,	/* column 8 */
  	GPIO108_GPIO,	/* column 9 */
  	GPIO114_GPIO,	/* column 10 */
  	GPIO12_GPIO,	/* row 0 */
  	GPIO17_GPIO,	/* row 1 */
  	GPIO91_GPIO,	/* row 2 */
  	GPIO34_GPIO,	/* row 3 */
  	GPIO36_GPIO,	/* row 4 */
  	GPIO38_GPIO,	/* row 5 */
  	GPIO39_GPIO,	/* row 6 */
6f584cfab   Eric Miao   [ARM] pxa: move I...
121
122
123
  	/* I2C */
  	GPIO117_I2C_SCL,
  	GPIO118_I2C_SDA,
b6eede112   Eric Miao   [ARM] pxa/spitz: ...
124
125
  	GPIO0_GPIO | WAKEUP_ON_EDGE_RISE,	/* SPITZ_GPIO_KEY_INT */
  	GPIO1_GPIO | WAKEUP_ON_EDGE_FALL,	/* SPITZ_GPIO_RESET */
5e96adec6   Eric Miao   [ARM] pxa/spitz: ...
126
  };
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
127
128
129
130
131
  
  /******************************************************************************
   * Scoop GPIO expander
   ******************************************************************************/
  #if defined(CONFIG_SHARP_SCOOP) || defined(CONFIG_SHARP_SCOOP_MODULE)
084115946   Marek Vasut   [ARM] pxa/spitz: ...
132
133
  /* SCOOP Device #1 */
  static struct resource spitz_scoop_1_resources[] = {
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
134
135
136
137
138
139
  	[0] = {
  		.start		= 0x10800000,
  		.end		= 0x10800fff,
  		.flags		= IORESOURCE_MEM,
  	},
  };
084115946   Marek Vasut   [ARM] pxa/spitz: ...
140
  static struct scoop_config spitz_scoop_1_setup = {
fff147208   Eric Miao   [ARM] pxa/spitz: ...
141
  	.io_dir		= SPITZ_SCP_IO_DIR,
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
142
  	.io_out		= SPITZ_SCP_IO_OUT,
fff147208   Eric Miao   [ARM] pxa/spitz: ...
143
144
145
  	.suspend_clr	= SPITZ_SCP_SUS_CLR,
  	.suspend_set	= SPITZ_SCP_SUS_SET,
  	.gpio_base	= SPITZ_SCP_GPIO_BASE,
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
146
  };
084115946   Marek Vasut   [ARM] pxa/spitz: ...
147
  struct platform_device spitz_scoop_1_device = {
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
148
149
150
  	.name		= "sharp-scoop",
  	.id		= 0,
  	.dev		= {
084115946   Marek Vasut   [ARM] pxa/spitz: ...
151
  		.platform_data	= &spitz_scoop_1_setup,
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
152
  	},
084115946   Marek Vasut   [ARM] pxa/spitz: ...
153
154
  	.num_resources	= ARRAY_SIZE(spitz_scoop_1_resources),
  	.resource	= spitz_scoop_1_resources,
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
155
  };
084115946   Marek Vasut   [ARM] pxa/spitz: ...
156
157
  /* SCOOP Device #2 */
  static struct resource spitz_scoop_2_resources[] = {
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
158
159
160
161
162
163
  	[0] = {
  		.start		= 0x08800040,
  		.end		= 0x08800fff,
  		.flags		= IORESOURCE_MEM,
  	},
  };
084115946   Marek Vasut   [ARM] pxa/spitz: ...
164
  static struct scoop_config spitz_scoop_2_setup = {
fff147208   Eric Miao   [ARM] pxa/spitz: ...
165
  	.io_dir		= SPITZ_SCP2_IO_DIR,
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
166
  	.io_out		= SPITZ_SCP2_IO_OUT,
fff147208   Eric Miao   [ARM] pxa/spitz: ...
167
168
169
  	.suspend_clr	= SPITZ_SCP2_SUS_CLR,
  	.suspend_set	= SPITZ_SCP2_SUS_SET,
  	.gpio_base	= SPITZ_SCP2_GPIO_BASE,
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
170
  };
084115946   Marek Vasut   [ARM] pxa/spitz: ...
171
  struct platform_device spitz_scoop_2_device = {
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
172
173
174
  	.name		= "sharp-scoop",
  	.id		= 1,
  	.dev		= {
084115946   Marek Vasut   [ARM] pxa/spitz: ...
175
  		.platform_data	= &spitz_scoop_2_setup,
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
176
  	},
084115946   Marek Vasut   [ARM] pxa/spitz: ...
177
178
  	.num_resources	= ARRAY_SIZE(spitz_scoop_2_resources),
  	.resource	= spitz_scoop_2_resources,
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
179
  };
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
180
181
  static void __init spitz_scoop_init(void)
  {
084115946   Marek Vasut   [ARM] pxa/spitz: ...
182
  	platform_device_register(&spitz_scoop_1_device);
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
183
184
185
  
  	/* Akita doesn't have the second SCOOP chip */
  	if (!machine_is_akita())
084115946   Marek Vasut   [ARM] pxa/spitz: ...
186
  		platform_device_register(&spitz_scoop_2_device);
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
187
  }
a63ae4427   Richard Purdie   [ARM] 3093/1: Sha...
188
189
  
  /* Power control is shared with between one of the CF slots and SD */
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
190
  static void spitz_card_pwr_ctrl(uint8_t enable, uint8_t new_cpr)
a63ae4427   Richard Purdie   [ARM] 3093/1: Sha...
191
  {
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
192
193
  	unsigned short cpr;
  	unsigned long flags;
a63ae4427   Richard Purdie   [ARM] 3093/1: Sha...
194

2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
195
  	if (new_cpr & 0x7) {
fff147208   Eric Miao   [ARM] pxa/spitz: ...
196
  		gpio_set_value(SPITZ_GPIO_CF_POWER, 1);
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
  		mdelay(5);
  	}
  
  	local_irq_save(flags);
  
  	cpr = read_scoop_reg(&spitz_scoop_1_device.dev, SCOOP_CPR);
  
  	if (enable & new_cpr)
  		cpr |= new_cpr;
  	else
  		cpr &= ~enable;
  
  	write_scoop_reg(&spitz_scoop_1_device.dev, SCOOP_CPR, cpr);
  
  	local_irq_restore(flags);
  
  	if (!(cpr & 0x7)) {
  		mdelay(1);
  		gpio_set_value(SPITZ_GPIO_CF_POWER, 0);
a63ae4427   Richard Purdie   [ARM] 3093/1: Sha...
216
217
  	}
  }
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
218
219
220
221
222
223
224
225
226
227
  #else
  static inline void spitz_scoop_init(void) {}
  static inline void spitz_card_pwr_ctrl(uint8_t enable, uint8_t new_cpr) {}
  #endif
  
  /******************************************************************************
   * PCMCIA
   ******************************************************************************/
  #if defined(CONFIG_PCMCIA_PXA2XX) || defined(CONFIG_PCMCIA_PXA2XX_MODULE)
  static void spitz_pcmcia_pwr(struct device *scoop, uint16_t cpr, int nr)
a63ae4427   Richard Purdie   [ARM] 3093/1: Sha...
228
229
230
  {
  	/* Only need to override behaviour for slot 0 */
  	if (nr == 0)
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
231
232
  		spitz_card_pwr_ctrl(
  			cpr & (SCOOP_CPR_CF_3V | SCOOP_CPR_CF_XV), cpr);
a63ae4427   Richard Purdie   [ARM] 3093/1: Sha...
233
234
235
  	else
  		write_scoop_reg(scoop, SCOOP_CPR, cpr);
  }
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
236
  static struct scoop_pcmcia_dev spitz_pcmcia_scoop[] = {
084115946   Marek Vasut   [ARM] pxa/spitz: ...
237
238
239
240
241
242
243
244
245
246
  	{
  		.dev		= &spitz_scoop_1_device.dev,
  		.irq		= SPITZ_IRQ_GPIO_CF_IRQ,
  		.cd_irq		= SPITZ_IRQ_GPIO_CF_CD,
  		.cd_irq_str	= "PCMCIA0 CD",
  	}, {
  		.dev		= &spitz_scoop_2_device.dev,
  		.irq		= SPITZ_IRQ_GPIO_CF2_IRQ,
  		.cd_irq		= -1,
  	},
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
247
  };
a63ae4427   Richard Purdie   [ARM] 3093/1: Sha...
248
  static struct scoop_pcmcia_config spitz_pcmcia_config = {
084115946   Marek Vasut   [ARM] pxa/spitz: ...
249
250
251
  	.devs		= &spitz_pcmcia_scoop[0],
  	.num_devs	= 2,
  	.power_ctrl	= spitz_pcmcia_pwr,
a63ae4427   Richard Purdie   [ARM] 3093/1: Sha...
252
  };
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
  static void __init spitz_pcmcia_init(void)
  {
  	/* Akita has only one PCMCIA slot used */
  	if (machine_is_akita())
  		spitz_pcmcia_config.num_devs = 1;
  
  	platform_scoop_config = &spitz_pcmcia_config;
  }
  #else
  static inline void spitz_pcmcia_init(void) {}
  #endif
  
  /******************************************************************************
   * GPIO keyboard
   ******************************************************************************/
  #if defined(CONFIG_KEYBOARD_MATRIX) || defined(CONFIG_KEYBOARD_MATRIX_MODULE)
a63ae4427   Richard Purdie   [ARM] 3093/1: Sha...
269

93dd29a81   Eric Miao   [ARM] pxa/spitz: ...
270
271
272
273
274
275
276
277
278
279
280
281
282
283
  #define SPITZ_KEY_CALENDAR	KEY_F1
  #define SPITZ_KEY_ADDRESS	KEY_F2
  #define SPITZ_KEY_FN		KEY_F3
  #define SPITZ_KEY_CANCEL	KEY_F4
  #define SPITZ_KEY_EXOK		KEY_F5
  #define SPITZ_KEY_EXCANCEL	KEY_F6
  #define SPITZ_KEY_EXJOGDOWN	KEY_F7
  #define SPITZ_KEY_EXJOGUP	KEY_F8
  #define SPITZ_KEY_JAP1		KEY_LEFTALT
  #define SPITZ_KEY_JAP2		KEY_RIGHTCTRL
  #define SPITZ_KEY_SYNC		KEY_F9
  #define SPITZ_KEY_MAIL		KEY_F10
  #define SPITZ_KEY_OK		KEY_F11
  #define SPITZ_KEY_MENU		KEY_F12
084115946   Marek Vasut   [ARM] pxa/spitz: ...
284
  static const uint32_t spitz_keymap[] = {
93dd29a81   Eric Miao   [ARM] pxa/spitz: ...
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
  	KEY(0, 0, KEY_LEFTCTRL),
  	KEY(0, 1, KEY_1),
  	KEY(0, 2, KEY_3),
  	KEY(0, 3, KEY_5),
  	KEY(0, 4, KEY_6),
  	KEY(0, 5, KEY_7),
  	KEY(0, 6, KEY_9),
  	KEY(0, 7, KEY_0),
  	KEY(0, 8, KEY_BACKSPACE),
  	KEY(0, 9, SPITZ_KEY_EXOK),	/* EXOK */
  	KEY(0, 10, SPITZ_KEY_EXCANCEL),	/* EXCANCEL */
  	KEY(1, 1, KEY_2),
  	KEY(1, 2, KEY_4),
  	KEY(1, 3, KEY_R),
  	KEY(1, 4, KEY_Y),
  	KEY(1, 5, KEY_8),
  	KEY(1, 6, KEY_I),
  	KEY(1, 7, KEY_O),
  	KEY(1, 8, KEY_P),
  	KEY(1, 9, SPITZ_KEY_EXJOGDOWN),	/* EXJOGDOWN */
  	KEY(1, 10, SPITZ_KEY_EXJOGUP),	/* EXJOGUP */
  	KEY(2, 0, KEY_TAB),
  	KEY(2, 1, KEY_Q),
  	KEY(2, 2, KEY_E),
  	KEY(2, 3, KEY_T),
  	KEY(2, 4, KEY_G),
  	KEY(2, 5, KEY_U),
  	KEY(2, 6, KEY_J),
  	KEY(2, 7, KEY_K),
  	KEY(3, 0, SPITZ_KEY_ADDRESS),	/* ADDRESS */
  	KEY(3, 1, KEY_W),
  	KEY(3, 2, KEY_S),
  	KEY(3, 3, KEY_F),
  	KEY(3, 4, KEY_V),
  	KEY(3, 5, KEY_H),
  	KEY(3, 6, KEY_M),
  	KEY(3, 7, KEY_L),
  	KEY(3, 9, KEY_RIGHTSHIFT),
  	KEY(4, 0, SPITZ_KEY_CALENDAR),	/* CALENDAR */
  	KEY(4, 1, KEY_A),
  	KEY(4, 2, KEY_D),
  	KEY(4, 3, KEY_C),
  	KEY(4, 4, KEY_B),
  	KEY(4, 5, KEY_N),
  	KEY(4, 6, KEY_DOT),
  	KEY(4, 8, KEY_ENTER),
  	KEY(4, 9, KEY_LEFTSHIFT),
  	KEY(5, 0, SPITZ_KEY_MAIL),	/* MAIL */
  	KEY(5, 1, KEY_Z),
  	KEY(5, 2, KEY_X),
  	KEY(5, 3, KEY_MINUS),
  	KEY(5, 4, KEY_SPACE),
  	KEY(5, 5, KEY_COMMA),
  	KEY(5, 7, KEY_UP),
  	KEY(5, 10, SPITZ_KEY_FN),	/* FN */
  	KEY(6, 0, KEY_SYSRQ),
  	KEY(6, 1, SPITZ_KEY_JAP1),	/* JAP1 */
  	KEY(6, 2, SPITZ_KEY_JAP2),	/* JAP2 */
  	KEY(6, 3, SPITZ_KEY_CANCEL),	/* CANCEL */
  	KEY(6, 4, SPITZ_KEY_OK),	/* OK */
  	KEY(6, 5, SPITZ_KEY_MENU),	/* MENU */
  	KEY(6, 6, KEY_LEFT),
  	KEY(6, 7, KEY_DOWN),
  	KEY(6, 8, KEY_RIGHT),
  };
084115946   Marek Vasut   [ARM] pxa/spitz: ...
350
351
352
  static const struct matrix_keymap_data spitz_keymap_data = {
  	.keymap		= spitz_keymap,
  	.keymap_size	= ARRAY_SIZE(spitz_keymap),
93dd29a81   Eric Miao   [ARM] pxa/spitz: ...
353
  };
084115946   Marek Vasut   [ARM] pxa/spitz: ...
354
  static const uint32_t spitz_row_gpios[] =
93dd29a81   Eric Miao   [ARM] pxa/spitz: ...
355
  		{ 12, 17, 91, 34, 36, 38, 39 };
084115946   Marek Vasut   [ARM] pxa/spitz: ...
356
  static const uint32_t spitz_col_gpios[] =
93dd29a81   Eric Miao   [ARM] pxa/spitz: ...
357
  		{ 88, 23, 24, 25, 26, 27, 52, 103, 107, 108, 114 };
084115946   Marek Vasut   [ARM] pxa/spitz: ...
358
359
360
361
362
363
  static struct matrix_keypad_platform_data spitz_mkp_pdata = {
  	.keymap_data		= &spitz_keymap_data,
  	.row_gpios		= spitz_row_gpios,
  	.col_gpios		= spitz_col_gpios,
  	.num_row_gpios		= ARRAY_SIZE(spitz_row_gpios),
  	.num_col_gpios		= ARRAY_SIZE(spitz_col_gpios),
93dd29a81   Eric Miao   [ARM] pxa/spitz: ...
364
365
366
367
  	.col_scan_delay_us	= 10,
  	.debounce_ms		= 10,
  	.wakeup			= 1,
  };
084115946   Marek Vasut   [ARM] pxa/spitz: ...
368
  static struct platform_device spitz_mkp_device = {
93dd29a81   Eric Miao   [ARM] pxa/spitz: ...
369
  	.name		= "matrix-keypad",
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
370
  	.id		= -1,
93dd29a81   Eric Miao   [ARM] pxa/spitz: ...
371
  	.dev		= {
084115946   Marek Vasut   [ARM] pxa/spitz: ...
372
  		.platform_data	= &spitz_mkp_pdata,
93dd29a81   Eric Miao   [ARM] pxa/spitz: ...
373
  	},
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
374
  };
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
375
376
  static void __init spitz_mkp_init(void)
  {
084115946   Marek Vasut   [ARM] pxa/spitz: ...
377
  	platform_device_register(&spitz_mkp_device);
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
378
379
380
381
  }
  #else
  static inline void spitz_mkp_init(void) {}
  #endif
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
382

2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
383
384
385
386
  /******************************************************************************
   * GPIO keys
   ******************************************************************************/
  #if defined(CONFIG_KEYBOARD_GPIO) || defined(CONFIG_KEYBOARD_GPIO_MODULE)
f6919eb41   Stanislav Brabec   [ARM] pxa/spitz: ...
387
388
389
390
391
  static struct gpio_keys_button spitz_gpio_keys[] = {
  	{
  		.type	= EV_PWR,
  		.code	= KEY_SUSPEND,
  		.gpio	= SPITZ_GPIO_ON_KEY,
b53f77106   Pavel Machek   [ARM] pxa/spitz: ...
392
  		.desc	= "On Off",
f6919eb41   Stanislav Brabec   [ARM] pxa/spitz: ...
393
394
395
396
397
398
399
  		.wakeup	= 1,
  	},
  	/* Two buttons detecting the lid state */
  	{
  		.type	= EV_SW,
  		.code	= 0,
  		.gpio	= SPITZ_GPIO_SWA,
d13fecd02   Cyril Hrubis   [ARM] pxa: fix st...
400
  		.desc	= "Display Down",
f6919eb41   Stanislav Brabec   [ARM] pxa/spitz: ...
401
402
403
404
405
  	},
  	{
  		.type	= EV_SW,
  		.code	= 1,
  		.gpio	= SPITZ_GPIO_SWB,
d13fecd02   Cyril Hrubis   [ARM] pxa: fix st...
406
  		.desc	= "Lid Closed",
f6919eb41   Stanislav Brabec   [ARM] pxa/spitz: ...
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
  	},
  };
  
  static struct gpio_keys_platform_data spitz_gpio_keys_platform_data = {
  	.buttons	= spitz_gpio_keys,
  	.nbuttons	= ARRAY_SIZE(spitz_gpio_keys),
  };
  
  static struct platform_device spitz_gpio_keys_device = {
  	.name	= "gpio-keys",
  	.id	= -1,
  	.dev	= {
  		.platform_data	= &spitz_gpio_keys_platform_data,
  	},
  };
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
422
423
424
425
426
427
428
  static void __init spitz_keys_init(void)
  {
  	platform_device_register(&spitz_gpio_keys_device);
  }
  #else
  static inline void spitz_keys_init(void) {}
  #endif
f6919eb41   Stanislav Brabec   [ARM] pxa/spitz: ...
429

2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
430
431
432
433
  /******************************************************************************
   * LEDs
   ******************************************************************************/
  #if defined(CONFIG_LEDS_GPIO) || defined(CONFIG_LEDS_GPIO_MODULE)
4fe3224ff   Eric Miao   [ARM] pxa/spitz: ...
434
435
436
437
438
439
440
441
442
443
  static struct gpio_led spitz_gpio_leds[] = {
  	{
  		.name			= "spitz:amber:charge",
  		.default_trigger	= "sharpsl-charge",
  		.gpio			= SPITZ_GPIO_LED_ORANGE,
  	},
  	{
  		.name			= "spitz:green:hddactivity",
  		.default_trigger	= "ide-disk",
  		.gpio			= SPITZ_GPIO_LED_GREEN,
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
444
  	},
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
445
  };
4fe3224ff   Eric Miao   [ARM] pxa/spitz: ...
446
447
448
  static struct gpio_led_platform_data spitz_gpio_leds_info = {
  	.leds		= spitz_gpio_leds,
  	.num_leds	= ARRAY_SIZE(spitz_gpio_leds),
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
449
  };
084115946   Marek Vasut   [ARM] pxa/spitz: ...
450
  static struct platform_device spitz_led_device = {
4fe3224ff   Eric Miao   [ARM] pxa/spitz: ...
451
  	.name		= "leds-gpio",
3179108da   Richard Purdie   [PATCH] LED: add ...
452
  	.id		= -1,
4fe3224ff   Eric Miao   [ARM] pxa/spitz: ...
453
  	.dev		= {
084115946   Marek Vasut   [ARM] pxa/spitz: ...
454
  		.platform_data	= &spitz_gpio_leds_info,
4fe3224ff   Eric Miao   [ARM] pxa/spitz: ...
455
  	},
3179108da   Richard Purdie   [PATCH] LED: add ...
456
  };
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
457
458
  static void __init spitz_leds_init(void)
  {
084115946   Marek Vasut   [ARM] pxa/spitz: ...
459
  	platform_device_register(&spitz_led_device);
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
460
461
462
463
  }
  #else
  static inline void spitz_leds_init(void) {}
  #endif
ca4d6cfce   Richard Purdie   [ARM] 4737/1: Ref...
464

2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
465
466
467
468
  /******************************************************************************
   * SSP Devices
   ******************************************************************************/
  #if defined(CONFIG_SPI_PXA2XX) || defined(CONFIG_SPI_PXA2XX_MODULE)
084115946   Marek Vasut   [ARM] pxa/spitz: ...
469
  static void spitz_ads7846_wait_for_hsync(void)
3e36c0dee   Eric Miao   [ARM] pxa: make a...
470
471
472
473
474
475
476
  {
  	while (gpio_get_value(SPITZ_GPIO_HSYNC))
  		cpu_relax();
  
  	while (!gpio_get_value(SPITZ_GPIO_HSYNC))
  		cpu_relax();
  }
859b79634   Eric Miao   [ARM] pxa/spitz: ...
477
478
479
480
481
  static struct ads7846_platform_data spitz_ads7846_info = {
  	.model			= 7846,
  	.vref_delay_usecs	= 100,
  	.x_plate_ohms		= 419,
  	.y_plate_ohms		= 486,
3318c4bdd   Pavel Machek   ARM: spitz: fix t...
482
  	.pressure_max		= 1024,
859b79634   Eric Miao   [ARM] pxa/spitz: ...
483
  	.gpio_pendown		= SPITZ_GPIO_TP_INT,
084115946   Marek Vasut   [ARM] pxa/spitz: ...
484
  	.wait_for_sync		= spitz_ads7846_wait_for_hsync,
859b79634   Eric Miao   [ARM] pxa/spitz: ...
485
  };
ca4d6cfce   Richard Purdie   [ARM] 4737/1: Ref...
486

859b79634   Eric Miao   [ARM] pxa/spitz: ...
487
  static struct pxa2xx_spi_chip spitz_ads7846_chip = {
46580c030   Mike Rapoport   [ARM] pxa: update...
488
  	.gpio_cs		= SPITZ_GPIO_ADS7846_CS,
859b79634   Eric Miao   [ARM] pxa/spitz: ...
489
  };
ca4d6cfce   Richard Purdie   [ARM] 4737/1: Ref...
490

859b79634   Eric Miao   [ARM] pxa/spitz: ...
491
  static void spitz_bl_kick_battery(void)
ca4d6cfce   Richard Purdie   [ARM] 4737/1: Ref...
492
  {
859b79634   Eric Miao   [ARM] pxa/spitz: ...
493
  	void (*kick_batt)(void);
ca4d6cfce   Richard Purdie   [ARM] 4737/1: Ref...
494

859b79634   Eric Miao   [ARM] pxa/spitz: ...
495
496
497
498
  	kick_batt = symbol_get(sharpsl_battery_kick);
  	if (kick_batt) {
  		kick_batt();
  		symbol_put(sharpsl_battery_kick);
ca4d6cfce   Richard Purdie   [ARM] 4737/1: Ref...
499
  	}
ca4d6cfce   Richard Purdie   [ARM] 4737/1: Ref...
500
  }
859b79634   Eric Miao   [ARM] pxa/spitz: ...
501
502
503
504
505
  static struct corgi_lcd_platform_data spitz_lcdcon_info = {
  	.init_mode		= CORGI_LCD_MODE_VGA,
  	.max_intensity		= 0x2f,
  	.default_intensity	= 0x1f,
  	.limit_mask		= 0x0b,
ff7a4c713   Eric Miao   [ARM] corgi_lcd: ...
506
507
  	.gpio_backlight_cont	= SPITZ_GPIO_BACKLIGHT_CONT,
  	.gpio_backlight_on	= SPITZ_GPIO_BACKLIGHT_ON,
859b79634   Eric Miao   [ARM] pxa/spitz: ...
508
509
  	.kick_battery		= spitz_bl_kick_battery,
  };
ca4d6cfce   Richard Purdie   [ARM] 4737/1: Ref...
510

859b79634   Eric Miao   [ARM] pxa/spitz: ...
511
  static struct pxa2xx_spi_chip spitz_lcdcon_chip = {
46580c030   Mike Rapoport   [ARM] pxa: update...
512
  	.gpio_cs	= SPITZ_GPIO_LCDCON_CS,
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
513
  };
859b79634   Eric Miao   [ARM] pxa/spitz: ...
514
  static struct pxa2xx_spi_chip spitz_max1111_chip = {
46580c030   Mike Rapoport   [ARM] pxa: update...
515
  	.gpio_cs	= SPITZ_GPIO_MAX1111_CS,
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
516
  };
859b79634   Eric Miao   [ARM] pxa/spitz: ...
517
518
  static struct spi_board_info spitz_spi_devices[] = {
  	{
084115946   Marek Vasut   [ARM] pxa/spitz: ...
519
520
521
522
523
524
  		.modalias		= "ads7846",
  		.max_speed_hz		= 1200000,
  		.bus_num		= 2,
  		.chip_select		= 0,
  		.platform_data		= &spitz_ads7846_info,
  		.controller_data	= &spitz_ads7846_chip,
4929f5a8a   Haojian Zhuang   ARM: pxa: rename ...
525
  		.irq			= PXA_GPIO_TO_IRQ(SPITZ_GPIO_TP_INT),
859b79634   Eric Miao   [ARM] pxa/spitz: ...
526
  	}, {
084115946   Marek Vasut   [ARM] pxa/spitz: ...
527
528
529
530
531
532
  		.modalias		= "corgi-lcd",
  		.max_speed_hz		= 50000,
  		.bus_num		= 2,
  		.chip_select		= 1,
  		.platform_data		= &spitz_lcdcon_info,
  		.controller_data	= &spitz_lcdcon_chip,
859b79634   Eric Miao   [ARM] pxa/spitz: ...
533
  	}, {
084115946   Marek Vasut   [ARM] pxa/spitz: ...
534
535
536
537
538
  		.modalias		= "max1111",
  		.max_speed_hz		= 450000,
  		.bus_num		= 2,
  		.chip_select		= 2,
  		.controller_data	= &spitz_max1111_chip,
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
539
  	},
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
540
  };
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
541
542
543
  static struct pxa2xx_spi_master spitz_spi_info = {
  	.num_chipselect	= 3,
  };
084115946   Marek Vasut   [ARM] pxa/spitz: ...
544
  static void __init spitz_spi_init(void)
859b79634   Eric Miao   [ARM] pxa/spitz: ...
545
  {
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
546
  	struct corgi_lcd_platform_data *lcd_data = &spitz_lcdcon_info;
ff7a4c713   Eric Miao   [ARM] corgi_lcd: ...
547
  	if (machine_is_akita()) {
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
548
549
  		lcd_data->gpio_backlight_cont = AKITA_GPIO_BACKLIGHT_CONT;
  		lcd_data->gpio_backlight_on = AKITA_GPIO_BACKLIGHT_ON;
ff7a4c713   Eric Miao   [ARM] corgi_lcd: ...
550
  	}
859b79634   Eric Miao   [ARM] pxa/spitz: ...
551
552
  	pxa2xx_set_spi_info(2, &spitz_spi_info);
  	spi_register_board_info(ARRAY_AND_SIZE(spitz_spi_devices));
859b79634   Eric Miao   [ARM] pxa/spitz: ...
553
554
  }
  #else
084115946   Marek Vasut   [ARM] pxa/spitz: ...
555
  static inline void spitz_spi_init(void) {}
859b79634   Eric Miao   [ARM] pxa/spitz: ...
556
  #endif
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
557

2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
558
559
560
561
  /******************************************************************************
   * SD/MMC card controller
   ******************************************************************************/
  #if defined(CONFIG_MMC_PXA) || defined(CONFIG_MMC_PXA_MODULE)
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
562
  /*
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
563
564
   * NOTE: The card detect interrupt isn't debounced so we delay it by 250ms to
   * give the card a chance to fully insert/eject.
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
565
   */
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
566
567
568
  static void spitz_mci_setpower(struct device *dev, unsigned int vdd)
  {
  	struct pxamci_platform_data* p_d = dev->platform_data;
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
569
570
  	if ((1 << vdd) & p_d->ocr_mask)
  		spitz_card_pwr_ctrl(SCOOP_CPR_SD_3V, SCOOP_CPR_SD_3V);
a63ae4427   Richard Purdie   [ARM] 3093/1: Sha...
571
  	else
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
572
  		spitz_card_pwr_ctrl(SCOOP_CPR_SD_3V, 0x0);
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
573
  }
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
574
  static struct pxamci_platform_data spitz_mci_platform_data = {
f97cab28b   Eric Miao   [ARM] pxa: make i...
575
  	.detect_delay_ms	= 250,
7a648256b   Robert Jarzmik   [ARM] pxa: factor...
576
  	.ocr_mask		= MMC_VDD_32_33|MMC_VDD_33_34,
084115946   Marek Vasut   [ARM] pxa/spitz: ...
577
  	.setpower		= spitz_mci_setpower,
7a648256b   Robert Jarzmik   [ARM] pxa: factor...
578
579
580
  	.gpio_card_detect	= SPITZ_GPIO_nSD_DETECT,
  	.gpio_card_ro		= SPITZ_GPIO_nSD_WP,
  	.gpio_power		= -1,
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
581
  };
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
582
583
584
585
586
587
588
  static void __init spitz_mmc_init(void)
  {
  	pxa_set_mci_info(&spitz_mci_platform_data);
  }
  #else
  static inline void spitz_mmc_init(void) {}
  #endif
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
589

2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
590
591
592
593
  /******************************************************************************
   * USB Host
   ******************************************************************************/
  #if defined(CONFIG_USB_OHCI_HCD) || defined(CONFIG_USB_OHCI_HCD_MODULE)
3125c68d7   Richard Purdie   [ARM] 3227/1: Spi...
594
595
  static int spitz_ohci_init(struct device *dev)
  {
dd5980d68   Eric Miao   [ARM] pxa/spitz: ...
596
  	int err;
3125c68d7   Richard Purdie   [ARM] 3227/1: Spi...
597

dd5980d68   Eric Miao   [ARM] pxa/spitz: ...
598
599
600
  	err = gpio_request(SPITZ_GPIO_USB_HOST, "USB_HOST");
  	if (err)
  		return err;
3125c68d7   Richard Purdie   [ARM] 3227/1: Spi...
601

2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
602
  	/* Only Port 2 is connected, setup USB Port 2 Output Control Register */
3125c68d7   Richard Purdie   [ARM] 3227/1: Spi...
603
  	UP2OCR = UP2OCR_HXS | UP2OCR_HXOE | UP2OCR_DPPDE | UP2OCR_DMPDE;
3125c68d7   Richard Purdie   [ARM] 3227/1: Spi...
604

097b53348   Eric Miao   [ARM] ohci-pxa27x...
605
  	return gpio_direction_output(SPITZ_GPIO_USB_HOST, 1);
3125c68d7   Richard Purdie   [ARM] 3227/1: Spi...
606
  }
a81b38688   Dmitry Eremin-Solenikov   [ARM] pxa/spitz: ...
607
608
609
610
  static void spitz_ohci_exit(struct device *dev)
  {
  	gpio_free(SPITZ_GPIO_USB_HOST);
  }
3125c68d7   Richard Purdie   [ARM] 3227/1: Spi...
611
612
613
  static struct pxaohci_platform_data spitz_ohci_platform_data = {
  	.port_mode	= PMM_NPS_MODE,
  	.init		= spitz_ohci_init,
a81b38688   Dmitry Eremin-Solenikov   [ARM] pxa/spitz: ...
614
  	.exit		= spitz_ohci_exit,
097b53348   Eric Miao   [ARM] ohci-pxa27x...
615
  	.flags		= ENABLE_PORT_ALL | NO_OC_PROTECTION,
0c27c5d5b   Richard Purdie   [ARM] 3547/1: PXA...
616
  	.power_budget	= 150,
3125c68d7   Richard Purdie   [ARM] 3227/1: Spi...
617
  };
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
618
619
620
621
622
623
624
  static void __init spitz_uhc_init(void)
  {
  	pxa_set_ohci_info(&spitz_ohci_platform_data);
  }
  #else
  static inline void spitz_uhc_init(void) {}
  #endif
3125c68d7   Richard Purdie   [ARM] 3227/1: Spi...
625

2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
626
627
628
629
  /******************************************************************************
   * IrDA
   ******************************************************************************/
  #if defined(CONFIG_PXA_FICP) || defined(CONFIG_PXA_FICP_MODULE)
dc07845d0   Richard Purdie   [ARM] 3069/1: Add...
630
  static struct pxaficp_platform_data spitz_ficp_platform_data = {
fff147208   Eric Miao   [ARM] pxa/spitz: ...
631
  	.transceiver_cap	= IR_SIRMODE | IR_OFF,
dc07845d0   Richard Purdie   [ARM] 3069/1: Add...
632
  };
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
633
634
635
636
637
638
  static void __init spitz_irda_init(void)
  {
  	if (machine_is_akita())
  		spitz_ficp_platform_data.gpio_pwdown = AKITA_GPIO_IR_ON;
  	else
  		spitz_ficp_platform_data.gpio_pwdown = SPITZ_GPIO_IR_ON;
dc07845d0   Richard Purdie   [ARM] 3069/1: Add...
639

2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
640
641
642
643
644
  	pxa_set_ficp_info(&spitz_ficp_platform_data);
  }
  #else
  static inline void spitz_irda_init(void) {}
  #endif
d14b272bc   Richard Purdie   [ARM] 3848/1: pxa...
645

2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
646
647
648
649
  /******************************************************************************
   * Framebuffer
   ******************************************************************************/
  #if defined(CONFIG_FB_PXA) || defined(CONFIG_FB_PXA_MODULE)
d14b272bc   Richard Purdie   [ARM] 3848/1: pxa...
650
  static struct pxafb_mode_info spitz_pxafb_modes[] = {
084115946   Marek Vasut   [ARM] pxa/spitz: ...
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
  	{
  		.pixclock       = 19231,
  		.xres           = 480,
  		.yres           = 640,
  		.bpp            = 16,
  		.hsync_len      = 40,
  		.left_margin    = 46,
  		.right_margin   = 125,
  		.vsync_len      = 3,
  		.upper_margin   = 1,
  		.lower_margin   = 0,
  		.sync           = 0,
  	}, {
  		.pixclock       = 134617,
  		.xres           = 240,
  		.yres           = 320,
  		.bpp            = 16,
  		.hsync_len      = 20,
  		.left_margin    = 20,
  		.right_margin   = 46,
  		.vsync_len      = 2,
  		.upper_margin   = 1,
  		.lower_margin   = 0,
  		.sync           = 0,
  	},
d14b272bc   Richard Purdie   [ARM] 3848/1: pxa...
676
677
678
  };
  
  static struct pxafb_mach_info spitz_pxafb_info = {
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
679
680
  	.modes          = spitz_pxafb_modes,
  	.num_modes      = ARRAY_SIZE(spitz_pxafb_modes),
d14b272bc   Richard Purdie   [ARM] 3848/1: pxa...
681
  	.fixed_modes    = 1,
79009a063   Eric Miao   [ARM] pxa/spitz: ...
682
  	.lcd_conn	= LCD_COLOR_TFT_16BPP | LCD_ALTERNATE_MAPPING,
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
683
  };
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
684
685
  static void __init spitz_lcd_init(void)
  {
4321e1a12   Russell King - ARM Linux   ARM: pxa: clean u...
686
  	pxa_set_fb_info(NULL, &spitz_pxafb_info);
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
687
688
689
690
691
692
693
694
695
  }
  #else
  static inline void spitz_lcd_init(void) {}
  #endif
  
  /******************************************************************************
   * Framebuffer
   ******************************************************************************/
  #if defined(CONFIG_MTD_NAND_SHARPSL) || defined(CONFIG_MTD_NAND_SHARPSL_MODULE)
084115946   Marek Vasut   [ARM] pxa/spitz: ...
696
  static struct mtd_partition spitz_nand_partitions[] = {
6af7a8eb1   Dmitry Eremin-Solenikov   [MTD] sharpsl-nan...
697
698
699
700
  	{
  		.name = "System Area",
  		.offset = 0,
  		.size = 7 * 1024 * 1024,
084115946   Marek Vasut   [ARM] pxa/spitz: ...
701
  	}, {
6af7a8eb1   Dmitry Eremin-Solenikov   [MTD] sharpsl-nan...
702
703
  		.name = "Root Filesystem",
  		.offset = 7 * 1024 * 1024,
084115946   Marek Vasut   [ARM] pxa/spitz: ...
704
  	}, {
6af7a8eb1   Dmitry Eremin-Solenikov   [MTD] sharpsl-nan...
705
706
707
708
709
710
711
  		.name = "Home Filesystem",
  		.offset = MTDPART_OFS_APPEND,
  		.size = MTDPART_SIZ_FULL,
  	},
  };
  
  static uint8_t scan_ff_pattern[] = { 0xff, 0xff };
084115946   Marek Vasut   [ARM] pxa/spitz: ...
712
713
714
715
716
  static struct nand_bbt_descr spitz_nand_bbt = {
  	.options	= 0,
  	.offs		= 4,
  	.len		= 2,
  	.pattern	= scan_ff_pattern
6af7a8eb1   Dmitry Eremin-Solenikov   [MTD] sharpsl-nan...
717
  };
084115946   Marek Vasut   [ARM] pxa/spitz: ...
718
  static struct nand_ecclayout akita_oobinfo = {
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
719
720
721
722
723
724
725
  	.oobfree	= { {0x08, 0x09} },
  	.eccbytes	= 24,
  	.eccpos		= {
  			0x05, 0x01, 0x02, 0x03, 0x06, 0x07, 0x15, 0x11,
  			0x12, 0x13, 0x16, 0x17, 0x25, 0x21, 0x22, 0x23,
  			0x26, 0x27, 0x35, 0x31, 0x32, 0x33, 0x36, 0x37,
  	},
6af7a8eb1   Dmitry Eremin-Solenikov   [MTD] sharpsl-nan...
726
  };
084115946   Marek Vasut   [ARM] pxa/spitz: ...
727
728
729
730
  static struct sharpsl_nand_platform_data spitz_nand_pdata = {
  	.badblock_pattern	= &spitz_nand_bbt,
  	.partitions		= spitz_nand_partitions,
  	.nr_partitions		= ARRAY_SIZE(spitz_nand_partitions),
6af7a8eb1   Dmitry Eremin-Solenikov   [MTD] sharpsl-nan...
731
  };
084115946   Marek Vasut   [ARM] pxa/spitz: ...
732
  static struct resource spitz_nand_resources[] = {
6af7a8eb1   Dmitry Eremin-Solenikov   [MTD] sharpsl-nan...
733
  	{
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
734
735
  		.start	= PXA_CS3_PHYS,
  		.end	= PXA_CS3_PHYS + SZ_4K - 1,
6af7a8eb1   Dmitry Eremin-Solenikov   [MTD] sharpsl-nan...
736
737
738
  		.flags	= IORESOURCE_MEM,
  	},
  };
084115946   Marek Vasut   [ARM] pxa/spitz: ...
739
  static struct platform_device spitz_nand_device = {
6af7a8eb1   Dmitry Eremin-Solenikov   [MTD] sharpsl-nan...
740
741
  	.name		= "sharpsl-nand",
  	.id		= -1,
084115946   Marek Vasut   [ARM] pxa/spitz: ...
742
743
  	.resource	= spitz_nand_resources,
  	.num_resources	= ARRAY_SIZE(spitz_nand_resources),
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
744
  	.dev		= {
084115946   Marek Vasut   [ARM] pxa/spitz: ...
745
  		.platform_data	= &spitz_nand_pdata,
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
746
  	}
6af7a8eb1   Dmitry Eremin-Solenikov   [MTD] sharpsl-nan...
747
  };
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
748
749
750
  static void __init spitz_nand_init(void)
  {
  	if (machine_is_spitz()) {
084115946   Marek Vasut   [ARM] pxa/spitz: ...
751
  		spitz_nand_partitions[1].size = 5 * 1024 * 1024;
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
752
  	} else if (machine_is_akita()) {
084115946   Marek Vasut   [ARM] pxa/spitz: ...
753
754
755
  		spitz_nand_partitions[1].size = 58 * 1024 * 1024;
  		spitz_nand_bbt.len = 1;
  		spitz_nand_pdata.ecc_layout = &akita_oobinfo;
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
756
  	} else if (machine_is_borzoi()) {
084115946   Marek Vasut   [ARM] pxa/spitz: ...
757
758
759
  		spitz_nand_partitions[1].size = 32 * 1024 * 1024;
  		spitz_nand_bbt.len = 1;
  		spitz_nand_pdata.ecc_layout = &akita_oobinfo;
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
760
  	}
084115946   Marek Vasut   [ARM] pxa/spitz: ...
761
  	platform_device_register(&spitz_nand_device);
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
762
763
764
765
  }
  #else
  static inline void spitz_nand_init(void) {}
  #endif
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
766

2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
767
768
769
770
  /******************************************************************************
   * NOR Flash
   ******************************************************************************/
  #if defined(CONFIG_MTD_PHYSMAP) || defined(CONFIG_MTD_PHYSMAP_MODULE)
084115946   Marek Vasut   [ARM] pxa/spitz: ...
771
  static struct mtd_partition spitz_rom_parts[] = {
e5d3bf3c1   Dmitry Eremin-Solenikov   [ARM] pxa/spitz: ...
772
773
774
775
776
777
  	{
  		.name	="Boot PROM Filesystem",
  		.offset	= 0x00140000,
  		.size	= MTDPART_SIZ_FULL,
  	},
  };
084115946   Marek Vasut   [ARM] pxa/spitz: ...
778
  static struct physmap_flash_data spitz_rom_data = {
e5d3bf3c1   Dmitry Eremin-Solenikov   [ARM] pxa/spitz: ...
779
  	.width		= 2,
084115946   Marek Vasut   [ARM] pxa/spitz: ...
780
781
  	.nr_parts	= ARRAY_SIZE(spitz_rom_parts),
  	.parts		= spitz_rom_parts,
e5d3bf3c1   Dmitry Eremin-Solenikov   [ARM] pxa/spitz: ...
782
  };
084115946   Marek Vasut   [ARM] pxa/spitz: ...
783
  static struct resource spitz_rom_resources[] = {
e5d3bf3c1   Dmitry Eremin-Solenikov   [ARM] pxa/spitz: ...
784
  	{
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
785
786
  		.start	= PXA_CS0_PHYS,
  		.end	= PXA_CS0_PHYS + SZ_8M - 1,
e5d3bf3c1   Dmitry Eremin-Solenikov   [ARM] pxa/spitz: ...
787
788
789
  		.flags	= IORESOURCE_MEM,
  	},
  };
084115946   Marek Vasut   [ARM] pxa/spitz: ...
790
791
792
793
794
  static struct platform_device spitz_rom_device = {
  	.name		= "physmap-flash",
  	.id		= -1,
  	.resource	= spitz_rom_resources,
  	.num_resources	= ARRAY_SIZE(spitz_rom_resources),
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
795
  	.dev		= {
084115946   Marek Vasut   [ARM] pxa/spitz: ...
796
  		.platform_data	= &spitz_rom_data,
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
797
  	},
e5d3bf3c1   Dmitry Eremin-Solenikov   [ARM] pxa/spitz: ...
798
  };
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
799
800
  static void __init spitz_nor_init(void)
  {
084115946   Marek Vasut   [ARM] pxa/spitz: ...
801
  	platform_device_register(&spitz_rom_device);
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
802
803
804
805
806
807
808
809
810
811
812
  }
  #else
  static inline void spitz_nor_init(void) {}
  #endif
  
  /******************************************************************************
   * GPIO expander
   ******************************************************************************/
  #if defined(CONFIG_I2C_PXA) || defined(CONFIG_I2C_PXA_MODULE)
  static struct pca953x_platform_data akita_pca953x_pdata = {
  	.gpio_base		= AKITA_IOEXP_GPIO_BASE,
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
813
  };
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
  static struct i2c_board_info spitz_i2c_devs[] = {
  	{
  		.type		= "wm8750",
  		.addr		= 0x1b,
  	}, {
  		.type		= "max7310",
  		.addr		= 0x18,
  		.platform_data	= &akita_pca953x_pdata,
  	},
  };
  
  static struct regulator_consumer_supply isl6271a_consumers[] = {
  	{
  		.supply	= "vcc_core",
  	}
e5d3bf3c1   Dmitry Eremin-Solenikov   [ARM] pxa/spitz: ...
829
  };
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
830
831
832
833
834
835
836
837
838
839
840
841
  static struct regulator_init_data isl6271a_info[] = {
  	{
  		.constraints = {
  			.name		= "vcc_core range",
  			.min_uV		= 850000,
  			.max_uV		= 1600000,
  			.always_on	= 1,
  			.valid_ops_mask	= REGULATOR_CHANGE_VOLTAGE,
  		},
  	.consumer_supplies	= isl6271a_consumers,
  	.num_consumer_supplies	= ARRAY_SIZE(isl6271a_consumers),
  	}
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
842
  };
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
  static struct i2c_board_info spitz_pi2c_devs[] = {
  	{
  		.type		= "isl6271a",
  		.addr		= 0x0c,
  		.platform_data	= &isl6271a_info,
  	},
  };
  
  static void __init spitz_i2c_init(void)
  {
  	int size = ARRAY_SIZE(spitz_i2c_devs);
  
  	/* Only Akita has the max7310 chip */
  	if (!machine_is_akita())
  		size--;
  
  	pxa_set_i2c_info(NULL);
  	pxa27x_set_i2c_power_info(NULL);
  	i2c_register_board_info(0, spitz_i2c_devs, size);
  	i2c_register_board_info(1, ARRAY_AND_SIZE(spitz_pi2c_devs));
  }
  #else
  static inline void spitz_i2c_init(void) {}
  #endif
  
  /******************************************************************************
   * Machine init
   ******************************************************************************/
74617fb6b   Richard Purdie   [ARM] 3593/1: Add...
871
872
  static void spitz_poweroff(void)
  {
271a74fc8   Russell King   ARM: restart: pxa...
873
  	pxa_restart('g', NULL);
74617fb6b   Richard Purdie   [ARM] 3593/1: Add...
874
  }
be093beb6   Russell King   [ARM] pass reboot...
875
  static void spitz_restart(char mode, const char *cmd)
74617fb6b   Richard Purdie   [ARM] 3593/1: Add...
876
  {
ad68bb9f7   Marek Vasut   ARM: pxa: Access ...
877
  	uint32_t msc0 = __raw_readl(MSC0);
74617fb6b   Richard Purdie   [ARM] 3593/1: Add...
878
  	/* Bootloader magic for a reboot */
ad68bb9f7   Marek Vasut   ARM: pxa: Access ...
879
880
  	if ((msc0 & 0xffff0000) == 0x7ff00000)
  		__raw_writel((msc0 & 0xffff) | 0x7ee00000, MSC0);
74617fb6b   Richard Purdie   [ARM] 3593/1: Add...
881
882
883
  
  	spitz_poweroff();
  }
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
884
  static void __init spitz_init(void)
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
885
  {
216e3b7ab   Daniel Ribeiro   [ARM] pxa: allow ...
886
  	init_gpio_reset(SPITZ_GPIO_ON_RESET, 1, 0);
74617fb6b   Richard Purdie   [ARM] 3593/1: Add...
887
  	pm_power_off = spitz_poweroff;
74617fb6b   Richard Purdie   [ARM] 3593/1: Add...
888

0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
889
  	PMCR = 0x00;
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
890
891
  	/* Stop 3.6MHz and drive HIGH to PCMCIA and CS */
  	PCFR |= PCFR_OPDE;
5e96adec6   Eric Miao   [ARM] pxa/spitz: ...
892
  	pxa2xx_mfp_config(ARRAY_AND_SIZE(spitz_pin_config));
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
893

cc155c6f2   Russell King   [ARM] pxa: allow ...
894
895
896
  	pxa_set_ffuart_info(NULL);
  	pxa_set_btuart_info(NULL);
  	pxa_set_stuart_info(NULL);
084115946   Marek Vasut   [ARM] pxa/spitz: ...
897
  	spitz_spi_init();
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
898
899
900
901
902
903
904
905
906
907
908
909
  	spitz_scoop_init();
  	spitz_mkp_init();
  	spitz_keys_init();
  	spitz_leds_init();
  	spitz_mmc_init();
  	spitz_pcmcia_init();
  	spitz_irda_init();
  	spitz_uhc_init();
  	spitz_lcd_init();
  	spitz_nor_init();
  	spitz_nand_init();
  	spitz_i2c_init();
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
910
  }
0744a3ee3   Russell King   ARM: platform fix...
911
912
  static void __init spitz_fixup(struct tag *tags, char **cmdline,
  			       struct meminfo *mi)
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
913
914
915
916
  {
  	sharpsl_save_param();
  	mi->nr_banks = 1;
  	mi->bank[0].start = 0xa0000000;
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
917
918
919
920
921
  	mi->bank[0].size = (64*1024*1024);
  }
  
  #ifdef CONFIG_MACH_SPITZ
  MACHINE_START(SPITZ, "SHARP Spitz")
34adeda94   Russell King   ARM: restart: add...
922
  	.restart_mode	= 'g',
084115946   Marek Vasut   [ARM] pxa/spitz: ...
923
  	.fixup		= spitz_fixup,
851982c1b   Marek Vasut   ARM: pxa: Introdu...
924
  	.map_io		= pxa27x_map_io,
cd49104d9   Eric Miao   [ARM] 4450/1: pxa...
925
  	.init_irq	= pxa27x_init_irq,
8a97ae2f5   Eric Miao   ARM: pxa: enable ...
926
  	.handle_irq	= pxa27x_handle_irq,
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
927
928
  	.init_machine	= spitz_init,
  	.timer		= &pxa_timer,
271a74fc8   Russell King   ARM: restart: pxa...
929
  	.restart	= spitz_restart,
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
930
931
932
933
934
  MACHINE_END
  #endif
  
  #ifdef CONFIG_MACH_BORZOI
  MACHINE_START(BORZOI, "SHARP Borzoi")
34adeda94   Russell King   ARM: restart: add...
935
  	.restart_mode	= 'g',
084115946   Marek Vasut   [ARM] pxa/spitz: ...
936
  	.fixup		= spitz_fixup,
851982c1b   Marek Vasut   ARM: pxa: Introdu...
937
  	.map_io		= pxa27x_map_io,
cd49104d9   Eric Miao   [ARM] 4450/1: pxa...
938
  	.init_irq	= pxa27x_init_irq,
8a97ae2f5   Eric Miao   ARM: pxa: enable ...
939
  	.handle_irq	= pxa27x_handle_irq,
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
940
941
  	.init_machine	= spitz_init,
  	.timer		= &pxa_timer,
271a74fc8   Russell King   ARM: restart: pxa...
942
  	.restart	= spitz_restart,
0dd28f1dd   Richard Purdie   [PATCH] SharpSL: ...
943
944
  MACHINE_END
  #endif
94cabd003   Richard Purdie   [ARM] 3149/1: Sha...
945
946
947
  
  #ifdef CONFIG_MACH_AKITA
  MACHINE_START(AKITA, "SHARP Akita")
34adeda94   Russell King   ARM: restart: add...
948
  	.restart_mode	= 'g',
084115946   Marek Vasut   [ARM] pxa/spitz: ...
949
  	.fixup		= spitz_fixup,
851982c1b   Marek Vasut   ARM: pxa: Introdu...
950
  	.map_io		= pxa27x_map_io,
cd49104d9   Eric Miao   [ARM] 4450/1: pxa...
951
  	.init_irq	= pxa27x_init_irq,
8a97ae2f5   Eric Miao   ARM: pxa: enable ...
952
  	.handle_irq	= pxa27x_handle_irq,
2d679827e   Marek Vasut   [ARM] pxa/spitz: ...
953
  	.init_machine	= spitz_init,
94cabd003   Richard Purdie   [ARM] 3149/1: Sha...
954
  	.timer		= &pxa_timer,
271a74fc8   Russell King   ARM: restart: pxa...
955
  	.restart	= spitz_restart,
94cabd003   Richard Purdie   [ARM] 3149/1: Sha...
956
957
  MACHINE_END
  #endif