arm: tegra: loki: add initial board files
[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         [1] = GPIO_KEY(KEY_VOLUMEUP, PQ6, 0),
73         [2] = GPIO_KEY(KEY_VOLUMEDOWN, PQ7, 0),
74         [3] = GPIO_KEY(KEY_HOME, PI5, 0),
75         [4] = GPIO_KEY(KEY_CAMERA_FOCUS, PQ2, 0),
76 #if 0
77         [5] = GPIO_KEY(KEY_CAMERA, PV3, 0),
78 #endif
79 };
80
81 static struct gpio_keys_platform_data loki_int_keys_pdata = {
82         .buttons        = loki_int_keys,
83         .nbuttons       = ARRAY_SIZE(loki_int_keys),
84         .wakeup_key     = loki_wakeup_key,
85 };
86
87 static struct platform_device loki_int_keys_device = {
88         .name   = "gpio-keys",
89         .id     = 0,
90         .dev    = {
91                 .platform_data  = &loki_int_keys_pdata,
92         },
93 };
94
95 static int loki_wakeup_key(void)
96 {
97         u32 status;
98         status = __raw_readl(IO_ADDRESS(TEGRA_PMC_BASE) + PMC_WAKE_STATUS);
99
100         pr_info("%s: Power key pressed\n", __func__);
101
102         return (status & TEGRA_WAKE_PWR_INT) ? KEY_POWER : KEY_RESERVED;
103 }
104
105 int __init loki_kbc_init(void)
106 {
107         struct board_info board_info;
108         int ret;
109
110         tegra_get_board_info(&board_info);
111         pr_info("Boardid:SKU = 0x%04x:0x%04x\n",
112                         board_info.board_id, board_info.sku);
113
114         loki_int_keys[0].gpio = TEGRA_GPIO_PQ0;
115         loki_int_keys[0].active_low = 1;
116
117         ret = platform_device_register(&loki_int_keys_device);
118         return ret;
119 }