From patchwork Fri May 28 11:51:48 2010 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Joonyoung Shim X-Patchwork-Id: 102875 Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by demeter.kernel.org (8.14.3/8.14.3) with ESMTP id o4SBpgPE005119 for ; Fri, 28 May 2010 11:51:51 GMT Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1756649Ab0E1Lvv (ORCPT ); Fri, 28 May 2010 07:51:51 -0400 Received: from mailout1.samsung.com ([203.254.224.24]:39003 "EHLO mailout1.samsung.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754160Ab0E1Lvu (ORCPT ); Fri, 28 May 2010 07:51:50 -0400 Received: from epmmp2 (mailout1.samsung.com [203.254.224.24]) by mailout1.samsung.com (iPlanet Messaging Server 5.2 Patch 2 (built Jul 14 2004)) with ESMTP id <0L3400I3EOYC38@mailout1.samsung.com>; Fri, 28 May 2010 20:51:48 +0900 (KST) Received: from TNRNDGASPAPP1.tn.corp.samsungelectronics.net ([165.213.149.150]) by mmp2.samsung.com (iPlanet Messaging Server 5.2 Patch 2 (built Jul 14 2004)) with ESMTPA id <0L3400DJEOYCSY@mmp2.samsung.com>; Fri, 28 May 2010 20:51:48 +0900 (KST) Received: from [165.213.115.198] ([165.213.115.198]) by TNRNDGASPAPP1.tn.corp.samsungelectronics.net with Microsoft SMTPSVC(6.0.3790.4675); Fri, 28 May 2010 20:51:48 +0900 Date: Fri, 28 May 2010 20:51:48 +0900 From: Joonyoung Shim Subject: [PATCH 4/5] ARM: S5PV210: Add keypad device to the Aquila board To: ben-linux@fluff.org Cc: linux-arm-kernel@lists.infradead.org, linux-samsung-soc@vger.kernel.org, linux-input@vger.kernel.org, kyungmin.park@samsung.com Message-id: <4BFFAE54.7030203@samsung.com> MIME-version: 1.0 Content-type: text/plain; charset=UTF-8 Content-transfer-encoding: 7BIT User-Agent: Thunderbird 2.0.0.21 (Windows/20090302) X-OriginalArrivalTime: 28 May 2010 11:51:48.0730 (UTC) FILETIME=[278A45A0:01CAFE5C] Sender: linux-input-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-input@vger.kernel.org X-Greylist: IP, sender and recipient auto-whitelisted, not delayed by milter-greylist-4.2.3 (demeter.kernel.org [140.211.167.41]); Fri, 28 May 2010 11:51:51 +0000 (UTC) diff --git a/arch/arm/mach-s5pv210/Kconfig b/arch/arm/mach-s5pv210/Kconfig index 6f41b2d..25b9e96 100644 --- a/arch/arm/mach-s5pv210/Kconfig +++ b/arch/arm/mach-s5pv210/Kconfig @@ -55,8 +55,10 @@ config MACH_AQUILA select CPU_S5PV210 select ARCH_SPARSEMEM_ENABLE select S5PV210_SETUP_FB_24BPP + select S5PV210_SETUP_KEYPAD select S3C_DEV_FB select S5PC110_DEV_ONENAND + select SAMSUNG_DEV_KEYPAD help Machine support for the Samsung Aquila target based on S5PC110 SoC diff --git a/arch/arm/mach-s5pv210/mach-aquila.c b/arch/arm/mach-s5pv210/mach-aquila.c index fb9dbb2..526fed8 100644 --- a/arch/arm/mach-s5pv210/mach-aquila.c +++ b/arch/arm/mach-s5pv210/mach-aquila.c @@ -28,6 +28,7 @@ #include #include #include +#include /* Following are default values for UCON, ULCON and UFCON UART registers */ #define S5PV210_UCON_DEFAULT (S3C2410_UCON_TXILEVEL | \ @@ -116,9 +117,30 @@ static struct s3c_fb_platdata aquila_lcd_pdata __initdata = { .setup_gpio = s5pv210_fb_gpio_setup_24bpp, }; +/* KEYPAD */ +static uint32_t keymap[] __initdata = { + /* KEY(row, col, keycode) */ + KEY(0, 0, KEY_CAMERA), /* Full Shot */ + KEY(0, 1, KEY_VOLUMEUP), + KEY(1, 0, KEY_CONFIG), /* Halt Shot */ + KEY(1, 1, KEY_VOLUMEDOWN), +}; + +static struct matrix_keymap_data keymap_data __initdata = { + .keymap = keymap, + .keymap_size = ARRAY_SIZE(keymap), +}; + +static struct samsung_kp_platdata keypad_data __initdata = { + .keymap_data = &keymap_data, + .rows = 2, + .cols = 3, +}; + static struct platform_device *aquila_devices[] __initdata = { &s3c_device_fb, &s5pc110_device_onenand, + &samsung_device_keypad, }; static void __init aquila_map_io(void) @@ -133,6 +155,9 @@ static void __init aquila_machine_init(void) /* FB */ s3c_fb_set_platdata(&aquila_lcd_pdata); + /* KEYPAD */ + samsung_kp_set_platdata(&keypad_data); + platform_add_devices(aquila_devices, ARRAY_SIZE(aquila_devices)); }