diff options
author | Sundar Iyer <sundar.iyer@stericsson.com> | 2010-09-29 22:43:09 -0400 |
---|---|---|
committer | Dmitry Torokhov <dmitry.torokhov@gmail.com> | 2010-10-13 10:49:24 -0400 |
commit | 4c61c8457ee92a2afc5a43aa0821971727ebd38c (patch) | |
tree | 4fa8ea576337b003bad0548a881cb5a01def0c86 /arch/arm/mach-ux500 | |
parent | 1158f0f16224068e27e384c1a27218aa00243967 (diff) |
ux500 - add platform data for Nomadik SKE keypad controller
Signed-off-by: Sundar Iyer <sundar.iyer@stericsson.com>
Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
Diffstat (limited to 'arch/arm/mach-ux500')
-rw-r--r-- | arch/arm/mach-ux500/board-mop500.c | 129 | ||||
-rw-r--r-- | arch/arm/mach-ux500/clock.c | 1 | ||||
-rw-r--r-- | arch/arm/mach-ux500/devices-db8500.c | 20 | ||||
-rw-r--r-- | arch/arm/mach-ux500/include/mach/devices.h | 1 | ||||
-rw-r--r-- | arch/arm/mach-ux500/pins-db8500.h | 32 |
5 files changed, 167 insertions, 16 deletions
diff --git a/arch/arm/mach-ux500/board-mop500.c b/arch/arm/mach-ux500/board-mop500.c index 0e8fd135a57d..5265fb9835cc 100644 --- a/arch/arm/mach-ux500/board-mop500.c +++ b/arch/arm/mach-ux500/board-mop500.c | |||
@@ -18,12 +18,14 @@ | |||
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> |
@@ -47,6 +49,24 @@ static pin_cfg_t mop500_pins[] = { | |||
47 | GPIO11_I2C2_SCL, | 49 | GPIO11_I2C2_SCL, |
48 | GPIO229_I2C3_SDA, | 50 | GPIO229_I2C3_SDA, |
49 | GPIO230_I2C3_SCL, | 51 | GPIO230_I2C3_SCL, |
52 | |||
53 | /* SKE keypad */ | ||
54 | GPIO153_KP_I7, | ||
55 | GPIO154_KP_I6, | ||
56 | GPIO155_KP_I5, | ||
57 | GPIO156_KP_I4, | ||
58 | GPIO157_KP_O7, | ||
59 | GPIO158_KP_O6, | ||
60 | GPIO159_KP_O5, | ||
61 | GPIO160_KP_O4, | ||
62 | GPIO161_KP_I3, | ||
63 | GPIO162_KP_I2, | ||
64 | GPIO163_KP_I1, | ||
65 | GPIO164_KP_I0, | ||
66 | GPIO165_KP_O3, | ||
67 | GPIO166_KP_O2, | ||
68 | GPIO167_KP_O1, | ||
69 | GPIO168_KP_O0, | ||
50 | }; | 70 | }; |
51 | 71 | ||
52 | static void ab4500_spi_cs_control(u32 command) | 72 | static void ab4500_spi_cs_control(u32 command) |
@@ -134,12 +154,120 @@ static struct amba_device *amba_devs[] __initdata = { | |||
134 | &u8500_ssp0_device, | 154 | &u8500_ssp0_device, |
135 | }; | 155 | }; |
136 | 156 | ||
157 | static const unsigned int ux500_keymap[] = { | ||
158 | KEY(2, 5, KEY_END), | ||
159 | KEY(4, 1, KEY_POWER), | ||
160 | KEY(3, 5, KEY_VOLUMEDOWN), | ||
161 | KEY(1, 3, KEY_3), | ||
162 | KEY(5, 2, KEY_RIGHT), | ||
163 | KEY(5, 0, KEY_9), | ||
164 | |||
165 | KEY(0, 5, KEY_MENU), | ||
166 | KEY(7, 6, KEY_ENTER), | ||
167 | KEY(4, 5, KEY_0), | ||
168 | KEY(6, 7, KEY_2), | ||
169 | KEY(3, 4, KEY_UP), | ||
170 | KEY(3, 3, KEY_DOWN), | ||
171 | |||
172 | KEY(6, 4, KEY_SEND), | ||
173 | KEY(6, 2, KEY_BACK), | ||
174 | KEY(4, 2, KEY_VOLUMEUP), | ||
175 | KEY(5, 5, KEY_1), | ||
176 | KEY(4, 3, KEY_LEFT), | ||
177 | KEY(3, 2, KEY_7), | ||
178 | }; | ||
179 | |||
180 | static const struct matrix_keymap_data ux500_keymap_data = { | ||
181 | .keymap = ux500_keymap, | ||
182 | .keymap_size = ARRAY_SIZE(ux500_keymap), | ||
183 | }; | ||
184 | |||
185 | /* | ||
186 | * Nomadik SKE keypad | ||
187 | */ | ||
188 | #define ROW_PIN_I0 164 | ||
189 | #define ROW_PIN_I1 163 | ||
190 | #define ROW_PIN_I2 162 | ||
191 | #define ROW_PIN_I3 161 | ||
192 | #define ROW_PIN_I4 156 | ||
193 | #define ROW_PIN_I5 155 | ||
194 | #define ROW_PIN_I6 154 | ||
195 | #define ROW_PIN_I7 153 | ||
196 | #define COL_PIN_O0 168 | ||
197 | #define COL_PIN_O1 167 | ||
198 | #define COL_PIN_O2 166 | ||
199 | #define COL_PIN_O3 165 | ||
200 | #define COL_PIN_O4 160 | ||
201 | #define COL_PIN_O5 159 | ||
202 | #define COL_PIN_O6 158 | ||
203 | #define COL_PIN_O7 157 | ||
204 | |||
205 | #define SKE_KPD_MAX_ROWS 8 | ||
206 | #define SKE_KPD_MAX_COLS 8 | ||
207 | |||
208 | static int ske_kp_rows[] = { | ||
209 | ROW_PIN_I0, ROW_PIN_I1, ROW_PIN_I2, ROW_PIN_I3, | ||
210 | ROW_PIN_I4, ROW_PIN_I5, ROW_PIN_I6, ROW_PIN_I7, | ||
211 | }; | ||
212 | |||
213 | /* | ||
214 | * ske_set_gpio_row: request and set gpio rows | ||
215 | */ | ||
216 | static int ske_set_gpio_row(int gpio) | ||
217 | { | ||
218 | int ret; | ||
219 | |||
220 | ret = gpio_request(gpio, "ske-kp"); | ||
221 | if (ret < 0) { | ||
222 | pr_err("ske_set_gpio_row: gpio request failed\n"); | ||
223 | return ret; | ||
224 | } | ||
225 | |||
226 | ret = gpio_direction_output(gpio, 1); | ||
227 | if (ret < 0) { | ||
228 | pr_err("ske_set_gpio_row: gpio direction failed\n"); | ||
229 | gpio_free(gpio); | ||
230 | } | ||
231 | |||
232 | return ret; | ||
233 | } | ||
234 | |||
235 | /* | ||
236 | * ske_kp_init - enable the gpio configuration | ||
237 | */ | ||
238 | static int ske_kp_init(void) | ||
239 | { | ||
240 | int ret, i; | ||
241 | |||
242 | for (i = 0; i < SKE_KPD_MAX_ROWS; i++) { | ||
243 | ret = ske_set_gpio_row(ske_kp_rows[i]); | ||
244 | if (ret < 0) { | ||
245 | pr_err("ske_kp_init: failed init\n"); | ||
246 | return ret; | ||
247 | } | ||
248 | } | ||
249 | |||
250 | return 0; | ||
251 | } | ||
252 | |||
253 | static struct ske_keypad_platform_data ske_keypad_board = { | ||
254 | .init = ske_kp_init, | ||
255 | .keymap_data = &ux500_keymap_data, | ||
256 | .no_autorepeat = true, | ||
257 | .krow = SKE_KPD_MAX_ROWS, /* 8x8 matrix */ | ||
258 | .kcol = SKE_KPD_MAX_COLS, | ||
259 | .debounce_ms = 40, /* in millsecs */ | ||
260 | }; | ||
261 | |||
262 | |||
263 | |||
137 | /* add any platform devices here - TODO */ | 264 | /* add any platform devices here - TODO */ |
138 | static struct platform_device *platform_devs[] __initdata = { | 265 | static struct platform_device *platform_devs[] __initdata = { |
139 | &u8500_i2c0_device, | 266 | &u8500_i2c0_device, |
140 | &ux500_i2c1_device, | 267 | &ux500_i2c1_device, |
141 | &ux500_i2c2_device, | 268 | &ux500_i2c2_device, |
142 | &ux500_i2c3_device, | 269 | &ux500_i2c3_device, |
270 | &ux500_ske_keypad_device, | ||
143 | }; | 271 | }; |
144 | 272 | ||
145 | static void __init u8500_init_machine(void) | 273 | static void __init u8500_init_machine(void) |
@@ -154,6 +282,7 @@ static void __init u8500_init_machine(void) | |||
154 | ux500_i2c1_device.dev.platform_data = &u8500_i2c1_data; | 282 | ux500_i2c1_device.dev.platform_data = &u8500_i2c1_data; |
155 | ux500_i2c2_device.dev.platform_data = &u8500_i2c2_data; | 283 | ux500_i2c2_device.dev.platform_data = &u8500_i2c2_data; |
156 | ux500_i2c3_device.dev.platform_data = &u8500_i2c3_data; | 284 | ux500_i2c3_device.dev.platform_data = &u8500_i2c3_data; |
285 | ux500_ske_keypad_device.dev.platform_data = &ske_keypad_board; | ||
157 | 286 | ||
158 | u8500_ssp0_device.dev.platform_data = &ssp0_platform_data; | 287 | u8500_ssp0_device.dev.platform_data = &ssp0_platform_data; |
159 | 288 | ||
diff --git a/arch/arm/mach-ux500/clock.c b/arch/arm/mach-ux500/clock.c index d8ab7f184fe4..1675047daf20 100644 --- a/arch/arm/mach-ux500/clock.c +++ b/arch/arm/mach-ux500/clock.c | |||
@@ -477,6 +477,7 @@ static struct clk_lookup u8500_common_clks[] = { | |||
477 | CLK(sdi5, "sdi5", NULL), | 477 | CLK(sdi5, "sdi5", NULL), |
478 | CLK(uart2, "uart2", NULL), | 478 | CLK(uart2, "uart2", NULL), |
479 | CLK(ske, "ske", NULL), | 479 | CLK(ske, "ske", NULL), |
480 | CLK(ske, "nmk-ske-keypad", NULL), | ||
480 | CLK(sdi2, "sdi2", NULL), | 481 | CLK(sdi2, "sdi2", NULL), |
481 | CLK(i2c0, "nmk-i2c.0", NULL), | 482 | CLK(i2c0, "nmk-i2c.0", NULL), |
482 | CLK(fsmc, "fsmc", NULL), | 483 | CLK(fsmc, "fsmc", NULL), |
diff --git a/arch/arm/mach-ux500/devices-db8500.c b/arch/arm/mach-ux500/devices-db8500.c index 9280d2561111..735aaeec2c19 100644 --- a/arch/arm/mach-ux500/devices-db8500.c +++ b/arch/arm/mach-ux500/devices-db8500.c | |||
@@ -216,3 +216,23 @@ void dma40_u8500ed_fixup(void) | |||
216 | dma40_resources[1].start = U8500_DMA_LCPA_BASE_ED; | 216 | dma40_resources[1].start = U8500_DMA_LCPA_BASE_ED; |
217 | dma40_resources[1].end = U8500_DMA_LCPA_BASE_ED + 2 * SZ_1K - 1; | 217 | dma40_resources[1].end = U8500_DMA_LCPA_BASE_ED + 2 * SZ_1K - 1; |
218 | } | 218 | } |
219 | |||
220 | struct resource keypad_resources[] = { | ||
221 | [0] = { | ||
222 | .start = U8500_SKE_BASE, | ||
223 | .end = U8500_SKE_BASE + SZ_4K - 1, | ||
224 | .flags = IORESOURCE_MEM, | ||
225 | }, | ||
226 | [1] = { | ||
227 | .start = IRQ_DB8500_KB, | ||
228 | .end = IRQ_DB8500_KB, | ||
229 | .flags = IORESOURCE_IRQ, | ||
230 | }, | ||
231 | }; | ||
232 | |||
233 | struct platform_device ux500_ske_keypad_device = { | ||
234 | .name = "nmk-ske-keypad", | ||
235 | .id = -1, | ||
236 | .num_resources = ARRAY_SIZE(keypad_resources), | ||
237 | .resource = keypad_resources, | ||
238 | }; | ||
diff --git a/arch/arm/mach-ux500/include/mach/devices.h b/arch/arm/mach-ux500/include/mach/devices.h index c2b2f2574947..12e6606e34b1 100644 --- a/arch/arm/mach-ux500/include/mach/devices.h +++ b/arch/arm/mach-ux500/include/mach/devices.h | |||
@@ -26,6 +26,7 @@ extern struct platform_device ux500_i2c3_device; | |||
26 | extern struct platform_device u8500_i2c0_device; | 26 | extern struct platform_device u8500_i2c0_device; |
27 | extern struct platform_device u8500_i2c4_device; | 27 | extern struct platform_device u8500_i2c4_device; |
28 | extern struct platform_device u8500_dma40_device; | 28 | extern struct platform_device u8500_dma40_device; |
29 | extern struct platform_device ux500_ske_keypad_device; | ||
29 | 30 | ||
30 | void dma40_u8500ed_fixup(void); | 31 | void dma40_u8500ed_fixup(void); |
31 | 32 | ||
diff --git a/arch/arm/mach-ux500/pins-db8500.h b/arch/arm/mach-ux500/pins-db8500.h index 9055d5d3233c..8cf06494e8c6 100644 --- a/arch/arm/mach-ux500/pins-db8500.h +++ b/arch/arm/mach-ux500/pins-db8500.h | |||
@@ -459,82 +459,82 @@ | |||
459 | #define GPIO152_KP_O9 PIN_CFG(152, ALT_C) | 459 | #define GPIO152_KP_O9 PIN_CFG(152, ALT_C) |
460 | 460 | ||
461 | #define GPIO153_GPIO PIN_CFG(153, GPIO) | 461 | #define GPIO153_GPIO PIN_CFG(153, GPIO) |
462 | #define GPIO153_KP_I7 PIN_CFG(153, ALT_A) | 462 | #define GPIO153_KP_I7 PIN_CFG_PULL(153, ALT_A, DOWN) |
463 | #define GPIO153_LCD_D24 PIN_CFG(153, ALT_B) | 463 | #define GPIO153_LCD_D24 PIN_CFG(153, ALT_B) |
464 | #define GPIO153_U2_RXD PIN_CFG(153, ALT_C) | 464 | #define GPIO153_U2_RXD PIN_CFG(153, ALT_C) |
465 | 465 | ||
466 | #define GPIO154_GPIO PIN_CFG(154, GPIO) | 466 | #define GPIO154_GPIO PIN_CFG(154, GPIO) |
467 | #define GPIO154_KP_I6 PIN_CFG(154, ALT_A) | 467 | #define GPIO154_KP_I6 PIN_CFG_PULL(154, ALT_A, DOWN) |
468 | #define GPIO154_LCD_D25 PIN_CFG(154, ALT_B) | 468 | #define GPIO154_LCD_D25 PIN_CFG(154, ALT_B) |
469 | #define GPIO154_U2_TXD PIN_CFG(154, ALT_C) | 469 | #define GPIO154_U2_TXD PIN_CFG(154, ALT_C) |
470 | 470 | ||
471 | #define GPIO155_GPIO PIN_CFG(155, GPIO) | 471 | #define GPIO155_GPIO PIN_CFG(155, GPIO) |
472 | #define GPIO155_KP_I5 PIN_CFG(155, ALT_A) | 472 | #define GPIO155_KP_I5 PIN_CFG_PULL(155, ALT_A, DOWN) |
473 | #define GPIO155_LCD_D26 PIN_CFG(155, ALT_B) | 473 | #define GPIO155_LCD_D26 PIN_CFG(155, ALT_B) |
474 | #define GPIO155_STMAPE_CLK PIN_CFG(155, ALT_C) | 474 | #define GPIO155_STMAPE_CLK PIN_CFG(155, ALT_C) |
475 | 475 | ||
476 | #define GPIO156_GPIO PIN_CFG(156, GPIO) | 476 | #define GPIO156_GPIO PIN_CFG(156, GPIO) |
477 | #define GPIO156_KP_I4 PIN_CFG(156, ALT_A) | 477 | #define GPIO156_KP_I4 PIN_CFG_PULL(156, ALT_A, DOWN) |
478 | #define GPIO156_LCD_D27 PIN_CFG(156, ALT_B) | 478 | #define GPIO156_LCD_D27 PIN_CFG(156, ALT_B) |
479 | #define GPIO156_STMAPE_DAT3 PIN_CFG(156, ALT_C) | 479 | #define GPIO156_STMAPE_DAT3 PIN_CFG(156, ALT_C) |
480 | 480 | ||
481 | #define GPIO157_GPIO PIN_CFG(157, GPIO) | 481 | #define GPIO157_GPIO PIN_CFG(157, GPIO) |
482 | #define GPIO157_KP_O7 PIN_CFG(157, ALT_A) | 482 | #define GPIO157_KP_O7 PIN_CFG_PULL(157, ALT_A, UP) |
483 | #define GPIO157_LCD_D28 PIN_CFG(157, ALT_B) | 483 | #define GPIO157_LCD_D28 PIN_CFG(157, ALT_B) |
484 | #define GPIO157_STMAPE_DAT2 PIN_CFG(157, ALT_C) | 484 | #define GPIO157_STMAPE_DAT2 PIN_CFG(157, ALT_C) |
485 | 485 | ||
486 | #define GPIO158_GPIO PIN_CFG(158, GPIO) | 486 | #define GPIO158_GPIO PIN_CFG(158, GPIO) |
487 | #define GPIO158_KP_O6 PIN_CFG(158, ALT_A) | 487 | #define GPIO158_KP_O6 PIN_CFG_PULL(158, ALT_A, UP) |
488 | #define GPIO158_LCD_D29 PIN_CFG(158, ALT_B) | 488 | #define GPIO158_LCD_D29 PIN_CFG(158, ALT_B) |
489 | #define GPIO158_STMAPE_DAT1 PIN_CFG(158, ALT_C) | 489 | #define GPIO158_STMAPE_DAT1 PIN_CFG(158, ALT_C) |
490 | 490 | ||
491 | #define GPIO159_GPIO PIN_CFG(159, GPIO) | 491 | #define GPIO159_GPIO PIN_CFG(159, GPIO) |
492 | #define GPIO159_KP_O5 PIN_CFG(159, ALT_A) | 492 | #define GPIO159_KP_O5 PIN_CFG_PULL(159, ALT_A, UP) |
493 | #define GPIO159_LCD_D30 PIN_CFG(159, ALT_B) | 493 | #define GPIO159_LCD_D30 PIN_CFG(159, ALT_B) |
494 | #define GPIO159_STMAPE_DAT0 PIN_CFG(159, ALT_C) | 494 | #define GPIO159_STMAPE_DAT0 PIN_CFG(159, ALT_C) |
495 | 495 | ||
496 | #define GPIO160_GPIO PIN_CFG(160, GPIO) | 496 | #define GPIO160_GPIO PIN_CFG(160, GPIO) |
497 | #define GPIO160_KP_O4 PIN_CFG(160, ALT_A) | 497 | #define GPIO160_KP_O4 PIN_CFG_PULL(160, ALT_A, UP) |
498 | #define GPIO160_LCD_D31 PIN_CFG(160, ALT_B) | 498 | #define GPIO160_LCD_D31 PIN_CFG(160, ALT_B) |
499 | #define GPIO160_NONE PIN_CFG(160, ALT_C) | 499 | #define GPIO160_NONE PIN_CFG(160, ALT_C) |
500 | 500 | ||
501 | #define GPIO161_GPIO PIN_CFG(161, GPIO) | 501 | #define GPIO161_GPIO PIN_CFG(161, GPIO) |
502 | #define GPIO161_KP_I3 PIN_CFG(161, ALT_A) | 502 | #define GPIO161_KP_I3 PIN_CFG_PULL(161, ALT_A, DOWN) |
503 | #define GPIO161_LCD_D32 PIN_CFG(161, ALT_B) | 503 | #define GPIO161_LCD_D32 PIN_CFG(161, ALT_B) |
504 | #define GPIO161_UARTMOD_RXD PIN_CFG(161, ALT_C) | 504 | #define GPIO161_UARTMOD_RXD PIN_CFG(161, ALT_C) |
505 | 505 | ||
506 | #define GPIO162_GPIO PIN_CFG(162, GPIO) | 506 | #define GPIO162_GPIO PIN_CFG(162, GPIO) |
507 | #define GPIO162_KP_I2 PIN_CFG(162, ALT_A) | 507 | #define GPIO162_KP_I2 PIN_CFG_PULL(162, ALT_A, DOWN) |
508 | #define GPIO162_LCD_D33 PIN_CFG(162, ALT_B) | 508 | #define GPIO162_LCD_D33 PIN_CFG(162, ALT_B) |
509 | #define GPIO162_UARTMOD_TXD PIN_CFG(162, ALT_C) | 509 | #define GPIO162_UARTMOD_TXD PIN_CFG(162, ALT_C) |
510 | 510 | ||
511 | #define GPIO163_GPIO PIN_CFG(163, GPIO) | 511 | #define GPIO163_GPIO PIN_CFG(163, GPIO) |
512 | #define GPIO163_KP_I1 PIN_CFG(163, ALT_A) | 512 | #define GPIO163_KP_I1 PIN_CFG_PULL(163, ALT_A, DOWN) |
513 | #define GPIO163_LCD_D34 PIN_CFG(163, ALT_B) | 513 | #define GPIO163_LCD_D34 PIN_CFG(163, ALT_B) |
514 | #define GPIO163_STMMOD_CLK PIN_CFG(163, ALT_C) | 514 | #define GPIO163_STMMOD_CLK PIN_CFG(163, ALT_C) |
515 | 515 | ||
516 | #define GPIO164_GPIO PIN_CFG(164, GPIO) | 516 | #define GPIO164_GPIO PIN_CFG(164, GPIO) |
517 | #define GPIO164_KP_I0 PIN_CFG(164, ALT_A) | 517 | #define GPIO164_KP_I0 PIN_CFG_PULL(164, ALT_A, UP) |
518 | #define GPIO164_LCD_D35 PIN_CFG(164, ALT_B) | 518 | #define GPIO164_LCD_D35 PIN_CFG(164, ALT_B) |
519 | #define GPIO164_STMMOD_DAT3 PIN_CFG(164, ALT_C) | 519 | #define GPIO164_STMMOD_DAT3 PIN_CFG(164, ALT_C) |
520 | 520 | ||
521 | #define GPIO165_GPIO PIN_CFG(165, GPIO) | 521 | #define GPIO165_GPIO PIN_CFG(165, GPIO) |
522 | #define GPIO165_KP_O3 PIN_CFG(165, ALT_A) | 522 | #define GPIO165_KP_O3 PIN_CFG_PULL(165, ALT_A, UP) |
523 | #define GPIO165_LCD_D36 PIN_CFG(165, ALT_B) | 523 | #define GPIO165_LCD_D36 PIN_CFG(165, ALT_B) |
524 | #define GPIO165_STMMOD_DAT2 PIN_CFG(165, ALT_C) | 524 | #define GPIO165_STMMOD_DAT2 PIN_CFG(165, ALT_C) |
525 | 525 | ||
526 | #define GPIO166_GPIO PIN_CFG(166, GPIO) | 526 | #define GPIO166_GPIO PIN_CFG(166, GPIO) |
527 | #define GPIO166_KP_O2 PIN_CFG(166, ALT_A) | 527 | #define GPIO166_KP_O2 PIN_CFG_PULL(166, ALT_A, UP) |
528 | #define GPIO166_LCD_D37 PIN_CFG(166, ALT_B) | 528 | #define GPIO166_LCD_D37 PIN_CFG(166, ALT_B) |
529 | #define GPIO166_STMMOD_DAT1 PIN_CFG(166, ALT_C) | 529 | #define GPIO166_STMMOD_DAT1 PIN_CFG(166, ALT_C) |
530 | 530 | ||
531 | #define GPIO167_GPIO PIN_CFG(167, GPIO) | 531 | #define GPIO167_GPIO PIN_CFG(167, GPIO) |
532 | #define GPIO167_KP_O1 PIN_CFG(167, ALT_A) | 532 | #define GPIO167_KP_O1 PIN_CFG_PULL(167, ALT_A, UP) |
533 | #define GPIO167_LCD_D38 PIN_CFG(167, ALT_B) | 533 | #define GPIO167_LCD_D38 PIN_CFG(167, ALT_B) |
534 | #define GPIO167_STMMOD_DAT0 PIN_CFG(167, ALT_C) | 534 | #define GPIO167_STMMOD_DAT0 PIN_CFG(167, ALT_C) |
535 | 535 | ||
536 | #define GPIO168_GPIO PIN_CFG(168, GPIO) | 536 | #define GPIO168_GPIO PIN_CFG(168, GPIO) |
537 | #define GPIO168_KP_O0 PIN_CFG(168, ALT_A) | 537 | #define GPIO168_KP_O0 PIN_CFG_PULL(168, ALT_A, UP) |
538 | #define GPIO168_LCD_D39 PIN_CFG(168, ALT_B) | 538 | #define GPIO168_LCD_D39 PIN_CFG(168, ALT_B) |
539 | #define GPIO168_NONE PIN_CFG(168, ALT_C) | 539 | #define GPIO168_NONE PIN_CFG(168, ALT_C) |
540 | 540 | ||