diff options
author | Olof Johansson <olof@lixom.net> | 2012-03-14 00:35:51 -0400 |
---|---|---|
committer | Dmitry Torokhov <dmitry.torokhov@gmail.com> | 2012-03-14 00:37:04 -0400 |
commit | 2cd36877ad1c61429e00c099b6903ebcd936ca00 (patch) | |
tree | c9f7618f3b49c2ba5516c9023ba7e5604aa6b08c /drivers/input | |
parent | b51425becfe127e0c17a8501ffa079b37241ed11 (diff) |
Input: of_keymap - add device tree bindings for simple key matrices
This adds a simple device tree binding for simple key matrix data and
a helper to fill in the platform data.
Signed-off-by: Olof Johansson <olof@lixom.net>
Acked-by: Stephen Warren <swarren@nvidia.com>
Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
Diffstat (limited to 'drivers/input')
-rw-r--r-- | drivers/input/Kconfig | 4 | ||||
-rw-r--r-- | drivers/input/Makefile | 1 | ||||
-rw-r--r-- | drivers/input/keyboard/Kconfig | 1 | ||||
-rw-r--r-- | drivers/input/of_keymap.c | 87 |
4 files changed, 93 insertions, 0 deletions
diff --git a/drivers/input/Kconfig b/drivers/input/Kconfig index 001b147c7f95..332597980817 100644 --- a/drivers/input/Kconfig +++ b/drivers/input/Kconfig | |||
@@ -25,6 +25,10 @@ config INPUT | |||
25 | 25 | ||
26 | if INPUT | 26 | if INPUT |
27 | 27 | ||
28 | config INPUT_OF_MATRIX_KEYMAP | ||
29 | depends on USE_OF | ||
30 | bool | ||
31 | |||
28 | config INPUT_FF_MEMLESS | 32 | config INPUT_FF_MEMLESS |
29 | tristate "Support for memoryless force-feedback devices" | 33 | tristate "Support for memoryless force-feedback devices" |
30 | help | 34 | help |
diff --git a/drivers/input/Makefile b/drivers/input/Makefile index 0c789490e0b3..b173a13a73ca 100644 --- a/drivers/input/Makefile +++ b/drivers/input/Makefile | |||
@@ -24,3 +24,4 @@ obj-$(CONFIG_INPUT_TOUCHSCREEN) += touchscreen/ | |||
24 | obj-$(CONFIG_INPUT_MISC) += misc/ | 24 | obj-$(CONFIG_INPUT_MISC) += misc/ |
25 | 25 | ||
26 | obj-$(CONFIG_INPUT_APMPOWER) += apm-power.o | 26 | obj-$(CONFIG_INPUT_APMPOWER) += apm-power.o |
27 | obj-$(CONFIG_INPUT_OF_MATRIX_KEYMAP) += of_keymap.o | ||
diff --git a/drivers/input/keyboard/Kconfig b/drivers/input/keyboard/Kconfig index cdc385b2cf7d..3371954c979b 100644 --- a/drivers/input/keyboard/Kconfig +++ b/drivers/input/keyboard/Kconfig | |||
@@ -394,6 +394,7 @@ config KEYBOARD_NOMADIK | |||
394 | config KEYBOARD_TEGRA | 394 | config KEYBOARD_TEGRA |
395 | tristate "NVIDIA Tegra internal matrix keyboard controller support" | 395 | tristate "NVIDIA Tegra internal matrix keyboard controller support" |
396 | depends on ARCH_TEGRA | 396 | depends on ARCH_TEGRA |
397 | select INPUT_OF_MATRIX_KEYMAP if USE_OF | ||
397 | help | 398 | help |
398 | Say Y here if you want to use a matrix keyboard connected directly | 399 | Say Y here if you want to use a matrix keyboard connected directly |
399 | to the internal keyboard controller on Tegra SoCs. | 400 | to the internal keyboard controller on Tegra SoCs. |
diff --git a/drivers/input/of_keymap.c b/drivers/input/of_keymap.c new file mode 100644 index 000000000000..061493d57682 --- /dev/null +++ b/drivers/input/of_keymap.c | |||
@@ -0,0 +1,87 @@ | |||
1 | /* | ||
2 | * Helpers for open firmware matrix keyboard bindings | ||
3 | * | ||
4 | * Copyright (C) 2012 Google, Inc | ||
5 | * | ||
6 | * Author: | ||
7 | * Olof Johansson <olof@lixom.net> | ||
8 | * | ||
9 | * This software is licensed under the terms of the GNU General Public | ||
10 | * License version 2, as published by the Free Software Foundation, and | ||
11 | * may be copied, distributed, and modified under those terms. | ||
12 | * | ||
13 | * This program is distributed in the hope that it will be useful, | ||
14 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
15 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
16 | * GNU General Public License for more details. | ||
17 | * | ||
18 | */ | ||
19 | |||
20 | #include <linux/kernel.h> | ||
21 | #include <linux/types.h> | ||
22 | #include <linux/input.h> | ||
23 | #include <linux/of.h> | ||
24 | #include <linux/input/matrix_keypad.h> | ||
25 | #include <linux/export.h> | ||
26 | #include <linux/gfp.h> | ||
27 | #include <linux/slab.h> | ||
28 | |||
29 | struct matrix_keymap_data * | ||
30 | matrix_keyboard_of_fill_keymap(struct device_node *np, | ||
31 | const char *propname) | ||
32 | { | ||
33 | struct matrix_keymap_data *kd; | ||
34 | u32 *keymap; | ||
35 | int proplen, i; | ||
36 | const __be32 *prop; | ||
37 | |||
38 | if (!np) | ||
39 | return NULL; | ||
40 | |||
41 | if (!propname) | ||
42 | propname = "linux,keymap"; | ||
43 | |||
44 | prop = of_get_property(np, propname, &proplen); | ||
45 | if (!prop) | ||
46 | return NULL; | ||
47 | |||
48 | if (proplen % sizeof(u32)) { | ||
49 | pr_warn("Malformed keymap property %s in %s\n", | ||
50 | propname, np->full_name); | ||
51 | return NULL; | ||
52 | } | ||
53 | |||
54 | kd = kzalloc(sizeof(*kd), GFP_KERNEL); | ||
55 | if (!kd) | ||
56 | return NULL; | ||
57 | |||
58 | kd->keymap = keymap = kzalloc(proplen, GFP_KERNEL); | ||
59 | if (!kd->keymap) { | ||
60 | kfree(kd); | ||
61 | return NULL; | ||
62 | } | ||
63 | |||
64 | kd->keymap_size = proplen / sizeof(u32); | ||
65 | |||
66 | for (i = 0; i < kd->keymap_size; i++) { | ||
67 | u32 tmp = be32_to_cpup(prop + i); | ||
68 | int key_code, row, col; | ||
69 | |||
70 | row = (tmp >> 24) & 0xff; | ||
71 | col = (tmp >> 16) & 0xff; | ||
72 | key_code = tmp & 0xffff; | ||
73 | keymap[i] = KEY(row, col, key_code); | ||
74 | } | ||
75 | |||
76 | return kd; | ||
77 | } | ||
78 | EXPORT_SYMBOL_GPL(matrix_keyboard_of_fill_keymap); | ||
79 | |||
80 | void matrix_keyboard_of_free_keymap(const struct matrix_keymap_data *kd) | ||
81 | { | ||
82 | if (kd) { | ||
83 | kfree(kd->keymap); | ||
84 | kfree(kd); | ||
85 | } | ||
86 | } | ||
87 | EXPORT_SYMBOL_GPL(matrix_keyboard_of_free_keymap); | ||