mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-01 02:36:02 +00:00
3717194f24
Some SoCs have a separate dedicated wake-up interrupt controller that can be used to wake up the system from deeper idle states. We already support configuring a separate interrupt for a gpio-keys button to be used with a gpio line. However, we are lacking support system suspend for cases where a separate interrupt needs to be used in deeper sleep modes. Because of it's nature, gpio-keys does not know about the runtime PM state of the button gpios, and may have several gpio buttons configured for each gpio-keys device instance. Implementing runtime PM support for gpio-keys does not help, and we cannot use drivers/base/power/wakeirq.c support. We need to implement custom wakeirq support for gpio-keys. For handling a dedicated wakeirq for system suspend, we enable and disable it with gpio_keys_enable_wakeup() and gpio_keys_disable_wakeup() that we already use based on device_may_wakeup(). Some systems may have a dedicated wakeirq that can also be used as the main interrupt, this is already working for gpio-keys. Let's add some wakeirq related comments while at it as the usage with a gpio line and separate interrupt line may not be obvious. Tested-by: Dhruva Gole <d-gole@ti.com> Signed-off-by: Tony Lindgren <tony@atomide.com> Link: https://lore.kernel.org/r/20231129110618.27551-2-tony@atomide.com Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
63 lines
1.8 KiB
C
63 lines
1.8 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
#ifndef _GPIO_KEYS_H
|
|
#define _GPIO_KEYS_H
|
|
|
|
#include <linux/types.h>
|
|
|
|
struct device;
|
|
|
|
/**
|
|
* struct gpio_keys_button - configuration parameters
|
|
* @code: input event code (KEY_*, SW_*)
|
|
* @gpio: %-1 if this key does not support gpio
|
|
* @active_low: %true indicates that button is considered
|
|
* depressed when gpio is low
|
|
* @desc: label that will be attached to button's gpio
|
|
* @type: input event type (%EV_KEY, %EV_SW, %EV_ABS)
|
|
* @wakeup: configure the button as a wake-up source
|
|
* @wakeup_event_action: event action to trigger wakeup
|
|
* @debounce_interval: debounce ticks interval in msecs
|
|
* @can_disable: %true indicates that userspace is allowed to
|
|
* disable button via sysfs
|
|
* @value: axis value for %EV_ABS
|
|
* @irq: Irq number in case of interrupt keys
|
|
* @wakeirq: Optional dedicated wake-up interrupt
|
|
*/
|
|
struct gpio_keys_button {
|
|
unsigned int code;
|
|
int gpio;
|
|
int active_low;
|
|
const char *desc;
|
|
unsigned int type;
|
|
int wakeup;
|
|
int wakeup_event_action;
|
|
int debounce_interval;
|
|
bool can_disable;
|
|
int value;
|
|
unsigned int irq;
|
|
unsigned int wakeirq;
|
|
};
|
|
|
|
/**
|
|
* struct gpio_keys_platform_data - platform data for gpio_keys driver
|
|
* @buttons: pointer to array of &gpio_keys_button structures
|
|
* describing buttons attached to the device
|
|
* @nbuttons: number of elements in @buttons array
|
|
* @poll_interval: polling interval in msecs - for polling driver only
|
|
* @rep: enable input subsystem auto repeat
|
|
* @enable: platform hook for enabling the device
|
|
* @disable: platform hook for disabling the device
|
|
* @name: input device name
|
|
*/
|
|
struct gpio_keys_platform_data {
|
|
const struct gpio_keys_button *buttons;
|
|
int nbuttons;
|
|
unsigned int poll_interval;
|
|
unsigned int rep:1;
|
|
int (*enable)(struct device *dev);
|
|
void (*disable)(struct device *dev);
|
|
const char *name;
|
|
};
|
|
|
|
#endif
|