|  | // SPDX-License-Identifier: GPL-2.0 | 
|  | #include <linux/init.h> | 
|  | #include <linux/suspend.h> | 
|  | #include <asm/suspend.h> | 
|  | #include "smc.h" | 
|  | #include "pm.h" | 
|  |  | 
|  | static int tango_pm_powerdown(unsigned long arg) | 
|  | { | 
|  | tango_suspend(__pa_symbol(cpu_resume)); | 
|  |  | 
|  | return -EIO; /* tango_suspend has failed */ | 
|  | } | 
|  |  | 
|  | static int tango_pm_enter(suspend_state_t state) | 
|  | { | 
|  | if (state == PM_SUSPEND_MEM) | 
|  | return cpu_suspend(0, tango_pm_powerdown); | 
|  |  | 
|  | return -EINVAL; | 
|  | } | 
|  |  | 
|  | static const struct platform_suspend_ops tango_pm_ops = { | 
|  | .enter = tango_pm_enter, | 
|  | .valid = suspend_valid_only_mem, | 
|  | }; | 
|  |  | 
|  | void __init tango_pm_init(void) | 
|  | { | 
|  | suspend_set_ops(&tango_pm_ops); | 
|  | } |