blob: 75a0f8acef669ce5560f627f516dae54168a898d [file] [log] [blame]
Lorenzo Pieralisid64f84f2014-07-17 10:30:07 +01001/*
2 * ARM64 CPU idle arch support
3 *
4 * Copyright (C) 2014 ARM Ltd.
5 * Author: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>
6 *
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License version 2 as
9 * published by the Free Software Foundation.
10 */
11
Sudeep Holla5a611ed2016-07-19 18:52:58 +010012#include <linux/acpi.h>
13#include <linux/cpuidle.h>
14#include <linux/cpu_pm.h>
Lorenzo Pieralisid64f84f2014-07-17 10:30:07 +010015#include <linux/of.h>
16#include <linux/of_device.h>
17
18#include <asm/cpuidle.h>
19#include <asm/cpu_ops.h>
20
Sudeep Hollace3ad712016-07-19 18:52:55 +010021int arm_cpuidle_init(unsigned int cpu)
Lorenzo Pieralisid64f84f2014-07-17 10:30:07 +010022{
23 int ret = -EOPNOTSUPP;
Lorenzo Pieralisid64f84f2014-07-17 10:30:07 +010024
Jisheng Zhangb5fda7e2016-03-25 11:08:55 +080025 if (cpu_ops[cpu] && cpu_ops[cpu]->cpu_suspend &&
26 cpu_ops[cpu]->cpu_init_idle)
Lorenzo Pieralisi819a8822015-05-13 14:12:46 +010027 ret = cpu_ops[cpu]->cpu_init_idle(cpu);
Lorenzo Pieralisid64f84f2014-07-17 10:30:07 +010028
Lorenzo Pieralisid64f84f2014-07-17 10:30:07 +010029 return ret;
30}
Lorenzo Pieralisiaf3cfdb2015-01-26 18:33:44 +000031
32/**
33 * cpu_suspend() - function to enter a low-power idle state
34 * @arg: argument to pass to CPU suspend operations
35 *
36 * Return: 0 on success, -EOPNOTSUPP if CPU suspend hook not initialized, CPU
37 * operations back-end error code otherwise.
38 */
Sudeep Hollaaf391b12015-06-18 15:41:32 +010039int arm_cpuidle_suspend(int index)
Lorenzo Pieralisiaf3cfdb2015-01-26 18:33:44 +000040{
41 int cpu = smp_processor_id();
42
Sudeep Hollaaf391b12015-06-18 15:41:32 +010043 return cpu_ops[cpu]->cpu_suspend(index);
Lorenzo Pieralisiaf3cfdb2015-01-26 18:33:44 +000044}
Sudeep Holla5a611ed2016-07-19 18:52:58 +010045
46#ifdef CONFIG_ACPI
47
48#include <acpi/processor.h>
49
50int acpi_processor_ffh_lpi_probe(unsigned int cpu)
51{
52 return arm_cpuidle_init(cpu);
53}
54
55int acpi_processor_ffh_lpi_enter(struct acpi_lpi_state *lpi)
56{
57 return CPU_PM_CPU_IDLE_ENTER(arm_cpuidle_suspend, lpi->index);
58}
59#endif