2007-02-11 20:31:01 +03:00
/* linux/arch/arm/mach-s3c2440/mach-nexcoder.c
2005-04-17 02:20:36 +04:00
*
* Copyright ( c ) 2004 Nex Vision
* Guillaume GOURAT < guillaume . gourat @ nexvision . tv >
*
* 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 .
*
* Modifications :
* 15 - 10 - 2004 GG Created initial version
* 12 - 03 - 2005 BJD Updated for release
*/
# include <linux/kernel.h>
# include <linux/types.h>
# include <linux/interrupt.h>
# include <linux/list.h>
# include <linux/timer.h>
# include <linux/init.h>
2009-05-14 01:52:24 +04:00
# include <linux/gpio.h>
2005-04-17 02:20:36 +04:00
# include <linux/string.h>
2006-12-18 01:22:26 +03:00
# include <linux/serial_core.h>
2005-10-29 22:07:23 +04:00
# include <linux/platform_device.h>
2008-09-06 15:10:45 +04:00
# include <linux/io.h>
2005-04-17 02:20:36 +04:00
# include <linux/mtd/map.h>
# include <asm/mach/arch.h>
# include <asm/mach/map.h>
# include <asm/mach/irq.h>
# include <asm/setup.h>
2008-08-05 19:14:15 +04:00
# include <mach/hardware.h>
2005-04-17 02:20:36 +04:00
# include <asm/irq.h>
# include <asm/mach-types.h>
//#include <asm/debug-ll.h>
2008-08-05 19:14:15 +04:00
# include <mach/regs-gpio.h>
2008-10-08 01:26:09 +04:00
# include <plat/regs-serial.h>
2008-10-31 19:14:40 +03:00
# include <plat/iic.h>
2005-04-17 02:20:36 +04:00
2010-05-04 09:38:49 +04:00
# include <plat/gpio-cfg.h>
2008-10-08 01:26:09 +04:00
# include <plat/s3c2410.h>
2010-01-26 10:54:21 +03:00
# include <plat/s3c244x.h>
2008-10-08 02:09:51 +04:00
# include <plat/clock.h>
2008-10-08 01:26:09 +04:00
# include <plat/devs.h>
# include <plat/cpu.h>
2005-04-17 02:20:36 +04:00
static struct map_desc nexcoder_iodesc [ ] __initdata = {
/* nothing here yet */
} ;
# define UCON S3C2410_UCON_DEFAULT
# define ULCON S3C2410_LCON_CS8 | S3C2410_LCON_PNONE | S3C2410_LCON_STOPB
# define UFCON S3C2410_UFCON_RXTRIG12 | S3C2410_UFCON_FIFOMODE
2006-06-19 02:04:05 +04:00
static struct s3c2410_uartcfg nexcoder_uartcfgs [ ] __initdata = {
2005-04-17 02:20:36 +04:00
[ 0 ] = {
. hwport = 0 ,
. flags = 0 ,
. ucon = UCON ,
. ulcon = ULCON ,
. ufcon = UFCON ,
} ,
[ 1 ] = {
. hwport = 1 ,
. flags = 0 ,
. ucon = UCON ,
. ulcon = ULCON ,
. ufcon = UFCON ,
} ,
[ 2 ] = {
. hwport = 2 ,
. flags = 0 ,
. ucon = UCON ,
. ulcon = ULCON ,
. ufcon = UFCON ,
}
} ;
/* NOR Flash on NexVision NexCoder 2440 board */
static struct resource nexcoder_nor_resource [ ] = {
[ 0 ] = {
. start = S3C2410_CS0 ,
. end = S3C2410_CS0 + ( 8 * 1024 * 1024 ) - 1 ,
. flags = IORESOURCE_MEM ,
}
} ;
static struct map_info nexcoder_nor_map = {
. bankwidth = 2 ,
} ;
static struct platform_device nexcoder_device_nor = {
. name = " mtd-flash " ,
. id = - 1 ,
. num_resources = ARRAY_SIZE ( nexcoder_nor_resource ) ,
. resource = nexcoder_nor_resource ,
. dev =
{
. platform_data = & nexcoder_nor_map ,
}
} ;
/* Standard Nexcoder devices */
static struct platform_device * nexcoder_devices [ ] __initdata = {
2009-11-23 03:13:39 +03:00
& s3c_device_ohci ,
2005-04-17 02:20:36 +04:00
& s3c_device_lcd ,
& s3c_device_wdt ,
2008-10-31 19:14:40 +03:00
& s3c_device_i2c0 ,
2005-04-17 02:20:36 +04:00
& s3c_device_iis ,
& s3c_device_rtc ,
& s3c_device_camif ,
& s3c_device_spi0 ,
& s3c_device_spi1 ,
& nexcoder_device_nor ,
} ;
static void __init nexcoder_sensorboard_init ( void )
{
// Initialize SCCB bus
2009-05-18 01:32:23 +04:00
s3c2410_gpio_setpin ( S3C2410_GPE ( 14 ) , 1 ) ; // IICSCL
2010-05-04 09:38:49 +04:00
s3c_gpio_cfgpin ( S3C2410_GPE ( 14 ) , S3C2410_GPIO_OUTPUT ) ;
2009-05-18 01:32:23 +04:00
s3c2410_gpio_setpin ( S3C2410_GPE ( 15 ) , 1 ) ; // IICSDA
2010-05-04 09:38:49 +04:00
s3c_gpio_cfgpin ( S3C2410_GPE ( 15 ) , S3C2410_GPIO_OUTPUT ) ;
2005-04-17 02:20:36 +04:00
// Power up the sensor board
2009-05-18 01:32:23 +04:00
s3c2410_gpio_setpin ( S3C2410_GPF ( 1 ) , 1 ) ;
2010-05-04 09:38:49 +04:00
s3c_gpio_cfgpin ( S3C2410_GPF ( 1 ) , S3C2410_GPIO_OUTPUT ) ; // CAM_GPIO7 => nLDO_PWRDN
2009-05-18 01:32:23 +04:00
s3c2410_gpio_setpin ( S3C2410_GPF ( 2 ) , 0 ) ;
2010-05-04 09:38:49 +04:00
s3c_gpio_cfgpin ( S3C2410_GPF ( 2 ) , S3C2410_GPIO_OUTPUT ) ; // CAM_GPIO6 => CAM_PWRDN
2005-04-17 02:20:36 +04:00
}
2005-09-20 20:24:33 +04:00
static void __init nexcoder_map_io ( void )
2005-04-17 02:20:36 +04:00
{
s3c24xx_init_io ( nexcoder_iodesc , ARRAY_SIZE ( nexcoder_iodesc ) ) ;
s3c24xx_init_clocks ( 0 ) ;
s3c24xx_init_uarts ( nexcoder_uartcfgs , ARRAY_SIZE ( nexcoder_uartcfgs ) ) ;
2007-04-20 14:19:16 +04:00
2005-04-17 02:20:36 +04:00
nexcoder_sensorboard_init ( ) ;
}
2007-04-20 14:19:16 +04:00
static void __init nexcoder_init ( void )
{
2008-10-31 19:14:40 +03:00
s3c_i2c0_set_platdata ( NULL ) ;
2007-04-20 14:19:16 +04:00
platform_add_devices ( nexcoder_devices , ARRAY_SIZE ( nexcoder_devices ) ) ;
} ;
2005-04-17 02:20:36 +04:00
MACHINE_START ( NEXCODER_2440 , " NexVision - Nexcoder 2440 " )
2005-07-03 20:38:58 +04:00
/* Maintainer: Guillaume GOURAT <guillaume.gourat@nexvision.tv> */
. boot_params = S3C2410_SDRAM_PA + 0x100 ,
2005-04-17 02:20:36 +04:00
. map_io = nexcoder_map_io ,
2007-04-20 14:19:16 +04:00
. init_machine = nexcoder_init ,
2005-04-17 02:20:36 +04:00
. init_irq = s3c24xx_init_irq ,
. timer = & s3c24xx_timer ,
MACHINE_END