Linux Kernel  3.7.1
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Groups Pages
keypad-pxa27x.h
Go to the documentation of this file.
1 #ifndef __ASM_ARCH_PXA27x_KEYPAD_H
2 #define __ASM_ARCH_PXA27x_KEYPAD_H
3 
4 #include <linux/input.h>
6 
7 #define MAX_MATRIX_KEY_ROWS (8)
8 #define MAX_MATRIX_KEY_COLS (8)
9 #define MATRIX_ROW_SHIFT (3)
10 #define MAX_DIRECT_KEY_NUM (8)
11 
12 /* 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)
25  *
26  * 4. matrix key and direct key will use the same debounce_interval by
27  * default, which should be sufficient in most cases
28  *
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.
35  */
37 
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;
43 
44  /* direct keys */
47  /* the key output may be low active */
49  /* give board a chance to choose the start direct key */
50  unsigned int direct_key_mask;
51 
52  /* rotary encoders 0 */
57 
58  /* rotary encoders 1 */
63 
64  /* key debounce interval */
65  unsigned int debounce_interval;
66 
67  /* clear wakeup event requirement for pxa168 */
69 };
70 
72 
73 #endif /* __ASM_ARCH_PXA27x_KEYPAD_H */