The CP15 diagnostic register holds ARM errata bits on Cortex-A9, so it needs to be saved/restored on suspend/resume. Otherwise, the effectiveness of errata workaround gets lost together with diagnostic register bit across suspend/resume cycle. And the CP15 power control register of Cortex-A9 shares the same problem. The patch adds a couple of Cortex-A9 specific suspend/resume functions to save/restore these two Cortex-A9 CP15 registers across the suspend/resume cycle. Signed-off-by: Shawn Guo <shawn.guo@freescale.com> Acked-by: Nicolas Pitre <nico@linaro.org> Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
		
			
				
	
	
		
			264 lines
		
	
	
	
		
			4.5 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			264 lines
		
	
	
	
		
			4.5 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
/*
 | 
						|
 *  arch/arm/include/asm/glue-proc.h
 | 
						|
 *
 | 
						|
 *  Copyright (C) 1997-1999 Russell King
 | 
						|
 *  Copyright (C) 2000 Deep Blue Solutions Ltd
 | 
						|
 *
 | 
						|
 * This program is free software; you can redistribute it and/or modify
 | 
						|
 * it under the terms of the GNU General Public License version 2 as
 | 
						|
 * published by the Free Software Foundation.
 | 
						|
 */
 | 
						|
#ifndef ASM_GLUE_PROC_H
 | 
						|
#define ASM_GLUE_PROC_H
 | 
						|
 | 
						|
#include <asm/glue.h>
 | 
						|
 | 
						|
/*
 | 
						|
 * Work out if we need multiple CPU support
 | 
						|
 */
 | 
						|
#undef MULTI_CPU
 | 
						|
#undef CPU_NAME
 | 
						|
 | 
						|
/*
 | 
						|
 * CPU_NAME - the prefix for CPU related functions
 | 
						|
 */
 | 
						|
 | 
						|
#ifdef CONFIG_CPU_ARM7TDMI
 | 
						|
# ifdef CPU_NAME
 | 
						|
#  undef  MULTI_CPU
 | 
						|
#  define MULTI_CPU
 | 
						|
# else
 | 
						|
#  define CPU_NAME cpu_arm7tdmi
 | 
						|
# endif
 | 
						|
#endif
 | 
						|
 | 
						|
#ifdef CONFIG_CPU_ARM720T
 | 
						|
# ifdef CPU_NAME
 | 
						|
#  undef  MULTI_CPU
 | 
						|
#  define MULTI_CPU
 | 
						|
# else
 | 
						|
#  define CPU_NAME cpu_arm720
 | 
						|
# endif
 | 
						|
#endif
 | 
						|
 | 
						|
#ifdef CONFIG_CPU_ARM740T
 | 
						|
# ifdef CPU_NAME
 | 
						|
#  undef  MULTI_CPU
 | 
						|
#  define MULTI_CPU
 | 
						|
# else
 | 
						|
#  define CPU_NAME cpu_arm740
 | 
						|
# endif
 | 
						|
#endif
 | 
						|
 | 
						|
#ifdef CONFIG_CPU_ARM9TDMI
 | 
						|
# ifdef CPU_NAME
 | 
						|
#  undef  MULTI_CPU
 | 
						|
#  define MULTI_CPU
 | 
						|
# else
 | 
						|
#  define CPU_NAME cpu_arm9tdmi
 | 
						|
# endif
 | 
						|
#endif
 | 
						|
 | 
						|
#ifdef CONFIG_CPU_ARM920T
 | 
						|
# ifdef CPU_NAME
 | 
						|
#  undef  MULTI_CPU
 | 
						|
#  define MULTI_CPU
 | 
						|
# else
 | 
						|
#  define CPU_NAME cpu_arm920
 | 
						|
# endif
 | 
						|
#endif
 | 
						|
 | 
						|
#ifdef CONFIG_CPU_ARM922T
 | 
						|
# ifdef CPU_NAME
 | 
						|
#  undef  MULTI_CPU
 | 
						|
#  define MULTI_CPU
 | 
						|
# else
 | 
						|
#  define CPU_NAME cpu_arm922
 | 
						|
# endif
 | 
						|
#endif
 | 
						|
 | 
						|
#ifdef CONFIG_CPU_FA526
 | 
						|
