copy header to proper location
This commit is contained in:
82
arch/arm/mach-msm/include/mach/pm.h
Normal file
82
arch/arm/mach-msm/include/mach/pm.h
Normal file
@@ -0,0 +1,82 @@
|
||||
/* arch/arm/mach-msm/pm.h
|
||||
*
|
||||
* Copyright (C) 2007 Google, Inc.
|
||||
* Copyright (c) 2009-2012, Code Aurora Forum. All rights reserved.
|
||||
* Author: San Mehat <san@android.com>
|
||||
*
|
||||
* This software is licensed under the terms of the GNU General Public
|
||||
* License version 2, as published by the Free Software Foundation, and
|
||||
* may be copied, distributed, and modified under those terms.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
*/
|
||||
|
||||
#ifndef __ARCH_ARM_MACH_MSM_PM_H
|
||||
#define __ARCH_ARM_MACH_MSM_PM_H
|
||||
|
||||
#include <linux/types.h>
|
||||
#include <linux/cpuidle.h>
|
||||
|
||||
#ifdef CONFIG_SMP
|
||||
extern void msm_secondary_startup(void);
|
||||
#else
|
||||
#define msm_secondary_startup NULL
|
||||
#endif
|
||||
|
||||
enum msm_pm_sleep_mode {
|
||||
MSM_PM_SLEEP_MODE_POWER_COLLAPSE_SUSPEND,
|
||||
MSM_PM_SLEEP_MODE_POWER_COLLAPSE,
|
||||
MSM_PM_SLEEP_MODE_APPS_SLEEP,
|
||||
MSM_PM_SLEEP_MODE_RAMP_DOWN_AND_WAIT_FOR_INTERRUPT,
|
||||
MSM_PM_SLEEP_MODE_WAIT_FOR_INTERRUPT,
|
||||
MSM_PM_SLEEP_MODE_POWER_COLLAPSE_NO_XO_SHUTDOWN,
|
||||
MSM_PM_SLEEP_MODE_POWER_COLLAPSE_STANDALONE,
|
||||
MSM_PM_SLEEP_MODE_NR
|
||||
};
|
||||
|
||||
#define MSM_PM_MODE(cpu, mode_nr) ((cpu) * MSM_PM_SLEEP_MODE_NR + (mode_nr))
|
||||
|
||||
struct msm_pm_platform_data {
|
||||
u8 idle_supported; /* Allow device to enter mode during idle */
|
||||
u8 suspend_supported; /* Allow device to enter mode during suspend */
|
||||
u8 suspend_enabled; /* enabled for suspend */
|
||||
u8 idle_enabled; /* enabled for idle low power */
|
||||
u32 latency; /* interrupt latency in microseconds when entering
|
||||
and exiting the low power mode */
|
||||
u32 residency; /* time threshold in microseconds beyond which
|
||||
staying in the low power mode saves power */
|
||||
};
|
||||
|
||||
struct msm_pm_sleep_status_data {
|
||||
void *base_addr;
|
||||
uint32_t cpu_offset;
|
||||
uint32_t mask;
|
||||
};
|
||||
|
||||
void msm_pm_set_platform_data(struct msm_pm_platform_data *data, int count);
|
||||
int msm_pm_idle_prepare(struct cpuidle_device *dev);
|
||||
int msm_pm_idle_enter(enum msm_pm_sleep_mode sleep_mode);
|
||||
void msm_pm_cpu_enter_lowpower(unsigned int cpu);
|
||||
|
||||
void __init msm_pm_init_sleep_status_data(
|
||||
struct msm_pm_sleep_status_data *sleep_data);
|
||||
#ifdef CONFIG_MSM_PM8X60
|
||||
void msm_pm_set_rpm_wakeup_irq(unsigned int irq);
|
||||
int msm_pm_wait_cpu_shutdown(unsigned int cpu);
|
||||
bool msm_pm_verify_cpu_pc(unsigned int cpu);
|
||||
#else
|
||||
static inline void msm_pm_set_rpm_wakeup_irq(unsigned int irq) {}
|
||||
static inline int msm_pm_wait_cpu_shutdown(unsigned int cpu) { return 0; }
|
||||
static inline bool msm_pm_verify_cpu_pc(unsigned int cpu) { return true; }
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_HOTPLUG_CPU
|
||||
int msm_platform_secondary_init(unsigned int cpu);
|
||||
#else
|
||||
static inline int msm_platform_secondary_init(unsigned int cpu) { return 0; }
|
||||
#endif
|
||||
#endif /* __ARCH_ARM_MACH_MSM_PM_H */
|
||||
Reference in New Issue
Block a user