/* Copyright (c) 2007-2009,2012 The Linux Foundation. All rights reserved. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 and * only version 2 as published by the Free Software Foundation. * * 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_IDLE_H_ #define _ARCH_ARM_MACH_MSM_IDLE_H_ /* 11 general purpose registers (r4-r14), 10 cp15 registers */ #define CPU_SAVED_STATE_SIZE (4 * 11 + 4 * 10) #define ON 1 #define OFF 0 #define TARGET_IS_8625 1 #define POWER_COLLAPSED 1 #ifndef __ASSEMBLY__ int msm_arch_idle(void); int msm_pm_collapse(void); void msm_pm_collapse_exit(void); extern void *msm_saved_state; extern unsigned long msm_saved_state_phys; #ifdef CONFIG_CPU_V7 void msm_pm_boot_entry(void); void msm_pm_set_l2_flush_flag(unsigned int flag); int msm_pm_get_l2_flush_flag(void); extern unsigned long msm_pm_pc_pgd; extern unsigned long msm_pm_boot_vector[NR_CPUS]; extern uint32_t target_type; extern uint32_t apps_power_collapse; extern uint32_t *l2x0_base_addr; #else static inline void msm_pm_set_l2_flush_flag(unsigned int flag) { /* empty */ } static inline void msm_pm_boot_entry(void) { /* empty */ } static inline void msm_pm_write_boot_vector(unsigned int cpu, unsigned long address) { /* empty */ } #endif #endif #endif