ARM: tegra: remove TEGRA_11x SoC supports from T124 platform
[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 #include "wakeups-t12x.h"
37
38
39 #define GPIO_KEY(_id, _gpio, _iswake)           \
40         {                                       \
41                 .code = _id,                    \
42                 .gpio = TEGRA_GPIO_##_gpio,     \
43                 .active_low = 1,                \
44                 .desc = #_id,                   \
45                 .type = EV_KEY,                 \
46                 .wakeup = _iswake,              \
47                 .debounce_interval = 10,        \
48         }
49
50 #define GPIO_IKEY(_id, _irq, _iswake, _deb)     \
51         {                                       \
52                 .code = _id,                    \
53                 .gpio = -1,                     \
54                 .irq = _irq,                    \
55                 .desc = #_id,                   \
56                 .type = EV_KEY,                 \
57                 .wakeup = _iswake,              \
58                 .debounce_interval = _deb,      \
59         }
60
61 #define PMC_WAKE_STATUS         0x14
62 #define TEGRA_WAKE_PWR_INT      (1UL << 18)
63
64 static int loki_wakeup_key(void);
65
66 static struct gpio_keys_button loki_int_keys[] = {
67         [0] = GPIO_IKEY(KEY_POWER, 0, 1, 10),
68 };
69
70 static struct gpio_keys_platform_data loki_int_keys_pdata = {
71         .buttons        = loki_int_keys,
72         .nbuttons       = ARRAY_SIZE(loki_int_keys),
73         .wakeup_key     = loki_wakeup_key,
74 };
75
76 static struct platform_device loki_int_keys_device = {
77         .name   = "gpio-keys",
78         .id     = 0,
79         .dev    = {
80                 .platform_data  = &loki_int_keys_pdata,
81         },
82 };
83
84 static int loki_wakeup_key(void)
85 {
86         u32 status;
87         status = __raw_readl(IO_ADDRESS(TEGRA_PMC_BASE) + PMC_WAKE_STATUS);
88
89         pr_info("%s: Power key pressed\n", __func__);
90
91         return (status & TEGRA_WAKE_PWR_INT) ? KEY_POWER : KEY_RESERVED;
92 }
93
94 int __init loki_kbc_init(void)
95 {
96         struct board_info board_info;
97         int ret;
98
99         tegra_get_board_info(&board_info);
100         pr_info("Boardid:SKU = 0x%04x:0x%04x\n",
101                         board_info.board_id, board_info.sku);
102
103         loki_int_keys[0].gpio = TEGRA_GPIO_PQ0;
104         loki_int_keys[0].active_low = 1;
105
106         ret = platform_device_register(&loki_int_keys_device);
107         return ret;
108 }