8 * struct gpio_keys_button - configuration parameters
9 * @code: input event code (KEY_*, SW_*)
10 * @gpio: %-1 if this key does not support gpio
11 * @active_low: %true indicates that button is considered
12 * depressed when gpio is low
13 * @desc: label that will be attached to button's gpio
14 * @type: input event type (%EV_KEY, %EV_SW, %EV_ABS)
15 * @wakeup: configure the button as a wake-up source
16 * @debounce_interval: debounce ticks interval in msecs
17 * @can_disable: %true indicates that userspace is allowed to
18 * disable button via sysfs
19 * @value: axis value for %EV_ABS
20 * @irq: Irq number in case of interrupt keys
21 * @gpiod: GPIO descriptor
23 struct gpio_keys_button
{
30 int debounce_interval
;
34 struct gpio_desc
*gpiod
;
38 * struct gpio_keys_platform_data - platform data for gpio_keys driver
39 * @buttons: pointer to array of &gpio_keys_button structures
40 * describing buttons attached to the device
41 * @nbuttons: number of elements in @buttons array
42 * @poll_interval: polling interval in msecs - for polling driver only
43 * @rep: enable input subsystem auto repeat
44 * @enable: platform hook for enabling the device
45 * @disable: platform hook for disabling the device
46 * @name: input device name
48 struct gpio_keys_platform_data
{
49 struct gpio_keys_button
*buttons
;
51 unsigned int poll_interval
;
53 int (*enable
)(struct device
*dev
);
54 void (*disable
)(struct device
*dev
);