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
*
2011-07-10 05:14:05 +04:00
* Copyright ( C ) 2009 - 2011 Nokia Corporation
2012-04-19 14:04:31 +04:00
* Copyright ( C ) 2012 Texas Instruments , Inc .
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>
2010-09-27 18:49:30 +04:00
# include <plat/serial.h>
2010-09-30 01:10:12 +04:00
# include <plat/i2c.h>
2010-12-08 03:26:56 +03:00
# include <plat/gpio.h>
2011-02-17 20:53:09 +03:00
# include <plat/mcspi.h>
2011-02-23 10:14:04 +03:00
# include <plat/dmtimer.h>
2011-02-22 10:50:36 +03:00
# include <plat/l3_2xxx.h>
# include <plat/l4_2xxx.h>
2009-09-03 21:14:05 +04:00
2010-02-23 08:09:34 +03:00
# include "omap_hwmod_common_data.h"
2010-09-23 18:32:39 +04:00
# include "cm-regbits-24xx.h"
2010-09-30 01:10:12 +04:00
# include "prm-regbits-24xx.h"
OMAP2+: wd_timer: disable on boot via hwmod postsetup mechanism
The OMAP watchdog timer IP blocks require a specific set of register
writes to occur before they will be disabled[1], even if the device
clocks appear to be disabled in the CM_*CLKEN registers. In the MPU
watchdog case, failure to execute this reset sequence will eventually
cause the watchdog to reset the OMAP unexpectedly.
Previously, the code to disable this watchdog was manually called from
mach-omap2/devices.c during device initialization. This causes the
watchdog to be unconditionally disabled for a portion of kernel
initialization. This should be controllable by the board-*.c files,
since some system integrators will want full watchdog coverage of
kernel initialization. Also, the watchdog disable code was not
connected to the hwmod shutdown code. This means that calling
omap_hwmod_shutdown() will not, in fact, disable the watchdog, and the
goal of omap_hwmod_shutdown() is to be able to shutdown any on-chip
OMAP device.
To resolve the latter problem, populate the pre_shutdown pointer in
the watchdog timer hwmod classes with a function that executes the
watchdog shutdown sequence. This allows the hwmod code to fully
disable the watchdog.
Then, to allow some board files to support watchdog coverage
throughout kernel initialization, add common code to mach-omap2/io.c
to cause the MPU watchdog to be disabled on boot unless a board file
specifically requests it to remain enabled. Board files can do this
by changing the watchdog timer hwmod's postsetup state between the
omap2_init_common_infrastructure() and omap2_init_common_devices()
function calls.
1. OMAP34xx Multimedia Device Silicon Revision 3.1.x Rev. ZH
[SWPU222H], Section 16.4.3.6, "Start/Stop Sequence for WDTs (Using
WDTi.WSPR Register)"
Signed-off-by: Paul Walmsley <paul@pwsan.com>
Cc: Benoît Cousson <b-cousson@ti.com>
Cc: Kevin Hilman <khilman@deeprootsystems.com>
Cc: Charulatha Varadarajan <charu@ti.com>
2010-12-22 01:39:15 +03:00
# include "wd_timer.h"
2009-09-03 21:14:05 +04:00
2010-02-23 08:09:32 +03:00
/*
* OMAP2420 hardware module integration data
*
2012-04-19 14:04:33 +04:00
* All of the data in this section should be autogeneratable from the
2010-02-23 08:09:32 +03:00
* TI hardware database or other technical documentation . Data that
* is driver - specific or driver - kernel integration - specific belongs
* elsewhere .
*/
2012-04-19 14:04:33 +04:00
/*
* IP blocks
*/
2011-02-22 10:50:36 +03:00
2012-04-19 14:04:33 +04:00
/* IVA2 (IVA2) */
2010-07-27 02:34:33 +04:00
static struct omap_hwmod omap2420_iva_hwmod = {
. name = " iva " ,
. class = & iva_hwmod_class ,
} ;
2010-09-30 01:10:12 +04:00
/* I2C common */
static struct omap_hwmod_class_sysconfig i2c_sysc = {
. rev_offs = 0x00 ,
. sysc_offs = 0x20 ,
. syss_offs = 0x10 ,
2011-03-04 00:22:46 +03:00
. sysc_flags = ( SYSC_HAS_SOFTRESET | SYSS_HAS_RESET_STATUS ) ,
2010-09-30 01:10:12 +04:00
. sysc_fields = & omap_hwmod_sysc_type1 ,
} ;
static struct omap_hwmod_class i2c_class = {
. name = " i2c " ,
. sysc = & i2c_sysc ,
2011-07-10 15:27:15 +04:00
. rev = OMAP_I2C_IP_VERSION_1 ,
2011-07-10 15:27:16 +04:00
. reset = & omap_i2c_reset ,
2010-09-30 01:10:12 +04:00
} ;
2011-07-10 15:27:16 +04:00
static struct omap_i2c_dev_attr i2c_dev_attr = {
. flags = OMAP_I2C_FLAG_NO_FIFO |
OMAP_I2C_FLAG_SIMPLE_CLOCK |
OMAP_I2C_FLAG_16BIT_DATA_REG |
OMAP_I2C_FLAG_BUS_SHIFT_2 ,
} ;
2010-09-30 01:10:12 +04:00
/* I2C1 */
static struct omap_hwmod omap2420_i2c1_hwmod = {
. name = " i2c1 " ,
2011-07-10 05:14:07 +04:00
. mpu_irqs = omap2_i2c1_mpu_irqs ,
2011-07-10 05:14:07 +04:00
. sdma_reqs = omap2_i2c1_sdma_reqs ,
2010-09-30 01:10:12 +04:00
. main_clk = " i2c1_fck " ,
. prcm = {
. omap2 = {
. module_offs = CORE_MOD ,
. prcm_reg_id = 1 ,
. module_bit = OMAP2420_EN_I2C1_SHIFT ,
. idlest_reg_id = 1 ,
. idlest_idle_bit = OMAP2420_ST_I2C1_SHIFT ,
} ,
} ,
. class = & i2c_class ,
. dev_attr = & i2c_dev_attr ,
. flags = HWMOD_16BIT_REG ,
} ;
/* I2C2 */
static struct omap_hwmod omap2420_i2c2_hwmod = {
. name = " i2c2 " ,
2011-07-10 05:14:07 +04:00
. mpu_irqs = omap2_i2c2_mpu_irqs ,
2011-07-10 05:14:07 +04:00
. sdma_reqs = omap2_i2c2_sdma_reqs ,
2010-09-30 01:10:12 +04:00
. main_clk = " i2c2_fck " ,
. prcm = {
. omap2 = {
. module_offs = CORE_MOD ,
. prcm_reg_id = 1 ,
. module_bit = OMAP2420_EN_I2C2_SHIFT ,
. idlest_reg_id = 1 ,
. idlest_idle_bit = OMAP2420_ST_I2C2_SHIFT ,
} ,
} ,
. class = & i2c_class ,
. dev_attr = & i2c_dev_attr ,
. flags = HWMOD_16BIT_REG ,
} ;
2010-12-21 05:27:18 +03:00
/* dma attributes */
static struct omap_dma_dev_attr dma_dev_attr = {
. dev_caps = RESERVE_CHANNEL | DMA_LINKED_LCH | GLOBAL_PRIORITY |
IS_CSSA_32 | IS_CDSA_32 ,
. lch_count = 32 ,
} ;
static struct omap_hwmod omap2420_dma_system_hwmod = {
. name = " dma " ,
2011-07-10 05:14:08 +04:00
. class = & omap2xxx_dma_hwmod_class ,
2011-07-10 05:14:07 +04:00
. mpu_irqs = omap2_dma_system_irqs ,
2010-12-21 05:27:18 +03:00
. main_clk = " core_l3_ck " ,
. dev_attr = & dma_dev_attr ,
. flags = HWMOD_NO_IDLEST ,
} ;
2011-02-24 23:51:32 +03:00
/* mailbox */
static struct omap_hwmod_irq_info omap2420_mailbox_irqs [ ] = {
{ . name = " dsp " , . irq = 26 } ,
{ . name = " iva " , . irq = 34 } ,
2011-07-10 05:14:06 +04:00
{ . irq = - 1 }
2011-02-24 23:51:32 +03:00
} ;
static struct omap_hwmod omap2420_mailbox_hwmod = {
. name = " mailbox " ,
2011-07-10 05:14:08 +04:00
. class = & omap2xxx_mailbox_hwmod_class ,
2011-02-24 23:51:32 +03:00
. mpu_irqs = omap2420_mailbox_irqs ,
. main_clk = " mailboxes_ick " ,
. prcm = {
. omap2 = {
. prcm_reg_id = 1 ,
. module_bit = OMAP24XX_EN_MAILBOXES_SHIFT ,
. module_offs = CORE_MOD ,
. idlest_reg_id = 1 ,
. idlest_idle_bit = OMAP24XX_ST_MAILBOXES_SHIFT ,
} ,
} ,
} ;
2011-02-24 23:51:46 +03:00
/*
* ' mcbsp ' class
* multi channel buffered serial port controller
*/
static struct omap_hwmod_class omap2420_mcbsp_hwmod_class = {
. name = " mcbsp " ,
} ;
/* mcbsp1 */
static struct omap_hwmod_irq_info omap2420_mcbsp1_irqs [ ] = {
{ . name = " tx " , . irq = 59 } ,
{ . name = " rx " , . irq = 60 } ,
2011-07-10 05:14:06 +04:00
{ . irq = - 1 }
2011-02-24 23:51:46 +03:00
} ;
static struct omap_hwmod omap2420_mcbsp1_hwmod = {
. name = " mcbsp1 " ,
. class = & omap2420_mcbsp_hwmod_class ,
. mpu_irqs = omap2420_mcbsp1_irqs ,
2011-07-10 05:14:07 +04:00
. sdma_reqs = omap2_mcbsp1_sdma_reqs ,
2011-02-24 23:51:46 +03:00
. main_clk = " mcbsp1_fck " ,
. prcm = {
. omap2 = {
. prcm_reg_id = 1 ,
. module_bit = OMAP24XX_EN_MCBSP1_SHIFT ,
. module_offs = CORE_MOD ,
. idlest_reg_id = 1 ,
. idlest_idle_bit = OMAP24XX_ST_MCBSP1_SHIFT ,
} ,
} ,
} ;
/* mcbsp2 */
static struct omap_hwmod_irq_info omap2420_mcbsp2_irqs [ ] = {
{ . name = " tx " , . irq = 62 } ,
{ . name = " rx " , . irq = 63 } ,
2011-07-10 05:14:06 +04:00
{ . irq = - 1 }
2011-02-24 23:51:46 +03:00
} ;
static struct omap_hwmod omap2420_mcbsp2_hwmod = {
. name = " mcbsp2 " ,
. class = & omap2420_mcbsp_hwmod_class ,
. mpu_irqs = omap2420_mcbsp2_irqs ,
2011-07-10 05:14:07 +04:00
. sdma_reqs = omap2_mcbsp2_sdma_reqs ,
2011-02-24 23:51:46 +03:00
. main_clk = " mcbsp2_fck " ,
. prcm = {
. omap2 = {
. prcm_reg_id = 1 ,
. module_bit = OMAP24XX_EN_MCBSP2_SHIFT ,
. module_offs = CORE_MOD ,
. idlest_reg_id = 1 ,
. idlest_idle_bit = OMAP24XX_ST_MCBSP2_SHIFT ,
} ,
} ,
2012-04-19 14:04:31 +04:00
} ;
2012-04-19 14:04:33 +04:00
/*
* interfaces
*/
/* L4 CORE -> I2C1 interface */
static struct omap_hwmod_ocp_if omap2420_l4_core__i2c1 = {
2012-04-19 14:04:33 +04:00
. master = & omap2xxx_l4_core_hwmod ,
2012-04-19 14:04:33 +04:00
. slave = & omap2420_i2c1_hwmod ,
. clk = " i2c1_ick " ,
. addr = omap2_i2c1_addr_space ,
. user = OCP_USER_MPU | OCP_USER_SDMA ,
} ;
/* L4 CORE -> I2C2 interface */
static struct omap_hwmod_ocp_if omap2420_l4_core__i2c2 = {
2012-04-19 14:04:33 +04:00
. master = & omap2xxx_l4_core_hwmod ,
2012-04-19 14:04:33 +04:00
. slave = & omap2420_i2c2_hwmod ,
. clk = " i2c2_ick " ,
. addr = omap2_i2c2_addr_space ,
. user = OCP_USER_MPU | OCP_USER_SDMA ,
} ;
/* IVA <- L3 interface */
static struct omap_hwmod_ocp_if omap2420_l3__iva = {
2012-04-19 14:04:33 +04:00
. master = & omap2xxx_l3_main_hwmod ,
2012-04-19 14:04:33 +04:00
. slave = & omap2420_iva_hwmod ,
. clk = " iva1_ifck " ,
. user = OCP_USER_MPU | OCP_USER_SDMA ,
} ;
static struct omap_hwmod_addr_space omap2420_timer1_addrs [ ] = {
{
. pa_start = 0x48028000 ,
. pa_end = 0x48028000 + SZ_1K - 1 ,
. flags = ADDR_TYPE_RT
} ,
{ }
} ;
/* l4_wkup -> timer1 */
static struct omap_hwmod_ocp_if omap2420_l4_wkup__timer1 = {
2012-04-19 14:04:33 +04:00
. master = & omap2xxx_l4_wkup_hwmod ,
. slave = & omap2xxx_timer1_hwmod ,
2012-04-19 14:04:33 +04:00
. clk = " gpt1_ick " ,
. addr = omap2420_timer1_addrs ,
. user = OCP_USER_MPU | OCP_USER_SDMA ,
} ;
/* l4_wkup -> wd_timer2 */
static struct omap_hwmod_addr_space omap2420_wd_timer2_addrs [ ] = {
{
. pa_start = 0x48022000 ,
. pa_end = 0x4802207f ,
. flags = ADDR_TYPE_RT
} ,
{ }
} ;
static struct omap_hwmod_ocp_if omap2420_l4_wkup__wd_timer2 = {
2012-04-19 14:04:33 +04:00
. master = & omap2xxx_l4_wkup_hwmod ,
. slave = & omap2xxx_wd_timer2_hwmod ,
2012-04-19 14:04:33 +04:00
. clk = " mpu_wdt_ick " ,
. addr = omap2420_wd_timer2_addrs ,
. user = OCP_USER_MPU | OCP_USER_SDMA ,
} ;
/* l4_wkup -> gpio1 */
static struct omap_hwmod_addr_space omap2420_gpio1_addr_space [ ] = {
{
. pa_start = 0x48018000 ,
. pa_end = 0x480181ff ,
. flags = ADDR_TYPE_RT
} ,
{ }
} ;
static struct omap_hwmod_ocp_if omap2420_l4_wkup__gpio1 = {
2012-04-19 14:04:33 +04:00
. master = & omap2xxx_l4_wkup_hwmod ,
. slave = & omap2xxx_gpio1_hwmod ,
2012-04-19 14:04:33 +04:00
. clk = " gpios_ick " ,
. addr = omap2420_gpio1_addr_space ,
. user = OCP_USER_MPU | OCP_USER_SDMA ,
} ;
/* l4_wkup -> gpio2 */
static struct omap_hwmod_addr_space omap2420_gpio2_addr_space [ ] = {
{
. pa_start = 0x4801a000 ,
. pa_end = 0x4801a1ff ,
. flags = ADDR_TYPE_RT
} ,
{ }
} ;
static struct omap_hwmod_ocp_if omap2420_l4_wkup__gpio2 = {
2012-04-19 14:04:33 +04:00
. master = & omap2xxx_l4_wkup_hwmod ,
. slave = & omap2xxx_gpio2_hwmod ,
2012-04-19 14:04:33 +04:00
. clk = " gpios_ick " ,
. addr = omap2420_gpio2_addr_space ,
. user = OCP_USER_MPU | OCP_USER_SDMA ,
} ;
/* l4_wkup -> gpio3 */
static struct omap_hwmod_addr_space omap2420_gpio3_addr_space [ ] = {
{
. pa_start = 0x4801c000 ,
. pa_end = 0x4801c1ff ,
. flags = ADDR_TYPE_RT
} ,
{ }
} ;
static struct omap_hwmod_ocp_if omap2420_l4_wkup__gpio3 = {
2012-04-19 14:04:33 +04:00
. master = & omap2xxx_l4_wkup_hwmod ,
. slave = & omap2xxx_gpio3_hwmod ,
2012-04-19 14:04:33 +04:00
. clk = " gpios_ick " ,
. addr = omap2420_gpio3_addr_space ,
. user = OCP_USER_MPU | OCP_USER_SDMA ,
} ;
/* l4_wkup -> gpio4 */
static struct omap_hwmod_addr_space omap2420_gpio4_addr_space [ ] = {
{
. pa_start = 0x4801e000 ,
. pa_end = 0x4801e1ff ,
. flags = ADDR_TYPE_RT
} ,
{ }
} ;
static struct omap_hwmod_ocp_if omap2420_l4_wkup__gpio4 = {
2012-04-19 14:04:33 +04:00
. master = & omap2xxx_l4_wkup_hwmod ,
. slave = & omap2xxx_gpio4_hwmod ,
2012-04-19 14:04:33 +04:00
. clk = " gpios_ick " ,
. addr = omap2420_gpio4_addr_space ,
. user = OCP_USER_MPU | OCP_USER_SDMA ,
} ;
/* dma_system -> L3 */
static struct omap_hwmod_ocp_if omap2420_dma_system__l3 = {
. master = & omap2420_dma_system_hwmod ,
2012-04-19 14:04:33 +04:00
. slave = & omap2xxx_l3_main_hwmod ,
2012-04-19 14:04:33 +04:00
. clk = " core_l3_ck " ,
. user = OCP_USER_MPU | OCP_USER_SDMA ,
} ;
/* l4_core -> dma_system */
static struct omap_hwmod_ocp_if omap2420_l4_core__dma_system = {
2012-04-19 14:04:33 +04:00
. master = & omap2xxx_l4_core_hwmod ,
2012-04-19 14:04:33 +04:00
. slave = & omap2420_dma_system_hwmod ,
. clk = " sdma_ick " ,
. addr = omap2_dma_system_addrs ,
. user = OCP_USER_MPU | OCP_USER_SDMA ,
} ;
/* l4_core -> mailbox */
static struct omap_hwmod_ocp_if omap2420_l4_core__mailbox = {
2012-04-19 14:04:33 +04:00
. master = & omap2xxx_l4_core_hwmod ,
2012-04-19 14:04:33 +04:00
. slave = & omap2420_mailbox_hwmod ,
. addr = omap2_mailbox_addrs ,
. user = OCP_USER_MPU | OCP_USER_SDMA ,
} ;
/* l4_core -> mcbsp1 */
static struct omap_hwmod_ocp_if omap2420_l4_core__mcbsp1 = {
2012-04-19 14:04:33 +04:00
. master = & omap2xxx_l4_core_hwmod ,
2012-04-19 14:04:33 +04:00
. slave = & omap2420_mcbsp1_hwmod ,
. clk = " mcbsp1_ick " ,
. addr = omap2_mcbsp1_addrs ,
. user = OCP_USER_MPU | OCP_USER_SDMA ,
} ;
/* l4_core -> mcbsp2 */
static struct omap_hwmod_ocp_if omap2420_l4_core__mcbsp2 = {
2012-04-19 14:04:33 +04:00
. master = & omap2xxx_l4_core_hwmod ,
2012-04-19 14:04:33 +04:00
. slave = & omap2420_mcbsp2_hwmod ,
. clk = " mcbsp2_ick " ,
. addr = omap2xxx_mcbsp2_addrs ,
. user = OCP_USER_MPU | OCP_USER_SDMA ,
} ;
2012-04-19 14:04:31 +04:00
static struct omap_hwmod_ocp_if * omap2420_hwmod_ocp_ifs [ ] __initdata = {
2012-04-19 14:04:34 +04:00
& omap2xxx_l3_main__l4_core ,
& omap2xxx_mpu__l3_main ,
& omap2xxx_dss__l3 ,
& omap2xxx_l4_core__mcspi1 ,
& omap2xxx_l4_core__mcspi2 ,
& omap2xxx_l4_core__l4_wkup ,
2012-04-19 14:04:31 +04:00
& omap2_l4_core__uart1 ,
& omap2_l4_core__uart2 ,
& omap2_l4_core__uart3 ,
& omap2420_l4_core__i2c1 ,
& omap2420_l4_core__i2c2 ,
& omap2420_l3__iva ,
& omap2420_l4_wkup__timer1 ,
2012-04-19 14:04:34 +04:00
& omap2xxx_l4_core__timer2 ,
& omap2xxx_l4_core__timer3 ,
& omap2xxx_l4_core__timer4 ,
& omap2xxx_l4_core__timer5 ,
& omap2xxx_l4_core__timer6 ,
& omap2xxx_l4_core__timer7 ,
& omap2xxx_l4_core__timer8 ,
& omap2xxx_l4_core__timer9 ,
& omap2xxx_l4_core__timer10 ,
& omap2xxx_l4_core__timer11 ,
& omap2xxx_l4_core__timer12 ,
2012-04-19 14:04:31 +04:00
& omap2420_l4_wkup__wd_timer2 ,
2012-04-19 14:04:34 +04:00
& omap2xxx_l4_core__dss ,
& omap2xxx_l4_core__dss_dispc ,
& omap2xxx_l4_core__dss_rfbi ,
& omap2xxx_l4_core__dss_venc ,
2012-04-19 14:04:31 +04:00
& omap2420_l4_wkup__gpio1 ,
& omap2420_l4_wkup__gpio2 ,
& omap2420_l4_wkup__gpio3 ,
& omap2420_l4_wkup__gpio4 ,
& omap2420_dma_system__l3 ,
& omap2420_l4_core__dma_system ,
& omap2420_l4_core__mailbox ,
& omap2420_l4_core__mcbsp1 ,
& omap2420_l4_core__mcbsp2 ,
2009-09-03 21:14:05 +04:00
NULL ,
} ;
2010-02-23 08:09:32 +03:00
int __init omap2420_hwmod_init ( void )
{
2012-04-19 14:04:31 +04:00
return omap_hwmod_register_links ( omap2420_hwmod_ocp_ifs ) ;
2010-02-23 08:09:32 +03:00
}