From 66cf8f46fd5646dae9d2facff84eb516f39f2c35 Mon Sep 17 00:00:00 2001 From: arun c Date: Tue, 12 Aug 2008 14:28:49 +0530 Subject: [PATCH] OMAP2EVM: Add keypad support TWL4030 keypad controller driver support for OMAP2EVM Signed-off-by: Arun C Signed-off-by: Tony Lindgren --- arch/arm/mach-omap2/board-omap2evm.c | 38 ++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) diff --git a/arch/arm/mach-omap2/board-omap2evm.c b/arch/arm/mach-omap2/board-omap2evm.c index b6354e368bd..9eb93b6802c 100644 --- a/arch/arm/mach-omap2/board-omap2evm.c +++ b/arch/arm/mach-omap2/board-omap2evm.c @@ -17,6 +17,7 @@ #include #include #include +#include #include #include @@ -27,6 +28,7 @@ #include #include #include +#include static struct resource omap2evm_smc911x_resources[] = { [0] = { @@ -72,6 +74,41 @@ static struct omap_lcd_config omap2_evm_lcd_config __initdata = { .ctrl_name = "internal", }; +static int omap2evm_keymap[] = { + KEY(0, 0, KEY_LEFT), + KEY(0, 1, KEY_RIGHT), + KEY(0, 2, KEY_A), + KEY(0, 3, KEY_B), + KEY(1, 0, KEY_DOWN), + KEY(1, 1, KEY_UP), + KEY(1, 2, KEY_E), + KEY(1, 3, KEY_F), + KEY(2, 0, KEY_ENTER), + KEY(2, 1, KEY_I), + KEY(2, 2, KEY_J), + KEY(2, 3, KEY_K), + KEY(3, 0, KEY_M), + KEY(3, 1, KEY_N), + KEY(3, 2, KEY_O), + KEY(3, 3, KEY_P) +}; + +static struct omap_kp_platform_data omap2evm_kp_data = { + .rows = 4, + .cols = 4, + .keymap = omap2evm_keymap, + .keymapsize = ARRAY_SIZE(omap2evm_keymap), + .rep = 1, +}; + +static struct platform_device omap2evm_kp_device = { + .name = "omap_twl4030keypad", + .id = -1, + .dev = { + .platform_data = &omap2evm_kp_data, + }, +}; + static void __init omap2_evm_init_irq(void) { omap2_init_common_hw(NULL); @@ -111,6 +148,7 @@ static int __init omap2_evm_i2c_init(void) static struct platform_device *omap2_evm_devices[] __initdata = { &omap2_evm_lcd_device, &omap2evm_smc911x_device, + &omap2evm_kp_device, }; static void __init omap2_evm_init(void) -- 2.41.1