2008-11-14 13:01:38 +03:00
/*
* author : Sascha Hauer
* Created : april 20 th , 2004
* Copyright : Synertronixx GmbH
*
2010-06-14 17:56:58 +04:00
* Common code for i . MX1 machines
2008-11-14 13:01:38 +03:00
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation ; either version 2 of the License , or
* ( at your option ) any later version .
*
* 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>
# include <linux/io.h>
2012-05-02 15:31:20 +04:00
# include <linux/pinctrl/machine.h>
2008-11-14 13:01:38 +03:00
# include <asm/mach/map.h>
2012-09-13 17:01:00 +04:00
# include "common.h"
2012-09-15 11:57:00 +04:00
# include "devices/devices-common.h"
2012-09-14 10:14:45 +04:00
# include "hardware.h"
2012-09-13 09:26:00 +04:00
# include "iomux-v1.h"
2008-11-14 13:01:38 +03:00
static struct map_desc imx_io_desc [ ] __initdata = {
2010-10-25 17:38:09 +04:00
imx_map_entry ( MX1 , IO , MT_DEVICE ) ,
2008-11-14 13:01:38 +03:00
} ;
2009-04-03 00:32:10 +04:00
void __init mx1_map_io ( void )
2011-02-07 18:35:19 +03:00
{
iotable_init ( imx_io_desc , ARRAY_SIZE ( imx_io_desc ) ) ;
}
void __init imx1_init_early ( void )
2008-11-14 13:01:38 +03:00
{
2009-04-03 00:32:10 +04:00
mxc_set_cpu_type ( MXC_CPU_MX1 ) ;
2010-03-04 23:02:41 +03:00
mxc_arch_reset_init ( MX1_IO_ADDRESS ( MX1_WDT_BASE_ADDR ) ) ;
2011-02-17 17:08:12 +03:00
imx_iomuxv1_init ( MX1_IO_ADDRESS ( MX1_GPIO_BASE_ADDR ) ,
MX1_NUM_GPIO_PORT ) ;
2008-11-14 13:01:38 +03:00
}
2009-05-25 19:36:19 +04:00
void __init mx1_init_irq ( void )
{
2010-03-04 23:02:41 +03:00
mxc_init_irq ( MX1_IO_ADDRESS ( MX1_AVIC_BASE_ADDR ) ) ;
2011-06-05 20:07:55 +04:00
}
void __init imx1_soc_init ( void )
{
2013-03-16 19:49:59 +04:00
mxc_device_init ( ) ;
2011-07-06 20:37:41 +04:00
mxc_register_gpio ( " imx1-gpio " , 0 , MX1_GPIO1_BASE_ADDR , SZ_256 ,
MX1_GPIO_INT_PORTA , 0 ) ;
mxc_register_gpio ( " imx1-gpio " , 1 , MX1_GPIO2_BASE_ADDR , SZ_256 ,
MX1_GPIO_INT_PORTB , 0 ) ;
mxc_register_gpio ( " imx1-gpio " , 2 , MX1_GPIO3_BASE_ADDR , SZ_256 ,
MX1_GPIO_INT_PORTC , 0 ) ;
mxc_register_gpio ( " imx1-gpio " , 3 , MX1_GPIO4_BASE_ADDR , SZ_256 ,
MX1_GPIO_INT_PORTD , 0 ) ;
2012-09-15 17:11:28 +04:00
imx_add_imx_dma ( " imx1-dma " , MX1_DMA_BASE_ADDR ,
MX1_DMA_INT , MX1_DMA_ERR ) ;
2012-05-02 15:31:20 +04:00
pinctrl_provide_dummies ( ) ;
2009-05-25 19:36:19 +04:00
}