forked from mirrors/linux
		
	 3717194f24
			
		
	
	
		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>
		
			
				
	
	
		
			62 lines
		
	
	
	
		
			1.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			62 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
 |