2010-01-26 04:11:04 +03:00
/* linux/arch/arm/mach-s3c64xx/mach-smdk6410.c
2008-10-21 17:07:09 +04:00
*
* Copyright 2008 Openmoko , Inc .
* Copyright 2008 Simtec Electronics
* Ben Dooks < ben @ simtec . co . uk >
* http : //armlinux.simtec.co.uk/
*
* 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>
2010-06-22 02:39:18 +04:00
# include <linux/input.h>
2008-10-21 17:07:09 +04:00
# include <linux/serial_core.h>
# include <linux/platform_device.h>
# include <linux/io.h>
2008-10-31 19:14:59 +03:00
# include <linux/i2c.h>
2010-02-17 21:19:31 +03:00
# include <linux/leds.h>
2008-11-19 18:41:34 +03:00
# include <linux/fb.h>
# include <linux/gpio.h>
# include <linux/delay.h>
2009-01-27 19:18:01 +03:00
# include <linux/smsc911x.h>
2009-11-03 17:42:06 +03:00
# include <linux/regulator/fixed.h>
2011-03-04 01:59:20 +03:00
# include <linux/regulator/machine.h>
2011-02-28 15:12:35 +03:00
# include <linux/pwm_backlight.h>
2008-11-19 18:41:34 +03:00
2009-02-17 18:59:38 +03:00
# ifdef CONFIG_SMDK6410_WM1190_EV1
# include <linux/mfd/wm8350/core.h>
# include <linux/mfd/wm8350/pmic.h>
# endif
2008-11-19 18:41:34 +03:00
2010-02-17 21:19:29 +03:00
# ifdef CONFIG_SMDK6410_WM1192_EV1
2010-02-17 21:19:31 +03:00
# include <linux/mfd/wm831x/core.h>
2010-02-17 21:19:29 +03:00
# include <linux/mfd/wm831x/pdata.h>
# endif
2008-11-19 18:41:34 +03:00
# include <video/platform_lcd.h>
2008-10-21 17:07:09 +04:00
# include <asm/mach/arch.h>
# include <asm/mach/map.h>
# include <asm/mach/irq.h>
# include <mach/hardware.h>
2008-11-19 18:41:34 +03:00
# include <mach/regs-fb.h>
2008-10-21 17:07:09 +04:00
# include <mach/map.h>
2011-02-28 15:12:35 +03:00
# include <mach/gpio-bank-f.h>
2008-10-21 17:07:09 +04:00
# include <asm/irq.h>
# include <asm/mach-types.h>
# include <plat/regs-serial.h>
2010-01-26 04:45:40 +03:00
# include <mach/regs-modem.h>
# include <mach/regs-gpio.h>
# include <mach/regs-sys.h>
# include <mach/regs-srom.h>
2010-06-08 11:55:45 +04:00
# include <plat/ata.h>
2008-10-31 19:14:52 +03:00
# include <plat/iic.h>
2008-11-19 18:41:34 +03:00
# include <plat/fb.h>
2009-01-27 19:18:01 +03:00
# include <plat/gpio-cfg.h>
2008-10-21 17:07:09 +04:00
2010-01-26 07:41:30 +03:00
# include <mach/s3c6410.h>
2008-10-21 17:07:09 +04:00
# include <plat/clock.h>
# include <plat/devs.h>
# include <plat/cpu.h>
2010-05-20 06:39:52 +04:00
# include <plat/adc.h>
# include <plat/ts.h>
2010-06-22 02:39:18 +04:00
# include <plat/keypad.h>
2008-10-21 17:07:09 +04:00
# define UCON S3C2410_UCON_DEFAULT | S3C2410_UCON_UCLK
# define ULCON S3C2410_LCON_CS8 | S3C2410_LCON_PNONE | S3C2410_LCON_STOPB
# define UFCON S3C2410_UFCON_RXTRIG8 | S3C2410_UFCON_FIFOMODE
static struct s3c2410_uartcfg smdk6410_uartcfgs [ ] __initdata = {
[ 0 ] = {
. hwport = 0 ,
. flags = 0 ,
2009-06-29 15:03:41 +04:00
. ucon = UCON ,
. ulcon = ULCON ,
. ufcon = UFCON ,
2008-10-21 17:07:09 +04:00
} ,
[ 1 ] = {
. hwport = 1 ,
. flags = 0 ,
2009-06-29 15:03:41 +04:00
. ucon = UCON ,
. ulcon = ULCON ,
. ufcon = UFCON ,
} ,
[ 2 ] = {
. hwport = 2 ,
. flags = 0 ,
. ucon = UCON ,
. ulcon = ULCON ,
. ufcon = UFCON ,
} ,
[ 3 ] = {
. hwport = 3 ,
. flags = 0 ,
. ucon = UCON ,
. ulcon = ULCON ,
. ufcon = UFCON ,
2008-10-21 17:07:09 +04:00
} ,
} ;
2008-11-19 18:41:34 +03:00
/* framebuffer and LCD setup. */
/* GPF15 = LCD backlight control
* GPF13 = > Panel power
* GPN5 = LCD nRESET signal
* PWM_TOUT1 = > backlight brightness
*/
static void smdk6410_lcd_power_set ( struct plat_lcd_data * pd ,
unsigned int power )
{
if ( power ) {
gpio_direction_output ( S3C64XX_GPF ( 13 ) , 1 ) ;
/* fire nRESET on power up */
gpio_direction_output ( S3C64XX_GPN ( 5 ) , 0 ) ;
msleep ( 10 ) ;
gpio_direction_output ( S3C64XX_GPN ( 5 ) , 1 ) ;
msleep ( 1 ) ;
} else {
gpio_direction_output ( S3C64XX_GPF ( 13 ) , 0 ) ;
}
}
static struct plat_lcd_data smdk6410_lcd_power_data = {
. set_power = smdk6410_lcd_power_set ,
} ;
static struct platform_device smdk6410_lcd_powerdev = {
. name = " platform-lcd " ,
. dev . parent = & s3c_device_fb . dev ,
. dev . platform_data = & smdk6410_lcd_power_data ,
} ;
static struct s3c_fb_pd_win smdk6410_fb_win0 = {
/* this is to ensure we use win0 */
. win_mode = {
. left_margin = 8 ,
. right_margin = 13 ,
. upper_margin = 7 ,
. lower_margin = 5 ,
. hsync_len = 3 ,
. vsync_len = 1 ,
. xres = 800 ,
. yres = 480 ,
} ,
. max_bpp = 32 ,
. default_bpp = 16 ,
2010-07-26 13:56:40 +04:00
. virtual_y = 480 * 2 ,
. virtual_x = 800 ,
2008-11-19 18:41:34 +03:00
} ;
/* 405566 clocks per frame => 60Hz refresh requires 24333960Hz clock */
static struct s3c_fb_platdata smdk6410_lcd_pdata __initdata = {
. setup_gpio = s3c64xx_fb_gpio_setup_24bpp ,
. win [ 0 ] = & smdk6410_fb_win0 ,
. vidcon0 = VIDCON0_VIDOUT_RGB | VIDCON0_PNRMODE_RGB ,
. vidcon1 = VIDCON1_INV_HSYNC | VIDCON1_INV_VSYNC ,
} ;
2009-12-29 17:40:43 +03:00
/*
* Configuring Ethernet on SMDK6410
*
* Both CS8900A and LAN9115 chips share one chip select mediated by CFG6 .
* The constant address below corresponds to nCS1
*
* 1 ) Set CFGB2 p3 ON others off , no other CFGB selects " ethernet "
* 2 ) CFG6 needs to be switched to " LAN9115 " side
*/
2009-01-27 19:18:01 +03:00
static struct resource smdk6410_smsc911x_resources [ ] = {
[ 0 ] = {
2009-12-29 17:40:36 +03:00
. start = S3C64XX_PA_XM0CSN1 ,
. end = S3C64XX_PA_XM0CSN1 + SZ_64K - 1 ,
2009-01-27 19:18:01 +03:00
. flags = IORESOURCE_MEM ,
} ,
[ 1 ] = {
. start = S3C_EINT ( 10 ) ,
. end = S3C_EINT ( 10 ) ,
. flags = IORESOURCE_IRQ | IRQ_TYPE_LEVEL_LOW ,
} ,
} ;
static struct smsc911x_platform_config smdk6410_smsc911x_pdata = {
. irq_polarity = SMSC911X_IRQ_POLARITY_ACTIVE_LOW ,
. irq_type = SMSC911X_IRQ_TYPE_OPEN_DRAIN ,
. flags = SMSC911X_USE_32BIT | SMSC911X_FORCE_INTERNAL_PHY ,
. phy_interface = PHY_INTERFACE_MODE_MII ,
} ;
static struct platform_device smdk6410_smsc911x = {
. name = " smsc911x " ,
. id = - 1 ,
. num_resources = ARRAY_SIZE ( smdk6410_smsc911x_resources ) ,
. resource = & smdk6410_smsc911x_resources [ 0 ] ,
. dev = {
. platform_data = & smdk6410_smsc911x_pdata ,
} ,
} ;
2009-11-03 17:42:06 +03:00
# ifdef CONFIG_REGULATOR
static struct regulator_consumer_supply smdk6410_b_pwr_5v_consumers [ ] = {
{
/* WM8580 */
. supply = " PVDD " ,
. dev_name = " 0-001b " ,
} ,
{
/* WM8580 */
. supply = " AVDD " ,
. dev_name = " 0-001b " ,
} ,
} ;
static struct regulator_init_data smdk6410_b_pwr_5v_data = {
. constraints = {
. always_on = 1 ,
} ,
. num_consumer_supplies = ARRAY_SIZE ( smdk6410_b_pwr_5v_consumers ) ,
. consumer_supplies = smdk6410_b_pwr_5v_consumers ,
} ;
static struct fixed_voltage_config smdk6410_b_pwr_5v_pdata = {
. supply_name = " B_PWR_5V " ,
. microvolts = 5000000 ,
. init_data = & smdk6410_b_pwr_5v_data ,
2010-01-13 16:57:04 +03:00
. gpio = - EINVAL ,
2009-11-03 17:42:06 +03:00
} ;
static struct platform_device smdk6410_b_pwr_5v = {
. name = " reg-fixed-voltage " ,
. id = - 1 ,
. dev = {
. platform_data = & smdk6410_b_pwr_5v_pdata ,
} ,
} ;
# endif
2010-06-08 11:55:45 +04:00
static struct s3c_ide_platdata smdk6410_ide_pdata __initdata = {
. setup_gpio = s3c64xx_ide_setup_gpio ,
} ;
2010-06-22 02:39:18 +04:00
static uint32_t smdk6410_keymap [ ] __initdata = {
/* KEY(row, col, keycode) */
KEY ( 0 , 3 , KEY_1 ) , KEY ( 0 , 4 , KEY_2 ) , KEY ( 0 , 5 , KEY_3 ) ,
KEY ( 0 , 6 , KEY_4 ) , KEY ( 0 , 7 , KEY_5 ) ,
KEY ( 1 , 3 , KEY_A ) , KEY ( 1 , 4 , KEY_B ) , KEY ( 1 , 5 , KEY_C ) ,
KEY ( 1 , 6 , KEY_D ) , KEY ( 1 , 7 , KEY_E )
} ;
static struct matrix_keymap_data smdk6410_keymap_data __initdata = {
. keymap = smdk6410_keymap ,
. keymap_size = ARRAY_SIZE ( smdk6410_keymap ) ,
} ;
static struct samsung_keypad_platdata smdk6410_keypad_data __initdata = {
. keymap_data = & smdk6410_keymap_data ,
. rows = 2 ,
. cols = 8 ,
} ;
2011-02-28 15:12:35 +03:00
static int smdk6410_backlight_init ( struct device * dev )
{
int ret ;
ret = gpio_request ( S3C64XX_GPF ( 15 ) , " Backlight " ) ;
if ( ret ) {
printk ( KERN_ERR " failed to request GPF for PWM-OUT1 \n " ) ;
return ret ;
}
/* Configure GPIO pin with S3C64XX_GPF15_PWM_TOUT1 */
s3c_gpio_cfgpin ( S3C64XX_GPF ( 15 ) , S3C_GPIO_SFN ( 2 ) ) ;
return 0 ;
}
static void smdk6410_backlight_exit ( struct device * dev )
{
s3c_gpio_cfgpin ( S3C64XX_GPF ( 15 ) , S3C_GPIO_OUTPUT ) ;
gpio_free ( S3C64XX_GPF ( 15 ) ) ;
}
static struct platform_pwm_backlight_data smdk6410_backlight_data = {
. pwm_id = 1 ,
. max_brightness = 255 ,
. dft_brightness = 255 ,
. pwm_period_ns = 78770 ,
. init = smdk6410_backlight_init ,
. exit = smdk6410_backlight_exit ,
} ;
static struct platform_device smdk6410_backlight_device = {
. name = " pwm-backlight " ,
. dev = {
. parent = & s3c_device_timer [ 1 ] . dev ,
. platform_data = & smdk6410_backlight_data ,
} ,
} ;
2009-01-23 19:29:43 +03:00
static struct map_desc smdk6410_iodesc [ ] = { } ;
2008-10-21 17:07:09 +04:00
static struct platform_device * smdk6410_devices [ ] __initdata = {
2008-11-03 23:14:53 +03:00
# ifdef CONFIG_SMDK6410_SD_CH0
2008-10-31 19:14:29 +03:00
& s3c_device_hsmmc0 ,
2008-11-03 23:14:53 +03:00
# endif
# ifdef CONFIG_SMDK6410_SD_CH1
& s3c_device_hsmmc1 ,
# endif
2008-10-31 19:14:52 +03:00
& s3c_device_i2c0 ,
2008-10-31 19:14:57 +03:00
& s3c_device_i2c1 ,
2008-11-19 18:41:34 +03:00
& s3c_device_fb ,
2009-11-23 03:13:39 +03:00
& s3c_device_ohci ,
2009-05-17 01:11:20 +04:00
& s3c_device_usb_hsotg ,
2010-11-22 09:35:53 +03:00
& samsung_asoc_dma ,
2010-02-17 22:03:20 +03:00
& s3c64xx_device_iisv4 ,
2010-06-22 02:39:18 +04:00
& samsung_device_keypad ,
2009-11-03 17:42:06 +03:00
# ifdef CONFIG_REGULATOR
& smdk6410_b_pwr_5v ,
# endif
2008-11-19 18:41:34 +03:00
& smdk6410_lcd_powerdev ,
2009-01-27 19:18:01 +03:00
& smdk6410_smsc911x ,
2010-05-20 06:39:52 +04:00
& s3c_device_adc ,
2010-06-08 11:55:45 +04:00
& s3c_device_cfcon ,
2010-07-20 15:01:32 +04:00
& s3c_device_rtc ,
2010-05-20 06:39:52 +04:00
& s3c_device_ts ,
2010-05-20 11:21:30 +04:00
& s3c_device_wdt ,
2011-02-28 15:12:35 +03:00
& s3c_device_timer [ 1 ] ,
& smdk6410_backlight_device ,
2008-10-21 17:07:09 +04:00
} ;
2010-02-17 21:19:29 +03:00
# ifdef CONFIG_REGULATOR
/* ARM core */
static struct regulator_consumer_supply smdk6410_vddarm_consumers [ ] = {
{
. supply = " vddarm " ,
}
} ;
/* VDDARM, BUCK1 on J5 */
static struct regulator_init_data smdk6410_vddarm = {
2009-02-17 18:59:38 +03:00
. constraints = {
2010-02-17 21:19:29 +03:00
. name = " PVDD_ARM " ,
. min_uV = 1000000 ,
. max_uV = 1300000 ,
. always_on = 1 ,
. valid_ops_mask = REGULATOR_CHANGE_VOLTAGE ,
} ,
. num_consumer_supplies = ARRAY_SIZE ( smdk6410_vddarm_consumers ) ,
. consumer_supplies = smdk6410_vddarm_consumers ,
} ;
/* VDD_INT, BUCK2 on J5 */
static struct regulator_init_data smdk6410_vddint = {
. constraints = {
. name = " PVDD_INT " ,
. min_uV = 1000000 ,
2009-02-17 18:59:38 +03:00
. max_uV = 1200000 ,
. always_on = 1 ,
2010-02-17 21:19:29 +03:00
. valid_ops_mask = REGULATOR_CHANGE_VOLTAGE ,
2009-02-17 18:59:38 +03:00
} ,
} ;
2010-02-17 21:19:29 +03:00
/* VDD_HI, LDO3 on J5 */
static struct regulator_init_data smdk6410_vddhi = {
2009-02-17 18:59:38 +03:00
. constraints = {
2010-02-17 21:19:29 +03:00
. name = " PVDD_HI " ,
2009-02-17 18:59:38 +03:00
. always_on = 1 ,
} ,
} ;
2010-02-17 21:19:29 +03:00
/* VDD_PLL, LDO2 on J5 */
static struct regulator_init_data smdk6410_vddpll = {
. constraints = {
. name = " PVDD_PLL " ,
. always_on = 1 ,
2009-11-03 17:42:06 +03:00
} ,
} ;
2010-02-17 21:19:29 +03:00
/* VDD_UH_MMC, LDO5 on J5 */
static struct regulator_init_data smdk6410_vdduh_mmc = {
2009-02-17 18:59:38 +03:00
. constraints = {
2011-03-04 02:24:15 +03:00
. name = " PVDD_UH+PVDD_MMC " ,
2009-02-17 18:59:38 +03:00
. always_on = 1 ,
} ,
} ;
2010-02-17 21:19:29 +03:00
/* VCCM3BT, LDO8 on J5 */
static struct regulator_init_data smdk6410_vccmc3bt = {
. constraints = {
. name = " PVCCM3BT " ,
. always_on = 1 ,
} ,
2009-04-15 20:11:53 +04:00
} ;
2010-02-17 21:19:29 +03:00
/* VCCM2MTV, LDO11 on J5 */
static struct regulator_init_data smdk6410_vccm2mtv = {
2009-02-17 18:59:38 +03:00
. constraints = {
2010-02-17 21:19:29 +03:00
. name = " PVCCM2MTV " ,
. always_on = 1 ,
} ,
} ;
/* VDD_LCD, LDO12 on J5 */
static struct regulator_init_data smdk6410_vddlcd = {
. constraints = {
. name = " PVDD_LCD " ,
. always_on = 1 ,
} ,
} ;
/* VDD_OTGI, LDO9 on J5 */
static struct regulator_init_data smdk6410_vddotgi = {
. constraints = {
. name = " PVDD_OTGI " ,
. always_on = 1 ,
} ,
} ;
/* VDD_OTG, LDO14 on J5 */
static struct regulator_init_data smdk6410_vddotg = {
. constraints = {
. name = " PVDD_OTG " ,
2009-02-17 18:59:38 +03:00
. always_on = 1 ,
} ,
2008-10-21 17:07:09 +04:00
} ;
2010-02-17 21:19:29 +03:00
/* VDD_ALIVE, LDO15 on J5 */
static struct regulator_init_data smdk6410_vddalive = {
2009-02-17 18:59:38 +03:00
. constraints = {
. name = " PVDD_ALIVE " ,
2010-02-17 21:19:29 +03:00
. always_on = 1 ,
} ,
} ;
/* VDD_AUDIO, VLDO_AUDIO on J5 */
static struct regulator_init_data smdk6410_vddaudio = {
. constraints = {
. name = " PVDD_AUDIO " ,
. always_on = 1 ,
} ,
} ;
# endif
# ifdef CONFIG_SMDK6410_WM1190_EV1
/* S3C64xx internal logic & PLL */
static struct regulator_init_data wm8350_dcdc1_data = {
. constraints = {
2011-03-04 02:24:15 +03:00
. name = " PVDD_INT+PVDD_PLL " ,
2009-02-17 18:59:38 +03:00
. min_uV = 1200000 ,
. max_uV = 1200000 ,
. always_on = 1 ,
. apply_uV = 1 ,
} ,
} ;
2010-02-17 21:19:29 +03:00
/* Memory */
static struct regulator_init_data wm8350_dcdc3_data = {
2009-02-17 18:59:38 +03:00
. constraints = {
2010-02-17 21:19:29 +03:00
. name = " PVDD_MEM " ,
. min_uV = 1800000 ,
. max_uV = 1800000 ,
2009-04-09 19:30:40 +04:00
. always_on = 1 ,
2010-02-17 21:19:29 +03:00
. state_mem = {
. uV = 1800000 ,
. mode = REGULATOR_MODE_NORMAL ,
. enabled = 1 ,
} ,
. initial_state = PM_SUSPEND_MEM ,
2009-02-17 18:59:38 +03:00
} ,
} ;
2010-02-17 21:19:29 +03:00
/* USB, EXT, PCM, ADC/DAC, USB, MMC */
static struct regulator_consumer_supply wm8350_dcdc4_consumers [ ] = {
{
/* WM8580 */
. supply = " DVDD " ,
. dev_name = " 0-001b " ,
} ,
} ;
static struct regulator_init_data wm8350_dcdc4_data = {
2009-02-17 18:59:38 +03:00
. constraints = {
2011-03-04 02:24:15 +03:00
. name = " PVDD_HI+PVDD_EXT+PVDD_SYS+PVCCM2MTV " ,
2009-02-17 18:59:38 +03:00
. min_uV = 3000000 ,
. max_uV = 3000000 ,
2009-04-09 19:30:40 +04:00
. always_on = 1 ,
2009-02-17 18:59:38 +03:00
} ,
2010-02-17 21:19:29 +03:00
. num_consumer_supplies = ARRAY_SIZE ( wm8350_dcdc4_consumers ) ,
. consumer_supplies = wm8350_dcdc4_consumers ,
2009-02-17 18:59:38 +03:00
} ;
/* OTGi/1190-EV1 HPVDD & AVDD */
static struct regulator_init_data wm8350_ldo4_data = {
. constraints = {
2011-03-04 02:24:15 +03:00
. name = " PVDD_OTGI+HPVDD+AVDD " ,
2009-02-17 18:59:38 +03:00
. min_uV = 1200000 ,
. max_uV = 1200000 ,
. apply_uV = 1 ,
2009-04-09 19:30:40 +04:00
. always_on = 1 ,
2009-02-17 18:59:38 +03:00
} ,
} ;
static struct {
int regulator ;
struct regulator_init_data * initdata ;
} wm1190_regulators [ ] = {
{ WM8350_DCDC_1 , & wm8350_dcdc1_data } ,
{ WM8350_DCDC_3 , & wm8350_dcdc3_data } ,
{ WM8350_DCDC_4 , & wm8350_dcdc4_data } ,
2010-02-17 21:19:29 +03:00
{ WM8350_DCDC_6 , & smdk6410_vddarm } ,
{ WM8350_LDO_1 , & smdk6410_vddalive } ,
{ WM8350_LDO_2 , & smdk6410_vddotg } ,
{ WM8350_LDO_3 , & smdk6410_vddlcd } ,
2009-02-17 18:59:38 +03:00
{ WM8350_LDO_4 , & wm8350_ldo4_data } ,
} ;
static int __init smdk6410_wm8350_init ( struct wm8350 * wm8350 )
{
int i ;
2009-11-03 17:42:04 +03:00
/* Configure the IRQ line */
s3c_gpio_setpull ( S3C64XX_GPN ( 12 ) , S3C_GPIO_PULL_UP ) ;
2009-02-17 18:59:38 +03:00
/* Instantiate the regulators */
for ( i = 0 ; i < ARRAY_SIZE ( wm1190_regulators ) ; i + + )
wm8350_register_regulator ( wm8350 ,
wm1190_regulators [ i ] . regulator ,
wm1190_regulators [ i ] . initdata ) ;
return 0 ;
}
static struct wm8350_platform_data __initdata smdk6410_wm8350_pdata = {
. init = smdk6410_wm8350_init ,
2009-04-09 22:00:19 +04:00
. irq_high = 1 ,
2010-01-19 18:26:56 +03:00
. irq_base = IRQ_BOARD_START ,
2009-02-17 18:59:38 +03:00
} ;
# endif
2010-02-17 21:19:29 +03:00
# ifdef CONFIG_SMDK6410_WM1192_EV1
2010-02-17 21:19:31 +03:00
static struct gpio_led wm1192_pmic_leds [ ] = {
{
. name = " PMIC:red:power " ,
. gpio = GPIO_BOARD_START + 3 ,
. default_state = LEDS_GPIO_DEFSTATE_ON ,
} ,
} ;
static struct gpio_led_platform_data wm1192_pmic_led = {
. num_leds = ARRAY_SIZE ( wm1192_pmic_leds ) ,
. leds = wm1192_pmic_leds ,
} ;
static struct platform_device wm1192_pmic_led_dev = {
. name = " leds-gpio " ,
. id = - 1 ,
. dev = {
. platform_data = & wm1192_pmic_led ,
} ,
} ;
2010-02-17 21:19:29 +03:00
static int wm1192_pre_init ( struct wm831x * wm831x )
{
2010-02-17 21:19:31 +03:00
int ret ;
2010-02-17 21:19:29 +03:00
/* Configure the IRQ line */
s3c_gpio_setpull ( S3C64XX_GPN ( 12 ) , S3C_GPIO_PULL_UP ) ;
2010-02-17 21:19:31 +03:00
ret = platform_device_register ( & wm1192_pmic_led_dev ) ;
if ( ret ! = 0 )
dev_err ( wm831x - > dev , " Failed to add PMIC LED: %d \n " , ret ) ;
2010-02-17 21:19:29 +03:00
return 0 ;
}
static struct wm831x_backlight_pdata wm1192_backlight_pdata = {
. isink = 1 ,
. max_uA = 27554 ,
} ;
static struct regulator_init_data wm1192_dcdc3 = {
. constraints = {
2011-03-04 02:24:15 +03:00
. name = " PVDD_MEM+PVDD_GPS " ,
2010-02-17 21:19:29 +03:00
. always_on = 1 ,
} ,
} ;
static struct regulator_consumer_supply wm1192_ldo1_consumers [ ] = {
{ . supply = " DVDD " , . dev_name = " 0-001b " , } , /* WM8580 */
} ;
static struct regulator_init_data wm1192_ldo1 = {
. constraints = {
2011-03-04 02:24:15 +03:00
. name = " PVDD_LCD+PVDD_EXT " ,
2010-02-17 21:19:29 +03:00
. always_on = 1 ,
} ,
. consumer_supplies = wm1192_ldo1_consumers ,
. num_consumer_supplies = ARRAY_SIZE ( wm1192_ldo1_consumers ) ,
} ;
static struct wm831x_status_pdata wm1192_led7_pdata = {
. name = " LED7:green: " ,
} ;
static struct wm831x_status_pdata wm1192_led8_pdata = {
. name = " LED8:green: " ,
} ;
static struct wm831x_pdata smdk6410_wm1192_pdata = {
. pre_init = wm1192_pre_init ,
. irq_base = IRQ_BOARD_START ,
. backlight = & wm1192_backlight_pdata ,
. dcdc = {
& smdk6410_vddarm , /* DCDC1 */
& smdk6410_vddint , /* DCDC2 */
& wm1192_dcdc3 ,
} ,
2010-02-17 21:19:31 +03:00
. gpio_base = GPIO_BOARD_START ,
2010-02-17 21:19:29 +03:00
. ldo = {
& wm1192_ldo1 , /* LDO1 */
& smdk6410_vdduh_mmc , /* LDO2 */
NULL , /* LDO3 NC */
& smdk6410_vddotgi , /* LDO4 */
& smdk6410_vddotg , /* LDO5 */
& smdk6410_vddhi , /* LDO6 */
& smdk6410_vddaudio , /* LDO7 */
& smdk6410_vccm2mtv , /* LDO8 */
& smdk6410_vddpll , /* LDO9 */
& smdk6410_vccmc3bt , /* LDO10 */
& smdk6410_vddalive , /* LDO11 */
} ,
. status = {
& wm1192_led7_pdata ,
& wm1192_led8_pdata ,
} ,
} ;
# endif
2008-10-31 19:14:59 +03:00
static struct i2c_board_info i2c_devs0 [ ] __initdata = {
{ I2C_BOARD_INFO ( " 24c08 " , 0x50 ) , } ,
2009-01-23 19:29:41 +03:00
{ I2C_BOARD_INFO ( " wm8580 " , 0x1b ) , } ,
2009-02-17 18:59:38 +03:00
2010-02-17 21:19:29 +03:00
# ifdef CONFIG_SMDK6410_WM1192_EV1
{ I2C_BOARD_INFO ( " wm8312 " , 0x34 ) ,
. platform_data = & smdk6410_wm1192_pdata ,
. irq = S3C_EINT ( 12 ) ,
} ,
# endif
2009-02-17 18:59:38 +03:00
# ifdef CONFIG_SMDK6410_WM1190_EV1
{ I2C_BOARD_INFO ( " wm8350 " , 0x1a ) ,
. platform_data = & smdk6410_wm8350_pdata ,
. irq = S3C_EINT ( 12 ) ,
} ,
# endif
2008-10-31 19:14:59 +03:00
} ;
static struct i2c_board_info i2c_devs1 [ ] __initdata = {
{ I2C_BOARD_INFO ( " 24c128 " , 0x57 ) , } , /* Samsung S524AD0XD1 */
2008-10-21 17:07:09 +04:00
} ;
2010-05-20 06:39:52 +04:00
static struct s3c2410_ts_mach_info s3c_ts_platform __initdata = {
. delay = 10000 ,
. presc = 49 ,
. oversampling_shift = 2 ,
} ;
2008-10-21 17:07:09 +04:00
static void __init smdk6410_map_io ( void )
{
2008-12-12 03:24:40 +03:00
u32 tmp ;
2008-10-21 17:07:09 +04:00
s3c64xx_init_io ( smdk6410_iodesc , ARRAY_SIZE ( smdk6410_iodesc ) ) ;
s3c24xx_init_clocks ( 12000000 ) ;
s3c24xx_init_uarts ( smdk6410_uartcfgs , ARRAY_SIZE ( smdk6410_uartcfgs ) ) ;
2008-12-12 03:24:40 +03:00
/* set the LCD type */
tmp = __raw_readl ( S3C64XX_SPCON ) ;
tmp & = ~ S3C64XX_SPCON_LCD_SEL_MASK ;
tmp | = S3C64XX_SPCON_LCD_SEL_RGB ;
__raw_writel ( tmp , S3C64XX_SPCON ) ;
/* remove the lcd bypass */
tmp = __raw_readl ( S3C64XX_MODEM_MIFPCON ) ;
tmp & = ~ MIFPCON_LCD_BYPASS ;
__raw_writel ( tmp , S3C64XX_MODEM_MIFPCON ) ;
2008-10-21 17:07:09 +04:00
}
static void __init smdk6410_machine_init ( void )
{
2009-12-29 17:40:36 +03:00
u32 cs1 ;
2008-10-31 19:14:52 +03:00
s3c_i2c0_set_platdata ( NULL ) ;
2008-10-31 19:14:57 +03:00
s3c_i2c1_set_platdata ( NULL ) ;
2008-11-19 18:41:34 +03:00
s3c_fb_set_platdata ( & smdk6410_lcd_pdata ) ;
2008-10-31 19:14:59 +03:00
2010-06-22 02:39:18 +04:00
samsung_keypad_set_platdata ( & smdk6410_keypad_data ) ;
2010-05-20 06:39:52 +04:00
s3c24xx_ts_set_platdata ( & s3c_ts_platform ) ;
2009-12-29 17:40:36 +03:00
/* configure nCS1 width to 16 bits */
cs1 = __raw_readl ( S3C64XX_SROM_BW ) &
~ ( S3C64XX_SROM_BW__CS_MASK < < S3C64XX_SROM_BW__NCS1__SHIFT ) ;
cs1 | = ( ( 1 < < S3C64XX_SROM_BW__DATAWIDTH__SHIFT ) |
( 1 < < S3C64XX_SROM_BW__WAITENABLE__SHIFT ) |
( 1 < < S3C64XX_SROM_BW__BYTEENABLE__SHIFT ) ) < <
S3C64XX_SROM_BW__NCS1__SHIFT ;
__raw_writel ( cs1 , S3C64XX_SROM_BW ) ;
/* set timing for nCS1 suitable for ethernet chip */
__raw_writel ( ( 0 < < S3C64XX_SROM_BCX__PMC__SHIFT ) |
( 6 < < S3C64XX_SROM_BCX__TACP__SHIFT ) |
( 4 < < S3C64XX_SROM_BCX__TCAH__SHIFT ) |
( 1 < < S3C64XX_SROM_BCX__TCOH__SHIFT ) |
( 0xe < < S3C64XX_SROM_BCX__TACC__SHIFT ) |
( 4 < < S3C64XX_SROM_BCX__TCOS__SHIFT ) |
( 0 < < S3C64XX_SROM_BCX__TACS__SHIFT ) , S3C64XX_SROM_BC1 ) ;
2009-04-08 19:12:35 +04:00
gpio_request ( S3C64XX_GPN ( 5 ) , " LCD power " ) ;
gpio_request ( S3C64XX_GPF ( 13 ) , " LCD power " ) ;
2008-10-31 19:14:59 +03:00
i2c_register_board_info ( 0 , i2c_devs0 , ARRAY_SIZE ( i2c_devs0 ) ) ;
i2c_register_board_info ( 1 , i2c_devs1 , ARRAY_SIZE ( i2c_devs1 ) ) ;
2010-06-08 11:55:45 +04:00
s3c_ide_set_platdata ( & smdk6410_ide_pdata ) ;
2008-10-21 17:07:09 +04:00
platform_add_devices ( smdk6410_devices , ARRAY_SIZE ( smdk6410_devices ) ) ;
}
MACHINE_START ( SMDK6410 , " SMDK6410 " )
2010-05-07 04:24:05 +04:00
/* Maintainer: Ben Dooks <ben-linux@fluff.org> */
2008-10-21 17:07:09 +04:00
. boot_params = S3C64XX_PA_SDRAM + 0x100 ,
. init_irq = s3c6410_init_irq ,
. map_io = smdk6410_map_io ,
. init_machine = smdk6410_machine_init ,
. timer = & s3c24xx_timer ,
MACHINE_END