2007-11-26 15:11:43 +03:00
/* arch/arm/mach-msm/io.c
*
2010-05-05 02:12:27 +04:00
* MSM7K , QSD io support
2007-11-26 15:11:43 +03:00
*
* Copyright ( C ) 2007 Google , Inc .
2011-01-07 21:20:49 +03:00
* Copyright ( c ) 2008 - 2011 , Code Aurora Forum . All rights reserved .
2007-11-26 15:11:43 +03:00
* Author : Brian Swetland < swetland @ google . com >
*
* This software is licensed under the terms of the GNU General Public
* License version 2 , as published by the Free Software Foundation , and
* may be copied , distributed , and modified under those terms .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
*/
# include <linux/kernel.h>
# include <linux/init.h>
2008-09-06 15:10:45 +04:00
# include <linux/io.h>
2007-11-26 15:11:43 +03:00
2008-08-05 19:14:15 +04:00
# include <mach/hardware.h>
2007-11-26 15:11:43 +03:00
# include <asm/page.h>
2008-08-05 19:14:15 +04:00
# include <mach/msm_iomap.h>
2007-11-26 15:11:43 +03:00
# include <asm/mach/map.h>
2008-08-05 19:14:15 +04:00
# include <mach/board.h>
2007-11-26 15:11:43 +03:00
2011-01-07 21:20:49 +03:00
# define MSM_CHIP_DEVICE(name, chip) { \
2008-09-11 01:00:53 +04:00
. virtual = ( unsigned long ) MSM_ # # name # # _BASE , \
2011-01-07 21:20:49 +03:00
. pfn = __phys_to_pfn ( chip # # _ # # name # # _PHYS ) , \
. length = chip # # _ # # name # # _SIZE , \
2007-11-26 15:11:43 +03:00
. type = MT_DEVICE_NONSHARED , \
}
2011-01-07 21:20:49 +03:00
# define MSM_DEVICE(name) MSM_CHIP_DEVICE(name, MSM)
2010-05-05 02:12:27 +04:00
# if defined(CONFIG_ARCH_MSM7X00A) || defined(CONFIG_ARCH_MSM7X27) \
| | defined ( CONFIG_ARCH_MSM7X25 )
2007-11-26 15:11:43 +03:00
static struct map_desc msm_io_desc [ ] __initdata = {
MSM_DEVICE ( VIC ) ,
2011-01-07 21:20:49 +03:00
MSM_CHIP_DEVICE ( CSR , MSM7X00 ) ,
2007-11-26 15:11:43 +03:00
MSM_DEVICE ( DMOV ) ,
2011-05-12 11:54:36 +04:00
MSM_CHIP_DEVICE ( GPIO1 , MSM7X00 ) ,
MSM_CHIP_DEVICE ( GPIO2 , MSM7X00 ) ,
2007-11-26 15:11:43 +03:00
MSM_DEVICE ( CLK_CTL ) ,
2009-11-02 13:48:29 +03:00
# ifdef CONFIG_MSM_DEBUG_UART
MSM_DEVICE ( DEBUG_UART ) ,
2010-01-29 22:43:42 +03:00
# endif
# ifdef CONFIG_ARCH_MSM7X30
MSM_DEVICE ( GCC ) ,
2009-11-02 13:48:29 +03:00
# endif
2007-11-26 15:11:43 +03:00
{
2008-09-11 01:00:53 +04:00
. virtual = ( unsigned long ) MSM_SHARED_RAM_BASE ,
2010-05-05 02:12:27 +04:00
. pfn = __phys_to_pfn ( MSM_SHARED_RAM_PHYS ) ,
2007-11-26 15:11:43 +03:00
. length = MSM_SHARED_RAM_SIZE ,
. type = MT_DEVICE ,
} ,
} ;
void __init msm_map_common_io ( void )
{
/* Make sure the peripheral register window is closed, since
* we will use PTE flags ( TEX [ 1 ] = 1 , B = 0 , C = 1 ) to determine which
* pages are peripheral interface or not .
*/
asm ( " mcr p15, 0, %0, c15, c2, 4 " : : " r " ( 0 ) ) ;
iotable_init ( msm_io_desc , ARRAY_SIZE ( msm_io_desc ) ) ;
}
2010-05-05 02:12:27 +04:00
# endif
# ifdef CONFIG_ARCH_QSD8X50
static struct map_desc qsd8x50_io_desc [ ] __initdata = {
MSM_DEVICE ( VIC ) ,
2011-01-07 21:20:49 +03:00
MSM_CHIP_DEVICE ( CSR , QSD8X50 ) ,
2010-05-05 02:12:27 +04:00
MSM_DEVICE ( DMOV ) ,
2011-05-12 11:54:36 +04:00
MSM_CHIP_DEVICE ( GPIO1 , QSD8X50 ) ,
MSM_CHIP_DEVICE ( GPIO2 , QSD8X50 ) ,
2010-05-05 02:12:27 +04:00
MSM_DEVICE ( CLK_CTL ) ,
MSM_DEVICE ( SIRC ) ,
MSM_DEVICE ( SCPLL ) ,
MSM_DEVICE ( AD5 ) ,
MSM_DEVICE ( MDC ) ,
# ifdef CONFIG_MSM_DEBUG_UART
MSM_DEVICE ( DEBUG_UART ) ,
# endif
{
. virtual = ( unsigned long ) MSM_SHARED_RAM_BASE ,
. pfn = __phys_to_pfn ( MSM_SHARED_RAM_PHYS ) ,
. length = MSM_SHARED_RAM_SIZE ,
. type = MT_DEVICE ,
} ,
} ;
void __init msm_map_qsd8x50_io ( void )
{
iotable_init ( qsd8x50_io_desc , ARRAY_SIZE ( qsd8x50_io_desc ) ) ;
}
# endif /* CONFIG_ARCH_QSD8X50 */
2007-11-26 15:11:43 +03:00
2010-01-07 01:55:24 +03:00
# ifdef CONFIG_ARCH_MSM8X60
static struct map_desc msm8x60_io_desc [ ] __initdata = {
2011-01-04 22:02:59 +03:00
MSM_CHIP_DEVICE ( QGIC_DIST , MSM8X60 ) ,
MSM_CHIP_DEVICE ( QGIC_CPU , MSM8X60 ) ,
2011-01-07 21:20:49 +03:00
MSM_CHIP_DEVICE ( TMR , MSM8X60 ) ,
MSM_CHIP_DEVICE ( TMR0 , MSM8X60 ) ,
2010-01-07 01:55:24 +03:00
MSM_DEVICE ( ACC ) ,
MSM_DEVICE ( GCC ) ,
} ;
void __init msm_map_msm8x60_io ( void )
{
iotable_init ( msm8x60_io_desc , ARRAY_SIZE ( msm8x60_io_desc ) ) ;
}
# endif /* CONFIG_ARCH_MSM8X60 */
2010-12-02 06:05:49 +03:00
# ifdef CONFIG_ARCH_MSM8960
static struct map_desc msm8960_io_desc [ ] __initdata = {
MSM_CHIP_DEVICE ( QGIC_DIST , MSM8960 ) ,
MSM_CHIP_DEVICE ( QGIC_CPU , MSM8960 ) ,
MSM_CHIP_DEVICE ( TMR , MSM8960 ) ,
MSM_CHIP_DEVICE ( TMR0 , MSM8960 ) ,
} ;
void __init msm_map_msm8960_io ( void )
{
iotable_init ( msm8960_io_desc , ARRAY_SIZE ( msm8960_io_desc ) ) ;
}
# endif /* CONFIG_ARCH_MSM8960 */
2010-05-05 02:26:13 +04:00
# ifdef CONFIG_ARCH_MSM7X30
static struct map_desc msm7x30_io_desc [ ] __initdata = {
MSM_DEVICE ( VIC ) ,
2011-01-07 21:20:49 +03:00
MSM_CHIP_DEVICE ( CSR , MSM7X30 ) ,
2010-05-05 02:26:13 +04:00
MSM_DEVICE ( DMOV ) ,
2011-05-12 11:54:36 +04:00
MSM_CHIP_DEVICE ( GPIO1 , MSM7X30 ) ,
MSM_CHIP_DEVICE ( GPIO2 , MSM7X30 ) ,
2010-05-05 02:26:13 +04:00
MSM_DEVICE ( CLK_CTL ) ,
MSM_DEVICE ( CLK_CTL_SH2 ) ,
MSM_DEVICE ( AD5 ) ,
MSM_DEVICE ( MDC ) ,
MSM_DEVICE ( ACC ) ,
MSM_DEVICE ( SAW ) ,
MSM_DEVICE ( GCC ) ,
MSM_DEVICE ( TCSR ) ,
# ifdef CONFIG_MSM_DEBUG_UART
MSM_DEVICE ( DEBUG_UART ) ,
# endif
{
. virtual = ( unsigned long ) MSM_SHARED_RAM_BASE ,
. pfn = __phys_to_pfn ( MSM_SHARED_RAM_PHYS ) ,
. length = MSM_SHARED_RAM_SIZE ,
. type = MT_DEVICE ,
} ,
} ;
void __init msm_map_msm7x30_io ( void )
{
iotable_init ( msm7x30_io_desc , ARRAY_SIZE ( msm7x30_io_desc ) ) ;
}
# endif /* CONFIG_ARCH_MSM7X30 */
2007-11-26 15:11:43 +03:00
void __iomem *
__msm_ioremap ( unsigned long phys_addr , size_t size , unsigned int mtype )
{
if ( mtype = = MT_DEVICE ) {
/* The peripherals in the 88000000 - D0000000 range
tree-wide: fix comment/printk typos
"gadget", "through", "command", "maintain", "maintain", "controller", "address",
"between", "initiali[zs]e", "instead", "function", "select", "already",
"equal", "access", "management", "hierarchy", "registration", "interest",
"relative", "memory", "offset", "already",
Signed-off-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
Signed-off-by: Jiri Kosina <jkosina@suse.cz>
2010-11-01 22:38:34 +03:00
* are only accessible by type MT_DEVICE_NONSHARED .
2007-11-26 15:11:43 +03:00
* Adjust mtype as necessary to make this " just work. "
*/
if ( ( phys_addr > = 0x88000000 ) & & ( phys_addr < 0xD0000000 ) )
mtype = MT_DEVICE_NONSHARED ;
}
2009-12-18 14:10:03 +03:00
return __arm_ioremap_caller ( phys_addr , size , mtype ,
__builtin_return_address ( 0 ) ) ;
2007-11-26 15:11:43 +03:00
}
2010-11-09 13:11:29 +03:00
EXPORT_SYMBOL ( __msm_ioremap ) ;