# ifdef CPU_NAME
 | 
						|
#  undef  MULTI_CPU
 | 
						|
#  define MULTI_CPU
 | 
						|
# else
 | 
						|
#  define CPU_NAME cpu_fa526
 | 
						|
# endif
 | 
						|
#endif
 | 
						|
 | 
						|
#ifdef CONFIG_CPU_ARM925T
 | 
						|
# ifdef CPU_NAME
 | 
						|
#  undef  MULTI_CPU
 | 
						|
#  define MULTI_CPU
 | 
						|
# else
 | 
						|
#  define CPU_NAME cpu_arm925
 | 
						|
# endif
 | 
						|
#endif
 | 
						|
 | 
						|
#ifdef CONFIG_CPU_ARM926T
 | 
						|
# ifdef CPU_NAME
 | 
						|
#  undef  MULTI_CPU
 | 
						|
#  define MULTI_CPU
 | 
						|
# else
 | 
						|
#  define CPU_NAME cpu_arm926
 | 
						|
# endif
 | 
						|
#endif
 | 
						|
 | 
						|
#ifdef CONFIG_CPU_ARM940T
 | 
						|
# ifdef CPU_NAME
 | 
						|
#  undef  MULTI_CPU
 | 
						|
#  define MULTI_CPU
 | 
						|
# else
 | 
						|
#  define CPU_NAME cpu_arm940
 | 
						|
# endif
 | 
						|
#endif
 | 
						|
 | 
						|
#ifdef CONFIG_CPU_ARM946E
 | 
						|
# ifdef CPU_NAME
 | 
						|
#  undef  MULTI_CPU
 | 
						|
#  define MULTI_CPU
 | 
						|
# else
 | 
						|
#  define CPU_NAME cpu_arm946
 | 
						|
# endif
 | 
						|
#endif
 | 
						|
 | 
						|
#ifdef CONFIG_CPU_SA110
 | 
						|
# ifdef CPU_NAME
 | 
						|
#  undef  MULTI_CPU
 | 
						|
#  define MULTI_CPU
 | 
						|
# else
 | 
						|
#  define CPU_NAME cpu_sa110
 | 
						|
# endif
 | 
						|
#endif
 | 
						|
 | 
						|
#ifdef CONFIG_CPU_SA1100
 | 
						|
# ifdef CPU_NAME
 | 
						|
#  undef  MULTI_CPU
 | 
						|
#  define MULTI_CPU
 | 
						|
# else
 | 
						|
#  define CPU_NAME cpu_sa1100
 | 
						|
# endif
 | 
						|
#endif
 | 
						|
 | 
						|
#ifdef CONFIG_CPU_ARM1020
 | 
						|
# ifdef CPU_NAME
 | 
						|
#  undef  MULTI_CPU
 | 
						|
#  define MULTI_CPU
 | 
						|
# else
 | 
						|
#  define CPU_NAME cpu_arm1020
 | 
						|
# endif
 | 
						|
#endif
 | 
						|
 | 
						|
#ifdef CONFIG_CPU_ARM1020E
 | 
						|
# ifdef CPU_NAME
 | 
						|
#  undef  MULTI_CPU
 | 
						|
#  define MULTI_CPU
 | 
						|
# else
 | 
						|
#  define CPU_NAME cpu_arm1020e
 | 
						|
# endif
 | 
						|
#endif
 | 
						|
 | 
						|
#ifdef CONFIG_CPU_ARM1022
 | 
						|
# ifdef CPU_NAME
 | 
						|
#  undef  MULTI_CPU
 | 
						|
#  define MULTI_CPU
 | 
						|
# else
 | 
						|
#  define CPU_NAME cpu_arm1022
 | 
						|
# endif
 | 
						|
#endif
 | 
						|
 | 
						|
#ifdef CONFIG_CPU_ARM1026
 | 
						|
# ifdef CPU_NAME
 | 
						|
#  undef  MULTI_CPU
 | 
						|
#  define MULTI_CPU
 | 
						|
# else
 | 
						|
#  define CPU_NAME cpu_arm1026
 | 
						|
# endif
 | 
						|
#endif
 | 
						|
 | 
						|
