blob: ee2d8c6f91300db725b3681c830d4568de71cb19 [file] [log] [blame]
Kyle Swenson8d8f6542021-03-15 11:02:55 -06001#ifndef _GPIO_KEYS_H
2#define _GPIO_KEYS_H
3
4struct device;
5struct gpio_desc;
6
7/**
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
22 */
23struct gpio_keys_button {
24 unsigned int code;
25 int gpio;
26 int active_low;
27 const char *desc;
28 unsigned int type;
29 int wakeup;
30 int debounce_interval;
31 bool can_disable;
32 int value;
33 unsigned int irq;
34 struct gpio_desc *gpiod;
35};
36
37/**
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
47 */
48struct gpio_keys_platform_data {
49 struct gpio_keys_button *buttons;
50 int nbuttons;
51 unsigned int poll_interval;
52 unsigned int rep:1;
53 int (*enable)(struct device *dev);
54 void (*disable)(struct device *dev);
55 const char *name;
56};
57
58#endif