mirror of
https://github.com/FEX-Emu/linux.git
synced 2025-01-04 08:15:44 +00:00
a335750b9a
Pull ACPI & Power Management changes from Len Brown: - ACPI 5.0 after-ripples, ACPICA/Linux divergence cleanup - cpuidle evolving, more ARM use - thermal sub-system evolving, ditto - assorted other PM bits Fix up conflicts in various cpuidle implementations due to ARM cpuidle cleanups (ARM at91 self-refresh and cpu idle code rewritten into "standby" in asm conflicting with the consolidation of cpuidle time keeping), trivial SH include file context conflict and RCU tracing fixes in generic code. * 'release' of git://git.kernel.org/pub/scm/linux/kernel/git/lenb/linux: (77 commits) ACPI throttling: fix endian bug in acpi_read_throttling_status() Disable MCP limit exceeded messages from Intel IPS driver ACPI video: Don't start video device until its associated input device has been allocated ACPI video: Harden video bus adding. ACPI: Add support for exposing BGRT data ACPI: export acpi_kobj ACPI: Fix logic for removing mappings in 'acpi_unmap' CPER failed to handle generic error records with multiple sections ACPI: Clean redundant codes in scan.c ACPI: Fix unprotected smp_processor_id() in acpi_processor_cst_has_changed() ACPI: consistently use should_use_kmap() PNPACPI: Fix device ref leaking in acpi_pnp_match ACPI: Fix use-after-free in acpi_map_lsapic ACPI: processor_driver: add missing kfree ACPI, APEI: Fix incorrect APEI register bit width check and usage Update documentation for parameter *notrigger* in einj.txt ACPI, APEI, EINJ, new parameter to control trigger action ACPI, APEI, EINJ, limit the range of einj_param ACPI, APEI, Fix ERST header length check cpuidle: power_usage should be declared signed integer ...
69 lines
1.5 KiB
C
69 lines
1.5 KiB
C
/*
|
|
* CPUIdle support code for SH-Mobile ARM
|
|
*
|
|
* Copyright (C) 2011 Magnus Damm
|
|
*
|
|
* This file is subject to the terms and conditions of the GNU General Public
|
|
* License. See the file "COPYING" in the main directory of this archive
|
|
* for more details.
|
|
*/
|
|
|
|
#include <linux/pm.h>
|
|
#include <linux/cpuidle.h>
|
|
#include <linux/suspend.h>
|
|
#include <linux/module.h>
|
|
#include <linux/err.h>
|
|
#include <asm/cpuidle.h>
|
|
#include <asm/io.h>
|
|
|
|
static void shmobile_enter_wfi(void)
|
|
{
|
|
cpu_do_idle();
|
|
}
|
|
|
|
void (*shmobile_cpuidle_modes[CPUIDLE_STATE_MAX])(void) = {
|
|
shmobile_enter_wfi, /* regular sleep mode */
|
|
};
|
|
|
|
static int shmobile_cpuidle_enter(struct cpuidle_device *dev,
|
|
struct cpuidle_driver *drv,
|
|
int index)
|
|
{
|
|
shmobile_cpuidle_modes[index]();
|
|
|
|
return index;
|
|
}
|
|
|
|
static struct cpuidle_device shmobile_cpuidle_dev;
|
|
static struct cpuidle_driver shmobile_cpuidle_driver = {
|
|
.name = "shmobile_cpuidle",
|
|
.owner = THIS_MODULE,
|
|
.en_core_tk_irqen = 1,
|
|
.states[0] = ARM_CPUIDLE_WFI_STATE,
|
|
.safe_state_index = 0, /* C1 */
|
|
.state_count = 1,
|
|
};
|
|
|
|
void (*shmobile_cpuidle_setup)(struct cpuidle_driver *drv);
|
|
|
|
static int shmobile_cpuidle_init(void)
|
|
{
|
|
struct cpuidle_device *dev = &shmobile_cpuidle_dev;
|
|
struct cpuidle_driver *drv = &shmobile_cpuidle_driver;
|
|
int i;
|
|
|
|
for (i = 0; i < CPUIDLE_STATE_MAX; i++)
|
|
drv->states[i].enter = shmobile_cpuidle_enter;
|
|
|
|
if (shmobile_cpuidle_setup)
|
|
shmobile_cpuidle_setup(drv);
|
|
|
|
cpuidle_register_driver(drv);
|
|
|
|
dev->state_count = drv->state_count;
|
|
cpuidle_register_device(dev);
|
|
|
|
return 0;
|
|
}
|
|
late_initcall(shmobile_cpuidle_init);
|