2008-08-19 11:08:40 +03:00
/*
* OMAP2 / 3 common powerdomain definitions
*
* Copyright ( C ) 2007 - 8 Texas Instruments , Inc .
* Copyright ( C ) 2007 - 8 Nokia Corporation
*
* Written by Paul Walmsley
* Debugging and integration fixes by Jouni Högander
*
* 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 ARCH_ARM_MACH_OMAP2_POWERDOMAINS
# define ARCH_ARM_MACH_OMAP2_POWERDOMAINS
/*
* This file contains all of the powerdomains that have some element
* of software control for the OMAP24xx and OMAP34XX chips .
*
* A few notes :
*
* This is not an exhaustive listing of powerdomains on the chips ; only
* powerdomains that can be controlled in software .
*
* A useful validation rule for struct powerdomain :
* Any powerdomain referenced by a wkdep_srcs or sleepdep_srcs array
* must have a dep_bit assigned . So wkdep_srcs / sleepdep_srcs are really
* just software - controllable dependencies . Non - software - controllable
* dependencies do exist , but they are not encoded below ( yet ) .
*
* 24 xx does not support programmable sleep dependencies ( SLEEPDEP )
*
*/
/*
* The names for the DSP / IVA2 powerdomains are confusing .
*
* Most OMAP chips have an on - board DSP .
*
* On the 2420 , this is a ' C55 DSP called , simply , the DSP . Its
* powerdomain is called the " DSP power domain. " On the 2430 , the
* on - board DSP is a ' C64 DSP , now called the IVA2 or IVA2 .1 . Its
* powerdomain is still called the " DSP power domain. " On the 3430 ,
* the DSP is a ' C64 DSP like the 2430 , also known as the IVA2 ; but
* its powerdomain is now called the " IVA2 power domain. "
*
* The 2420 also has something called the IVA , which is a separate ARM
* core , and has nothing to do with the DSP / IVA2 .
*
* Ideally the DSP / IVA2 could just be the same powerdomain , but the PRCM
* address offset is different between the C55 and C64 DSPs .
*
* The overly - specific dep_bit names are due to a bit name collision
* with CM_FCLKEN_ { DSP , IVA2 } . The DSP / IVA2 PM_WKDEP and CM_SLEEPDEP shift
* value are the same for all powerdomains : 2
*/
/*
* XXX should dep_bit be a mask , so we can test to see if it is 0 as a
* sanity check ?
* XXX encode hardware fixed wakeup dependencies - - esp . for 3430 CORE
*/
2009-10-20 09:40:47 -07:00
# include <plat/powerdomain.h>
2008-08-19 11:08:40 +03:00
# include "prcm-common.h"
# include "prm.h"
# include "cm.h"
/* OMAP2/3-common powerdomains and wakeup dependencies */
/*
* 2420 / 2430 PM_WKDEP_GFX : CORE , MPU , WKUP
* 3430 ES1 PM_WKDEP_GFX : adds IVA2 , removes CORE
* 3430 ES2 PM_WKDEP_SGX : adds IVA2 , removes CORE
*/
static struct pwrdm_dep gfx_sgx_wkdeps [ ] = {
{
. pwrdm_name = " core_pwrdm " ,
. omap_chip = OMAP_CHIP_INIT ( CHIP_IS_OMAP24XX )
} ,
{
. pwrdm_name = " iva2_pwrdm " ,
. omap_chip = OMAP_CHIP_INIT ( CHIP_IS_OMAP3430 )
} ,
{
. pwrdm_name = " mpu_pwrdm " ,
. omap_chip = OMAP_CHIP_INIT ( CHIP_IS_OMAP24XX |
CHIP_IS_OMAP3430 )
} ,
{
. pwrdm_name = " wkup_pwrdm " ,
. omap_chip = OMAP_CHIP_INIT ( CHIP_IS_OMAP24XX |
CHIP_IS_OMAP3430 )
} ,
{ NULL } ,
} ;
2008-08-19 11:08:43 +03:00
/*
* 3430 : CM_SLEEPDEP_CAM : MPU
* 3430 ES1 : CM_SLEEPDEP_GFX : MPU
* 3430 ES2 : CM_SLEEPDEP_SGX : MPU
*/
static struct pwrdm_dep cam_gfx_sleepdeps [ ] = {
{
. pwrdm_name = " mpu_pwrdm " ,
. omap_chip = OMAP_CHIP_INIT ( CHIP_IS_OMAP3430 )
} ,
{ NULL } ,
} ;
2008-08-19 11:08:42 +03:00
# include "powerdomains24xx.h"
2008-08-19 11:08:43 +03:00
# include "powerdomains34xx.h"
2008-08-19 11:08:42 +03:00
2008-08-19 11:08:40 +03:00
/*
* OMAP2 / 3 common powerdomains
*/
/*
* The GFX powerdomain is not present on 3430 ES2 , but currently we do not
* have a macro to filter it out at compile - time .
*/
static struct powerdomain gfx_pwrdm = {
. name = " gfx_pwrdm " ,
. prcm_offs = GFX_MOD ,
. omap_chip = OMAP_CHIP_INIT ( CHIP_IS_OMAP24XX |
CHIP_IS_OMAP3430ES1 ) ,
. wkdep_srcs = gfx_sgx_wkdeps ,
2008-08-19 11:08:43 +03:00
. sleepdep_srcs = cam_gfx_sleepdeps ,
2008-08-19 11:08:40 +03:00
. pwrsts = PWRSTS_OFF_RET_ON ,
. pwrsts_logic_ret = PWRDM_POWER_RET ,
. banks = 1 ,
. pwrsts_mem_ret = {
[ 0 ] = PWRDM_POWER_RET , /* MEMRETSTATE */
} ,
. pwrsts_mem_on = {
[ 0 ] = PWRDM_POWER_ON , /* MEMONSTATE */
} ,
} ;
static struct powerdomain wkup_pwrdm = {
. name = " wkup_pwrdm " ,
. prcm_offs = WKUP_MOD ,
. omap_chip = OMAP_CHIP_INIT ( CHIP_IS_OMAP24XX | CHIP_IS_OMAP3430 ) ,
. dep_bit = OMAP_EN_WKUP_SHIFT ,
} ;
/* As powerdomains are added or removed above, this list must also be changed */
static struct powerdomain * powerdomains_omap [ ] __initdata = {
& gfx_pwrdm ,
& wkup_pwrdm ,
2008-08-19 11:08:42 +03:00
# ifdef CONFIG_ARCH_OMAP24XX
& dsp_pwrdm ,
& mpu_24xx_pwrdm ,
& core_24xx_pwrdm ,
# endif
# ifdef CONFIG_ARCH_OMAP2430
& mdm_pwrdm ,
# endif
2008-08-19 11:08:43 +03:00
# ifdef CONFIG_ARCH_OMAP34XX
& iva2_pwrdm ,
& mpu_34xx_pwrdm ,
& neon_pwrdm ,
2009-02-05 20:45:28 -07:00
& core_34xx_pre_es3_1_pwrdm ,
& core_34xx_es3_1_pwrdm ,
2008-08-19 11:08:43 +03:00
& cam_pwrdm ,
& dss_pwrdm ,
& per_pwrdm ,
& emu_pwrdm ,
& sgx_pwrdm ,
& usbhost_pwrdm ,
2009-01-27 19:44:18 -07:00
& dpll1_pwrdm ,
& dpll2_pwrdm ,
& dpll3_pwrdm ,
& dpll4_pwrdm ,
& dpll5_pwrdm ,
2008-08-19 11:08:43 +03:00
# endif
2008-08-19 11:08:40 +03:00
NULL
} ;
# endif