[ubicom32]: move new files out from platform support patch
[openwrt.git] / target / linux / ubicom32 / files / arch / ubicom32 / include / asm / ubicom32input_i2c.h
1 /*
2  * arch/ubicom32/include/asm/ubicom32input_i2c.h
3  *   Ubicom32 architecture Input driver over I2C platform data definitions.
4  *
5  * (C) Copyright 2009, Ubicom, Inc.
6  *
7  * This file is part of the Ubicom32 Linux Kernel Port.
8  *
9  * The Ubicom32 Linux Kernel Port is free software: you can redistribute
10  * it and/or modify it under the terms of the GNU General Public License
11  * as published by the Free Software Foundation, either version 2 of the
12  * License, or (at your option) any later version.
13  *
14  * The Ubicom32 Linux Kernel Port is distributed in the hope that it
15  * will be useful, but WITHOUT ANY WARRANTY; without even the implied
16  * warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See
17  * the GNU General Public License for more details.
18  *
19  * You should have received a copy of the GNU General Public License
20  * along with the Ubicom32 Linux Kernel Port.  If not,
21  * see <http://www.gnu.org/licenses/>.
22  *
23  * Ubicom32 implementation derived from (with many thanks):
24  *   arch/m68knommu
25  *   arch/blackfin
26  *   arch/parisc
27  *
28  * TODO: add groups for inputs which can be sampled together
29  */
30
31 #ifndef _ASM_UBICOM32_UBICOM32_INPUT_I2C_H
32 #define _ASM_UBICOM32_UBICOM32_INPUT_I2C_H
33
34 struct ubicom32input_i2c_button {
35         /*
36          * Input event code (KEY_*, SW_*, etc)
37          */
38         int             code;
39
40         /*
41          * Input event type (EV_KEY, EV_SW, etc)
42          */
43         int             type;
44
45         /*
46          * Bit number of this button. (0 - ngpio)
47          */
48         int             bit;
49
50         /*
51          * 1 for active low, 0 for active high
52          */
53         int             active_low;
54 };
55
56 struct ubicom32input_i2c_platform_data {
57         struct ubicom32input_i2c_button *buttons;
58         int                             nbuttons;
59
60         /*
61          * Optional poll interval, in ms, defaults to 100ms
62          */
63         int                             poll_interval;
64
65         /*
66          * Option Name of this driver
67          */
68         const char                      *name;
69 };
70
71 #endif /* _ASM_UBICOM32_UBICOM32_INPUT_I2C_H */