53 lines
1.0 KiB
C
53 lines
1.0 KiB
C
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
||
|
/*
|
||
|
* loongson-specific suspend support
|
||
|
*
|
||
|
* Copyright (C) 2009 Lemote Inc.
|
||
|
* Author: Wu Zhangjin <wuzhangjin@gmail.com>
|
||
|
*/
|
||
|
#include <linux/suspend.h>
|
||
|
#include <linux/pm.h>
|
||
|
|
||
|
#include <asm/mipsregs.h>
|
||
|
|
||
|
#include <loongson.h>
|
||
|
|
||
|
asmlinkage void loongson_lefi_sleep(unsigned long sleep_addr);
|
||
|
|
||
|
static int lefi_pm_enter(suspend_state_t state)
|
||
|
{
|
||
|
switch (state) {
|
||
|
case PM_SUSPEND_MEM:
|
||
|
pm_set_suspend_via_firmware();
|
||
|
loongson_lefi_sleep(loongson_sysconf.suspend_addr);
|
||
|
pm_set_resume_via_firmware();
|
||
|
return 0;
|
||
|
default:
|
||
|
return -EINVAL;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
static int lefi_pm_valid_state(suspend_state_t state)
|
||
|
{
|
||
|
switch (state) {
|
||
|
case PM_SUSPEND_MEM:
|
||
|
return !!loongson_sysconf.suspend_addr;
|
||
|
default:
|
||
|
return 0;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
static const struct platform_suspend_ops lefi_pm_ops = {
|
||
|
.valid = lefi_pm_valid_state,
|
||
|
.enter = lefi_pm_enter,
|
||
|
};
|
||
|
|
||
|
static int __init loongson_pm_init(void)
|
||
|
{
|
||
|
if (loongson_sysconf.fw_interface == LOONGSON_LEFI)
|
||
|
suspend_set_ops(&lefi_pm_ops);
|
||
|
|
||
|
return 0;
|
||
|
}
|
||
|
arch_initcall(loongson_pm_init);
|