#ifdef CONFIG_CPU_XSCALE
 | 
						|
# ifdef CPU_NAME
 | 
						|
#  undef  MULTI_CPU
 | 
						|
#  define MULTI_CPU
 | 
						|
# else
 | 
						|
#  define CPU_NAME cpu_xscale
 | 
						|
# endif
 | 
						|
#endif
 | 
						|
 | 
						|
#ifdef CONFIG_CPU_XSC3
 | 
						|
# ifdef CPU_NAME
 | 
						|
#  undef  MULTI_CPU
 | 
						|
#  define MULTI_CPU
 | 
						|
# else
 | 
						|
#  define CPU_NAME cpu_xsc3
 | 
						|
# endif
 | 
						|
#endif
 | 
						|
 | 
						|
#ifdef CONFIG_CPU_MOHAWK
 | 
						|
# ifdef CPU_NAME
 | 
						|
#  undef  MULTI_CPU
 | 
						|
#  define MULTI_CPU
 | 
						|
# else
 | 
						|
#  define CPU_NAME cpu_mohawk
 | 
						|
# endif
 | 
						|
#endif
 | 
						|
 | 
						|
#ifdef CONFIG_CPU_FEROCEON
 | 
						|
# ifdef CPU_NAME
 | 
						|
#  undef  MULTI_CPU
 | 
						|
#  define MULTI_CPU
 | 
						|
# else
 | 
						|
#  define CPU_NAME cpu_feroceon
 | 
						|
# endif
 | 
						|
#endif
 | 
						|
 | 
						|
#if defined(CONFIG_CPU_V6) || defined(CONFIG_CPU_V6K)
 | 
						|
# ifdef CPU_NAME
 | 
						|
#  undef  MULTI_CPU
 | 
						|
#  define MULTI_CPU
 | 
						|
# else
 | 
						|
#  define CPU_NAME cpu_v6
 | 
						|
# endif
 | 
						|
#endif
 | 
						|
 | 
						|
#ifdef CONFIG_CPU_V7M
 | 
						|
# ifdef CPU_NAME
 | 
						|
#  undef  MULTI_CPU
 | 
						|
#  define MULTI_CPU
 | 
						|
# else
 | 
						|
#  define CPU_NAME cpu_v7m
 | 
						|
# endif
 | 
						|
#endif
 | 
						|
 | 
						|
#ifdef CONFIG_CPU_PJ4B
 | 
						|
# ifdef CPU_NAME
 | 
						|
#  undef  MULTI_CPU
 | 
						|
#  define MULTI_CPU
 | 
						|
# else
 | 
						|
#  define CPU_NAME cpu_pj4b
 | 
						|
# endif
 | 
						|
#endif
 | 
						|
 | 
						|
#ifdef CONFIG_CPU_V7
 | 
						|
/*
 | 
						|
 * Cortex-A9 needs a different suspend/resume function, so we need
 | 
						|
 * multiple CPU support for ARMv7 anyway.
 | 
						|
 */
 | 
						|
#  undef  MULTI_CPU
 | 
						|
#  define MULTI_CPU
 | 
						|
#endif
 | 
						|
 | 
						|
#ifndef MULTI_CPU
 | 
						|
#define cpu_proc_init			__glue(CPU_NAME,_proc_init)
 | 
						|
#define cpu_proc_fin			__glue(CPU_NAME,_proc_fin)
 | 
						|
#define cpu_reset			__glue(CPU_NAME,_reset)
 | 
						|
#define cpu_do_idle			__glue(CPU_NAME,_do_idle)
 | 
						|
#define cpu_dcache_clean_area		__glue(CPU_NAME,_dcache_clean_area)
 | 
						|
#define cpu_do_switch_mm		__glue(CPU_NAME,_switch_mm)
 | 
						|
#define cpu_set_pte_ext			__glue(CPU_NAME,_set_pte_ext)
 | 
						|
#define cpu_suspend_size		__glue(CPU_NAME,_suspend_size)
 | 
						|
#define cpu_do_suspend			__glue(CPU_NAME,_do_suspend)
 | 
						|
#define cpu_do_resume			__glue(CPU_NAME,_do_resume)
 | 
						|
#endif
 | 
						|
 | 
						|
#endif
 |