2017-12-25 20:54:33 +01:00
// SPDX-License-Identifier: GPL-2.0
//
// Copyright 2011 Wolfson Microelectronics plc
// Mark Brown <broonie@opensource.wolfsonmicro.com>
//
// Copyright 2011 Simtec Electronics
// Ben Dooks <ben@simtec.co.uk>
2011-05-06 09:45:13 +09:00
# include <linux/kernel.h>
# include <linux/list.h>
# include <linux/serial_core.h>
2014-02-14 10:32:45 +09:00
# include <linux/serial_s3c.h>
2011-05-06 09:45:13 +09:00
# include <linux/platform_device.h>
# include <linux/fb.h>
# include <linux/io.h>
# include <linux/init.h>
2022-10-28 09:48:00 -07:00
# include <linux/input-event-codes.h>
2011-05-06 09:45:13 +09:00
# include <linux/gpio.h>
2019-06-12 09:42:22 +02:00
# include <linux/gpio/machine.h>
2011-12-29 18:05:29 +09:00
# include <linux/leds.h>
2011-05-06 09:45:13 +09:00
# include <linux/delay.h>
2011-12-30 13:44:31 +09:00
# include <linux/mmc/host.h>
2011-05-06 09:45:13 +09:00
# include <linux/regulator/machine.h>
2011-06-22 13:08:13 +09:00
# include <linux/regulator/fixed.h>
2015-10-13 05:04:22 +09:00
# include <linux/pwm.h>
2011-05-06 09:45:13 +09:00
# include <linux/pwm_backlight.h>
# include <linux/dm9000.h>
# include <linux/gpio_keys.h>
2015-12-04 14:02:58 +01:00
# include <linux/gpio/driver.h>
2011-05-06 09:45:13 +09:00
# include <linux/spi/spi.h>
2013-08-29 15:24:14 -04:00
# include <linux/platform_data/pca953x.h>
2012-05-09 13:16:53 +02:00
# include <linux/platform_data/s3c-hsotg.h>
2011-05-06 09:45:13 +09:00
# include <video/platform_lcd.h>
# include <linux/mfd/wm831x/core.h>
# include <linux/mfd/wm831x/pdata.h>
2011-06-22 13:08:13 +09:00
# include <linux/mfd/wm831x/irq.h>
2011-05-06 09:45:13 +09:00
# include <linux/mfd/wm831x/gpio.h>
2011-12-02 14:29:07 +09:00
# include <sound/wm1250-ev1.h>
2011-05-06 09:45:13 +09:00
# include <asm/mach/arch.h>
# include <asm/mach-types.h>
2012-08-08 09:44:49 +09:00
# include <video/samsung_fimd.h>
2019-09-02 18:37:30 +02:00
# include "map.h"
# include "regs-gpio.h"
# include "gpio-samsung.h"
2022-04-02 15:28:18 +02:00
# include "irqs.h"
2011-05-06 09:45:13 +09:00
2019-09-02 18:37:30 +02:00
# include "fb.h"
# include "sdhci.h"
# include "gpio-cfg.h"
2012-08-24 15:22:12 +02:00
# include <linux/platform_data/spi-s3c64xx.h>
2011-05-06 09:45:13 +09:00
2019-09-02 18:37:30 +02:00
# include "keypad.h"
# include "devs.h"
# include "cpu.h"
2020-08-06 20:20:39 +02:00
# include <linux/soc/samsung/s3c-adc.h>
2012-08-24 15:22:12 +02:00
# include <linux/platform_data/i2c-s3c2410.h>
2019-09-02 18:37:30 +02:00
# include "pm.h"
2011-05-06 09:45:13 +09:00
2019-09-02 17:47:55 +02:00
# include "s3c64xx.h"
2013-01-02 11:18:31 -08:00
# include "crag6410.h"
2019-09-02 17:47:55 +02:00
# include "regs-gpio-memport-s3c64xx.h"
# include "regs-modem-s3c64xx.h"
# include "regs-sys-s3c64xx.h"
2011-12-22 23:27:42 +01:00
2011-05-06 09:45:13 +09:00
/* serial port setup */
# 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 crag6410_uartcfgs [ ] __initdata = {
[ 0 ] = {
2011-06-22 13:08:13 +09:00
. hwport = 0 ,
. flags = 0 ,
. ucon = UCON ,
. ulcon = ULCON ,
. ufcon = UFCON ,
2011-05-06 09:45:13 +09:00
} ,
[ 1 ] = {
2011-06-22 13:08:13 +09:00
. hwport = 1 ,
. flags = 0 ,
. ucon = UCON ,
. ulcon = ULCON ,
. ufcon = UFCON ,
2011-05-06 09:45:13 +09:00
} ,
[ 2 ] = {
2011-06-22 13:08:13 +09:00
. hwport = 2 ,
. flags = 0 ,
. ucon = UCON ,
. ulcon = ULCON ,
. ufcon = UFCON ,
2011-05-06 09:45:13 +09:00
} ,
[ 3 ] = {
2011-06-22 13:08:13 +09:00
. hwport = 3 ,
. flags = 0 ,
. ucon = UCON ,
. ulcon = ULCON ,
. ufcon = UFCON ,
2011-05-06 09:45:13 +09:00
} ,
} ;
2015-10-13 05:04:22 +09:00
static struct pwm_lookup crag6410_pwm_lookup [ ] = {
PWM_LOOKUP ( " samsung-pwm " , 0 , " pwm-backlight " , NULL , 100000 ,
PWM_POLARITY_NORMAL ) ,
} ;
2011-05-06 09:45:13 +09:00
static struct platform_pwm_backlight_data crag6410_backlight_data = {
. max_brightness = 1000 ,
. dft_brightness = 600 ,
} ;
static struct platform_device crag6410_backlight_device = {
. name = " pwm-backlight " ,
. id = - 1 ,
. dev = {
2013-03-09 15:37:53 +01:00
. parent = & samsung_device_pwm . dev ,
2011-05-06 09:45:13 +09:00
. platform_data = & crag6410_backlight_data ,
} ,
} ;
static void crag6410_lcd_power_set ( struct plat_lcd_data * pd , unsigned int power )
{
pr_debug ( " %s: setting power %d \n " , __func__ , power ) ;
if ( power ) {
gpio_set_value ( S3C64XX_GPB ( 0 ) , 1 ) ;
msleep ( 1 ) ;
s3c_gpio_cfgpin ( S3C64XX_GPF ( 14 ) , S3C_GPIO_SFN ( 2 ) ) ;
} else {
gpio_direction_output ( S3C64XX_GPF ( 14 ) , 0 ) ;
gpio_set_value ( S3C64XX_GPB ( 0 ) , 0 ) ;
}
}
static struct platform_device crag6410_lcd_powerdev = {
. name = " platform-lcd " ,
. id = - 1 ,
. dev . parent = & s3c_device_fb . dev ,
. dev . platform_data = & ( struct plat_lcd_data ) {
. set_power = crag6410_lcd_power_set ,
} ,
} ;
/* 640x480 URT */
static struct s3c_fb_pd_win crag6410_fb_win0 = {
. max_bpp = 32 ,
. default_bpp = 16 ,
2012-03-24 21:58:48 +05:30
. xres = 640 ,
. yres = 480 ,
2011-05-06 09:45:13 +09:00
. virtual_y = 480 * 2 ,
. virtual_x = 640 ,
} ;
2012-03-24 21:58:48 +05:30
static struct fb_videomode crag6410_lcd_timing = {
. left_margin = 150 ,
. right_margin = 80 ,
. upper_margin = 40 ,
. lower_margin = 5 ,
. hsync_len = 40 ,
. vsync_len = 5 ,
. xres = 640 ,
. yres = 480 ,
} ;
2011-05-06 09:45:13 +09:00
/* 405566 clocks per frame => 60Hz refresh requires 24333960Hz clock */
2012-12-21 14:02:24 -08:00
static struct s3c_fb_platdata crag6410_lcd_pdata = {
2011-05-06 09:45:13 +09:00
. setup_gpio = s3c64xx_fb_gpio_setup_24bpp ,
2012-03-24 21:58:48 +05:30
. vtiming = & crag6410_lcd_timing ,
2011-05-06 09:45:13 +09:00
. win [ 0 ] = & crag6410_fb_win0 ,
. vidcon0 = VIDCON0_VIDOUT_RGB | VIDCON0_PNRMODE_RGB ,
. vidcon1 = VIDCON1_INV_HSYNC | VIDCON1_INV_VSYNC ,
} ;
/* 2x6 keypad */
2012-12-21 14:02:24 -08:00
static uint32_t crag6410_keymap [ ] = {
2011-05-06 09:45:13 +09:00
/* KEY(row, col, keycode) */
KEY ( 0 , 0 , KEY_VOLUMEUP ) ,
KEY ( 0 , 1 , KEY_HOME ) ,
KEY ( 0 , 2 , KEY_VOLUMEDOWN ) ,
KEY ( 0 , 3 , KEY_HELP ) ,
KEY ( 0 , 4 , KEY_MENU ) ,
KEY ( 0 , 5 , KEY_MEDIA ) ,
KEY ( 1 , 0 , 232 ) ,
KEY ( 1 , 1 , KEY_DOWN ) ,
KEY ( 1 , 2 , KEY_LEFT ) ,
KEY ( 1 , 3 , KEY_UP ) ,
KEY ( 1 , 4 , KEY_RIGHT ) ,
KEY ( 1 , 5 , KEY_CAMERA ) ,
} ;
2012-12-21 14:02:24 -08:00
static struct matrix_keymap_data crag6410_keymap_data = {
2011-05-06 09:45:13 +09:00
. keymap = crag6410_keymap ,
. keymap_size = ARRAY_SIZE ( crag6410_keymap ) ,
} ;
2012-12-21 14:02:24 -08:00
static struct samsung_keypad_platdata crag6410_keypad_data = {
2011-05-06 09:45:13 +09:00
. keymap_data = & crag6410_keymap_data ,
. rows = 2 ,
. cols = 6 ,
} ;
static struct gpio_keys_button crag6410_gpio_keys [ ] = {
[ 0 ] = {
. code = KEY_SUSPEND ,
. gpio = S3C64XX_GPL ( 10 ) , /* EINT 18 */
2011-06-22 13:08:13 +09:00
. type = EV_KEY ,
2011-05-06 09:45:13 +09:00
. wakeup = 1 ,
. active_low = 1 ,
} ,
2011-06-22 13:08:13 +09:00
[ 1 ] = {
. code = SW_FRONT_PROXIMITY ,
. gpio = S3C64XX_GPN ( 11 ) , /* EINT 11 */
. type = EV_SW ,
} ,
2011-05-06 09:45:13 +09:00
} ;
static struct gpio_keys_platform_data crag6410_gpio_keydata = {
. buttons = crag6410_gpio_keys ,
. nbuttons = ARRAY_SIZE ( crag6410_gpio_keys ) ,
} ;
static struct platform_device crag6410_gpio_keydev = {
. name = " gpio-keys " ,
. id = 0 ,
. dev . platform_data = & crag6410_gpio_keydata ,
} ;
static struct resource crag6410_dm9k_resource [ ] = {
2012-05-12 16:12:26 +09:00
[ 0 ] = DEFINE_RES_MEM ( S3C64XX_PA_XM0CSN5 , 2 ) ,
[ 1 ] = DEFINE_RES_MEM ( S3C64XX_PA_XM0CSN5 + ( 1 < < 8 ) , 2 ) ,
[ 2 ] = DEFINE_RES_NAMED ( S3C_EINT ( 17 ) , 1 , NULL , IORESOURCE_IRQ \
| IORESOURCE_IRQ_HIGHLEVEL ) ,
2011-05-06 09:45:13 +09:00
} ;
static struct dm9000_plat_data mini6410_dm9k_pdata = {
. flags = DM9000_PLATF_16BITONLY ,
} ;
static struct platform_device crag6410_dm9k_device = {
. name = " dm9000 " ,
. id = - 1 ,
. num_resources = ARRAY_SIZE ( crag6410_dm9k_resource ) ,
. resource = crag6410_dm9k_resource ,
. dev . platform_data = & mini6410_dm9k_pdata ,
} ;
static struct resource crag6410_mmgpio_resource [ ] = {
2012-05-12 16:12:26 +09:00
[ 0 ] = DEFINE_RES_MEM_NAMED ( S3C64XX_PA_XM0CSN4 , 1 , " dat " ) ,
2011-05-06 09:45:13 +09:00
} ;
static struct platform_device crag6410_mmgpio = {
. name = " basic-mmio-gpio " ,
. id = - 1 ,
. resource = crag6410_mmgpio_resource ,
. num_resources = ARRAY_SIZE ( crag6410_mmgpio_resource ) ,
. dev . platform_data = & ( struct bgpio_pdata ) {
2011-12-29 18:02:39 +09:00
. base = MMGPIO_GPIO_BASE ,
2011-05-06 09:45:13 +09:00
} ,
} ;
2011-06-22 13:08:13 +09:00
static struct platform_device speyside_device = {
. name = " speyside " ,
. id = - 1 ,
} ;
2011-09-05 14:50:02 +09:00
static struct platform_device lowland_device = {
. name = " lowland " ,
. id = - 1 ,
} ;
2011-11-30 13:30:27 +00:00
static struct platform_device tobermory_device = {
. name = " tobermory " ,
2011-06-22 13:08:13 +09:00
. id = - 1 ,
} ;
2011-12-02 14:32:32 +09:00
static struct platform_device littlemill_device = {
. name = " littlemill " ,
. id = - 1 ,
} ;
2012-11-28 07:30:18 +09:00
static struct platform_device bells_wm2200_device = {
2012-08-10 13:03:18 +09:00
. name = " bells " ,
. id = 0 ,
} ;
2012-11-28 07:30:18 +09:00
static struct platform_device bells_wm5102_device = {
2012-08-10 13:03:18 +09:00
. name = " bells " ,
. id = 1 ,
} ;
2012-11-28 07:30:18 +09:00
static struct platform_device bells_wm5110_device = {
. name = " bells " ,
. id = 2 ,
} ;
2011-06-22 13:08:13 +09:00
static struct regulator_consumer_supply wallvdd_consumers [ ] = {
2012-01-27 14:58:46 +09:00
REGULATOR_SUPPLY ( " SPKVDD " , " 1-001a " ) ,
2011-06-22 13:08:13 +09:00
REGULATOR_SUPPLY ( " SPKVDD1 " , " 1-001a " ) ,
REGULATOR_SUPPLY ( " SPKVDD2 " , " 1-001a " ) ,
2011-08-31 08:03:11 +09:00
REGULATOR_SUPPLY ( " SPKVDDL " , " 1-001a " ) ,
REGULATOR_SUPPLY ( " SPKVDDR " , " 1-001a " ) ,
2012-04-04 09:21:15 -07:00
2012-10-17 17:41:07 +09:00
REGULATOR_SUPPLY ( " SPKVDDL " , " spi0.1 " ) ,
REGULATOR_SUPPLY ( " SPKVDDR " , " spi0.1 " ) ,
2012-04-04 09:21:15 -07:00
REGULATOR_SUPPLY ( " DC1VDD " , " 0-0034 " ) ,
REGULATOR_SUPPLY ( " DC2VDD " , " 0-0034 " ) ,
REGULATOR_SUPPLY ( " DC3VDD " , " 0-0034 " ) ,
REGULATOR_SUPPLY ( " LDO1VDD " , " 0-0034 " ) ,
REGULATOR_SUPPLY ( " LDO2VDD " , " 0-0034 " ) ,
REGULATOR_SUPPLY ( " LDO4VDD " , " 0-0034 " ) ,
REGULATOR_SUPPLY ( " LDO5VDD " , " 0-0034 " ) ,
REGULATOR_SUPPLY ( " LDO6VDD " , " 0-0034 " ) ,
REGULATOR_SUPPLY ( " LDO7VDD " , " 0-0034 " ) ,
REGULATOR_SUPPLY ( " LDO8VDD " , " 0-0034 " ) ,
REGULATOR_SUPPLY ( " LDO9VDD " , " 0-0034 " ) ,
REGULATOR_SUPPLY ( " LDO10VDD " , " 0-0034 " ) ,
REGULATOR_SUPPLY ( " LDO11VDD " , " 0-0034 " ) ,
REGULATOR_SUPPLY ( " DC1VDD " , " 1-0034 " ) ,
REGULATOR_SUPPLY ( " DC2VDD " , " 1-0034 " ) ,
REGULATOR_SUPPLY ( " DC3VDD " , " 1-0034 " ) ,
2012-11-28 07:32:10 +09:00
REGULATOR_SUPPLY ( " LDO1VDD " , " 1-0034 " ) ,
REGULATOR_SUPPLY ( " LDO2VDD " , " 1-0034 " ) ,
REGULATOR_SUPPLY ( " LDO4VDD " , " 1-0034 " ) ,
REGULATOR_SUPPLY ( " LDO5VDD " , " 1-0034 " ) ,
REGULATOR_SUPPLY ( " LDO6VDD " , " 1-0034 " ) ,
REGULATOR_SUPPLY ( " LDO7VDD " , " 1-0034 " ) ,
REGULATOR_SUPPLY ( " LDO8VDD " , " 1-0034 " ) ,
REGULATOR_SUPPLY ( " LDO9VDD " , " 1-0034 " ) ,
REGULATOR_SUPPLY ( " LDO10VDD " , " 1-0034 " ) ,
REGULATOR_SUPPLY ( " LDO11VDD " , " 1-0034 " ) ,
2011-06-22 13:08:13 +09:00
} ;
static struct regulator_init_data wallvdd_data = {
. constraints = {
. always_on = 1 ,
} ,
. num_consumer_supplies = ARRAY_SIZE ( wallvdd_consumers ) ,
. consumer_supplies = wallvdd_consumers ,
} ;
static struct fixed_voltage_config wallvdd_pdata = {
. supply_name = " WALLVDD " ,
. microvolts = 5000000 ,
. init_data = & wallvdd_data ,
} ;
static struct platform_device wallvdd_device = {
. name = " reg-fixed-voltage " ,
. id = - 1 ,
. dev = {
. platform_data = & wallvdd_pdata ,
} ,
} ;
2011-05-06 09:45:13 +09:00
static struct platform_device * crag6410_devices [ ] __initdata = {
& s3c_device_hsmmc0 ,
& s3c_device_hsmmc2 ,
& s3c_device_i2c0 ,
& s3c_device_i2c1 ,
& s3c_device_fb ,
& s3c_device_ohci ,
& s3c_device_usb_hsotg ,
2013-03-09 15:37:53 +01:00
& samsung_device_pwm ,
2011-05-06 09:45:13 +09:00
& s3c64xx_device_iis0 ,
& s3c64xx_device_iis1 ,
& samsung_device_keypad ,
& crag6410_gpio_keydev ,
& crag6410_dm9k_device ,
& s3c64xx_device_spi0 ,
& crag6410_mmgpio ,
& crag6410_lcd_powerdev ,
& crag6410_backlight_device ,
2011-06-22 13:08:13 +09:00
& speyside_device ,
2011-11-30 13:30:27 +00:00
& tobermory_device ,
2011-12-02 14:32:32 +09:00
& littlemill_device ,
2011-09-05 14:50:02 +09:00
& lowland_device ,
2012-11-28 07:30:18 +09:00
& bells_wm2200_device ,
2012-08-10 13:03:18 +09:00
& bells_wm5102_device ,
& bells_wm5110_device ,
2011-06-22 13:08:13 +09:00
& wallvdd_device ,
2011-05-06 09:45:13 +09:00
} ;
static struct pca953x_platform_data crag6410_pca_data = {
. gpio_base = PCA935X_GPIO_BASE ,
2011-12-30 09:46:40 +09:00
. irq_base = - 1 ,
2011-05-06 09:45:13 +09:00
} ;
2011-08-12 18:08:17 +09:00
/* VDDARM is controlled by DVS1 connected to GPK(0) */
static struct wm831x_buckv_pdata vddarm_pdata = {
. dvs_control_src = 1 ,
} ;
2012-12-21 14:02:24 -08:00
static struct regulator_consumer_supply vddarm_consumers [ ] = {
2011-05-06 09:45:13 +09:00
REGULATOR_SUPPLY ( " vddarm " , NULL ) ,
} ;
2012-12-21 14:02:24 -08:00
static struct regulator_init_data vddarm = {
2011-05-06 09:45:13 +09:00
. constraints = {
. name = " VDDARM " ,
. min_uV = 1000000 ,
. max_uV = 1300000 ,
. always_on = 1 ,
. valid_ops_mask = REGULATOR_CHANGE_VOLTAGE ,
} ,
. num_consumer_supplies = ARRAY_SIZE ( vddarm_consumers ) ,
. consumer_supplies = vddarm_consumers ,
2011-06-22 13:08:17 +09:00
. supply_regulator = " WALLVDD " ,
2011-08-12 18:08:17 +09:00
. driver_data = & vddarm_pdata ,
2011-05-06 09:45:13 +09:00
} ;
2012-12-21 14:02:24 -08:00
static struct regulator_consumer_supply vddint_consumers [ ] = {
2011-12-08 10:52:19 +09:00
REGULATOR_SUPPLY ( " vddint " , NULL ) ,
} ;
2012-12-21 14:02:24 -08:00
static struct regulator_init_data vddint = {
2011-05-06 09:45:13 +09:00
. constraints = {
. name = " VDDINT " ,
. min_uV = 1000000 ,
. max_uV = 1200000 ,
. always_on = 1 ,
. valid_ops_mask = REGULATOR_CHANGE_VOLTAGE ,
} ,
2011-12-08 10:52:19 +09:00
. num_consumer_supplies = ARRAY_SIZE ( vddint_consumers ) ,
. consumer_supplies = vddint_consumers ,
. supply_regulator = " WALLVDD " ,
2011-05-06 09:45:13 +09:00
} ;
2012-12-21 14:02:24 -08:00
static struct regulator_init_data vddmem = {
2011-05-06 09:45:13 +09:00
. constraints = {
. name = " VDDMEM " ,
. always_on = 1 ,
} ,
} ;
2012-12-21 14:02:24 -08:00
static struct regulator_init_data vddsys = {
2011-05-06 09:45:13 +09:00
. constraints = {
. name = " VDDSYS,VDDEXT,VDDPCM,VDDSS " ,
. always_on = 1 ,
} ,
} ;
2012-12-21 14:02:24 -08:00
static struct regulator_consumer_supply vddmmc_consumers [ ] = {
2011-05-06 09:45:13 +09:00
REGULATOR_SUPPLY ( " vmmc " , " s3c-sdhci.0 " ) ,
REGULATOR_SUPPLY ( " vmmc " , " s3c-sdhci.1 " ) ,
REGULATOR_SUPPLY ( " vmmc " , " s3c-sdhci.2 " ) ,
} ;
2012-12-21 14:02:24 -08:00
static struct regulator_init_data vddmmc = {
2011-05-06 09:45:13 +09:00
. constraints = {
. name = " VDDMMC,UH " ,
. always_on = 1 ,
} ,
. num_consumer_supplies = ARRAY_SIZE ( vddmmc_consumers ) ,
. consumer_supplies = vddmmc_consumers ,
2011-06-22 13:08:17 +09:00
. supply_regulator = " WALLVDD " ,
2011-05-06 09:45:13 +09:00
} ;
2012-12-21 14:02:24 -08:00
static struct regulator_init_data vddotgi = {
2011-05-06 09:45:13 +09:00
. constraints = {
. name = " VDDOTGi " ,
. always_on = 1 ,
} ,
2011-06-22 13:08:17 +09:00
. supply_regulator = " WALLVDD " ,
2011-05-06 09:45:13 +09:00
} ;
2012-12-21 14:02:24 -08:00
static struct regulator_init_data vddotg = {
2011-05-06 09:45:13 +09:00
. constraints = {
. name = " VDDOTG " ,
. always_on = 1 ,
} ,
2011-06-22 13:08:17 +09:00
. supply_regulator = " WALLVDD " ,
2011-05-06 09:45:13 +09:00
} ;
2012-12-21 14:02:24 -08:00
static struct regulator_init_data vddhi = {
2011-05-06 09:45:13 +09:00
. constraints = {
. name = " VDDHI " ,
. always_on = 1 ,
} ,
2011-06-22 13:08:17 +09:00
. supply_regulator = " WALLVDD " ,
2011-05-06 09:45:13 +09:00
} ;
2012-12-21 14:02:24 -08:00
static struct regulator_init_data vddadc = {
2011-05-06 09:45:13 +09:00
. constraints = {
. name = " VDDADC,VDDDAC " ,
. always_on = 1 ,
} ,
2011-06-22 13:08:17 +09:00
. supply_regulator = " WALLVDD " ,
2011-05-06 09:45:13 +09:00
} ;
2012-12-21 14:02:24 -08:00
static struct regulator_init_data vddmem0 = {
2011-05-06 09:45:13 +09:00
. constraints = {
. name = " VDDMEM0 " ,
. always_on = 1 ,
} ,
2011-06-22 13:08:17 +09:00
. supply_regulator = " WALLVDD " ,
2011-05-06 09:45:13 +09:00
} ;
2012-12-21 14:02:24 -08:00
static struct regulator_init_data vddpll = {
2011-05-06 09:45:13 +09:00
. constraints = {
. name = " VDDPLL " ,
. always_on = 1 ,
} ,
2011-06-22 13:08:17 +09:00
. supply_regulator = " WALLVDD " ,
2011-05-06 09:45:13 +09:00
} ;
2012-12-21 14:02:24 -08:00
static struct regulator_init_data vddlcd = {
2011-05-06 09:45:13 +09:00
. constraints = {
. name = " VDDLCD " ,
. always_on = 1 ,
} ,
2011-06-22 13:08:17 +09:00
. supply_regulator = " WALLVDD " ,
2011-05-06 09:45:13 +09:00
} ;
2012-12-21 14:02:24 -08:00
static struct regulator_init_data vddalive = {
2011-05-06 09:45:13 +09:00
. constraints = {
. name = " VDDALIVE " ,
. always_on = 1 ,
} ,
2011-06-22 13:08:17 +09:00
. supply_regulator = " WALLVDD " ,
2011-05-06 09:45:13 +09:00
} ;
2012-12-21 14:02:24 -08:00
static struct wm831x_backup_pdata banff_backup_pdata = {
2011-07-21 01:26:24 +09:00
. charger_enable = 1 ,
. vlim = 2500 , /* mV */
. ilim = 200 , /* uA */
} ;
2012-12-21 14:02:24 -08:00
static struct wm831x_status_pdata banff_red_led = {
2011-05-06 09:45:13 +09:00
. name = " banff:red: " ,
. default_src = WM831X_STATUS_MANUAL ,
} ;
2012-12-21 14:02:24 -08:00
static struct wm831x_status_pdata banff_green_led = {
2011-05-06 09:45:13 +09:00
. name = " banff:green: " ,
. default_src = WM831X_STATUS_MANUAL ,
} ;
2012-12-21 14:02:24 -08:00
static struct wm831x_touch_pdata touch_pdata = {
2011-05-06 09:45:13 +09:00
. data_irq = S3C_EINT ( 26 ) ,
2011-06-22 13:08:13 +09:00
. pd_irq = S3C_EINT ( 27 ) ,
2011-05-06 09:45:13 +09:00
} ;
2012-12-21 14:02:24 -08:00
static struct wm831x_pdata crag_pmic_pdata = {
2011-06-22 13:08:13 +09:00
. wm831x_num = 1 ,
2015-03-27 01:58:08 +09:00
. irq_base = BANFF_PMIC_IRQ_BASE ,
2011-11-03 16:28:15 +09:00
. gpio_base = BANFF_PMIC_GPIO_BASE ,
2011-12-02 14:29:07 +09:00
. soft_shutdown = true ,
2011-05-06 09:45:13 +09:00
2011-07-21 01:26:24 +09:00
. backup = & banff_backup_pdata ,
2011-06-22 13:08:13 +09:00
. gpio_defaults = {
2011-08-12 18:08:17 +09:00
/* GPIO5: DVS1_REQ - CMOS, DBVDD, active high */
[ 4 ] = WM831X_GPN_DIR | WM831X_GPN_POL | WM831X_GPN_ENA | 0x8 ,
2011-06-22 13:08:13 +09:00
/* GPIO11: Touchscreen data - CMOS, DBVDD, active high*/
[ 10 ] = WM831X_GPN_POL | WM831X_GPN_ENA | 0x6 ,
/* GPIO12: Touchscreen pen down - CMOS, DBVDD, active high*/
[ 11 ] = WM831X_GPN_POL | WM831X_GPN_ENA | 0x7 ,
} ,
2011-05-06 09:45:13 +09:00
. dcdc = {
& vddarm , /* DCDC1 */
& vddint , /* DCDC2 */
& vddmem , /* DCDC3 */
} ,
. ldo = {
& vddsys , /* LDO1 */
& vddmmc , /* LDO2 */
NULL , /* LDO3 */
& vddotgi , /* LDO4 */
& vddotg , /* LDO5 */
& vddhi , /* LDO6 */
& vddadc , /* LDO7 */
& vddmem0 , /* LDO8 */
& vddpll , /* LDO9 */
& vddlcd , /* LDO10 */
& vddalive , /* LDO11 */
} ,
. status = {
& banff_green_led ,
& banff_red_led ,
} ,
. touch = & touch_pdata ,
} ;
2019-06-12 09:42:22 +02:00
/*
* VDDARM is eventually ending up as a regulator hanging on the MFD cell device
* " wm831x-buckv.1 " spawn from drivers / mfd / wm831x - core . c .
*
* From the note on the platform data we can see that this is clearly DVS1
* and assigned as dcdc1 resource to the MFD core which sets . id of the cell
* spawning the DVS1 platform device to 1 , then the cell platform device
* name is calculated from 10 * instance + id resulting in the device name
* " wm831x-buckv.11 "
*/
static struct gpiod_lookup_table crag_pmic_gpiod_table = {
. dev_id = " wm831x-buckv.11 " ,
. table = {
GPIO_LOOKUP ( " GPIOK " , 0 , " dvs " , GPIO_ACTIVE_HIGH ) ,
{ } ,
} ,
} ;
2012-12-21 14:02:24 -08:00
static struct i2c_board_info i2c_devs0 [ ] = {
2011-05-06 09:45:13 +09:00
{ I2C_BOARD_INFO ( " 24c08 " , 0x50 ) , } ,
{ I2C_BOARD_INFO ( " tca6408 " , 0x20 ) ,
. platform_data = & crag6410_pca_data ,
} ,
{ I2C_BOARD_INFO ( " wm8312 " , 0x34 ) ,
. platform_data = & crag_pmic_pdata ,
. irq = S3C_EINT ( 23 ) ,
} ,
} ;
static struct s3c2410_platform_i2c i2c0_pdata = {
. frequency = 400000 ,
} ;
2012-12-21 14:02:24 -08:00
static struct regulator_consumer_supply pvdd_1v2_consumers [ ] = {
2012-01-12 11:04:56 +09:00
REGULATOR_SUPPLY ( " DCVDD " , " spi0.0 " ) ,
REGULATOR_SUPPLY ( " AVDD " , " spi0.0 " ) ,
2012-10-17 17:41:07 +09:00
REGULATOR_SUPPLY ( " AVDD " , " spi0.1 " ) ,
2012-01-12 11:04:56 +09:00
} ;
2012-12-21 14:02:24 -08:00
static struct regulator_init_data pvdd_1v2 = {
2011-06-22 13:08:13 +09:00
. constraints = {
. name = " PVDD_1V2 " ,
2012-01-12 11:04:56 +09:00
. valid_ops_mask = REGULATOR_CHANGE_STATUS ,
2011-06-22 13:08:13 +09:00
} ,
2012-01-12 11:04:56 +09:00
. consumer_supplies = pvdd_1v2_consumers ,
. num_consumer_supplies = ARRAY_SIZE ( pvdd_1v2_consumers ) ,
2011-06-22 13:08:13 +09:00
} ;
2012-12-21 14:02:24 -08:00
static struct regulator_consumer_supply pvdd_1v8_consumers [ ] = {
2011-09-26 13:18:28 +09:00
REGULATOR_SUPPLY ( " LDOVDD " , " 1-001a " ) ,
2011-06-22 13:08:13 +09:00
REGULATOR_SUPPLY ( " PLLVDD " , " 1-001a " ) ,
REGULATOR_SUPPLY ( " DBVDD " , " 1-001a " ) ,
2011-08-31 08:03:11 +09:00
REGULATOR_SUPPLY ( " DBVDD1 " , " 1-001a " ) ,
REGULATOR_SUPPLY ( " DBVDD2 " , " 1-001a " ) ,
REGULATOR_SUPPLY ( " DBVDD3 " , " 1-001a " ) ,
2011-06-22 13:08:13 +09:00
REGULATOR_SUPPLY ( " CPVDD " , " 1-001a " ) ,
REGULATOR_SUPPLY ( " AVDD2 " , " 1-001a " ) ,
REGULATOR_SUPPLY ( " DCVDD " , " 1-001a " ) ,
REGULATOR_SUPPLY ( " AVDD " , " 1-001a " ) ,
2012-01-12 11:04:56 +09:00
REGULATOR_SUPPLY ( " DBVDD " , " spi0.0 " ) ,
2012-10-17 17:41:09 +09:00
REGULATOR_SUPPLY ( " DBVDD " , " 1-003a " ) ,
REGULATOR_SUPPLY ( " LDOVDD " , " 1-003a " ) ,
REGULATOR_SUPPLY ( " CPVDD " , " 1-003a " ) ,
REGULATOR_SUPPLY ( " AVDD " , " 1-003a " ) ,
2012-10-17 17:41:07 +09:00
REGULATOR_SUPPLY ( " DBVDD1 " , " spi0.1 " ) ,
REGULATOR_SUPPLY ( " DBVDD2 " , " spi0.1 " ) ,
REGULATOR_SUPPLY ( " DBVDD3 " , " spi0.1 " ) ,
REGULATOR_SUPPLY ( " LDOVDD " , " spi0.1 " ) ,
REGULATOR_SUPPLY ( " CPVDD " , " spi0.1 " ) ,
2011-06-22 13:08:13 +09:00
} ;
2012-12-21 14:02:24 -08:00
static struct regulator_init_data pvdd_1v8 = {
2011-06-22 13:08:13 +09:00
. constraints = {
. name = " PVDD_1V8 " ,
. always_on = 1 ,
} ,
. consumer_supplies = pvdd_1v8_consumers ,
. num_consumer_supplies = ARRAY_SIZE ( pvdd_1v8_consumers ) ,
} ;
2012-12-21 14:02:24 -08:00
static struct regulator_consumer_supply pvdd_3v3_consumers [ ] = {
2011-06-22 13:08:13 +09:00
REGULATOR_SUPPLY ( " MICVDD " , " 1-001a " ) ,
REGULATOR_SUPPLY ( " AVDD1 " , " 1-001a " ) ,
} ;
2012-12-21 14:02:24 -08:00
static struct regulator_init_data pvdd_3v3 = {
2011-06-22 13:08:13 +09:00
. constraints = {
. name = " PVDD_3V3 " ,
. always_on = 1 ,
} ,
. consumer_supplies = pvdd_3v3_consumers ,
. num_consumer_supplies = ARRAY_SIZE ( pvdd_3v3_consumers ) ,
} ;
2012-12-21 14:02:24 -08:00
static struct wm831x_pdata glenfarclas_pmic_pdata = {
2011-06-22 13:08:13 +09:00
. wm831x_num = 2 ,
. irq_base = GLENFARCLAS_PMIC_IRQ_BASE ,
. gpio_base = GLENFARCLAS_PMIC_GPIO_BASE ,
2011-12-02 14:29:07 +09:00
. soft_shutdown = true ,
2011-06-22 13:08:13 +09:00
. gpio_defaults = {
/* GPIO1-3: IRQ inputs, rising edge triggered, CMOS */
[ 0 ] = WM831X_GPN_DIR | WM831X_GPN_POL | WM831X_GPN_ENA ,
[ 1 ] = WM831X_GPN_DIR | WM831X_GPN_POL | WM831X_GPN_ENA ,
[ 2 ] = WM831X_GPN_DIR | WM831X_GPN_POL | WM831X_GPN_ENA ,
} ,
. dcdc = {
& pvdd_1v2 , /* DCDC1 */
& pvdd_1v8 , /* DCDC2 */
& pvdd_3v3 , /* DCDC3 */
} ,
. disable_touch = true ,
} ;
2011-12-02 14:29:07 +09:00
static struct wm1250_ev1_pdata wm1250_ev1_pdata = {
. gpios = {
[ WM1250_EV1_GPIO_CLK_ENA ] = S3C64XX_GPN ( 12 ) ,
[ WM1250_EV1_GPIO_CLK_SEL0 ] = S3C64XX_GPL ( 12 ) ,
[ WM1250_EV1_GPIO_CLK_SEL1 ] = S3C64XX_GPL ( 13 ) ,
[ WM1250_EV1_GPIO_OSR ] = S3C64XX_GPL ( 14 ) ,
[ WM1250_EV1_GPIO_MASTER ] = S3C64XX_GPL ( 8 ) ,
} ,
} ;
2012-12-21 14:02:24 -08:00
static struct i2c_board_info i2c_devs1 [ ] = {
2011-05-06 09:45:13 +09:00
{ I2C_BOARD_INFO ( " wm8311 " , 0x34 ) ,
2011-06-22 13:08:13 +09:00
. irq = S3C_EINT ( 0 ) ,
. platform_data = & glenfarclas_pmic_pdata } ,
2012-10-17 17:41:10 +09:00
{ I2C_BOARD_INFO ( " wlf-gf-module " , 0x20 ) } ,
2012-05-16 07:01:10 +09:00
{ I2C_BOARD_INFO ( " wlf-gf-module " , 0x22 ) } ,
2011-08-19 22:40:07 +09:00
{ I2C_BOARD_INFO ( " wlf-gf-module " , 0x24 ) } ,
{ I2C_BOARD_INFO ( " wlf-gf-module " , 0x25 ) } ,
{ I2C_BOARD_INFO ( " wlf-gf-module " , 0x26 ) } ,
2011-12-02 14:29:07 +09:00
{ I2C_BOARD_INFO ( " wm1250-ev1 " , 0x27 ) ,
. platform_data = & wm1250_ev1_pdata } ,
2011-05-06 09:45:13 +09:00
} ;
2011-12-02 14:29:07 +09:00
static struct s3c2410_platform_i2c i2c1_pdata = {
. frequency = 400000 ,
. bus_num = 1 ,
2011-05-06 09:45:13 +09:00
} ;
static void __init crag6410_map_io ( void )
{
s3c64xx_init_io ( NULL , 0 ) ;
2013-08-26 02:00:38 +09:00
s3c64xx_set_xtal_freq ( 12000000 ) ;
2011-05-06 09:45:13 +09:00
s3c24xx_init_uarts ( crag6410_uartcfgs , ARRAY_SIZE ( crag6410_uartcfgs ) ) ;
2020-08-20 22:42:03 +02:00
s3c64xx_set_timer_source ( S3C64XX_PWM3 , S3C64XX_PWM4 ) ;
2011-05-06 09:45:13 +09:00
/* LCD type and Bypass set by bootloader */
}
static struct s3c_sdhci_platdata crag6410_hsmmc2_pdata = {
. max_width = 4 ,
. cd_type = S3C_SDHCI_CD_PERMANENT ,
2011-12-30 13:44:36 +09:00
. host_caps = MMC_CAP_POWER_OFF_CARD ,
2011-05-06 09:45:13 +09:00
} ;
static void crag6410_cfg_sdhci0 ( struct platform_device * dev , int width )
{
/* Set all the necessary GPG pins to special-function 2 */
s3c_gpio_cfgrange_nopull ( S3C64XX_GPG ( 0 ) , 2 + width , S3C_GPIO_SFN ( 2 ) ) ;
/* force card-detected for prototype 0 */
s3c_gpio_setpull ( S3C64XX_GPG ( 6 ) , S3C_GPIO_PULL_DOWN ) ;
}
static struct s3c_sdhci_platdata crag6410_hsmmc0_pdata = {
. max_width = 4 ,
. cd_type = S3C_SDHCI_CD_INTERNAL ,
. cfg_gpio = crag6410_cfg_sdhci0 ,
2011-12-30 13:44:31 +09:00
. host_caps = MMC_CAP_POWER_OFF_CARD ,
2011-05-06 09:45:13 +09:00
} ;
2011-12-29 18:05:29 +09:00
static const struct gpio_led gpio_leds [ ] = {
{
. name = " d13:green: " ,
. gpio = MMGPIO_GPIO_BASE + 0 ,
. default_state = LEDS_GPIO_DEFSTATE_ON ,
} ,
{
. name = " d14:green: " ,
. gpio = MMGPIO_GPIO_BASE + 1 ,
. default_state = LEDS_GPIO_DEFSTATE_ON ,
} ,
{
. name = " d15:green: " ,
. gpio = MMGPIO_GPIO_BASE + 2 ,
. default_state = LEDS_GPIO_DEFSTATE_ON ,
} ,
{
. name = " d16:green: " ,
. gpio = MMGPIO_GPIO_BASE + 3 ,
. default_state = LEDS_GPIO_DEFSTATE_ON ,
} ,
{
. name = " d17:green: " ,
. gpio = MMGPIO_GPIO_BASE + 4 ,
. default_state = LEDS_GPIO_DEFSTATE_ON ,
} ,
{
. name = " d18:green: " ,
. gpio = MMGPIO_GPIO_BASE + 5 ,
. default_state = LEDS_GPIO_DEFSTATE_ON ,
} ,
{
. name = " d19:green: " ,
. gpio = MMGPIO_GPIO_BASE + 6 ,
. default_state = LEDS_GPIO_DEFSTATE_ON ,
} ,
{
. name = " d20:green: " ,
. gpio = MMGPIO_GPIO_BASE + 7 ,
. default_state = LEDS_GPIO_DEFSTATE_ON ,
} ,
} ;
static const struct gpio_led_platform_data gpio_leds_pdata = {
. leds = gpio_leds ,
. num_leds = ARRAY_SIZE ( gpio_leds ) ,
2011-05-06 09:45:13 +09:00
} ;
2015-08-06 18:11:54 -05:00
static struct dwc2_hsotg_plat crag6410_hsotg_pdata ;
2012-03-07 04:23:47 -08:00
2022-01-19 00:09:15 +01:00
static struct gpiod_lookup_table crag_spi0_gpiod_table = {
. dev_id = " s3c6410-spi.0 " ,
. table = {
GPIO_LOOKUP_IDX ( " GPIOC " , 3 , " cs " , 0 , GPIO_ACTIVE_LOW ) ,
GPIO_LOOKUP_IDX ( " GPION " , 5 , " cs " , 1 , GPIO_ACTIVE_LOW ) ,
{ } ,
} ,
} ;
2011-05-06 09:45:13 +09:00
static void __init crag6410_machine_init ( void )
{
/* Open drain IRQs need pullups */
s3c_gpio_setpull ( S3C64XX_GPM ( 0 ) , S3C_GPIO_PULL_UP ) ;
s3c_gpio_setpull ( S3C64XX_GPN ( 0 ) , S3C_GPIO_PULL_UP ) ;
gpio_request ( S3C64XX_GPB ( 0 ) , " LCD power " ) ;
gpio_direction_output ( S3C64XX_GPB ( 0 ) , 0 ) ;
gpio_request ( S3C64XX_GPF ( 14 ) , " LCD PWM " ) ;
gpio_direction_output ( S3C64XX_GPF ( 14 ) , 0 ) ; /* turn off */
gpio_request ( S3C64XX_GPB ( 1 ) , " SD power " ) ;
gpio_direction_output ( S3C64XX_GPB ( 1 ) , 0 ) ;
gpio_request ( S3C64XX_GPF ( 10 ) , " nRESETSEL " ) ;
gpio_direction_output ( S3C64XX_GPF ( 10 ) , 1 ) ;
s3c_sdhci0_set_platdata ( & crag6410_hsmmc0_pdata ) ;
s3c_sdhci2_set_platdata ( & crag6410_hsmmc2_pdata ) ;
s3c_i2c0_set_platdata ( & i2c0_pdata ) ;
2011-12-02 14:29:07 +09:00
s3c_i2c1_set_platdata ( & i2c1_pdata ) ;
2011-05-06 09:45:13 +09:00
s3c_fb_set_platdata ( & crag6410_lcd_pdata ) ;
2015-08-06 18:11:54 -05:00
dwc2_hsotg_set_platdata ( & crag6410_hsotg_pdata ) ;
2011-05-06 09:45:13 +09:00
2019-06-12 09:42:22 +02:00
gpiod_add_lookup_table ( & crag_pmic_gpiod_table ) ;
2011-05-06 09:45:13 +09:00
i2c_register_board_info ( 0 , i2c_devs0 , ARRAY_SIZE ( i2c_devs0 ) ) ;
i2c_register_board_info ( 1 , i2c_devs1 , ARRAY_SIZE ( i2c_devs1 ) ) ;
samsung_keypad_set_platdata ( & crag6410_keypad_data ) ;
2022-01-19 00:09:15 +01:00
gpiod_add_lookup_table ( & crag_spi0_gpiod_table ) ;
2022-01-19 00:09:14 +01:00
s3c64xx_spi0_set_platdata ( 0 , 2 ) ;
2011-05-06 09:45:13 +09:00
2015-10-13 05:04:22 +09:00
pwm_add_table ( crag6410_pwm_lookup , ARRAY_SIZE ( crag6410_pwm_lookup ) ) ;
2011-05-06 09:45:13 +09:00
platform_add_devices ( crag6410_devices , ARRAY_SIZE ( crag6410_devices ) ) ;
2011-12-29 18:05:29 +09:00
gpio_led_register_device ( - 1 , & gpio_leds_pdata ) ;
2011-06-22 13:08:13 +09:00
regulator_has_full_constraints ( ) ;
2011-12-08 23:27:48 +01:00
s3c64xx_pm_init ( ) ;
2011-05-06 09:45:13 +09:00
}
MACHINE_START ( WLF_CRAGG_6410 , " Wolfson Cragganmore 6410 " )
/* Maintainer: Mark Brown <broonie@opensource.wolfsonmicro.com> */
2011-07-05 22:38:17 -04:00
. atag_offset = 0x100 ,
2015-02-27 22:06:58 +01:00
. nr_irqs = S3C64XX_NR_IRQS ,
2011-05-06 09:45:13 +09:00
. init_irq = s3c6410_init_irq ,
. map_io = crag6410_map_io ,
. init_machine = crag6410_machine_init ,
2020-08-20 22:42:03 +02:00
. init_time = s3c64xx_timer_init ,
2011-05-06 09:45:13 +09:00
MACHINE_END