2005-11-10 14:26:51 +00:00
/*
* linux / arch / arm / mach - omap2 / io . c
*
* OMAP2 I / O mapping code
*
* Copyright ( C ) 2005 Nokia Corporation
2009-05-28 14:16:04 -07:00
* Copyright ( C ) 2007 - 2009 Texas Instruments
2008-10-06 15:49:36 +03:00
*
* Author :
* Juha Yrjola < juha . yrjola @ nokia . com >
* Syed Khasim < x0khasim @ ti . com >
2005-11-10 14:26:51 +00:00
*
2009-05-28 14:16:04 -07:00
* Added OMAP4 support - Santosh Shilimkar < santosh . shilimkar @ ti . com >
*
2005-11-10 14:26:51 +00:00
* 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 .
*/
# include <linux/module.h>
# include <linux/kernel.h>
# include <linux/init.h>
2008-09-06 12:10:45 +01:00
# include <linux/io.h>
2009-06-19 19:08:25 -06:00
# include <linux/clk.h>
2005-11-10 14:26:51 +00:00
2006-04-02 17:46:27 +01:00
# include <asm/tlb.h>
# include <asm/mach/map.h>
2009-10-20 09:40:47 -07:00
# include <plat/sram.h>
# include <plat/sdrc.h>
# include <plat/serial.h>
# include <plat/omap-pm.h>
2012-02-24 10:34:35 -08:00
# include <plat/omap_hwmod.h>
# include <plat/multi.h>
2012-04-13 06:34:26 -06:00
# include <plat/dma.h>
2012-02-24 10:34:35 -08:00
# include "iomap.h"
2011-03-16 14:25:45 -07:00
# include "voltage.h"
2010-12-21 21:05:16 -07:00
# include "powerdomain.h"
2010-12-21 21:05:15 -07:00
# include "clockdomain.h"
2011-11-10 22:45:17 +01:00
# include "common.h"
2012-02-24 10:34:35 -08:00
# include "clock2xxx.h"
# include "clock3xxx.h"
# include "clock44xx.h"
2009-09-03 20:14:05 +03:00
2005-11-10 14:26:51 +00:00
/*
* The machine specific code may provide the extra mapping besides the
* default mapping provided here .
*/
2008-10-09 17:51:41 +03:00
2012-03-06 11:49:22 -08:00
# if defined(CONFIG_SOC_OMAP2420) || defined(CONFIG_SOC_OMAP2430)
2008-10-09 17:51:41 +03:00
static struct map_desc omap24xx_io_desc [ ] __initdata = {
2005-11-10 14:26:51 +00:00
{
. virtual = L3_24XX_VIRT ,
. pfn = __phys_to_pfn ( L3_24XX_PHYS ) ,
. length = L3_24XX_SIZE ,
. type = MT_DEVICE
} ,
2008-02-20 15:30:06 -08:00
{
2008-10-09 17:51:41 +03:00
. virtual = L4_24XX_VIRT ,
. pfn = __phys_to_pfn ( L4_24XX_PHYS ) ,
. length = L4_24XX_SIZE ,
. type = MT_DEVICE
2008-02-20 15:30:06 -08:00
} ,
2008-10-09 17:51:41 +03:00
} ;
2011-01-27 16:39:40 -08:00
# ifdef CONFIG_SOC_OMAP2420
2008-10-09 17:51:41 +03:00
static struct map_desc omap242x_io_desc [ ] __initdata = {
{
2010-01-08 15:23:05 -07:00
. virtual = DSP_MEM_2420_VIRT ,
. pfn = __phys_to_pfn ( DSP_MEM_2420_PHYS ) ,
. length = DSP_MEM_2420_SIZE ,
2008-10-09 17:51:41 +03:00
. type = MT_DEVICE
} ,
{
2010-01-08 15:23:05 -07:00
. virtual = DSP_IPI_2420_VIRT ,
. pfn = __phys_to_pfn ( DSP_IPI_2420_PHYS ) ,
. length = DSP_IPI_2420_SIZE ,
2008-10-09 17:51:41 +03:00
. type = MT_DEVICE
2008-02-20 15:30:06 -08:00
} ,
2008-10-09 17:51:41 +03:00
{
2010-01-08 15:23:05 -07:00
. virtual = DSP_MMU_2420_VIRT ,
. pfn = __phys_to_pfn ( DSP_MMU_2420_PHYS ) ,
. length = DSP_MMU_2420_SIZE ,
2008-10-09 17:51:41 +03:00
. type = MT_DEVICE
} ,
} ;
# endif
2011-01-27 16:39:40 -08:00
# ifdef CONFIG_SOC_OMAP2430
2008-10-09 17:51:41 +03:00
static struct map_desc omap243x_io_desc [ ] __initdata = {
2006-12-06 17:14:05 -08:00
{
. virtual = L4_WK_243X_VIRT ,
. pfn = __phys_to_pfn ( L4_WK_243X_PHYS ) ,
. length = L4_WK_243X_SIZE ,
. type = MT_DEVICE
} ,
{
. virtual = OMAP243X_GPMC_VIRT ,
. pfn = __phys_to_pfn ( OMAP243X_GPMC_PHYS ) ,
. length = OMAP243X_GPMC_SIZE ,
. type = MT_DEVICE
} ,
2008-10-09 17:51:41 +03:00
{
. virtual = OMAP243X_SDRC_VIRT ,
. pfn = __phys_to_pfn ( OMAP243X_SDRC_PHYS ) ,
. length = OMAP243X_SDRC_SIZE ,
. type = MT_DEVICE
} ,
{
. virtual = OMAP243X_SMS_VIRT ,
. pfn = __phys_to_pfn ( OMAP243X_SMS_PHYS ) ,
. length = OMAP243X_SMS_SIZE ,
. type = MT_DEVICE
} ,
} ;
2006-12-06 17:14:05 -08:00
# endif
# endif
2008-10-09 17:51:41 +03:00
2010-02-12 12:26:48 -08:00
# ifdef CONFIG_ARCH_OMAP3
2008-10-09 17:51:41 +03:00
static struct map_desc omap34xx_io_desc [ ] __initdata = {
2005-11-10 14:26:51 +00:00
{
2008-10-09 17:51:41 +03:00
. virtual = L3_34XX_VIRT ,
. pfn = __phys_to_pfn ( L3_34XX_PHYS ) ,
. length = L3_34XX_SIZE ,
2006-12-07 13:58:10 -08:00
. type = MT_DEVICE
} ,
{
2008-10-09 17:51:41 +03:00
. virtual = L4_34XX_VIRT ,
. pfn = __phys_to_pfn ( L4_34XX_PHYS ) ,
. length = L4_34XX_SIZE ,
2006-12-07 13:58:10 -08:00
. type = MT_DEVICE
} ,
2008-10-09 17:51:41 +03:00
{
. virtual = OMAP34XX_GPMC_VIRT ,
. pfn = __phys_to_pfn ( OMAP34XX_GPMC_PHYS ) ,
. length = OMAP34XX_GPMC_SIZE ,
2005-11-10 14:26:51 +00:00
. type = MT_DEVICE
2008-10-09 17:51:41 +03:00
} ,
{
. virtual = OMAP343X_SMS_VIRT ,
. pfn = __phys_to_pfn ( OMAP343X_SMS_PHYS ) ,
. length = OMAP343X_SMS_SIZE ,
. type = MT_DEVICE
} ,
{
. virtual = OMAP343X_SDRC_VIRT ,
. pfn = __phys_to_pfn ( OMAP343X_SDRC_PHYS ) ,
. length = OMAP343X_SDRC_SIZE ,
2005-11-10 14:26:51 +00:00
. type = MT_DEVICE
2008-10-09 17:51:41 +03:00
} ,
{
. virtual = L4_PER_34XX_VIRT ,
. pfn = __phys_to_pfn ( L4_PER_34XX_PHYS ) ,
. length = L4_PER_34XX_SIZE ,
. type = MT_DEVICE
} ,
{
. virtual = L4_EMU_34XX_VIRT ,
. pfn = __phys_to_pfn ( L4_EMU_34XX_PHYS ) ,
. length = L4_EMU_34XX_SIZE ,
. type = MT_DEVICE
} ,
2010-04-30 12:57:14 -07:00
# if defined(CONFIG_DEBUG_LL) && \
( defined ( CONFIG_MACH_OMAP_ZOOM2 ) | | defined ( CONFIG_MACH_OMAP_ZOOM3 ) )
{
. virtual = ZOOM_UART_VIRT ,
. pfn = __phys_to_pfn ( ZOOM_UART_BASE ) ,
. length = SZ_1M ,
. type = MT_DEVICE
} ,
# endif
2005-11-10 14:26:51 +00:00
} ;
2008-10-09 17:51:41 +03:00
# endif
2011-02-16 08:31:39 -08:00
2011-12-13 10:46:44 -08:00
# ifdef CONFIG_SOC_OMAPTI81XX
static struct map_desc omapti81xx_io_desc [ ] __initdata = {
2011-12-13 10:46:43 -08:00
{
. virtual = L4_34XX_VIRT ,
. pfn = __phys_to_pfn ( L4_34XX_PHYS ) ,
. length = L4_34XX_SIZE ,
. type = MT_DEVICE
}
} ;
# endif
# ifdef CONFIG_SOC_OMAPAM33XX
static struct map_desc omapam33xx_io_desc [ ] __initdata = {
2011-02-16 08:31:39 -08:00
{
. virtual = L4_34XX_VIRT ,
. pfn = __phys_to_pfn ( L4_34XX_PHYS ) ,
. length = L4_34XX_SIZE ,
. type = MT_DEVICE
} ,
2011-12-13 10:46:43 -08:00
{
. virtual = L4_WK_AM33XX_VIRT ,
. pfn = __phys_to_pfn ( L4_WK_AM33XX_PHYS ) ,
. length = L4_WK_AM33XX_SIZE ,
. type = MT_DEVICE
}
2011-02-16 08:31:39 -08:00
} ;
# endif
2009-05-28 14:16:04 -07:00
# ifdef CONFIG_ARCH_OMAP4
static struct map_desc omap44xx_io_desc [ ] __initdata = {
{
. virtual = L3_44XX_VIRT ,
. pfn = __phys_to_pfn ( L3_44XX_PHYS ) ,
. length = L3_44XX_SIZE ,
. type = MT_DEVICE ,
} ,
{
. virtual = L4_44XX_VIRT ,
. pfn = __phys_to_pfn ( L4_44XX_PHYS ) ,
. length = L4_44XX_SIZE ,
. type = MT_DEVICE ,
} ,
{
. virtual = OMAP44XX_GPMC_VIRT ,
. pfn = __phys_to_pfn ( OMAP44XX_GPMC_PHYS ) ,
. length = OMAP44XX_GPMC_SIZE ,
. type = MT_DEVICE ,
} ,
2009-10-19 17:25:57 -07:00
{
. virtual = OMAP44XX_EMIF1_VIRT ,
. pfn = __phys_to_pfn ( OMAP44XX_EMIF1_PHYS ) ,
. length = OMAP44XX_EMIF1_SIZE ,
. type = MT_DEVICE ,
} ,
{
. virtual = OMAP44XX_EMIF2_VIRT ,
. pfn = __phys_to_pfn ( OMAP44XX_EMIF2_PHYS ) ,
. length = OMAP44XX_EMIF2_SIZE ,
. type = MT_DEVICE ,
} ,
{
. virtual = OMAP44XX_DMM_VIRT ,
. pfn = __phys_to_pfn ( OMAP44XX_DMM_PHYS ) ,
. length = OMAP44XX_DMM_SIZE ,
. type = MT_DEVICE ,
} ,
2009-05-28 14:16:04 -07:00
{
. virtual = L4_PER_44XX_VIRT ,
. pfn = __phys_to_pfn ( L4_PER_44XX_PHYS ) ,
. length = L4_PER_44XX_SIZE ,
. type = MT_DEVICE ,
} ,
{
. virtual = L4_EMU_44XX_VIRT ,
. pfn = __phys_to_pfn ( L4_EMU_44XX_PHYS ) ,
. length = L4_EMU_44XX_SIZE ,
. type = MT_DEVICE ,
} ,
2011-06-25 18:04:31 -07:00
# ifdef CONFIG_OMAP4_ERRATA_I688
{
. virtual = OMAP4_SRAM_VA ,
. pfn = __phys_to_pfn ( OMAP4_SRAM_PA ) ,
. length = PAGE_SIZE ,
. type = MT_MEMORY_SO ,
} ,
# endif
2009-05-28 14:16:04 -07:00
} ;
# endif
2005-11-10 14:26:51 +00:00
2011-01-27 16:39:40 -08:00
# ifdef CONFIG_SOC_OMAP2420
2010-03-03 16:24:53 +00:00
void __init omap242x_map_common_io ( void )
2005-11-10 14:26:51 +00:00
{
2008-10-09 17:51:41 +03:00
iotable_init ( omap24xx_io_desc , ARRAY_SIZE ( omap24xx_io_desc ) ) ;
iotable_init ( omap242x_io_desc , ARRAY_SIZE ( omap242x_io_desc ) ) ;
2010-02-12 12:26:47 -08:00
}
2008-10-09 17:51:41 +03:00
# endif
2011-01-27 16:39:40 -08:00
# ifdef CONFIG_SOC_OMAP2430
2010-03-03 16:24:53 +00:00
void __init omap243x_map_common_io ( void )
2010-02-12 12:26:47 -08:00
{
2008-10-09 17:51:41 +03:00
iotable_init ( omap24xx_io_desc , ARRAY_SIZE ( omap24xx_io_desc ) ) ;
iotable_init ( omap243x_io_desc , ARRAY_SIZE ( omap243x_io_desc ) ) ;
2010-02-12 12:26:47 -08:00
}
2008-10-09 17:51:41 +03:00
# endif
2010-02-12 12:26:48 -08:00
# ifdef CONFIG_ARCH_OMAP3
2010-03-03 16:24:53 +00:00
void __init omap34xx_map_common_io ( void )
2010-02-12 12:26:47 -08:00
{
2008-10-09 17:51:41 +03:00
iotable_init ( omap34xx_io_desc , ARRAY_SIZE ( omap34xx_io_desc ) ) ;
2010-02-12 12:26:47 -08:00
}
2008-10-09 17:51:41 +03:00
# endif
2006-04-02 17:46:27 +01:00
2011-12-13 10:46:44 -08:00
# ifdef CONFIG_SOC_OMAPTI81XX
void __init omapti81xx_map_common_io ( void )
2011-02-16 08:31:39 -08:00
{
2011-12-13 10:46:44 -08:00
iotable_init ( omapti81xx_io_desc , ARRAY_SIZE ( omapti81xx_io_desc ) ) ;
2011-02-16 08:31:39 -08:00
}
# endif
2011-12-13 10:46:43 -08:00
# ifdef CONFIG_SOC_OMAPAM33XX
void __init omapam33xx_map_common_io ( void )
2011-02-16 08:31:39 -08:00
{
2011-12-13 10:46:43 -08:00
iotable_init ( omapam33xx_io_desc , ARRAY_SIZE ( omapam33xx_io_desc ) ) ;
2011-02-16 08:31:39 -08:00
}
# endif
2010-02-12 12:26:47 -08:00
# ifdef CONFIG_ARCH_OMAP4
2010-03-03 16:24:53 +00:00
void __init omap44xx_map_common_io ( void )
2010-02-12 12:26:47 -08:00
{
2009-05-28 14:16:04 -07:00
iotable_init ( omap44xx_io_desc , ARRAY_SIZE ( omap44xx_io_desc ) ) ;
2012-02-02 19:33:55 +05:30
omap_barriers_init ( ) ;
2006-04-02 17:46:27 +01:00
}
2010-02-12 12:26:47 -08:00
# endif
2006-04-02 17:46:27 +01:00
2009-06-19 19:08:25 -06:00
/*
* omap2_init_reprogram_sdrc - reprogram SDRC timing parameters
*
* Sets the CORE DPLL3 M2 divider to the same value that it ' s at
* currently . This has the effect of setting the SDRC SDRAM AC timing
* registers to the values currently defined by the kernel . Currently
* only defined for OMAP3 ; will return 0 if called on OMAP2 . Returns
* - EINVAL if the dpll3_m2_ck cannot be found , 0 if called on OMAP2 ,
* or passes along the return value of clk_set_rate ( ) .
*/
static int __init _omap2_init_reprogram_sdrc ( void )
{
struct clk * dpll3_m2_ck ;
int v = - EINVAL ;
long rate ;
if ( ! cpu_is_omap34xx ( ) )
return 0 ;
dpll3_m2_ck = clk_get ( NULL , " dpll3_m2_ck " ) ;
2010-11-30 14:17:58 +00:00
if ( IS_ERR ( dpll3_m2_ck ) )
2009-06-19 19:08:25 -06:00
return - EINVAL ;
rate = clk_get_rate ( dpll3_m2_ck ) ;
pr_info ( " Reprogramming SDRC clock to %ld Hz \n " , rate ) ;
v = clk_set_rate ( dpll3_m2_ck , rate ) ;
if ( v )
pr_err ( " dpll3_m2_clk rate change failed: %d \n " , v ) ;
clk_put ( dpll3_m2_ck ) ;
return v ;
}
2010-12-14 12:42:35 -07:00
static int _set_hwmod_postsetup_state ( struct omap_hwmod * oh , void * data )
{
return omap_hwmod_set_postsetup_state ( oh , * ( u8 * ) data ) ;
}
2011-10-04 18:26:28 -07:00
static void __init omap_common_init_early ( void )
2006-04-02 17:46:27 +01:00
{
2011-11-01 13:47:27 +01:00
omap_init_consistent_dma_size ( ) ;
2011-10-04 18:26:28 -07:00
}
2010-12-14 12:42:35 -07:00
2011-10-04 18:26:28 -07:00
static void __init omap_hwmod_init_postsetup ( void )
{
u8 postsetup_state ;
2010-12-14 12:42:35 -07:00
/* Set the default postsetup state for all hwmods */
# ifdef CONFIG_PM_RUNTIME
postsetup_state = _HWMOD_STATE_IDLE ;
# else
postsetup_state = _HWMOD_STATE_ENABLED ;
# endif
omap_hwmod_for_each ( _set_hwmod_postsetup_state , & postsetup_state ) ;
2010-05-12 17:54:36 +02:00
2010-12-09 09:13:48 -06:00
omap_pm_if_early_init ( ) ;
OMAP2+: io: split omap2_init_common_hw()
Split omap2_init_common_hw() into two functions. The first,
omap2_init_common_infrastructure(), initializes the hwmod code and
data, the OMAP PM code, and the clock code and data. The second,
omap2_init_common_devices(), handles any other early device
initialization that, for whatever reason, has not been or cannot be
moved to initcalls or early platform devices.
This patch is required for the hwmod postsetup patch, which allows
board files to change the state that hwmods should be placed into at
the conclusion of the hwmod _setup() function. For example, for a
board whose creators wish to ensure watchdog coverage across the
entire kernel boot process, code to change the watchdog's postsetup
state will be added in the board-*.c file between the
omap2_init_common_infrastructure() and omap2_init_common_devices() function
calls.
Signed-off-by: Paul Walmsley <paul@pwsan.com>
Cc: Tony Lindgren <tony@atomide.com>
2010-12-21 15:25:10 -07:00
}
2012-01-25 12:57:46 -07:00
# ifdef CONFIG_SOC_OMAP2420
2011-08-22 23:57:24 -07:00
void __init omap2420_init_early ( void )
{
2011-10-04 18:17:41 -07:00
omap2_set_globals_242x ( ) ;
2011-12-19 15:50:15 +05:30
omap2xxx_check_revision ( ) ;
2011-10-04 18:26:28 -07:00
omap_common_init_early ( ) ;
omap2xxx_voltagedomains_init ( ) ;
omap242x_powerdomains_init ( ) ;
omap242x_clockdomains_init ( ) ;
omap2420_hwmod_init ( ) ;
omap_hwmod_init_postsetup ( ) ;
omap2420_clk_init ( ) ;
2011-08-22 23:57:24 -07:00
}
2012-01-25 12:57:46 -07:00
# endif
2011-08-22 23:57:24 -07:00
2012-01-25 12:57:46 -07:00
# ifdef CONFIG_SOC_OMAP2430
2011-08-22 23:57:24 -07:00
void __init omap2430_init_early ( void )
{
2011-10-04 18:17:41 -07:00
omap2_set_globals_243x ( ) ;
2011-12-19 15:50:15 +05:30
omap2xxx_check_revision ( ) ;
2011-10-04 18:26:28 -07:00
omap_common_init_early ( ) ;
omap2xxx_voltagedomains_init ( ) ;
omap243x_powerdomains_init ( ) ;
omap243x_clockdomains_init ( ) ;
omap2430_hwmod_init ( ) ;
omap_hwmod_init_postsetup ( ) ;
omap2430_clk_init ( ) ;
}
2011-10-13 21:44:10 +05:30
# endif
2011-10-04 18:26:28 -07:00
/*
* Currently only board - omap3beagle . c should call this because of the
* same machine_id for 34 xx and 36 xx beagle . . Will get fixed with DT .
*/
2011-10-13 21:44:10 +05:30
# ifdef CONFIG_ARCH_OMAP3
2011-10-04 18:26:28 -07:00
void __init omap3_init_early ( void )
{
2011-10-04 18:17:41 -07:00
omap2_set_globals_3xxx ( ) ;
2011-12-19 15:50:15 +05:30
omap3xxx_check_revision ( ) ;
omap3xxx_check_features ( ) ;
2011-10-04 18:26:28 -07:00
omap_common_init_early ( ) ;
omap3xxx_voltagedomains_init ( ) ;
omap3xxx_powerdomains_init ( ) ;
omap3xxx_clockdomains_init ( ) ;
omap3xxx_hwmod_init ( ) ;
omap_hwmod_init_postsetup ( ) ;
omap3xxx_clk_init ( ) ;
2011-08-22 23:57:24 -07:00
}
void __init omap3430_init_early ( void )
{
2011-10-04 18:26:28 -07:00
omap3_init_early ( ) ;
2011-08-22 23:57:24 -07:00
}
void __init omap35xx_init_early ( void )
{
2011-10-04 18:26:28 -07:00
omap3_init_early ( ) ;
2011-08-22 23:57:24 -07:00
}
void __init omap3630_init_early ( void )
{
2011-10-04 18:26:28 -07:00
omap3_init_early ( ) ;
2011-08-22 23:57:24 -07:00
}
void __init am35xx_init_early ( void )
{
2011-10-04 18:26:28 -07:00
omap3_init_early ( ) ;
2011-08-22 23:57:24 -07:00
}
2011-12-13 10:46:44 -08:00
void __init ti81xx_init_early ( void )
2011-08-22 23:57:24 -07:00
{
2011-12-13 10:46:44 -08:00
omap2_set_globals_ti81xx ( ) ;
2011-12-19 15:50:15 +05:30
omap3xxx_check_revision ( ) ;
ti81xx_check_features ( ) ;
2011-10-04 18:17:41 -07:00
omap_common_init_early ( ) ;
omap3xxx_voltagedomains_init ( ) ;
omap3xxx_powerdomains_init ( ) ;
omap3xxx_clockdomains_init ( ) ;
omap3xxx_hwmod_init ( ) ;
omap_hwmod_init_postsetup ( ) ;
omap3xxx_clk_init ( ) ;
2011-08-22 23:57:24 -07:00
}
2011-10-13 21:44:10 +05:30
# endif
2011-08-22 23:57:24 -07:00
2011-10-13 21:44:10 +05:30
# ifdef CONFIG_ARCH_OMAP4
2011-08-22 23:57:24 -07:00
void __init omap4430_init_early ( void )
{
2011-10-04 18:17:41 -07:00
omap2_set_globals_443x ( ) ;
2011-12-19 15:50:15 +05:30
omap4xxx_check_revision ( ) ;
omap4xxx_check_features ( ) ;
2011-10-04 18:26:28 -07:00
omap_common_init_early ( ) ;
omap44xx_voltagedomains_init ( ) ;
omap44xx_powerdomains_init ( ) ;
omap44xx_clockdomains_init ( ) ;
omap44xx_hwmod_init ( ) ;
omap_hwmod_init_postsetup ( ) ;
omap4xxx_clk_init ( ) ;
2011-08-22 23:57:24 -07:00
}
2011-10-13 21:44:10 +05:30
# endif
2011-08-22 23:57:24 -07:00
2011-08-22 23:57:23 -07:00
void __init omap_sdrc_init ( struct omap_sdrc_params * sdrc_cs0 ,
OMAP2+: io: split omap2_init_common_hw()
Split omap2_init_common_hw() into two functions. The first,
omap2_init_common_infrastructure(), initializes the hwmod code and
data, the OMAP PM code, and the clock code and data. The second,
omap2_init_common_devices(), handles any other early device
initialization that, for whatever reason, has not been or cannot be
moved to initcalls or early platform devices.
This patch is required for the hwmod postsetup patch, which allows
board files to change the state that hwmods should be placed into at
the conclusion of the hwmod _setup() function. For example, for a
board whose creators wish to ensure watchdog coverage across the
entire kernel boot process, code to change the watchdog's postsetup
state will be added in the board-*.c file between the
omap2_init_common_infrastructure() and omap2_init_common_devices() function
calls.
Signed-off-by: Paul Walmsley <paul@pwsan.com>
Cc: Tony Lindgren <tony@atomide.com>
2010-12-21 15:25:10 -07:00
struct omap_sdrc_params * sdrc_cs1 )
{
2011-10-04 13:52:57 -07:00
omap_sram_init ( ) ;
2011-02-16 08:31:39 -08:00
if ( cpu_is_omap24xx ( ) | | omap3_has_sdrc ( ) ) {
2010-03-10 17:16:31 +00:00
omap2_sdrc_init ( sdrc_cs0 , sdrc_cs1 ) ;
_omap2_init_reprogram_sdrc ( ) ;
}
2005-11-10 14:26:51 +00:00
}