RE: [PATCH] ARM: EXYNOS4: Add keypad support for Origen

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Sachin Kamat wrote:
> 
> This patch adds keypad support for Origen board as GPIO keys.
> 
> Signed-off-by: Sachin Kamat <sachin.kamat@xxxxxxxxxx>
> ---
>  arch/arm/mach-exynos4/mach-origen.c |   58
> +++++++++++++++++++++++++++++++++++
>  1 files changed, 58 insertions(+), 0 deletions(-)
> 
> diff --git a/arch/arm/mach-exynos4/mach-origen.c
b/arch/arm/mach-exynos4/mach-
> origen.c
> index ed59f86..61da36b 100644
> --- a/arch/arm/mach-exynos4/mach-origen.c
> +++ b/arch/arm/mach-exynos4/mach-origen.c
> @@ -14,6 +14,7 @@
>  #include <linux/platform_device.h>
>  #include <linux/io.h>
>  #include <linux/input.h>
> +#include <linux/gpio_keys.h>
> 
>  #include <asm/mach/arch.h>
>  #include <asm/mach-types.h>
> @@ -79,10 +80,67 @@ static struct s3c_sdhci_platdata origen_hsmmc2_pdata
> __initdata = {
>  	.clk_type		= S3C_SDHCI_CLK_DIV_EXTERNAL,
>  };
> 
> +static struct gpio_keys_button origen_gpio_keys_table[] = {
> +	{
> +		.code = KEY_MENU,

If you're ok, will change tab between '.code' and '=', I think it would be
better to read code.

> +		.gpio = EXYNOS4_GPX1(5),
> +		.desc = "gpio-keys: KEY_MENU",
> +		.type = EV_KEY,
> +		.active_low = 1,
> +		.wakeup = 1,
> +		.debounce_interval = 1,
> +	}, {
> +		.code = KEY_HOME,
> +		.gpio = EXYNOS4_GPX1(6),
> +		.desc = "gpio-keys: KEY_HOME",
> +		.type = EV_KEY,
> +		.active_low = 1,
> +		.wakeup = 1,
> +		.debounce_interval = 1,
> +	}, {
> +		.code = KEY_BACK,
> +		.gpio = EXYNOS4_GPX1(7),
> +		.desc = "gpio-keys: KEY_BACK",
> +		.type = EV_KEY,
> +		.active_low = 1,
> +		.wakeup = 1,
> +		.debounce_interval = 1,
> +	}, {
> +		.code = KEY_UP,
> +		.gpio = EXYNOS4_GPX2(0),
> +		.desc = "gpio-keys: KEY_UP",
> +		.type = EV_KEY,
> +		.active_low = 1,
> +		.wakeup = 1,
> +		.debounce_interval = 1,
> +	}, {
> +		.code = KEY_DOWN,
> +		.gpio = EXYNOS4_GPX2(1),
> +		.desc = "gpio-keys: KEY_DOWN",
> +		.type = EV_KEY,
> +		.active_low = 1,
> +		.wakeup = 1,
> +		.debounce_interval = 1,
> +	},
> +};
> +
> +static struct gpio_keys_platform_data origen_gpio_keys_data = {
> +	.buttons = origen_gpio_keys_table,
> +	.nbuttons = ARRAY_SIZE(origen_gpio_keys_table),
> +};
> +
> +static struct platform_device origen_device_gpiokeys = {
> +	.name = "gpio-keys",
> +	.dev = {
> +		.platform_data = &origen_gpio_keys_data,
> +	},
> +};
> +
>  static struct platform_device *origen_devices[] __initdata = {
>  	&s3c_device_hsmmc2,
>  	&s3c_device_rtc,
>  	&s3c_device_wdt,
> +	&origen_device_gpiokeys,
>  };
> 
>  static void __init origen_map_io(void)
> --
> 1.7.4.1

Looks ok to me, will apply.
Thanks.

Best regards,
Kgene.
--
Kukjin Kim <kgene.kim@xxxxxxxxxxx>, Senior Engineer,
SW Solution Development Team, Samsung Electronics Co., Ltd.

--
To unsubscribe from this list: send the line "unsubscribe linux-samsung-soc" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Linux SoC Development]     [Linux Rockchip Development]     [Linux USB Development]     [Video for Linux]     [Linux Audio Users]     [Linux SCSI]     [Yosemite News]

  Powered by Linux