2019-05-19 15:51:31 +02:00
// SPDX-License-Identifier: GPL-2.0-or-later
2008-07-05 10:02:56 +02:00
/*
2010-06-10 15:11:13 +02:00
* arch / arm / mach - imx / mm - imx27 . c
2008-07-05 10:02:56 +02:00
*
* Copyright ( C ) 2008 Juergen Beisert ( kernel @ pengutronix . de )
*/
# include <linux/mm.h>
# include <linux/init.h>
2012-05-02 19:31:20 +08:00
# include <linux/pinctrl/machine.h>
2008-07-05 10:02:56 +02:00
# include <asm/pgtable.h>
# include <asm/mach/map.h>
2012-09-13 13:26:00 +08:00
2012-09-13 21:01:00 +08:00
# include "common.h"
2012-09-13 15:51:15 +08:00
# include "devices/devices-common.h"
2012-09-14 14:14:45 +08:00
# include "hardware.h"
2012-09-13 13:26:00 +08:00
# include "iomux-v1.h"
2008-07-05 10:02:56 +02:00
/* MX27 memory map definition */
2010-02-05 22:00:11 +01:00
static struct map_desc imx27_io_desc [ ] __initdata = {
2008-07-05 10:02:56 +02:00
/*
* this fixed mapping covers :
* - AIPI1
* - AIPI2
* - AITC
* - ROM Patch
* - and some reserved space
*/
2010-10-25 15:38:09 +02:00
imx_map_entry ( MX27 , AIPI , MT_DEVICE ) ,
2008-07-05 10:02:56 +02:00
/*
* this fixed mapping covers :
* - CSI
* - ATA
*/
2010-10-25 15:38:09 +02:00
imx_map_entry ( MX27 , SAHB1 , MT_DEVICE ) ,
2008-07-05 10:02:56 +02:00
/*
* this fixed mapping covers :
* - EMI
*/
2010-10-25 15:38:09 +02:00
imx_map_entry ( MX27 , X_MEMC , MT_DEVICE ) ,
2008-07-05 10:02:56 +02:00
} ;
/*
* Initialize the memory map . It is called during the
* system startup to create static physical to virtual
* memory map for the IO modules .
*/
2009-04-02 22:32:10 +02:00
void __init mx27_map_io ( void )
2011-02-07 16:35:19 +01:00
{
iotable_init ( imx27_io_desc , ARRAY_SIZE ( imx27_io_desc ) ) ;
}
void __init imx27_init_early ( void )
2009-04-02 22:32:10 +02:00
{
mxc_set_cpu_type ( MXC_CPU_MX27 ) ;
2011-02-17 15:08:12 +01:00
imx_iomuxv1_init ( MX27_IO_ADDRESS ( MX27_GPIO_BASE_ADDR ) ,
MX27_NUM_GPIO_PORT ) ;
2009-04-02 22:32:10 +02:00
}
2009-05-25 17:36:19 +02:00
void __init mx27_init_irq ( void )
{
2010-02-05 22:00:11 +01:00
mxc_init_irq ( MX27_IO_ADDRESS ( MX27_AVIC_BASE_ADDR ) ) ;
2011-06-06 00:07:55 +08:00
}
2012-03-05 22:30:52 +08:00
static const struct resource imx27_audmux_res [ ] __initconst = {
DEFINE_RES_MEM ( MX27_AUDMUX_BASE_ADDR , SZ_4K ) ,
} ;
2011-06-06 00:07:55 +08:00
void __init imx27_soc_init ( void )
{
2013-05-10 09:13:44 +08:00
mxc_arch_reset_init ( MX27_IO_ADDRESS ( MX27_WDOG_BASE_ADDR ) ) ;
2012-09-20 14:21:16 +08:00
mxc_device_init ( ) ;
2011-07-07 00:37:41 +08:00
/* i.mx27 has the i.mx21 type gpio */
mxc_register_gpio ( " imx21-gpio " , 0 , MX27_GPIO1_BASE_ADDR , SZ_256 , MX27_INT_GPIO , 0 ) ;
mxc_register_gpio ( " imx21-gpio " , 1 , MX27_GPIO2_BASE_ADDR , SZ_256 , MX27_INT_GPIO , 0 ) ;
mxc_register_gpio ( " imx21-gpio " , 2 , MX27_GPIO3_BASE_ADDR , SZ_256 , MX27_INT_GPIO , 0 ) ;
mxc_register_gpio ( " imx21-gpio " , 3 , MX27_GPIO4_BASE_ADDR , SZ_256 , MX27_INT_GPIO , 0 ) ;
mxc_register_gpio ( " imx21-gpio " , 4 , MX27_GPIO5_BASE_ADDR , SZ_256 , MX27_INT_GPIO , 0 ) ;
mxc_register_gpio ( " imx21-gpio " , 5 , MX27_GPIO6_BASE_ADDR , SZ_256 , MX27_INT_GPIO , 0 ) ;
2011-06-22 22:41:30 +08:00
2012-05-02 19:31:20 +08:00
pinctrl_provide_dummies ( ) ;
2012-09-15 21:11:28 +08:00
imx_add_imx_dma ( " imx27-dma " , MX27_DMA_BASE_ADDR ,
MX27_INT_DMACH0 , 0 ) ; /* No ERR irq */
2012-03-05 22:30:52 +08:00
/* imx27 has the imx21 type audmux */
platform_device_register_simple ( " imx21-audmux " , 0 , imx27_audmux_res ,
ARRAY_SIZE ( imx27_audmux_res ) ) ;
2016-06-28 10:22:16 +08:00
imx27_pm_init ( ) ;
2009-05-25 17:36:19 +02:00
}