2007-02-17 00:52:37 +01:00
/* linux/arch/arm/mach-s3c2410/mach-qt2410.c
*
* Copyright ( C ) 2006 by OpenMoko , Inc .
* Author : Harald Welte < laforge @ openmoko . org >
* All rights reserved .
*
* 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 .
*
* You should have received a copy of the GNU General Public License
* along with this program ; if not , write to the Free Software
* Foundation , Inc . , 59 Temple Place , Suite 330 , Boston ,
* MA 02111 - 1307 USA
*
*/
# 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>
2011-12-21 16:26:03 -08:00
# include <linux/device.h>
2007-02-17 00:52:37 +01:00
# include <linux/platform_device.h>
# include <linux/serial_core.h>
# include <linux/spi/spi.h>
2011-06-28 14:49:14 +02:00
# include <linux/spi/spi_gpio.h>
2008-09-06 12:10:45 +01:00
# include <linux/io.h>
2007-02-17 00:52:37 +01:00
# include <linux/mtd/mtd.h>
# include <linux/mtd/nand.h>
# include <linux/mtd/nand_ecc.h>
# include <linux/mtd/partitions.h>
# 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>
2007-02-17 00:52:37 +01:00
# include <asm/irq.h>
# include <asm/mach-types.h>
2012-08-24 15:22:12 +02:00
# include <linux/platform_data/leds-s3c24xx.h>
2011-10-03 09:46:13 +09:00
# include <mach/regs-lcd.h>
2008-10-07 22:26:09 +01:00
# include <plat/regs-serial.h>
2008-08-05 16:14:15 +01:00
# include <mach/fb.h>
2012-08-24 15:22:12 +02:00
# include <linux/platform_data/mtd-nand-s3c2410.h>
# include <linux/platform_data/usb-s3c2410_udc.h>
# include <linux/platform_data/i2c-s3c2410.h>
2007-02-17 00:52:37 +01:00
2008-10-07 23:09:51 +01:00
# include <plat/common-smdk.h>
2010-05-04 14:38:49 +09:00
# include <plat/gpio-cfg.h>
2008-10-07 22:26:09 +01:00
# include <plat/devs.h>
# include <plat/cpu.h>
# include <plat/pm.h>
2007-02-17 00:52:37 +01:00
2012-01-03 14:02:03 +01:00
# include "common.h"
2007-02-17 00:52:37 +01:00
static struct map_desc qt2410_iodesc [ ] __initdata = {
{ 0xe0000000 , __phys_to_pfn ( S3C2410_CS3 + 0x01000000 ) , SZ_1M , MT_DEVICE }
} ;
# define UCON S3C2410_UCON_DEFAULT
# define ULCON S3C2410_LCON_CS8 | S3C2410_LCON_PNONE | S3C2410_LCON_STOPB
# define UFCON S3C2410_UFCON_RXTRIG8 | S3C2410_UFCON_FIFOMODE
static struct s3c2410_uartcfg smdk2410_uartcfgs [ ] = {
[ 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 ,
}
} ;
/* LCD driver info */
2007-10-16 01:28:56 -07:00
static struct s3c2410fb_display qt2410_lcd_cfg [ ] __initdata = {
{
/* Configuration for 640x480 SHARP LQ080V3DG01 */
2007-10-16 01:28:58 -07:00
. lcdcon5 = S3C2410_LCDCON5_FRM565 |
S3C2410_LCDCON5_INVVLINE |
S3C2410_LCDCON5_INVVFRAME |
S3C2410_LCDCON5_PWREN |
S3C2410_LCDCON5_HWSWP ,
2007-10-16 01:28:56 -07:00
2007-10-16 01:28:57 -07:00
. type = S3C2410_LCDCON1_TFT ,
2007-10-16 01:28:56 -07:00
. width = 640 ,
. height = 480 ,
2007-10-16 01:29:06 -07:00
. pixclock = 40000 , /* HCLK/4 */
2007-10-16 01:28:56 -07:00
. xres = 640 ,
. yres = 480 ,
. bpp = 16 ,
2007-10-16 01:28:57 -07:00
. left_margin = 44 ,
. right_margin = 116 ,
2007-10-16 01:29:00 -07:00
. hsync_len = 96 ,
2007-10-16 01:28:59 -07:00
. upper_margin = 19 ,
. lower_margin = 11 ,
2007-10-16 01:29:00 -07:00
. vsync_len = 15 ,
2007-02-17 00:52:37 +01:00
} ,
2007-10-16 01:28:56 -07:00
{
/* Configuration for 480x640 toppoly TD028TTEC1 */
2007-10-16 01:28:58 -07:00
. lcdcon5 = S3C2410_LCDCON5_FRM565 |
S3C2410_LCDCON5_INVVLINE |
S3C2410_LCDCON5_INVVFRAME |
S3C2410_LCDCON5_PWREN |
S3C2410_LCDCON5_HWSWP ,
2007-10-16 01:28:56 -07:00
2007-10-16 01:28:57 -07:00
. type = S3C2410_LCDCON1_TFT ,
2007-10-16 01:28:56 -07:00
. width = 480 ,
. height = 640 ,
2007-10-16 01:29:06 -07:00
. pixclock = 40000 , /* HCLK/4 */
2007-10-16 01:28:56 -07:00
. xres = 480 ,
. yres = 640 ,
. bpp = 16 ,
2007-10-16 01:28:57 -07:00
. left_margin = 8 ,
. right_margin = 24 ,
2007-10-16 01:29:00 -07:00
. hsync_len = 8 ,
2007-10-16 01:28:59 -07:00
. upper_margin = 2 ,
. lower_margin = 4 ,
2007-10-16 01:29:00 -07:00
. vsync_len = 2 ,
2007-02-17 00:52:37 +01:00
} ,
2007-10-16 01:28:56 -07:00
{
/* Config for 240x320 LCD */
2007-10-16 01:28:58 -07:00
. lcdcon5 = S3C2410_LCDCON5_FRM565 |
S3C2410_LCDCON5_INVVLINE |
S3C2410_LCDCON5_INVVFRAME |
S3C2410_LCDCON5_PWREN |
S3C2410_LCDCON5_HWSWP ,
2007-10-16 01:28:56 -07:00
2007-10-16 01:28:57 -07:00
. type = S3C2410_LCDCON1_TFT ,
2007-10-16 01:28:56 -07:00
. width = 240 ,
. height = 320 ,
2007-10-16 01:29:06 -07:00
. pixclock = 100000 , /* HCLK/10 */
2007-10-16 01:28:56 -07:00
. xres = 240 ,
. yres = 320 ,
. bpp = 16 ,
2007-10-16 01:28:57 -07:00
. left_margin = 13 ,
. right_margin = 8 ,
2007-10-16 01:29:00 -07:00
. hsync_len = 4 ,
2007-10-16 01:28:59 -07:00
. upper_margin = 2 ,
. lower_margin = 7 ,
2007-10-16 01:29:00 -07:00
. vsync_len = 4 ,
2007-02-17 00:52:37 +01:00
} ,
} ;
2007-10-16 01:28:56 -07:00
static struct s3c2410fb_mach_info qt2410_fb_info __initdata = {
. displays = qt2410_lcd_cfg ,
. num_displays = ARRAY_SIZE ( qt2410_lcd_cfg ) ,
. default_display = 0 ,
2007-02-17 00:52:37 +01:00
. lpcsel = ( ( 0xCE6 ) & ~ 7 ) | 1 < < 4 ,
} ;
/* CS8900 */
static struct resource qt2410_cs89x0_resources [ ] = {
2012-05-13 06:47:13 +09:00
[ 0 ] = DEFINE_RES_MEM ( 0x19000000 , 17 ) ,
[ 1 ] = DEFINE_RES_IRQ ( IRQ_EINT9 ) ,
2007-02-17 00:52:37 +01:00
} ;
static struct platform_device qt2410_cs89x0 = {
. name = " cirrus-cs89x0 " ,
. num_resources = ARRAY_SIZE ( qt2410_cs89x0_resources ) ,
. resource = qt2410_cs89x0_resources ,
} ;
/* LED */
static struct s3c24xx_led_platdata qt2410_pdata_led = {
2009-05-17 22:32:23 +01:00
. gpio = S3C2410_GPB ( 0 ) ,
2007-02-17 00:52:37 +01:00
. flags = S3C24XX_LEDF_ACTLOW | S3C24XX_LEDF_TRISTATE ,
. name = " led " ,
. def_trigger = " timer " ,
} ;
static struct platform_device qt2410_led = {
. name = " s3c24xx_led " ,
. id = 0 ,
. dev = {
. platform_data = & qt2410_pdata_led ,
} ,
} ;
/* SPI */
2011-06-28 14:49:14 +02:00
static struct spi_gpio_platform_data spi_gpio_cfg = {
. sck = S3C2410_GPG ( 7 ) ,
. mosi = S3C2410_GPG ( 6 ) ,
. miso = S3C2410_GPG ( 5 ) ,
2007-02-17 00:52:37 +01:00
} ;
static struct platform_device qt2410_spi = {
2011-06-28 14:49:14 +02:00
. name = " spi-gpio " ,
. id = 1 ,
. dev . platform_data = & spi_gpio_cfg ,
2007-02-17 00:52:37 +01:00
} ;
/* Board devices */
static struct platform_device * qt2410_devices [ ] __initdata = {
2009-11-23 00:13:39 +00:00
& s3c_device_ohci ,
2007-02-17 00:52:37 +01:00
& s3c_device_lcd ,
& s3c_device_wdt ,
2008-10-31 16:14:40 +00:00
& s3c_device_i2c0 ,
2007-02-17 00:52:37 +01:00
& s3c_device_iis ,
& s3c_device_sdi ,
& s3c_device_usbgadget ,
& qt2410_spi ,
& qt2410_cs89x0 ,
& qt2410_led ,
} ;
2009-09-28 13:59:49 +03:00
static struct mtd_partition __initdata qt2410_nand_part [ ] = {
2007-02-17 00:52:37 +01:00
[ 0 ] = {
. name = " U-Boot " ,
. size = 0x30000 ,
. offset = 0 ,
} ,
[ 1 ] = {
. name = " U-Boot environment " ,
. offset = 0x30000 ,
. size = 0x4000 ,
} ,
[ 2 ] = {
. name = " kernel " ,
. offset = 0x34000 ,
. size = SZ_2M ,
} ,
[ 3 ] = {
. name = " initrd " ,
. offset = 0x234000 ,
. size = SZ_4M ,
} ,
[ 4 ] = {
. name = " jffs2 " ,
. offset = 0x634000 ,
. size = 0x39cc000 ,
} ,
} ;
2009-09-28 13:59:49 +03:00
static struct s3c2410_nand_set __initdata qt2410_nand_sets [ ] = {
2007-02-17 00:52:37 +01:00
[ 0 ] = {
. name = " NAND " ,
. nr_chips = 1 ,
. nr_partitions = ARRAY_SIZE ( qt2410_nand_part ) ,
. partitions = qt2410_nand_part ,
} ,
} ;
/* choose a set of timings which should suit most 512Mbit
* chips and beyond .
*/
2009-09-28 13:59:49 +03:00
static struct s3c2410_platform_nand __initdata qt2410_nand_info = {
2007-02-17 00:52:37 +01:00
. tacls = 20 ,
. twrph0 = 60 ,
. twrph1 = 20 ,
. nr_sets = ARRAY_SIZE ( qt2410_nand_sets ) ,
. sets = qt2410_nand_sets ,
} ;
/* UDC */
static struct s3c2410_udc_mach_info qt2410_udc_cfg = {
} ;
static char tft_type = ' s ' ;
static int __init qt2410_tft_setup ( char * str )
{
tft_type = str [ 0 ] ;
return 1 ;
}
__setup ( " tft= " , qt2410_tft_setup ) ;
static void __init qt2410_map_io ( void )
{
s3c24xx_init_io ( qt2410_iodesc , ARRAY_SIZE ( qt2410_iodesc ) ) ;
s3c24xx_init_clocks ( 12 * 1000 * 1000 ) ;
s3c24xx_init_uarts ( smdk2410_uartcfgs , ARRAY_SIZE ( smdk2410_uartcfgs ) ) ;
}
static void __init qt2410_machine_init ( void )
{
2009-09-28 13:59:49 +03:00
s3c_nand_set_platdata ( & qt2410_nand_info ) ;
2007-02-17 00:52:37 +01:00
switch ( tft_type ) {
case ' p ' : /* production */
2007-10-16 01:28:56 -07:00
qt2410_fb_info . default_display = 1 ;
2007-02-17 00:52:37 +01:00
break ;
case ' b ' : /* big */
2007-10-16 01:28:56 -07:00
qt2410_fb_info . default_display = 0 ;
2007-02-17 00:52:37 +01:00
break ;
case ' s ' : /* small */
default :
2007-10-16 01:28:56 -07:00
qt2410_fb_info . default_display = 2 ;
2007-02-17 00:52:37 +01:00
break ;
}
2007-10-16 01:28:56 -07:00
s3c24xx_fb_set_platdata ( & qt2410_fb_info ) ;
2007-02-17 00:52:37 +01:00
2012-07-13 18:04:50 +09:00
/* set initial state of the LED GPIO */
WARN_ON ( gpio_request_one ( S3C2410_GPB ( 0 ) , GPIOF_OUT_INIT_HIGH , NULL ) ) ;
gpio_free ( S3C2410_GPB ( 0 ) ) ;
2007-02-17 00:52:37 +01:00
s3c24xx_udc_set_platdata ( & qt2410_udc_cfg ) ;
2008-10-31 16:14:40 +00:00
s3c_i2c0_set_platdata ( NULL ) ;
2007-02-17 00:52:37 +01:00
2010-05-04 12:32:16 +09:00
WARN_ON ( gpio_request ( S3C2410_GPB ( 5 ) , " spi cs " ) ) ;
gpio_direction_output ( S3C2410_GPB ( 5 ) , 1 ) ;
2007-02-17 00:52:37 +01:00
2007-04-20 11:19:16 +01:00
platform_add_devices ( qt2410_devices , ARRAY_SIZE ( qt2410_devices ) ) ;
2008-12-12 00:24:18 +00:00
s3c_pm_init ( ) ;
2007-02-17 00:52:37 +01:00
}
MACHINE_START ( QT2410 , " QT2410 " )
2011-07-05 22:38:17 -04:00
. atag_offset = 0x100 ,
2007-02-17 00:52:37 +01:00
. map_io = qt2410_map_io ,
. init_irq = s3c24xx_init_irq ,
. init_machine = qt2410_machine_init ,
. timer = & s3c24xx_timer ,
2012-01-03 14:02:03 +01:00
. restart = s3c2410_restart ,
2007-02-17 00:52:37 +01:00
MACHINE_END