2005-07-10 19:58:12 +01:00
/*
* linux / arch / arm / mach - omap1 / io . c
*
* OMAP1 I / O mapping code
*
* 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>
2005-07-10 19:58:12 +01:00
2006-02-08 22:06:45 +00:00
# include <asm/tlb.h>
2005-07-10 19:58:12 +01:00
# include <asm/mach/map.h>
2009-10-20 09:40:47 -07:00
# include <plat/mux.h>
# include <plat/tc.h>
2005-07-10 19:58:12 +01:00
2009-12-08 16:29:38 -07:00
# include "clock.h"
2005-07-10 19:58:12 +01:00
extern void omap_check_revision ( void ) ;
2005-09-08 23:07:38 +01:00
extern void omap_sram_init ( void ) ;
2005-07-10 19:58:12 +01:00
/*
* The machine specific code may provide the extra mapping besides the
* default mapping provided here .
*/
static struct map_desc omap_io_desc [ ] __initdata = {
2005-10-28 15:19:00 +01:00
{
2009-08-28 10:50:37 -07:00
. virtual = OMAP1_IO_VIRT ,
. pfn = __phys_to_pfn ( OMAP1_IO_PHYS ) ,
. length = OMAP1_IO_SIZE ,
2005-10-28 15:19:00 +01:00
. type = MT_DEVICE
}
2005-07-10 19:58:12 +01:00
} ;
2009-09-22 05:58:08 +01:00
# if defined (CONFIG_ARCH_OMAP730) || defined (CONFIG_ARCH_OMAP850)
2009-09-22 10:02:58 +01:00
static struct map_desc omap7xx_io_desc [ ] __initdata = {
2005-10-28 15:19:00 +01:00
{
2009-09-22 07:34:13 +01:00
. virtual = OMAP7XX_DSP_BASE ,
. pfn = __phys_to_pfn ( OMAP7XX_DSP_START ) ,
. length = OMAP7XX_DSP_SIZE ,
2005-10-28 15:19:00 +01:00
. type = MT_DEVICE
} , {
2009-09-22 07:34:13 +01:00
. virtual = OMAP7XX_DSPREG_BASE ,
. pfn = __phys_to_pfn ( OMAP7XX_DSPREG_START ) ,
. length = OMAP7XX_DSPREG_SIZE ,
2005-10-28 15:19:00 +01:00
. type = MT_DEVICE
}
2005-07-10 19:58:12 +01:00
} ;
# endif
2005-11-10 14:26:48 +00:00
# ifdef CONFIG_ARCH_OMAP15XX
2005-07-10 19:58:12 +01:00
static struct map_desc omap1510_io_desc [ ] __initdata = {
2005-10-28 15:19:00 +01:00
{
. virtual = OMAP1510_DSP_BASE ,
. pfn = __phys_to_pfn ( OMAP1510_DSP_START ) ,
. length = OMAP1510_DSP_SIZE ,
. type = MT_DEVICE
} , {
. virtual = OMAP1510_DSPREG_BASE ,
. pfn = __phys_to_pfn ( OMAP1510_DSPREG_START ) ,
. length = OMAP1510_DSPREG_SIZE ,
. type = MT_DEVICE
}
2005-07-10 19:58:12 +01:00
} ;
# endif
# if defined(CONFIG_ARCH_OMAP16XX)
2005-09-08 23:07:38 +01:00
static struct map_desc omap16xx_io_desc [ ] __initdata = {
2005-10-28 15:19:00 +01:00
{
. virtual = OMAP16XX_DSP_BASE ,
. pfn = __phys_to_pfn ( OMAP16XX_DSP_START ) ,
. length = OMAP16XX_DSP_SIZE ,
. type = MT_DEVICE
} , {
. virtual = OMAP16XX_DSPREG_BASE ,
. pfn = __phys_to_pfn ( OMAP16XX_DSPREG_START ) ,
. length = OMAP16XX_DSPREG_SIZE ,
. type = MT_DEVICE
}
2005-07-10 19:58:12 +01:00
} ;
# endif
2006-02-08 22:06:45 +00:00
/*
* Maps common IO regions for omap1 . This should only get called from
* board specific init .
*/
void __init omap1_map_common_io ( void )
2005-07-10 19:58:12 +01:00
{
iotable_init ( omap_io_desc , ARRAY_SIZE ( omap_io_desc ) ) ;
2006-02-08 22:06:45 +00:00
/* Normally devicemaps_init() would flush caches and tlb after
* mdesc - > map_io ( ) , but we must also do it here because of the CPU
* revision check below .
*/
local_flush_tlb_all ( ) ;
flush_cache_all ( ) ;
/* We want to check CPU revision early for cpu_is_omapxxxx() macros.
* IO space mapping must be initialized before we can do that .
*/
2005-07-10 19:58:12 +01:00
omap_check_revision ( ) ;
2009-09-22 05:58:08 +01:00
# if defined (CONFIG_ARCH_OMAP730) || defined (CONFIG_ARCH_OMAP850)
if ( cpu_is_omap7xx ( ) ) {
2009-09-22 10:02:58 +01:00
iotable_init ( omap7xx_io_desc , ARRAY_SIZE ( omap7xx_io_desc ) ) ;
2005-07-10 19:58:12 +01:00
}
# endif
2005-11-10 14:26:48 +00:00
# ifdef CONFIG_ARCH_OMAP15XX
2006-04-02 17:46:27 +01:00
if ( cpu_is_omap15xx ( ) ) {
2005-07-10 19:58:12 +01:00
iotable_init ( omap1510_io_desc , ARRAY_SIZE ( omap1510_io_desc ) ) ;
}
# endif
# if defined(CONFIG_ARCH_OMAP16XX)
2005-09-08 23:07:38 +01:00
if ( cpu_is_omap16xx ( ) ) {
iotable_init ( omap16xx_io_desc , ARRAY_SIZE ( omap16xx_io_desc ) ) ;
2005-07-10 19:58:12 +01:00
}
# endif
2005-09-08 23:07:38 +01:00
omap_sram_init ( ) ;
2006-02-08 22:06:45 +00:00
}
2005-09-08 23:07:38 +01:00
2006-02-08 22:06:45 +00:00
/*
* Common low - level hardware init for omap1 . This should only get called from
* board specific init .
*/
2008-12-01 17:40:54 +00:00
void __init omap1_init_common_hw ( void )
2006-02-08 22:06:45 +00:00
{
2005-07-10 19:58:12 +01:00
/* REVISIT: Refer to OMAP5910 Errata, Advisory SYS_1: "Timeout Abort
* on a Posted Write in the TIPB Bridge " .
*/
omap_writew ( 0x0 , MPU_PUBLIC_TIPB_CNTL ) ;
omap_writew ( 0x0 , MPU_PRIVATE_TIPB_CNTL ) ;
/* Must init clocks early to assure that timer interrupt works
*/
2005-11-10 14:26:48 +00:00
omap1_clk_init ( ) ;
2005-07-10 19:58:12 +01:00
2006-02-08 22:06:45 +00:00
omap1_mux_init ( ) ;
2005-07-10 19:58:12 +01:00
}
2005-09-08 23:07:38 +01:00