diff options
author | Daniel Solomon <daniels@nvidia.com> | 2011-07-22 17:21:58 -0700 |
---|---|---|
committer | Dan Willemsen <dwillemsen@nvidia.com> | 2011-11-30 21:47:58 -0800 |
commit | c4186ed5cbf7a07126479da350070b18b3c69c3b (patch) | |
tree | e3822951b3aa0976476fb9a1d8fd6bb770ab30de /arch/arm/mach-tegra/board-cardhu-kbc.c | |
parent | 84fca9fbd451e7a12febf620e28235ed74022371 (diff) |
ARM: tegra: cardhu: Allow LP0->LP3 using PM269 GPIO power button without KBC
Changed GPIO init for PM269 to allow wakeup using the power button
when the KBC module is not connected.
Bug 851432
Original-Change-Id: Ia597502807536b7ba00025805fb163602f022c88
Reviewed-on: http://git-master/r/42725
Reviewed-by: Raymond Poudrier <rapoudrier@nvidia.com>
Reviewed-by: Laxman Dewangan <ldewangan@nvidia.com>
Reviewed-by: Daniel Solomon <daniels@nvidia.com>
Tested-by: Daniel Solomon <daniels@nvidia.com>
Reviewed-by: Mayuresh Kulkarni <mkulkarni@nvidia.com>
Reviewed-by: Nitin Kumbhar <nkumbhar@nvidia.com>
Rebase-Id: R27207636ba09d2305ebd55230609f85dc500858a
Diffstat (limited to 'arch/arm/mach-tegra/board-cardhu-kbc.c')
-rw-r--r-- | arch/arm/mach-tegra/board-cardhu-kbc.c | 40 |
1 files changed, 19 insertions, 21 deletions
diff --git a/arch/arm/mach-tegra/board-cardhu-kbc.c b/arch/arm/mach-tegra/board-cardhu-kbc.c index 41725456f723..96e95436dc93 100644 --- a/arch/arm/mach-tegra/board-cardhu-kbc.c +++ b/arch/arm/mach-tegra/board-cardhu-kbc.c @@ -161,23 +161,6 @@ int __init cardhu_scroll_init(void) .debounce_interval = 10, \ } -static struct gpio_keys_button cardhu_keys_pm269[] = { - [0] = GPIO_KEY(KEY_POWER, PV0, 1), -}; - -static struct gpio_keys_platform_data cardhu_keys_pm269_platform_data = { - .buttons = cardhu_keys_pm269, - .nbuttons = ARRAY_SIZE(cardhu_keys_pm269), -}; - -static struct platform_device cardhu_keys_pm269_device = { - .name = "gpio-keys", - .id = 0, - .dev = { - .platform_data = &cardhu_keys_pm269_platform_data, - }, -}; - static struct gpio_keys_button cardhu_keys_e1198[] = { [0] = GPIO_KEY(KEY_HOME, PQ0, 0), [1] = GPIO_KEY(KEY_BACK, PQ1, 0), @@ -251,6 +234,24 @@ static struct platform_device cardhu_int_keys_e1291_device = { }, }; +static struct interrupt_keys_button cardhu_int_keys_pm269[] = { + [0] = INT_KEY(KEY_POWER, TPS6591X_IRQ_BASE + TPS6591X_INT_PWRON, 0, 100), + [1] = INT_KEY(KEY_POWER, TPS6591X_IRQ_BASE + TPS6591X_INT_PWRON_LP, 0, 8000), +}; + +static struct interrupt_keys_platform_data cardhu_int_keys_pm269_pdata = { + .int_buttons = cardhu_int_keys_pm269, + .nbuttons = ARRAY_SIZE(cardhu_int_keys_pm269), +}; + +static struct platform_device cardhu_int_keys_pm269_device = { + .name = "interrupt-keys", + .id = 0, + .dev = { + .platform_data = &cardhu_int_keys_pm269_pdata, + }, +}; + int __init cardhu_keys_init(void) { int i; @@ -272,10 +273,7 @@ int __init cardhu_keys_init(void) platform_device_register(&cardhu_keys_e1291_device); platform_device_register(&cardhu_int_keys_e1291_device); } else if (board_info.board_id == BOARD_PM269) { - for (i = 0; i < ARRAY_SIZE(cardhu_keys_pm269); i++) - tegra_gpio_enable(cardhu_keys_pm269[i].gpio); - - platform_device_register(&cardhu_keys_pm269_device); + platform_device_register(&cardhu_int_keys_pm269_device); } else { /* For E1198 */ for (i = 0; i < ARRAY_SIZE(cardhu_keys_e1198); i++) |