ARM: tegra: loki: Changes to boot into kernel
[linux-3.10.git] / arch / arm / mach-tegra / board-loki-kbc.c
1 /*
2  * arch/arm/mach-tegra/board-loki-kbc.c
3  * Keys configuration for Nvidia tegra4 loki platform.
4  *
5  * Copyright (c) 2012-2013, NVIDIA CORPORATION.  All rights reserved.
6  *
7  * This program is free software; you can redistribute it and/or modify
8  * it under the terms of the GNU General Public License version 2 as
9  * published by the Free Software Foundation.
10  *
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program; if not, write to the Free Software
18  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
19  * 02111-1307, USA
20  */
21
22 #include <linux/kernel.h>
23 #include <linux/platform_device.h>
24 #include <linux/input.h>
25 #include <linux/io.h>
26 #include <linux/input/tegra_kbc.h>
27 #include <linux/gpio.h>
28 #include <linux/gpio_keys.h>
29 #include <linux/mfd/palmas.h>
30
31 #include "tegra-board-id.h"
32 #include "board.h"
33 #include "board-loki.h"
34 #include "devices.h"
35 #include "iomap.h"
36 #ifdef CONFIG_ARCH_TEGRA_11x_SOC
37 #include "wakeups-t11x.h"
38 #else
39 #include "wakeups-t12x.h"
40 #endif
41
42
43 #define GPIO_KEY(_id, _gpio, _iswake)           \
44         {                                       \
45                 .code = _id,                    \
46                 .gpio = TEGRA_GPIO_##_gpio,     \
47                 .active_low = 1,                \
48                 .desc = #_id,                   \
49                 .type = EV_KEY,                 \
50                 .wakeup = _iswake,              \
51                 .debounce_interval = 10,        \
52         }
53
54 #define GPIO_IKEY(_id, _irq, _iswake, _deb)     \
55         {                                       \
56                 .code = _id,                    \
57                 .gpio = -1,                     \
58                 .irq = _irq,                    \
59                 .desc = #_id,                   \
60                 .type = EV_KEY,                 \
61                 .wakeup = _iswake,              \
62                 .debounce_interval = _deb,      \
63         }
64
65 #define PMC_WAKE_STATUS         0x14
66 #define TEGRA_WAKE_PWR_INT      (1UL << 18)
67
68 static int loki_wakeup_key(void);
69
70 static struct gpio_keys_button loki_int_keys[] = {
71         [0] = GPIO_IKEY(KEY_POWER, 0, 1, 10),
72 };
73
74 static struct gpio_keys_platform_data loki_int_keys_pdata = {
75         .buttons        = loki_int_keys,
76         .nbuttons       = ARRAY_SIZE(loki_int_keys),
77         .wakeup_key     = loki_wakeup_key,
78 };
79
80 static struct platform_device loki_int_keys_device = {
81         .name   = "gpio-keys",
82         .id     = 0,
83         .dev    = {
84                 .platform_data  = &loki_int_keys_pdata,
85         },
86 };
87
88 static int loki_wakeup_key(void)
89 {
90         u32 status;
91         status = __raw_readl(IO_ADDRESS(TEGRA_PMC_BASE) + PMC_WAKE_STATUS);
92
93         pr_info("%s: Power key pressed\n", __func__);
94
95         return (status & TEGRA_WAKE_PWR_INT) ? KEY_POWER : KEY_RESERVED;
96 }
97
98 int __init loki_kbc_init(void)
99 {
100         struct board_info board_info;
101         int ret;
102
103         tegra_get_board_info(&board_info);
104         pr_info("Boardid:SKU = 0x%04x:0x%04x\n",
105                         board_info.board_id, board_info.sku);
106
107         loki_int_keys[0].gpio = TEGRA_GPIO_PQ0;
108         loki_int_keys[0].active_low = 1;
109
110         ret = platform_device_register(&loki_int_keys_device);
111         return ret;
112 }