 27c9d80f51
			
		
	
	27c9d80f51
	
	
		
			
	
		
	
	
		
			Some checks failed
		
		
	
	Build Kernel / Build all affected Kernels (push) Has been cancelled
				
			Build all core packages / Build all core packages for selected target (push) Has been cancelled
				
			Build and Push prebuilt tools container / Build and Push all prebuilt containers (push) Has been cancelled
				
			Build Toolchains / Build Toolchains for each target (push) Has been cancelled
				
			Build host tools / Build host tools for linux and macos based systems (push) Has been cancelled
				
			Coverity scan build / Coverity x86/64 build (push) Has been cancelled
				
			
		
			
				
	
	
		
			54 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			54 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From a102c479c898390bf71200e4e1897f53700e7928 Mon Sep 17 00:00:00 2001
 | |
| From: Phil Elwell <phil@raspberrypi.com>
 | |
| Date: Tue, 27 Apr 2021 08:59:01 +0100
 | |
| Subject: [PATCH 0290/1085] gpio-poweroff: Remember the old poweroff handler
 | |
| 
 | |
| Keeping a copy of the old poweroff handler allows it to be restored
 | |
| should this module be unloaded, but also provides a fallback if the
 | |
| power hasn't been removed when the timeout elapses.
 | |
| 
 | |
| See: https://github.com/raspberrypi/rpi-eeprom/issues/330
 | |
| 
 | |
| Signed-off-by: Phil Elwell <phil@raspberrypi.com>
 | |
| ---
 | |
|  drivers/power/reset/gpio-poweroff.c | 7 ++++++-
 | |
|  1 file changed, 6 insertions(+), 1 deletion(-)
 | |
| 
 | |
| --- a/drivers/power/reset/gpio-poweroff.c
 | |
| +++ b/drivers/power/reset/gpio-poweroff.c
 | |
| @@ -26,6 +26,7 @@ static struct gpio_desc *reset_gpio;
 | |
|  static u32 timeout = DEFAULT_TIMEOUT_MS;
 | |
|  static u32 active_delay = 100;
 | |
|  static u32 inactive_delay = 100;
 | |
| +static void (*old_power_off)(void);
 | |
|  
 | |
|  static void gpio_poweroff_do_poweroff(void)
 | |
|  {
 | |
| @@ -45,6 +46,9 @@ static void gpio_poweroff_do_poweroff(vo
 | |
|  	/* give it some time */
 | |
|  	mdelay(timeout);
 | |
|  
 | |
| +	if (old_power_off)
 | |
| +		old_power_off();
 | |
| +
 | |
|  	WARN_ON(1);
 | |
|  }
 | |
|  
 | |
| @@ -85,6 +89,7 @@ static int gpio_poweroff_probe(struct pl
 | |
|  		gpiod_export_link(&pdev->dev, "poweroff-gpio", reset_gpio);
 | |
|  	}
 | |
|  
 | |
| +	old_power_off = pm_power_off;
 | |
|  	pm_power_off = &gpio_poweroff_do_poweroff;
 | |
|  	return 0;
 | |
|  }
 | |
| @@ -92,7 +97,7 @@ static int gpio_poweroff_probe(struct pl
 | |
|  static int gpio_poweroff_remove(struct platform_device *pdev)
 | |
|  {
 | |
|  	if (pm_power_off == &gpio_poweroff_do_poweroff)
 | |
| -		pm_power_off = NULL;
 | |
| +		pm_power_off = old_power_off;
 | |
|  
 | |
|  	gpiod_unexport(reset_gpio);
 | |
|  
 |