2009-09-03 21:14:05 +04:00
/*
2010-02-23 08:09:32 +03:00
* omap_hwmod_2420_data . c - hardware modules present on the OMAP2420 chips
2009-09-03 21:14:05 +04:00
*
2010-02-23 08:09:32 +03:00
* Copyright ( C ) 2009 - 2010 Nokia Corporation
2009-09-03 21:14:05 +04:00
* Paul Walmsley
*
* 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 .
*
* XXX handle crossbar / shared link difference for L3 ?
2010-02-23 08:09:32 +03:00
* XXX these should be marked initdata for multi - OMAP kernels
2009-09-03 21:14:05 +04:00
*/
2009-10-20 20:40:47 +04:00
# include <plat/omap_hwmod.h>
2009-09-03 21:14:05 +04:00
# include <mach/irqs.h>
2009-10-20 20:40:47 +04:00
# include <plat/cpu.h>
# include <plat/dma.h>
2009-09-03 21:14:05 +04:00
2010-02-23 08:09:34 +03:00
# include "omap_hwmod_common_data.h"
2009-09-03 21:14:05 +04:00
# include "prm-regbits-24xx.h"
2010-02-23 08:09:32 +03:00
/*
* OMAP2420 hardware module integration data
*
* ALl of the data in this section should be autogeneratable from the
* TI hardware database or other technical documentation . Data that
* is driver - specific or driver - kernel integration - specific belongs
* elsewhere .
*/
2009-09-03 21:14:05 +04:00
static struct omap_hwmod omap2420_mpu_hwmod ;
2010-07-27 02:34:33 +04:00
static struct omap_hwmod omap2420_iva_hwmod ;
2010-07-27 02:34:32 +04:00
static struct omap_hwmod omap2420_l3_main_hwmod ;
2009-09-03 21:14:05 +04:00
static struct omap_hwmod omap2420_l4_core_hwmod ;
/* L3 -> L4_CORE interface */
2010-07-27 02:34:32 +04:00
static struct omap_hwmod_ocp_if omap2420_l3_main__l4_core = {
. master = & omap2420_l3_main_hwmod ,
2009-09-03 21:14:05 +04:00
. slave = & omap2420_l4_core_hwmod ,
. user = OCP_USER_MPU | OCP_USER_SDMA ,
} ;
/* MPU -> L3 interface */
2010-07-27 02:34:32 +04:00
static struct omap_hwmod_ocp_if omap2420_mpu__l3_main = {
2009-09-03 21:14:05 +04:00
. master = & omap2420_mpu_hwmod ,
2010-07-27 02:34:32 +04:00
. slave = & omap2420_l3_main_hwmod ,
2009-09-03 21:14:05 +04:00
. user = OCP_USER_MPU ,
} ;
/* Slave interfaces on the L3 interconnect */
2010-07-27 02:34:32 +04:00
static struct omap_hwmod_ocp_if * omap2420_l3_main_slaves [ ] = {
& omap2420_mpu__l3_main ,
2009-09-03 21:14:05 +04:00
} ;
/* Master interfaces on the L3 interconnect */
2010-07-27 02:34:32 +04:00
static struct omap_hwmod_ocp_if * omap2420_l3_main_masters [ ] = {
& omap2420_l3_main__l4_core ,
2009-09-03 21:14:05 +04:00
} ;
/* L3 */
2010-07-27 02:34:32 +04:00
static struct omap_hwmod omap2420_l3_main_hwmod = {
2010-07-27 02:34:29 +04:00
. name = " l3_main " ,
2010-02-23 08:09:34 +03:00
. class = & l3_hwmod_class ,
2010-07-27 02:34:32 +04:00
. masters = omap2420_l3_main_masters ,
. masters_cnt = ARRAY_SIZE ( omap2420_l3_main_masters ) ,
. slaves = omap2420_l3_main_slaves ,
. slaves_cnt = ARRAY_SIZE ( omap2420_l3_main_slaves ) ,
2010-07-27 02:34:28 +04:00
. omap_chip = OMAP_CHIP_INIT ( CHIP_IS_OMAP2420 ) ,
. flags = HWMOD_NO_IDLEST ,
2009-09-03 21:14:05 +04:00
} ;
static struct omap_hwmod omap2420_l4_wkup_hwmod ;
/* L4_CORE -> L4_WKUP interface */
static struct omap_hwmod_ocp_if omap2420_l4_core__l4_wkup = {
. master = & omap2420_l4_core_hwmod ,
. slave = & omap2420_l4_wkup_hwmod ,
. user = OCP_USER_MPU | OCP_USER_SDMA ,
} ;
/* Slave interfaces on the L4_CORE interconnect */
static struct omap_hwmod_ocp_if * omap2420_l4_core_slaves [ ] = {
2010-07-27 02:34:32 +04:00
& omap2420_l3_main__l4_core ,
2009-09-03 21:14:05 +04:00
} ;
/* Master interfaces on the L4_CORE interconnect */
static struct omap_hwmod_ocp_if * omap2420_l4_core_masters [ ] = {
& omap2420_l4_core__l4_wkup ,
} ;
/* L4 CORE */
static struct omap_hwmod omap2420_l4_core_hwmod = {
2010-07-27 02:34:29 +04:00
. name = " l4_core " ,
2010-02-23 08:09:34 +03:00
. class = & l4_hwmod_class ,
2009-09-03 21:14:05 +04:00
. masters = omap2420_l4_core_masters ,
. masters_cnt = ARRAY_SIZE ( omap2420_l4_core_masters ) ,
. slaves = omap2420_l4_core_slaves ,
. slaves_cnt = ARRAY_SIZE ( omap2420_l4_core_slaves ) ,
2010-07-27 02:34:28 +04:00
. omap_chip = OMAP_CHIP_INIT ( CHIP_IS_OMAP2420 ) ,
. flags = HWMOD_NO_IDLEST ,
2009-09-03 21:14:05 +04:00
} ;
/* Slave interfaces on the L4_WKUP interconnect */
static struct omap_hwmod_ocp_if * omap2420_l4_wkup_slaves [ ] = {
& omap2420_l4_core__l4_wkup ,
} ;
/* Master interfaces on the L4_WKUP interconnect */
static struct omap_hwmod_ocp_if * omap2420_l4_wkup_masters [ ] = {
} ;
/* L4 WKUP */
static struct omap_hwmod omap2420_l4_wkup_hwmod = {
2010-07-27 02:34:29 +04:00
. name = " l4_wkup " ,
2010-02-23 08:09:34 +03:00
. class = & l4_hwmod_class ,
2009-09-03 21:14:05 +04:00
. masters = omap2420_l4_wkup_masters ,
. masters_cnt = ARRAY_SIZE ( omap2420_l4_wkup_masters ) ,
. slaves = omap2420_l4_wkup_slaves ,
. slaves_cnt = ARRAY_SIZE ( omap2420_l4_wkup_slaves ) ,
2010-07-27 02:34:28 +04:00
. omap_chip = OMAP_CHIP_INIT ( CHIP_IS_OMAP2420 ) ,
. flags = HWMOD_NO_IDLEST ,
2009-09-03 21:14:05 +04:00
} ;
/* Master interfaces on the MPU device */
static struct omap_hwmod_ocp_if * omap2420_mpu_masters [ ] = {
2010-07-27 02:34:32 +04:00
& omap2420_mpu__l3_main ,
2009-09-03 21:14:05 +04:00
} ;
/* MPU */
static struct omap_hwmod omap2420_mpu_hwmod = {
2010-05-20 22:31:10 +04:00
. name = " mpu " ,
2010-02-23 08:09:34 +03:00
. class = & mpu_hwmod_class ,
2010-02-23 08:09:31 +03:00
. main_clk = " mpu_ck " ,
2009-09-03 21:14:05 +04:00
. masters = omap2420_mpu_masters ,
. masters_cnt = ARRAY_SIZE ( omap2420_mpu_masters ) ,
. omap_chip = OMAP_CHIP_INIT ( CHIP_IS_OMAP2420 ) ,
} ;
2010-07-27 02:34:33 +04:00
/*
* IVA1 interface data
*/
/* IVA <- L3 interface */
static struct omap_hwmod_ocp_if omap2420_l3__iva = {
. master = & omap2420_l3_main_hwmod ,
. slave = & omap2420_iva_hwmod ,
. clk = " iva1_ifck " ,
. user = OCP_USER_MPU | OCP_USER_SDMA ,
} ;
static struct omap_hwmod_ocp_if * omap2420_iva_masters [ ] = {
& omap2420_l3__iva ,
} ;
/*
* IVA2 ( IVA2 )
*/
static struct omap_hwmod omap2420_iva_hwmod = {
. name = " iva " ,
. class = & iva_hwmod_class ,
. masters = omap2420_iva_masters ,
. masters_cnt = ARRAY_SIZE ( omap2420_iva_masters ) ,
. omap_chip = OMAP_CHIP_INIT ( CHIP_IS_OMAP2420 )
} ;
2009-09-03 21:14:05 +04:00
static __initdata struct omap_hwmod * omap2420_hwmods [ ] = {
2010-07-27 02:34:32 +04:00
& omap2420_l3_main_hwmod ,
2009-09-03 21:14:05 +04:00
& omap2420_l4_core_hwmod ,
& omap2420_l4_wkup_hwmod ,
& omap2420_mpu_hwmod ,
2010-07-27 02:34:33 +04:00
& omap2420_iva_hwmod ,
2009-09-03 21:14:05 +04:00
NULL ,
} ;
2010-02-23 08:09:32 +03:00
int __init omap2420_hwmod_init ( void )
{
return omap_hwmod_init ( omap2420_hwmods ) ;
}
2009-09-03 21:14:05 +04:00