2011-11-06 20:24:27 +04:00
/*
2012-09-21 05:13:29 +04:00
* Samsung ' s EXYNOS4 flattened device tree enabled machine
2011-11-06 20:24:27 +04:00
*
* Copyright ( c ) 2010 - 2011 Samsung Electronics Co . , Ltd .
* http : //www.samsung.com
* Copyright ( c ) 2010 - 2011 Linaro Ltd .
* www . linaro . org
*
* 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/of_platform.h>
# include <linux/serial_core.h>
# include <asm/mach/arch.h>
2012-02-08 06:42:39 +04:00
# include <asm/hardware/gic.h>
2011-11-06 20:24:27 +04:00
# include <mach/map.h>
# include <plat/cpu.h>
# include <plat/regs-serial.h>
2012-02-08 06:42:39 +04:00
# include "common.h"
2011-11-06 20:24:27 +04:00
/*
* The following lookup table is used to override device names when devices
* are registered from device tree . This is temporarily added to enable
* device tree support addition for the Exynos4 architecture .
*
* For drivers that require platform data to be provided from the machine
* file , a platform data pointer can also be supplied along with the
* devices names . Usually , the platform data elements that cannot be parsed
* from the device tree by the drivers ( example : function pointers ) are
* supplied . But it should be noted that this is a temporary mechanism and
* at some point , the drivers should be capable of parsing all the platform
* data from the device tree .
*/
2012-09-21 05:13:29 +04:00
static const struct of_dev_auxdata exynos4_auxdata_lookup [ ] __initconst = {
2012-03-07 17:14:07 +04:00
OF_DEV_AUXDATA ( " samsung,exynos4210-uart " , EXYNOS4_PA_UART0 ,
2011-11-06 20:24:27 +04:00
" exynos4210-uart.0 " , NULL ) ,
2012-03-07 17:14:07 +04:00
OF_DEV_AUXDATA ( " samsung,exynos4210-uart " , EXYNOS4_PA_UART1 ,
2011-11-06 20:24:27 +04:00
" exynos4210-uart.1 " , NULL ) ,
2012-03-07 17:14:07 +04:00
OF_DEV_AUXDATA ( " samsung,exynos4210-uart " , EXYNOS4_PA_UART2 ,
2011-11-06 20:24:27 +04:00
" exynos4210-uart.2 " , NULL ) ,
2012-03-07 17:14:07 +04:00
OF_DEV_AUXDATA ( " samsung,exynos4210-uart " , EXYNOS4_PA_UART3 ,
2011-11-06 20:24:27 +04:00
" exynos4210-uart.3 " , NULL ) ,
OF_DEV_AUXDATA ( " samsung,exynos4210-sdhci " , EXYNOS4_PA_HSMMC ( 0 ) ,
" exynos4-sdhci.0 " , NULL ) ,
OF_DEV_AUXDATA ( " samsung,exynos4210-sdhci " , EXYNOS4_PA_HSMMC ( 1 ) ,
" exynos4-sdhci.1 " , NULL ) ,
OF_DEV_AUXDATA ( " samsung,exynos4210-sdhci " , EXYNOS4_PA_HSMMC ( 2 ) ,
" exynos4-sdhci.2 " , NULL ) ,
OF_DEV_AUXDATA ( " samsung,exynos4210-sdhci " , EXYNOS4_PA_HSMMC ( 3 ) ,
" exynos4-sdhci.3 " , NULL ) ,
OF_DEV_AUXDATA ( " samsung,s3c2440-i2c " , EXYNOS4_PA_IIC ( 0 ) ,
" s3c2440-i2c.0 " , NULL ) ,
2012-09-21 05:21:35 +04:00
OF_DEV_AUXDATA ( " samsung,s3c2440-i2c " , EXYNOS4_PA_IIC ( 1 ) ,
" s3c2440-i2c.1 " , NULL ) ,
OF_DEV_AUXDATA ( " samsung,s3c2440-i2c " , EXYNOS4_PA_IIC ( 2 ) ,
" s3c2440-i2c.2 " , NULL ) ,
OF_DEV_AUXDATA ( " samsung,s3c2440-i2c " , EXYNOS4_PA_IIC ( 3 ) ,
" s3c2440-i2c.3 " , NULL ) ,
OF_DEV_AUXDATA ( " samsung,s3c2440-i2c " , EXYNOS4_PA_IIC ( 4 ) ,
" s3c2440-i2c.4 " , NULL ) ,
OF_DEV_AUXDATA ( " samsung,s3c2440-i2c " , EXYNOS4_PA_IIC ( 5 ) ,
" s3c2440-i2c.5 " , NULL ) ,
OF_DEV_AUXDATA ( " samsung,s3c2440-i2c " , EXYNOS4_PA_IIC ( 6 ) ,
" s3c2440-i2c.6 " , NULL ) ,
OF_DEV_AUXDATA ( " samsung,s3c2440-i2c " , EXYNOS4_PA_IIC ( 7 ) ,
" s3c2440-i2c.7 " , NULL ) ,
2012-07-14 05:54:26 +04:00
OF_DEV_AUXDATA ( " samsung,exynos4210-spi " , EXYNOS4_PA_SPI0 ,
" exynos4210-spi.0 " , NULL ) ,
OF_DEV_AUXDATA ( " samsung,exynos4210-spi " , EXYNOS4_PA_SPI1 ,
" exynos4210-spi.1 " , NULL ) ,
OF_DEV_AUXDATA ( " samsung,exynos4210-spi " , EXYNOS4_PA_SPI2 ,
" exynos4210-spi.2 " , NULL ) ,
2011-11-06 20:24:27 +04:00
OF_DEV_AUXDATA ( " arm,pl330 " , EXYNOS4_PA_PDMA0 , " dma-pl330.0 " , NULL ) ,
OF_DEV_AUXDATA ( " arm,pl330 " , EXYNOS4_PA_PDMA1 , " dma-pl330.1 " , NULL ) ,
{ } ,
} ;
2012-09-21 05:13:29 +04:00
static void __init exynos4_dt_map_io ( void )
2011-11-06 20:24:27 +04:00
{
2012-02-08 06:42:39 +04:00
exynos_init_io ( NULL , 0 ) ;
2011-11-06 20:24:27 +04:00
s3c24xx_init_clocks ( 24000000 ) ;
}
2012-09-21 05:13:29 +04:00
static void __init exynos4_dt_machine_init ( void )
2011-11-06 20:24:27 +04:00
{
of_platform_populate ( NULL , of_default_bus_match_table ,
2012-09-21 05:13:29 +04:00
exynos4_auxdata_lookup , NULL ) ;
2011-11-06 20:24:27 +04:00
}
2012-09-21 05:13:29 +04:00
static char const * exynos4_dt_compat [ ] __initdata = {
2011-11-06 20:24:27 +04:00
" samsung,exynos4210 " ,
NULL
} ;
DT_MACHINE_START ( EXYNOS4210_DT , " Samsung Exynos4 (Flattened Device Tree) " )
/* Maintainer: Thomas Abraham <thomas.abraham@linaro.org> */
2012-10-22 03:16:44 +04:00
. smp = smp_ops ( exynos_smp_ops ) ,
2011-11-06 20:24:27 +04:00
. init_irq = exynos4_init_irq ,
2012-09-21 05:13:29 +04:00
. map_io = exynos4_dt_map_io ,
2012-02-08 06:42:39 +04:00
. handle_irq = gic_handle_irq ,
2012-09-21 05:13:29 +04:00
. init_machine = exynos4_dt_machine_init ,
2012-04-26 06:35:40 +04:00
. init_late = exynos_init_late ,
2011-11-06 20:24:27 +04:00
. timer = & exynos4_timer ,
2012-09-21 05:13:29 +04:00
. dt_compat = exynos4_dt_compat ,
2012-02-08 06:42:39 +04:00
. restart = exynos4_restart ,
2011-11-06 20:24:27 +04:00
MACHINE_END