2007-02-11 18:31:01 +01:00
/* linux/arch/arm/mach-s3c2412/mach-smdk2413.c
2006-06-24 21:21:35 +01:00
*
* Copyright ( c ) 2006 Simtec Electronics
* Ben Dooks < ben @ simtec . co . uk >
*
* Thanks to Dimity Andric ( TomTom ) and Steven Ryu ( Samsung ) for the
* loans of SMDK2413 to work with .
*
* 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/kernel.h>
# include <linux/types.h>
# include <linux/interrupt.h>
# include <linux/list.h>
# include <linux/timer.h>
# include <linux/init.h>
2009-05-13 22:52:24 +01:00
# include <linux/gpio.h>
2006-12-17 23:22:26 +01:00
# include <linux/serial_core.h>
2006-06-24 21:21:35 +01:00
# include <linux/platform_device.h>
2008-09-06 12:10:45 +01:00
# include <linux/io.h>
2006-06-24 21:21:35 +01:00
# include <asm/mach/arch.h>
# include <asm/mach/map.h>
# include <asm/mach/irq.h>
2008-08-05 16:14:15 +01:00
# include <mach/hardware.h>
2006-06-24 21:21:35 +01:00
# include <asm/hardware/iomd.h>
# include <asm/setup.h>
# include <asm/irq.h>
# include <asm/mach-types.h>
//#include <asm/debug-ll.h>
2008-10-07 22:26:09 +01:00
# include <plat/regs-serial.h>
2008-08-05 16:14:15 +01:00
# include <mach/regs-gpio.h>
# include <mach/regs-lcd.h>
2006-06-24 21:21:35 +01:00
2008-08-05 16:14:15 +01:00
# include <mach/idle.h>
2008-10-30 10:14:37 +00:00
# include <plat/udc.h>
2008-10-31 16:14:40 +00:00
# include <plat/iic.h>
2008-08-05 16:14:15 +01:00
# include <mach/fb.h>
2006-06-24 21:21:35 +01:00
2008-10-07 22:26:09 +01:00
# include <plat/s3c2410.h>
2008-10-07 23:09:51 +01:00
# include <plat/s3c2412.h>
# include <plat/clock.h>
2008-10-07 22:26:09 +01:00
# include <plat/devs.h>
# include <plat/cpu.h>
2006-06-24 21:21:35 +01:00
2008-10-07 23:09:51 +01:00
# include <plat/common-smdk.h>
2006-06-24 21:21:35 +01:00
static struct map_desc smdk2413_iodesc [ ] __initdata = {
} ;
static struct s3c2410_uartcfg smdk2413_uartcfgs [ ] __initdata = {
[ 0 ] = {
. hwport = 0 ,
. flags = 0 ,
. ucon = 0x3c5 ,
. ulcon = 0x03 ,
. ufcon = 0x51 ,
} ,
[ 1 ] = {
. hwport = 1 ,
. flags = 0 ,
. ucon = 0x3c5 ,
. ulcon = 0x03 ,
. ufcon = 0x51 ,
} ,
/* IR port */
[ 2 ] = {
. hwport = 2 ,
. flags = 0 ,
. ucon = 0x3c5 ,
. ulcon = 0x43 ,
. ufcon = 0x51 ,
}
} ;
2007-02-13 00:39:08 +01:00
static void smdk2413_udc_pullup ( enum s3c2410_udc_cmd_e cmd )
{
printk ( KERN_DEBUG " udc: pullup(%d) \n " , cmd ) ;
switch ( cmd )
{
case S3C2410_UDC_P_ENABLE :
2010-05-04 11:40:51 +09:00
gpio_set_value ( S3C2410_GPF ( 2 ) , 1 ) ;
2007-02-13 00:39:08 +01:00
break ;
case S3C2410_UDC_P_DISABLE :
2010-05-04 11:40:51 +09:00
gpio_set_value ( S3C2410_GPF ( 2 ) , 0 ) ;
2007-02-13 00:39:08 +01:00
break ;
case S3C2410_UDC_P_RESET :
break ;
default :
break ;
}
}
static struct s3c2410_udc_mach_info smdk2413_udc_cfg __initdata = {
. udc_command = smdk2413_udc_pullup ,
} ;
2006-06-24 21:21:35 +01:00
static struct platform_device * smdk2413_devices [ ] __initdata = {
2009-11-23 00:13:39 +00:00
& s3c_device_ohci ,
2006-06-24 21:21:35 +01:00
& s3c_device_wdt ,
2008-10-31 16:14:40 +00:00
& s3c_device_i2c0 ,
2006-06-24 21:21:35 +01:00
& s3c_device_iis ,
2007-02-13 00:39:08 +01:00
& s3c_device_usbgadget ,
2006-06-24 21:21:35 +01:00
} ;
static void __init smdk2413_fixup ( struct machine_desc * desc ,
struct tag * tags , char * * cmdline ,
struct meminfo * mi )
{
if ( tags ! = phys_to_virt ( S3C2410_SDRAM_PA + 0x100 ) ) {
mi - > nr_banks = 1 ;
mi - > bank [ 0 ] . start = 0x30000000 ;
mi - > bank [ 0 ] . size = SZ_64M ;
mi - > bank [ 0 ] . node = 0 ;
}
}
static void __init smdk2413_map_io ( void )
{
s3c24xx_init_io ( smdk2413_iodesc , ARRAY_SIZE ( smdk2413_iodesc ) ) ;
s3c24xx_init_clocks ( 12000000 ) ;
s3c24xx_init_uarts ( smdk2413_uartcfgs , ARRAY_SIZE ( smdk2413_uartcfgs ) ) ;
}
static void __init smdk2413_machine_init ( void )
2007-02-13 00:39:08 +01:00
{ /* Turn off suspend on both USB ports, and switch the
* selectable USB port to USB device mode . */
2010-05-04 11:40:51 +09:00
WARN_ON ( gpio_request ( S3C2410_GPF ( 2 ) , " udc pull " ) ) ;
gpio_direction_output ( S3C2410_GPF ( 2 ) , 0 ) ;
2007-02-13 00:39:08 +01:00
s3c2410_modify_misccr ( S3C2410_MISCCR_USBHOST |
S3C2410_MISCCR_USBSUSPND0 |
S3C2410_MISCCR_USBSUSPND1 , 0x0 ) ;
s3c24xx_udc_set_platdata ( & smdk2413_udc_cfg ) ;
2008-10-31 16:14:40 +00:00
s3c_i2c0_set_platdata ( NULL ) ;
2007-02-13 00:39:08 +01:00
2007-04-20 11:19:16 +01:00
platform_add_devices ( smdk2413_devices , ARRAY_SIZE ( smdk2413_devices ) ) ;
2006-06-24 21:21:35 +01:00
smdk_machine_init ( ) ;
}
2006-09-06 19:03:31 +01:00
MACHINE_START ( S3C2413 , " S3C2413 " )
2010-05-07 09:24:05 +09:00
/* Maintainer: Ben Dooks <ben-linux@fluff.org> */
2006-09-06 19:03:31 +01:00
. phys_io = S3C2410_PA_UART ,
. io_pg_offst = ( ( ( u32 ) S3C24XX_VA_UART ) > > 18 ) & 0xfffc ,
. boot_params = S3C2410_SDRAM_PA + 0x100 ,
. fixup = smdk2413_fixup ,
. init_irq = s3c24xx_init_irq ,
. map_io = smdk2413_map_io ,
. init_machine = smdk2413_machine_init ,
. timer = & s3c24xx_timer ,
MACHINE_END
2007-02-12 18:57:05 +01:00
MACHINE_START ( SMDK2412 , " SMDK2412 " )
2010-05-07 09:24:05 +09:00
/* Maintainer: Ben Dooks <ben-linux@fluff.org> */
2007-02-12 18:57:05 +01:00
. phys_io = S3C2410_PA_UART ,
. io_pg_offst = ( ( ( u32 ) S3C24XX_VA_UART ) > > 18 ) & 0xfffc ,
. boot_params = S3C2410_SDRAM_PA + 0x100 ,
. fixup = smdk2413_fixup ,
. init_irq = s3c24xx_init_irq ,
. map_io = smdk2413_map_io ,
. init_machine = smdk2413_machine_init ,
. timer = & s3c24xx_timer ,
MACHINE_END
2006-09-06 19:03:31 +01:00
MACHINE_START ( SMDK2413 , " SMDK2413 " )
2010-05-07 09:24:05 +09:00
/* Maintainer: Ben Dooks <ben-linux@fluff.org> */
2006-06-24 21:21:35 +01:00
. phys_io = S3C2410_PA_UART ,
. io_pg_offst = ( ( ( u32 ) S3C24XX_VA_UART ) > > 18 ) & 0xfffc ,
. boot_params = S3C2410_SDRAM_PA + 0x100 ,
. fixup = smdk2413_fixup ,
. init_irq = s3c24xx_init_irq ,
. map_io = smdk2413_map_io ,
. init_machine = smdk2413_machine_init ,
. timer = & s3c24xx_timer ,
MACHINE_END