2009-11-18 18:41:07 -08:00
/*
2011-07-05 03:38:23 -07:00
* CompuLab CM - T35 / CM - T3730 modules support
2009-11-18 18:41:07 -08:00
*
2011-07-04 04:09:18 -07:00
* Copyright ( C ) 2009 - 2011 CompuLab , Ltd .
* Authors : Mike Rapoport < mike @ compulab . co . il >
* Igor Grinberg < grinberg @ compulab . co . il >
2009-11-18 18:41:07 -08:00
*
* 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 .
*
* 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 .
*
*/
# include <linux/kernel.h>
# include <linux/init.h>
# include <linux/platform_device.h>
# include <linux/input.h>
# include <linux/input/matrix_keypad.h>
# include <linux/delay.h>
# include <linux/gpio.h>
2012-08-30 15:37:24 -07:00
# include <linux/platform_data/gpio-omap.h>
2009-11-18 18:41:07 -08:00
# include <linux/i2c/at24.h>
2009-12-15 20:09:02 +05:30
# include <linux/i2c/twl.h>
2012-03-23 02:21:37 -07:00
# include <linux/regulator/fixed.h>
2009-11-18 18:41:07 -08:00
# include <linux/regulator/machine.h>
2010-09-15 14:49:23 +00:00
# include <linux/mmc/host.h>
2009-11-18 18:41:07 -08:00
2009-12-14 09:01:08 +01:00
# include <linux/spi/spi.h>
# include <linux/spi/tdo24m.h>
2009-11-18 18:41:07 -08:00
# include <asm/mach-types.h>
# include <asm/mach/arch.h>
# include <asm/mach/map.h>
2011-11-10 22:45:17 +01:00
# include "common.h"
2012-08-24 15:21:06 +02:00
# include <linux/platform_data/mtd-nand-omap2.h>
2012-10-05 10:37:27 +05:30
# include "gpmc.h"
2009-11-18 18:41:07 -08:00
# include <plat/usb.h>
2011-05-11 14:05:07 +03:00
# include <video/omapdss.h>
2011-05-10 19:48:10 +03:00
# include <video/omap-panel-generic-dpi.h>
2011-12-22 11:12:13 +02:00
# include <video/omap-panel-tfp410.h>
2012-08-24 15:21:06 +02:00
# include <linux/platform_data/spi-omap2-mcspi.h>
2009-11-18 18:41:07 -08:00
# include <mach/hardware.h>
2009-12-11 16:16:32 -08:00
# include "mux.h"
2009-11-18 18:41:07 -08:00
# include "sdram-micron-mt46h32m32lf-6.h"
2010-02-15 10:03:34 -08:00
# include "hsmmc.h"
2011-04-25 01:09:05 +03:00
# include "common-board-devices.h"
2012-09-29 12:26:13 +05:30
# include "gpmc-nand.h"
2009-11-18 18:41:07 -08:00
2011-12-13 10:48:53 -08:00
# define CM_T35_GPIO_PENDOWN 57
# define SB_T35_USB_HUB_RESET_GPIO 167
2009-11-18 18:41:07 -08:00
# define CM_T35_SMSC911X_CS 5
# define CM_T35_SMSC911X_GPIO 163
# define SB_T35_SMSC911X_CS 4
# define SB_T35_SMSC911X_GPIO 65
# if defined(CONFIG_SMSC911X) || defined(CONFIG_SMSC911X_MODULE)
# include <linux/smsc911x.h>
2012-09-20 11:41:46 -07:00
# include "gpmc-smsc911x.h"
2009-11-18 18:41:07 -08:00
2011-04-16 22:29:30 +00:00
static struct omap_smsc911x_platform_data cm_t35_smsc911x_cfg = {
2009-11-18 18:41:07 -08:00
. id = 0 ,
2011-04-16 22:29:30 +00:00
. cs = CM_T35_SMSC911X_CS ,
. gpio_irq = CM_T35_SMSC911X_GPIO ,
. gpio_reset = - EINVAL ,
. flags = SMSC911X_USE_32BIT | SMSC911X_SAVE_MAC_ADDRESS ,
2009-11-18 18:41:07 -08:00
} ;
2011-04-16 22:29:30 +00:00
static struct omap_smsc911x_platform_data sb_t35_smsc911x_cfg = {
2009-11-18 18:41:07 -08:00
. id = 1 ,
2011-04-16 22:29:30 +00:00
. cs = SB_T35_SMSC911X_CS ,
. gpio_irq = SB_T35_SMSC911X_GPIO ,
. gpio_reset = - EINVAL ,
. flags = SMSC911X_USE_32BIT | SMSC911X_SAVE_MAC_ADDRESS ,
2009-11-18 18:41:07 -08:00
} ;
2012-03-23 02:21:37 -07:00
static struct regulator_consumer_supply cm_t35_smsc911x_supplies [ ] = {
REGULATOR_SUPPLY ( " vddvario " , " smsc911x.0 " ) ,
REGULATOR_SUPPLY ( " vdd33a " , " smsc911x.0 " ) ,
} ;
static struct regulator_consumer_supply sb_t35_smsc911x_supplies [ ] = {
REGULATOR_SUPPLY ( " vddvario " , " smsc911x.1 " ) ,
REGULATOR_SUPPLY ( " vdd33a " , " smsc911x.1 " ) ,
} ;
2009-11-18 18:41:07 -08:00
static void __init cm_t35_init_ethernet ( void )
{
2012-03-23 02:21:37 -07:00
regulator_register_fixed ( 0 , cm_t35_smsc911x_supplies ,
ARRAY_SIZE ( cm_t35_smsc911x_supplies ) ) ;
regulator_register_fixed ( 1 , sb_t35_smsc911x_supplies ,
ARRAY_SIZE ( sb_t35_smsc911x_supplies ) ) ;
2011-04-16 22:29:30 +00:00
gpmc_smsc911x_init ( & cm_t35_smsc911x_cfg ) ;
gpmc_smsc911x_init ( & sb_t35_smsc911x_cfg ) ;
2009-11-18 18:41:07 -08:00
}
# else
static inline void __init cm_t35_init_ethernet ( void ) { return ; }
# endif
# if defined(CONFIG_LEDS_GPIO) || defined(CONFIG_LEDS_GPIO_MODULE)
# include <linux/leds.h>
static struct gpio_led cm_t35_leds [ ] = {
[ 0 ] = {
. gpio = 186 ,
. name = " cm-t35:green " ,
. default_trigger = " heartbeat " ,
. active_low = 0 ,
} ,
} ;
static struct gpio_led_platform_data cm_t35_led_pdata = {
. num_leds = ARRAY_SIZE ( cm_t35_leds ) ,
. leds = cm_t35_leds ,
} ;
static struct platform_device cm_t35_led_device = {
. name = " leds-gpio " ,
. id = - 1 ,
. dev = {
. platform_data = & cm_t35_led_pdata ,
} ,
} ;
static void __init cm_t35_init_led ( void )
{
platform_device_register ( & cm_t35_led_device ) ;
}
# else
static inline void cm_t35_init_led ( void ) { }
# endif
# if defined(CONFIG_MTD_NAND_OMAP2) || defined(CONFIG_MTD_NAND_OMAP2_MODULE)
# include <linux/mtd/mtd.h>
# include <linux/mtd/nand.h>
# include <linux/mtd/partitions.h>
static struct mtd_partition cm_t35_nand_partitions [ ] = {
{
. name = " xloader " ,
. offset = 0 , /* Offset = 0x00000 */
. size = 4 * NAND_BLOCK_SIZE ,
. mask_flags = MTD_WRITEABLE
} ,
{
. name = " uboot " ,
. offset = MTDPART_OFS_APPEND , /* Offset = 0x80000 */
. size = 15 * NAND_BLOCK_SIZE ,
} ,
{
. name = " uboot environment " ,
. offset = MTDPART_OFS_APPEND , /* Offset = 0x260000 */
. size = 2 * NAND_BLOCK_SIZE ,
} ,
{
. name = " linux " ,
2011-07-04 04:09:18 -07:00
. offset = MTDPART_OFS_APPEND , /* Offset = 0x2A0000 */
2009-11-18 18:41:07 -08:00
. size = 32 * NAND_BLOCK_SIZE ,
} ,
{
. name = " rootfs " ,
2011-07-04 04:09:18 -07:00
. offset = MTDPART_OFS_APPEND , /* Offset = 0x6A0000 */
2009-11-18 18:41:07 -08:00
. size = MTDPART_SIZ_FULL ,
} ,
} ;
static struct omap_nand_platform_data cm_t35_nand_data = {
. parts = cm_t35_nand_partitions ,
. nr_parts = ARRAY_SIZE ( cm_t35_nand_partitions ) ,
. cs = 0 ,
} ;
static void __init cm_t35_init_nand ( void )
{
2012-09-29 12:26:13 +05:30
if ( gpmc_nand_init ( & cm_t35_nand_data , NULL ) < 0 )
2009-11-18 18:41:07 -08:00
pr_err ( " CM-T35: Unable to register NAND device \n " ) ;
}
# else
static inline void cm_t35_init_nand ( void ) { }
# endif
2009-12-14 09:01:08 +01:00
# define CM_T35_LCD_EN_GPIO 157
# define CM_T35_LCD_BL_GPIO 58
# define CM_T35_DVI_EN_GPIO 54
static int lcd_enabled ;
static int dvi_enabled ;
static int cm_t35_panel_enable_lcd ( struct omap_dss_device * dssdev )
{
if ( dvi_enabled ) {
printk ( KERN_ERR " cannot enable LCD, DVI is enabled \n " ) ;
return - EINVAL ;
}
2011-05-03 18:22:09 +03:00
gpio_set_value ( CM_T35_LCD_EN_GPIO , 1 ) ;
gpio_set_value ( CM_T35_LCD_BL_GPIO , 1 ) ;
2009-12-14 09:01:08 +01:00
lcd_enabled = 1 ;
return 0 ;
}
static void cm_t35_panel_disable_lcd ( struct omap_dss_device * dssdev )
{
lcd_enabled = 0 ;
2011-05-03 18:22:09 +03:00
gpio_set_value ( CM_T35_LCD_BL_GPIO , 0 ) ;
gpio_set_value ( CM_T35_LCD_EN_GPIO , 0 ) ;
2009-12-14 09:01:08 +01:00
}
static int cm_t35_panel_enable_tv ( struct omap_dss_device * dssdev )
{
return 0 ;
}
static void cm_t35_panel_disable_tv ( struct omap_dss_device * dssdev )
{
}
2010-11-17 13:34:34 +00:00
static struct panel_generic_dpi_data lcd_panel = {
. name = " toppoly_tdo35s " ,
. platform_enable = cm_t35_panel_enable_lcd ,
. platform_disable = cm_t35_panel_disable_lcd ,
} ;
2009-12-14 09:01:08 +01:00
static struct omap_dss_device cm_t35_lcd_device = {
. name = " lcd " ,
. type = OMAP_DISPLAY_TYPE_DPI ,
2010-11-17 13:34:34 +00:00
. driver_name = " generic_dpi_panel " ,
. data = & lcd_panel ,
2009-12-14 09:01:08 +01:00
. phy . dpi . data_lines = 18 ,
2010-11-17 13:34:34 +00:00
} ;
2012-03-05 14:29:28 +02:00
static struct tfp410_platform_data dvi_panel = {
2012-02-17 13:30:27 +02:00
. power_down_gpio = CM_T35_DVI_EN_GPIO ,
2009-12-14 09:01:08 +01:00
} ;
static struct omap_dss_device cm_t35_dvi_device = {
. name = " dvi " ,
. type = OMAP_DISPLAY_TYPE_DPI ,
2012-03-05 14:29:28 +02:00
. driver_name = " tfp410 " ,
2010-11-17 13:34:34 +00:00
. data = & dvi_panel ,
2009-12-14 09:01:08 +01:00
. phy . dpi . data_lines = 24 ,
} ;
static struct omap_dss_device cm_t35_tv_device = {
. name = " tv " ,
. driver_name = " venc " ,
. type = OMAP_DISPLAY_TYPE_VENC ,
. phy . venc . type = OMAP_DSS_VENC_TYPE_SVIDEO ,
. platform_enable = cm_t35_panel_enable_tv ,
. platform_disable = cm_t35_panel_disable_tv ,
} ;
static struct omap_dss_device * cm_t35_dss_devices [ ] = {
& cm_t35_lcd_device ,
& cm_t35_dvi_device ,
& cm_t35_tv_device ,
} ;
static struct omap_dss_board_info cm_t35_dss_data = {
. num_devices = ARRAY_SIZE ( cm_t35_dss_devices ) ,
. devices = cm_t35_dss_devices ,
. default_device = & cm_t35_dvi_device ,
} ;
static struct omap2_mcspi_device_config tdo24m_mcspi_config = {
. turbo_mode = 0 ,
} ;
static struct tdo24m_platform_data tdo24m_config = {
. model = TDO35S ,
} ;
static struct spi_board_info cm_t35_lcd_spi_board_info [ ] __initdata = {
{
. modalias = " tdo24m " ,
. bus_num = 4 ,
. chip_select = 0 ,
. max_speed_hz = 1000000 ,
. controller_data = & tdo24m_mcspi_config ,
. platform_data = & tdo24m_config ,
} ,
} ;
2011-05-03 18:22:09 +03:00
static struct gpio cm_t35_dss_gpios [ ] __initdata = {
{ CM_T35_LCD_EN_GPIO , GPIOF_OUT_INIT_LOW , " lcd enable " } ,
{ CM_T35_LCD_BL_GPIO , GPIOF_OUT_INIT_LOW , " lcd bl enable " } ,
} ;
2009-12-14 09:01:08 +01:00
static void __init cm_t35_init_display ( void )
{
int err ;
spi_register_board_info ( cm_t35_lcd_spi_board_info ,
ARRAY_SIZE ( cm_t35_lcd_spi_board_info ) ) ;
2011-05-03 18:22:09 +03:00
err = gpio_request_array ( cm_t35_dss_gpios ,
ARRAY_SIZE ( cm_t35_dss_gpios ) ) ;
2009-12-14 09:01:08 +01:00
if ( err ) {
2011-05-03 18:22:09 +03:00
pr_err ( " CM-T35: failed to request DSS control GPIOs \n " ) ;
return ;
2009-12-14 09:01:08 +01:00
}
2011-05-03 18:22:09 +03:00
gpio_export ( CM_T35_LCD_EN_GPIO , 0 ) ;
gpio_export ( CM_T35_LCD_BL_GPIO , 0 ) ;
2009-12-14 09:01:08 +01:00
msleep ( 50 ) ;
2011-05-03 18:22:09 +03:00
gpio_set_value ( CM_T35_LCD_EN_GPIO , 1 ) ;
2009-12-14 09:01:08 +01:00
2011-02-22 11:24:50 +02:00
err = omap_display_init ( & cm_t35_dss_data ) ;
2009-12-14 09:01:08 +01:00
if ( err ) {
pr_err ( " CM-T35: failed to register DSS device \n " ) ;
2011-05-03 18:22:09 +03:00
gpio_free_array ( cm_t35_dss_gpios , ARRAY_SIZE ( cm_t35_dss_gpios ) ) ;
2009-12-14 09:01:08 +01:00
}
}
2011-06-06 18:57:07 +00:00
static struct regulator_consumer_supply cm_t35_vmmc1_supply [ ] = {
REGULATOR_SUPPLY ( " vmmc " , " omap_hsmmc.0 " ) ,
2009-11-18 18:41:07 -08:00
} ;
2011-06-06 18:57:07 +00:00
static struct regulator_consumer_supply cm_t35_vsim_supply [ ] = {
REGULATOR_SUPPLY ( " vmmc_aux " , " omap_hsmmc.0 " ) ,
2009-11-18 18:41:07 -08:00
} ;
2011-12-13 10:48:51 -08:00
static struct regulator_consumer_supply cm_t35_vio_supplies [ ] = {
REGULATOR_SUPPLY ( " vcc " , " spi1.0 " ) ,
2011-12-13 10:48:52 -08:00
REGULATOR_SUPPLY ( " vdds_dsi " , " omapdss " ) ,
REGULATOR_SUPPLY ( " vdds_dsi " , " omapdss_dsi1 " ) ,
2011-12-13 10:48:51 -08:00
} ;
2009-11-18 18:41:07 -08:00
/* VMMC1 for MMC1 pins CMD, CLK, DAT0..DAT3 (20 mA, plus card == max 220 mA) */
static struct regulator_init_data cm_t35_vmmc1 = {
. constraints = {
. min_uV = 1850000 ,
. max_uV = 3150000 ,
. valid_modes_mask = REGULATOR_MODE_NORMAL
| REGULATOR_MODE_STANDBY ,
. valid_ops_mask = REGULATOR_CHANGE_VOLTAGE
| REGULATOR_CHANGE_MODE
| REGULATOR_CHANGE_STATUS ,
} ,
2011-06-06 18:57:07 +00:00
. num_consumer_supplies = ARRAY_SIZE ( cm_t35_vmmc1_supply ) ,
. consumer_supplies = cm_t35_vmmc1_supply ,
2009-11-18 18:41:07 -08:00
} ;
/* VSIM for MMC1 pins DAT4..DAT7 (2 mA, plus card == max 50 mA) */
static struct regulator_init_data cm_t35_vsim = {
. constraints = {
. min_uV = 1800000 ,
. max_uV = 3000000 ,
. valid_modes_mask = REGULATOR_MODE_NORMAL
| REGULATOR_MODE_STANDBY ,
. valid_ops_mask = REGULATOR_CHANGE_VOLTAGE
| REGULATOR_CHANGE_MODE
| REGULATOR_CHANGE_STATUS ,
} ,
2011-06-06 18:57:07 +00:00
. num_consumer_supplies = ARRAY_SIZE ( cm_t35_vsim_supply ) ,
. consumer_supplies = cm_t35_vsim_supply ,
2009-11-18 18:41:07 -08:00
} ;
2011-12-13 10:48:51 -08:00
static struct regulator_init_data cm_t35_vio = {
. constraints = {
. min_uV = 1800000 ,
. max_uV = 1800000 ,
. apply_uV = true ,
. valid_modes_mask = REGULATOR_MODE_NORMAL
| REGULATOR_MODE_STANDBY ,
. valid_ops_mask = REGULATOR_CHANGE_MODE ,
} ,
. num_consumer_supplies = ARRAY_SIZE ( cm_t35_vio_supplies ) ,
. consumer_supplies = cm_t35_vio_supplies ,
} ;
2010-10-08 10:01:13 -07:00
static uint32_t cm_t35_keymap [ ] = {
2009-11-18 18:41:07 -08:00
KEY ( 0 , 0 , KEY_A ) , KEY ( 0 , 1 , KEY_B ) , KEY ( 0 , 2 , KEY_LEFT ) ,
KEY ( 1 , 0 , KEY_UP ) , KEY ( 1 , 1 , KEY_ENTER ) , KEY ( 1 , 2 , KEY_DOWN ) ,
KEY ( 2 , 0 , KEY_RIGHT ) , KEY ( 2 , 1 , KEY_C ) , KEY ( 2 , 2 , KEY_D ) ,
} ;
static struct matrix_keymap_data cm_t35_keymap_data = {
. keymap = cm_t35_keymap ,
. keymap_size = ARRAY_SIZE ( cm_t35_keymap ) ,
} ;
static struct twl4030_keypad_data cm_t35_kp_data = {
. keymap_data = & cm_t35_keymap_data ,
. rows = 3 ,
. cols = 3 ,
. rep = 1 ,
} ;
2010-02-15 10:03:34 -08:00
static struct omap2_hsmmc_info mmc [ ] = {
2009-11-18 18:41:07 -08:00
{
. mmc = 1 ,
2010-09-15 14:49:23 +00:00
. caps = MMC_CAP_4_BIT_DATA ,
2009-11-18 18:41:07 -08:00
. gpio_cd = - EINVAL ,
. gpio_wp = - EINVAL ,
2012-02-20 09:43:29 -08:00
. deferred = true ,
2009-11-18 18:41:07 -08:00
} ,
{
. mmc = 2 ,
2010-09-15 14:49:23 +00:00
. caps = MMC_CAP_4_BIT_DATA ,
2009-11-18 18:41:07 -08:00
. transceiver = 1 ,
. gpio_cd = - EINVAL ,
. gpio_wp = - EINVAL ,
. ocr_mask = 0x00100000 , /* 3.3V */
} ,
{ } /* Terminator */
} ;
2011-03-01 20:08:16 +05:30
static struct usbhs_omap_board_data usbhs_bdata __initdata = {
. port_mode [ 0 ] = OMAP_EHCI_PORT_MODE_PHY ,
. port_mode [ 1 ] = OMAP_EHCI_PORT_MODE_PHY ,
. port_mode [ 2 ] = OMAP_USBHS_PORT_MODE_UNUSED ,
2009-11-18 18:41:07 -08:00
. phy_reset = true ,
omap: kill all section mismatch warning for omap2plus_defconfig
This patch will kill following section mismatch warnings:
WARNING: vmlinux.o(.text+0x24a00): Section mismatch in reference from the function zoom_twl_gpio_setup() to the (unknown reference) .init.data:(unknown)
The function zoom_twl_gpio_setup() references
the (unknown reference) __initdata (unknown).
This is often because zoom_twl_gpio_setup lacks a __initdata
annotation or the annotation of (unknown) is wrong.
WARNING: vmlinux.o(.text+0x24bfc): Section mismatch in reference from the function cm_t35_twl_gpio_setup() to the (unknown reference) .init.data:(unknown)
The function cm_t35_twl_gpio_setup() references
the (unknown reference) __initdata (unknown).
This is often because cm_t35_twl_gpio_setup lacks a __initdata
annotation or the annotation of (unknown) is wrong.
WARNING: vmlinux.o(.data+0x1d3e0): Section mismatch in reference from the variable h4_config to the (unknown reference) .init.data:(unknown)
The variable h4_config references
the (unknown reference) __initdata (unknown)
If the reference is valid then annotate the
variable with __init* or __refdata (see linux/init.h) or name the variable:
*_template, *_timer, *_sht, *_ops, *_probe, *_probe_one, *_console,
WARNING: vmlinux.o(.data+0x1dc08): Section mismatch in reference from the variable sdp2430_config to the (unknown reference) .init.data:(unknown)
The variable sdp2430_config references
the (unknown reference) __initdata (unknown)
If the reference is valid then annotate the
variable with __init* or __refdata (see linux/init.h) or name the variable:
*_template, *_timer, *_sht, *_ops, *_probe, *_probe_one, *_console,
WARNING: vmlinux.o(.data+0x1e1d8): Section mismatch in reference from the variable apollon_config to the (unknown reference) .init.data:(unknown)
The variable apollon_config references
the (unknown reference) __initdata (unknown)
If the reference is valid then annotate the
variable with __init* or __refdata (see linux/init.h) or name the variable:
*_template, *_timer, *_sht, *_ops, *_probe, *_probe_one, *_console,
Signed-off-by: Bryan Wu <bryan.wu@canonical.com>
Cc: Paul Walmsley <paul@pwsan.com>
Signed-off-by: Tony Lindgren <tony@atomide.com>
2010-12-08 02:41:25 +00:00
. reset_gpio_port [ 0 ] = OMAP_MAX_GPIO_LINES + 6 ,
. reset_gpio_port [ 1 ] = OMAP_MAX_GPIO_LINES + 7 ,
2009-11-18 18:41:07 -08:00
. reset_gpio_port [ 2 ] = - EINVAL
} ;
2012-02-05 13:39:40 +02:00
static void __init cm_t35_init_usbh ( void )
2011-12-13 10:48:53 -08:00
{
int err ;
err = gpio_request_one ( SB_T35_USB_HUB_RESET_GPIO ,
GPIOF_OUT_INIT_LOW , " usb hub rst " ) ;
if ( err ) {
pr_err ( " SB-T35: usb hub rst gpio request failed: %d \n " , err ) ;
} else {
udelay ( 10 ) ;
gpio_set_value ( SB_T35_USB_HUB_RESET_GPIO , 1 ) ;
msleep ( 1 ) ;
}
usbhs_init ( & usbhs_bdata ) ;
}
2009-11-18 18:41:07 -08:00
static int cm_t35_twl_gpio_setup ( struct device * dev , unsigned gpio ,
unsigned ngpio )
{
int wlan_rst = gpio + 2 ;
2011-05-03 18:22:09 +03:00
if ( gpio_request_one ( wlan_rst , GPIOF_OUT_INIT_HIGH , " WLAN RST " ) = = 0 ) {
2009-11-18 18:41:07 -08:00
gpio_export ( wlan_rst , 0 ) ;
udelay ( 10 ) ;
2011-07-04 04:09:31 -07:00
gpio_set_value_cansleep ( wlan_rst , 0 ) ;
2009-11-18 18:41:07 -08:00
udelay ( 10 ) ;
2011-07-04 04:09:31 -07:00
gpio_set_value_cansleep ( wlan_rst , 1 ) ;
2009-11-18 18:41:07 -08:00
} else {
pr_err ( " CM-T35: could not obtain gpio for WiFi reset \n " ) ;
}
/* gpio + 0 is "mmc0_cd" (input/IRQ) */
mmc [ 0 ] . gpio_cd = gpio + 0 ;
2012-02-20 09:43:29 -08:00
omap_hsmmc_late_init ( mmc ) ;
2009-11-18 18:41:07 -08:00
return 0 ;
}
static struct twl4030_gpio_platform_data cm_t35_gpio_data = {
. setup = cm_t35_twl_gpio_setup ,
} ;
2012-05-09 14:19:13 -07:00
static struct twl4030_power_data cm_t35_power_data = {
. use_poweroff = true ,
} ;
2009-11-18 18:41:07 -08:00
static struct twl4030_platform_data cm_t35_twldata = {
/* platform_data for children goes here */
. keypad = & cm_t35_kp_data ,
. gpio = & cm_t35_gpio_data ,
. vmmc1 = & cm_t35_vmmc1 ,
. vsim = & cm_t35_vsim ,
2011-12-13 10:48:51 -08:00
. vio = & cm_t35_vio ,
2012-05-09 14:19:13 -07:00
. power = & cm_t35_power_data ,
2009-11-18 18:41:07 -08:00
} ;
2012-06-13 15:55:09 +03:00
# if defined(CONFIG_VIDEO_OMAP3) || defined(CONFIG_VIDEO_OMAP3_MODULE)
# include <media/omap3isp.h>
# include "devices.h"
static struct i2c_board_info cm_t35_isp_i2c_boardinfo [ ] = {
{
I2C_BOARD_INFO ( " mt9t001 " , 0x5d ) ,
} ,
2012-06-13 15:55:10 +03:00
{
I2C_BOARD_INFO ( " tvp5150 " , 0x5c ) ,
} ,
2012-06-13 15:55:09 +03:00
} ;
static struct isp_subdev_i2c_board_info cm_t35_isp_primary_subdevs [ ] = {
{
. board_info = & cm_t35_isp_i2c_boardinfo [ 0 ] ,
. i2c_adapter_id = 3 ,
} ,
{ NULL , 0 , } ,
} ;
2012-06-13 15:55:10 +03:00
static struct isp_subdev_i2c_board_info cm_t35_isp_secondary_subdevs [ ] = {
{
. board_info = & cm_t35_isp_i2c_boardinfo [ 1 ] ,
. i2c_adapter_id = 3 ,
} ,
{ NULL , 0 , } ,
} ;
2012-06-13 15:55:09 +03:00
static struct isp_v4l2_subdevs_group cm_t35_isp_subdevs [ ] = {
{
. subdevs = cm_t35_isp_primary_subdevs ,
. interface = ISP_INTERFACE_PARALLEL ,
. bus = {
. parallel = {
. clk_pol = 1 ,
} ,
} ,
} ,
2012-06-13 15:55:10 +03:00
{
. subdevs = cm_t35_isp_secondary_subdevs ,
. interface = ISP_INTERFACE_PARALLEL ,
. bus = {
. parallel = {
. clk_pol = 0 ,
} ,
} ,
} ,
2012-06-13 15:55:09 +03:00
{ NULL , 0 , } ,
} ;
static struct isp_platform_data cm_t35_isp_pdata = {
. subdevs = cm_t35_isp_subdevs ,
} ;
static void __init cm_t35_init_camera ( void )
{
if ( omap3_init_camera ( & cm_t35_isp_pdata ) < 0 )
pr_warn ( " CM-T3x: Failed registering camera device! \n " ) ;
}
# else
static inline void cm_t35_init_camera ( void ) { }
# endif /* CONFIG_VIDEO_OMAP3 */
2009-11-18 18:41:07 -08:00
static void __init cm_t35_init_i2c ( void )
{
2011-06-07 11:38:24 +03:00
omap3_pmic_get_config ( & cm_t35_twldata , TWL_COMMON_PDATA_USB ,
2011-12-13 10:48:52 -08:00
TWL_COMMON_REGULATOR_VDAC |
TWL_COMMON_PDATA_AUDIO ) ;
2011-06-07 11:38:24 +03:00
2011-04-25 01:09:06 +03:00
omap3_pmic_init ( " tps65930 " , & cm_t35_twldata ) ;
2012-06-13 15:55:09 +03:00
omap_register_i2c_bus ( 3 , 400 , NULL , 0 ) ;
2009-11-18 18:41:07 -08:00
}
2011-03-11 11:39:51 -08:00
# ifdef CONFIG_OMAP_MUX
2009-12-11 16:16:32 -08:00
static struct omap_board_mux board_mux [ ] __initdata = {
2009-12-11 16:16:35 -08:00
/* nCS and IRQ for CM-T35 ethernet */
OMAP3_MUX ( GPMC_NCS5 , OMAP_MUX_MODE0 ) ,
OMAP3_MUX ( UART3_CTS_RCTX , OMAP_MUX_MODE4 | OMAP_PIN_INPUT_PULLUP ) ,
/* nCS and IRQ for SB-T35 ethernet */
OMAP3_MUX ( GPMC_NCS4 , OMAP_MUX_MODE0 ) ,
OMAP3_MUX ( GPMC_WAIT3 , OMAP_MUX_MODE4 | OMAP_PIN_INPUT_PULLUP ) ,
/* PENDOWN GPIO */
OMAP3_MUX ( GPMC_NCS6 , OMAP_MUX_MODE4 | OMAP_PIN_INPUT ) ,
/* mUSB */
OMAP3_MUX ( HSUSB0_CLK , OMAP_MUX_MODE0 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( HSUSB0_STP , OMAP_MUX_MODE0 | OMAP_PIN_OUTPUT ) ,
OMAP3_MUX ( HSUSB0_DIR , OMAP_MUX_MODE0 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( HSUSB0_NXT , OMAP_MUX_MODE0 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( HSUSB0_DATA0 , OMAP_MUX_MODE0 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( HSUSB0_DATA1 , OMAP_MUX_MODE0 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( HSUSB0_DATA2 , OMAP_MUX_MODE0 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( HSUSB0_DATA3 , OMAP_MUX_MODE0 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( HSUSB0_DATA4 , OMAP_MUX_MODE0 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( HSUSB0_DATA5 , OMAP_MUX_MODE0 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( HSUSB0_DATA6 , OMAP_MUX_MODE0 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( HSUSB0_DATA7 , OMAP_MUX_MODE0 | OMAP_PIN_INPUT ) ,
/* MMC 2 */
OMAP3_MUX ( SDMMC2_DAT4 , OMAP_MUX_MODE1 | OMAP_PIN_OUTPUT ) ,
OMAP3_MUX ( SDMMC2_DAT5 , OMAP_MUX_MODE1 | OMAP_PIN_OUTPUT ) ,
OMAP3_MUX ( SDMMC2_DAT6 , OMAP_MUX_MODE1 | OMAP_PIN_OUTPUT ) ,
OMAP3_MUX ( SDMMC2_DAT7 , OMAP_MUX_MODE1 | OMAP_PIN_INPUT ) ,
/* McSPI 1 */
OMAP3_MUX ( MCSPI1_CLK , OMAP_MUX_MODE0 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( MCSPI1_SIMO , OMAP_MUX_MODE0 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( MCSPI1_SOMI , OMAP_MUX_MODE0 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( MCSPI1_CS0 , OMAP_MUX_MODE0 | OMAP_PIN_INPUT_PULLDOWN ) ,
/* McSPI 4 */
OMAP3_MUX ( MCBSP1_CLKR , OMAP_MUX_MODE1 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( MCBSP1_DX , OMAP_MUX_MODE1 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( MCBSP1_DR , OMAP_MUX_MODE1 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( MCBSP1_FSX , OMAP_MUX_MODE1 | OMAP_PIN_INPUT_PULLUP ) ,
/* McBSP 2 */
OMAP3_MUX ( MCBSP2_FSX , OMAP_MUX_MODE0 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( MCBSP2_CLKX , OMAP_MUX_MODE0 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( MCBSP2_DR , OMAP_MUX_MODE0 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( MCBSP2_DX , OMAP_MUX_MODE0 | OMAP_PIN_OUTPUT ) ,
/* serial ports */
OMAP3_MUX ( MCBSP3_CLKX , OMAP_MUX_MODE1 | OMAP_PIN_OUTPUT ) ,
OMAP3_MUX ( MCBSP3_FSX , OMAP_MUX_MODE1 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( UART1_TX , OMAP_MUX_MODE0 | OMAP_PIN_OUTPUT ) ,
OMAP3_MUX ( UART1_RX , OMAP_MUX_MODE0 | OMAP_PIN_INPUT ) ,
2011-07-05 03:38:23 -07:00
/* common DSS */
2009-12-11 16:16:35 -08:00
OMAP3_MUX ( DSS_PCLK , OMAP_MUX_MODE0 | OMAP_PIN_OUTPUT ) ,
OMAP3_MUX ( DSS_HSYNC , OMAP_MUX_MODE0 | OMAP_PIN_OUTPUT ) ,
OMAP3_MUX ( DSS_VSYNC , OMAP_MUX_MODE0 | OMAP_PIN_OUTPUT ) ,
OMAP3_MUX ( DSS_ACBIAS , OMAP_MUX_MODE0 | OMAP_PIN_OUTPUT ) ,
OMAP3_MUX ( DSS_DATA6 , OMAP_MUX_MODE0 | OMAP_PIN_OUTPUT ) ,
OMAP3_MUX ( DSS_DATA7 , OMAP_MUX_MODE0 | OMAP_PIN_OUTPUT ) ,
OMAP3_MUX ( DSS_DATA8 , OMAP_MUX_MODE0 | OMAP_PIN_OUTPUT ) ,
OMAP3_MUX ( DSS_DATA9 , OMAP_MUX_MODE0 | OMAP_PIN_OUTPUT ) ,
OMAP3_MUX ( DSS_DATA10 , OMAP_MUX_MODE0 | OMAP_PIN_OUTPUT ) ,
OMAP3_MUX ( DSS_DATA11 , OMAP_MUX_MODE0 | OMAP_PIN_OUTPUT ) ,
OMAP3_MUX ( DSS_DATA12 , OMAP_MUX_MODE0 | OMAP_PIN_OUTPUT ) ,
OMAP3_MUX ( DSS_DATA13 , OMAP_MUX_MODE0 | OMAP_PIN_OUTPUT ) ,
OMAP3_MUX ( DSS_DATA14 , OMAP_MUX_MODE0 | OMAP_PIN_OUTPUT ) ,
OMAP3_MUX ( DSS_DATA15 , OMAP_MUX_MODE0 | OMAP_PIN_OUTPUT ) ,
OMAP3_MUX ( DSS_DATA16 , OMAP_MUX_MODE0 | OMAP_PIN_OUTPUT ) ,
OMAP3_MUX ( DSS_DATA17 , OMAP_MUX_MODE0 | OMAP_PIN_OUTPUT ) ,
2012-06-13 15:55:09 +03:00
/* Camera */
OMAP3_MUX ( CAM_HS , OMAP_MUX_MODE0 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( CAM_VS , OMAP_MUX_MODE0 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( CAM_XCLKA , OMAP_MUX_MODE0 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( CAM_PCLK , OMAP_MUX_MODE0 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( CAM_FLD , OMAP_MUX_MODE0 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( CAM_D0 , OMAP_MUX_MODE0 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( CAM_D1 , OMAP_MUX_MODE0 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( CAM_D2 , OMAP_MUX_MODE0 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( CAM_D3 , OMAP_MUX_MODE0 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( CAM_D4 , OMAP_MUX_MODE0 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( CAM_D5 , OMAP_MUX_MODE0 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( CAM_D6 , OMAP_MUX_MODE0 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( CAM_D7 , OMAP_MUX_MODE0 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( CAM_D8 , OMAP_MUX_MODE0 | OMAP_PIN_INPUT_PULLDOWN ) ,
OMAP3_MUX ( CAM_D9 , OMAP_MUX_MODE0 | OMAP_PIN_INPUT_PULLDOWN ) ,
OMAP3_MUX ( CAM_STROBE , OMAP_MUX_MODE0 | OMAP_PIN_INPUT ) ,
OMAP3_MUX ( CAM_D10 , OMAP_MUX_MODE4 | OMAP_PIN_INPUT_PULLDOWN ) ,
OMAP3_MUX ( CAM_D11 , OMAP_MUX_MODE4 | OMAP_PIN_INPUT_PULLDOWN ) ,
2009-12-14 09:01:08 +01:00
/* display controls */
OMAP3_MUX ( MCBSP1_FSR , OMAP_MUX_MODE4 | OMAP_PIN_OUTPUT ) ,
OMAP3_MUX ( GPMC_NCS7 , OMAP_MUX_MODE4 | OMAP_PIN_OUTPUT ) ,
OMAP3_MUX ( GPMC_NCS3 , OMAP_MUX_MODE4 | OMAP_PIN_OUTPUT ) ,
2009-12-11 16:16:35 -08:00
/* TPS IRQ */
OMAP3_MUX ( SYS_NIRQ , OMAP_MUX_MODE0 | OMAP_WAKEUP_EN | \
OMAP_PIN_INPUT_PULLUP ) ,
2009-12-11 16:16:32 -08:00
{ . reg_offset = OMAP_MUX_TERMINATOR } ,
} ;
2011-07-05 03:38:23 -07:00
static void __init cm_t3x_common_dss_mux_init ( int mux_mode )
{
omap_mux_init_signal ( " dss_data18 " , mux_mode ) ;
omap_mux_init_signal ( " dss_data19 " , mux_mode ) ;
omap_mux_init_signal ( " dss_data20 " , mux_mode ) ;
omap_mux_init_signal ( " dss_data21 " , mux_mode ) ;
omap_mux_init_signal ( " dss_data22 " , mux_mode ) ;
omap_mux_init_signal ( " dss_data23 " , mux_mode ) ;
}
static void __init cm_t35_init_mux ( void )
{
2011-12-13 10:48:53 -08:00
int mux_mode = OMAP_MUX_MODE0 | OMAP_PIN_OUTPUT ;
omap_mux_init_signal ( " dss_data0.dss_data0 " , mux_mode ) ;
omap_mux_init_signal ( " dss_data1.dss_data1 " , mux_mode ) ;
omap_mux_init_signal ( " dss_data2.dss_data2 " , mux_mode ) ;
omap_mux_init_signal ( " dss_data3.dss_data3 " , mux_mode ) ;
omap_mux_init_signal ( " dss_data4.dss_data4 " , mux_mode ) ;
omap_mux_init_signal ( " dss_data5.dss_data5 " , mux_mode ) ;
cm_t3x_common_dss_mux_init ( mux_mode ) ;
2011-07-05 03:38:23 -07:00
}
static void __init cm_t3730_init_mux ( void )
{
2011-12-13 10:48:53 -08:00
int mux_mode = OMAP_MUX_MODE3 | OMAP_PIN_OUTPUT ;
omap_mux_init_signal ( " sys_boot0 " , mux_mode ) ;
omap_mux_init_signal ( " sys_boot1 " , mux_mode ) ;
omap_mux_init_signal ( " sys_boot3 " , mux_mode ) ;
omap_mux_init_signal ( " sys_boot4 " , mux_mode ) ;
omap_mux_init_signal ( " sys_boot5 " , mux_mode ) ;
omap_mux_init_signal ( " sys_boot6 " , mux_mode ) ;
cm_t3x_common_dss_mux_init ( mux_mode ) ;
2011-07-05 03:38:23 -07:00
}
# else
static inline void cm_t35_init_mux ( void ) { }
static inline void cm_t3730_init_mux ( void ) { }
2011-03-11 11:39:51 -08:00
# endif
2009-12-11 16:16:32 -08:00
2011-07-05 03:38:23 -07:00
static void __init cm_t3x_common_init ( void )
2009-11-18 18:41:07 -08:00
{
2009-12-11 16:16:32 -08:00
omap3_mux_init ( board_mux , OMAP_PACKAGE_CUS ) ;
2009-11-18 18:41:07 -08:00
omap_serial_init ( ) ;
2011-08-22 23:57:23 -07:00
omap_sdrc_init ( mt46h32m32lf6_sdrc_params ,
mt46h32m32lf6_sdrc_params ) ;
2012-02-20 09:43:29 -08:00
omap_hsmmc_init ( mmc ) ;
2009-11-18 18:41:07 -08:00
cm_t35_init_i2c ( ) ;
2011-04-25 01:09:05 +03:00
omap_ads7846_init ( 1 , CM_T35_GPIO_PENDOWN , 0 , NULL ) ;
2009-11-18 18:41:07 -08:00
cm_t35_init_ethernet ( ) ;
cm_t35_init_led ( ) ;
2009-12-14 09:01:08 +01:00
cm_t35_init_display ( ) ;
2012-08-14 12:07:58 +03:00
omap_twl4030_audio_init ( " cm-t3x " ) ;
2009-11-18 18:41:07 -08:00
2011-04-27 11:56:12 +03:00
usb_musb_init ( NULL ) ;
2011-12-13 10:48:53 -08:00
cm_t35_init_usbh ( ) ;
2012-06-13 15:55:09 +03:00
cm_t35_init_camera ( ) ;
2009-11-18 18:41:07 -08:00
}
2011-07-05 03:38:23 -07:00
static void __init cm_t35_init ( void )
{
cm_t3x_common_init ( ) ;
cm_t35_init_mux ( ) ;
cm_t35_init_nand ( ) ;
}
static void __init cm_t3730_init ( void )
{
cm_t3x_common_init ( ) ;
cm_t3730_init_mux ( ) ;
}
2009-11-18 18:41:07 -08:00
MACHINE_START ( CM_T35 , " Compulab CM-T35 " )
2011-07-05 22:38:15 -04:00
. atag_offset = 0x100 ,
2010-05-23 10:18:16 +01:00
. reserve = omap_reserve ,
2011-02-14 15:40:20 -08:00
. map_io = omap3_map_io ,
2011-08-22 23:57:24 -07:00
. init_early = omap35xx_init_early ,
2011-05-17 03:51:26 -07:00
. init_irq = omap3_init_irq ,
2011-09-06 10:23:45 +01:00
. handle_irq = omap3_intc_handle_irq ,
2009-11-18 18:41:07 -08:00
. init_machine = cm_t35_init ,
2012-04-26 16:06:50 +08:00
. init_late = omap35xx_init_late ,
2011-03-29 15:54:48 -07:00
. timer = & omap3_timer ,
2011-11-05 17:06:28 +00:00
. restart = omap_prcm_restart ,
2009-11-18 18:41:07 -08:00
MACHINE_END
2011-07-05 03:38:23 -07:00
MACHINE_START ( CM_T3730 , " Compulab CM-T3730 " )
2011-07-05 22:38:15 -04:00
. atag_offset = 0x100 ,
2011-07-05 03:38:23 -07:00
. reserve = omap_reserve ,
. map_io = omap3_map_io ,
2011-08-22 23:57:24 -07:00
. init_early = omap3630_init_early ,
2011-07-05 03:38:23 -07:00
. init_irq = omap3_init_irq ,
2011-09-06 10:23:45 +01:00
. handle_irq = omap3_intc_handle_irq ,
2011-07-05 03:38:23 -07:00
. init_machine = cm_t3730_init ,
2012-04-26 16:06:50 +08:00
. init_late = omap3630_init_late ,
2011-07-05 03:38:23 -07:00
. timer = & omap3_timer ,
2011-11-05 17:06:28 +00:00
. restart = omap_prcm_restart ,
2011-07-05 03:38:23 -07:00
MACHINE_END