blob: 5ce8d5e6ea518e7f4d0303b4d4ac066dcd294224 [file] [log] [blame]
Eric Miao1814db62008-01-31 00:58:37 -05001#ifndef __ASM_ARCH_PXA27x_KEYPAD_H
2#define __ASM_ARCH_PXA27x_KEYPAD_H
3
4#include <linux/input.h>
Dmitry Torokhov52ec7752009-07-22 21:51:40 -07005#include <linux/input/matrix_keypad.h>
Eric Miao1814db62008-01-31 00:58:37 -05006
7#define MAX_MATRIX_KEY_ROWS (8)
8#define MAX_MATRIX_KEY_COLS (8)
Dmitry Torokhovbd96f372009-09-04 23:46:18 -07009#define MATRIX_ROW_SHIFT (3)
10#define MAX_DIRECT_KEY_NUM (8)
Rodolfo Giometti5a90e5b2007-03-16 00:58:52 -040011
Eric Miao62059d92008-01-31 00:59:03 -050012/* pxa3xx keypad platform specific parameters
13 *
14 * NOTE:
15 * 1. direct_key_num indicates the number of keys in the direct keypad
16 * _plus_ the number of rotary-encoder sensor inputs, this can be
17 * left as 0 if only rotary encoders are enabled, the driver will
18 * automatically calculate this
19 *
20 * 2. direct_key_map is the key code map for the direct keys, if rotary
21 * encoder(s) are enabled, direct key 0/1(2/3) will be ignored
22 *
23 * 3. rotary can be either interpreted as a relative input event (e.g.
24 * REL_WHEEL/REL_HWHEEL) or specific keys (e.g. UP/DOWN/LEFT/RIGHT)
Eric Miao76cb44e2008-01-31 00:59:23 -050025 *
26 * 4. matrix key and direct key will use the same debounce_interval by
27 * default, which should be sufficient in most cases
Mark F. Brown3587c252010-09-03 18:28:09 -040028 *
29 * pxa168 keypad platform specific parameter
30 *
31 * NOTE:
32 * clear_wakeup_event callback is a workaround required to clear the
33 * keypad interrupt. The keypad wake must be cleared in addition to
34 * reading the MI/DI bits in the KPC register.
Eric Miao62059d92008-01-31 00:59:03 -050035 */
Eric Miao0e5f11a2008-01-31 00:56:46 -050036struct pxa27x_keypad_platform_data {
Eric Miao1814db62008-01-31 00:58:37 -050037
38 /* code map for the matrix keys */
39 unsigned int matrix_key_rows;
40 unsigned int matrix_key_cols;
41 unsigned int *matrix_key_map;
42 int matrix_key_map_size;
Eric Miao62059d92008-01-31 00:59:03 -050043
44 /* direct keys */
45 int direct_key_num;
Dmitry Torokhovbd96f372009-09-04 23:46:18 -070046 unsigned int direct_key_map[MAX_DIRECT_KEY_NUM];
Chao Xieee1d8042012-04-01 10:08:03 +080047 /* the key output may be low active */
48 int direct_key_low_active;
Chao Xiefb054bf2012-04-01 10:08:04 +080049 /* give board a chance to choose the start direct key */
50 unsigned int direct_key_mask;
Eric Miao62059d92008-01-31 00:59:03 -050051
52 /* rotary encoders 0 */
53 int enable_rotary0;
54 int rotary0_rel_code;
55 int rotary0_up_key;
56 int rotary0_down_key;
57
58 /* rotary encoders 1 */
59 int enable_rotary1;
60 int rotary1_rel_code;
61 int rotary1_up_key;
62 int rotary1_down_key;
Eric Miao76cb44e2008-01-31 00:59:23 -050063
64 /* key debounce interval */
65 unsigned int debounce_interval;
Mark F. Brown3587c252010-09-03 18:28:09 -040066
67 /* clear wakeup event requirement for pxa168 */
68 void (*clear_wakeup_event)(void);
Rodolfo Giometti5a90e5b2007-03-16 00:58:52 -040069};
Eric Miao1814db62008-01-31 00:58:37 -050070
eric miao37320982008-01-23 13:39:13 +080071extern void pxa_set_keypad_info(struct pxa27x_keypad_platform_data *info);
72
Eric Miao1814db62008-01-31 00:58:37 -050073#endif /* __ASM_ARCH_PXA27x_KEYPAD_H */