2009-03-20 12:50:22 +08:00
/*
* linux / arch / arm / mach - mmp / pxa910 . c
*
* Code specific to PXA910
*
* 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>
# include <linux/list.h>
# include <linux/io.h>
2011-10-17 20:37:52 +08:00
# include <linux/platform_device.h>
2009-03-20 12:50:22 +08:00
2012-08-04 23:57:38 +08:00
# include <asm/hardware/cache-tauros2.h>
2009-03-20 12:50:22 +08:00
# include <asm/mach/time.h>
# include <mach/addr-map.h>
# include <mach/regs-apbc.h>
# include <mach/cputype.h>
# include <mach/irqs.h>
# include <mach/dma.h>
# include <mach/mfp.h>
# include <mach/devices.h>
# include "common.h"
# define MFPR_VIRT_BASE (APB_VIRT_BASE + 0x1e000)
static struct mfp_addr_map pxa910_mfp_addr_map [ ] __initdata =
{
MFP_ADDR_X ( GPIO0 , GPIO54 , 0xdc ) ,
MFP_ADDR_X ( GPIO67 , GPIO98 , 0x1b8 ) ,
MFP_ADDR_X ( GPIO100 , GPIO109 , 0x238 ) ,
MFP_ADDR ( GPIO123 , 0xcc ) ,
MFP_ADDR ( GPIO124 , 0xd0 ) ,
MFP_ADDR ( DF_IO0 , 0x40 ) ,
MFP_ADDR ( DF_IO1 , 0x3c ) ,
MFP_ADDR ( DF_IO2 , 0x38 ) ,
MFP_ADDR ( DF_IO3 , 0x34 ) ,
MFP_ADDR ( DF_IO4 , 0x30 ) ,
MFP_ADDR ( DF_IO5 , 0x2c ) ,
MFP_ADDR ( DF_IO6 , 0x28 ) ,
MFP_ADDR ( DF_IO7 , 0x24 ) ,
MFP_ADDR ( DF_IO8 , 0x20 ) ,
MFP_ADDR ( DF_IO9 , 0x1c ) ,
MFP_ADDR ( DF_IO10 , 0x18 ) ,
MFP_ADDR ( DF_IO11 , 0x14 ) ,
MFP_ADDR ( DF_IO12 , 0x10 ) ,
MFP_ADDR ( DF_IO13 , 0xc ) ,
MFP_ADDR ( DF_IO14 , 0x8 ) ,
MFP_ADDR ( DF_IO15 , 0x4 ) ,
MFP_ADDR ( DF_nCS0_SM_nCS2 , 0x44 ) ,
MFP_ADDR ( DF_nCS1_SM_nCS3 , 0x48 ) ,
MFP_ADDR ( SM_nCS0 , 0x4c ) ,
MFP_ADDR ( SM_nCS1 , 0x50 ) ,
MFP_ADDR ( DF_WEn , 0x54 ) ,
MFP_ADDR ( DF_REn , 0x58 ) ,
MFP_ADDR ( DF_CLE_SM_OEn , 0x5c ) ,
MFP_ADDR ( DF_ALE_SM_WEn , 0x60 ) ,
MFP_ADDR ( SM_SCLK , 0x64 ) ,
MFP_ADDR ( DF_RDY0 , 0x68 ) ,
MFP_ADDR ( SM_BE0 , 0x6c ) ,
MFP_ADDR ( SM_BE1 , 0x70 ) ,
MFP_ADDR ( SM_ADV , 0x74 ) ,
MFP_ADDR ( DF_RDY1 , 0x78 ) ,
MFP_ADDR ( SM_ADVMUX , 0x7c ) ,
MFP_ADDR ( SM_RDY , 0x80 ) ,
MFP_ADDR_X ( MMC1_DAT7 , MMC1_WP , 0x84 ) ,
MFP_ADDR_END ,
} ;
void __init pxa910_init_irq ( void )
{
icu_init_irq ( ) ;
}
static int __init pxa910_init ( void )
{
if ( cpu_is_pxa910 ( ) ) {
2012-08-04 23:57:38 +08:00
# ifdef CONFIG_CACHE_TAUROS2
tauros2_init ( 0 ) ;
# endif
2009-03-20 12:50:22 +08:00
mfp_init_base ( MFPR_VIRT_BASE ) ;
mfp_init_addr ( pxa910_mfp_addr_map ) ;
pxa_init_dma ( IRQ_PXA910_DMA_INT0 , 32 ) ;
2012-08-27 10:54:01 +08:00
pxa910_clk_init ( ) ;
2009-03-20 12:50:22 +08:00
}
return 0 ;
}
postcore_initcall ( pxa910_init ) ;
/* system timer - clock enabled, 3.25MHz */
# define TIMER_CLK_RST (APBC_APBCLK | APBC_FNCLK | APBC_FNCLKSEL(3))
2012-08-27 10:54:01 +08:00
# define APBC_TIMERS APBC_REG(0x34)
2009-03-20 12:50:22 +08:00
2012-11-08 12:40:59 -07:00
void __init pxa910_timer_init ( void )
2009-03-20 12:50:22 +08:00
{
/* reset and configure */
2012-08-27 10:54:01 +08:00
__raw_writel ( APBC_APBCLK | APBC_RST , APBC_TIMERS ) ;
__raw_writel ( TIMER_CLK_RST , APBC_TIMERS ) ;
2009-03-20 12:50:22 +08:00
timer_init ( IRQ_PXA910_AP1_TIMER1 ) ;
}
/* on-chip devices */
/* NOTE: there are totally 3 UARTs on PXA910:
*
* UART1 - Slow UART ( can be used both by AP and CP )
* UART2 / 3 - Fast UART
*
* To be backward compatible with the legacy FFUART / BTUART / STUART sequence ,
* they are re - ordered as :
*
* pxa910_device_uart1 - UART2 as FFUART
* pxa910_device_uart2 - UART3 as BTUART
*
* UART1 is not used by AP for the moment .
*/
PXA910_DEVICE ( uart1 , " pxa2xx-uart " , 0 , UART2 , 0xd4017000 , 0x30 , 21 , 22 ) ;
PXA910_DEVICE ( uart2 , " pxa2xx-uart " , 1 , UART3 , 0xd4018000 , 0x30 , 23 , 24 ) ;
2009-04-13 15:34:54 +08:00
PXA910_DEVICE ( twsi0 , " pxa2xx-i2c " , 0 , TWSI0 , 0xd4011000 , 0x28 ) ;
PXA910_DEVICE ( twsi1 , " pxa2xx-i2c " , 1 , TWSI1 , 0xd4025000 , 0x28 ) ;
2009-04-13 18:29:52 +08:00
PXA910_DEVICE ( pwm1 , " pxa910-pwm " , 0 , NONE , 0xd401a000 , 0x10 ) ;
PXA910_DEVICE ( pwm2 , " pxa910-pwm " , 1 , NONE , 0xd401a400 , 0x10 ) ;
PXA910_DEVICE ( pwm3 , " pxa910-pwm " , 2 , NONE , 0xd401a800 , 0x10 ) ;
PXA910_DEVICE ( pwm4 , " pxa910-pwm " , 3 , NONE , 0xd401ac00 , 0x10 ) ;
2009-10-13 15:24:55 +08:00
PXA910_DEVICE ( nand , " pxa3xx-nand " , - 1 , NAND , 0xd4283000 , 0x80 , 97 , 99 ) ;
2011-10-17 20:37:52 +08:00
struct resource pxa910_resource_gpio [ ] = {
{
. start = 0xd4019000 ,
. end = 0xd4019fff ,
. flags = IORESOURCE_MEM ,
} , {
. start = IRQ_PXA910_AP_GPIO ,
. end = IRQ_PXA910_AP_GPIO ,
2012-02-27 10:37:02 +08:00
. name = " gpio_mux " ,
2011-10-17 20:37:52 +08:00
. flags = IORESOURCE_IRQ ,
} ,
} ;
struct platform_device pxa910_device_gpio = {
. name = " pxa-gpio " ,
. id = - 1 ,
. num_resources = ARRAY_SIZE ( pxa910_resource_gpio ) ,
. resource = pxa910_resource_gpio ,
} ;
2012-02-23 23:37:33 +08:00
static struct resource pxa910_resource_rtc [ ] = {
{
. start = 0xd4010000 ,
. end = 0xd401003f ,
. flags = IORESOURCE_MEM ,
} , {
. start = IRQ_PXA910_RTC_INT ,
. end = IRQ_PXA910_RTC_INT ,
. name = " rtc 1Hz " ,
. flags = IORESOURCE_IRQ ,
} , {
. start = IRQ_PXA910_RTC_ALARM ,
. end = IRQ_PXA910_RTC_ALARM ,
. name = " rtc alarm " ,
. flags = IORESOURCE_IRQ ,
} ,
} ;
struct platform_device pxa910_device_rtc = {
. name = " sa1100-rtc " ,
. id = - 1 ,
. num_resources = ARRAY_SIZE ( pxa910_resource_rtc ) ,
. resource = pxa910_resource_rtc ,
} ;