2009-05-29 01:13:28 +04:00
/*
* linux / arch / arm / mach - omap2 / board - omap3evm . c
*
* Copyright ( C ) 2008 Texas Instruments
*
* Modified from mach - omap2 / board - 3430 sdp . c
*
* Initial code : Syed Mohammed Khasim
*
* 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/init.h>
# include <linux/platform_device.h>
# include <linux/delay.h>
# include <linux/err.h>
# include <linux/clk.h>
# include <linux/gpio.h>
# include <linux/input.h>
2009-10-23 01:43:17 +04:00
# include <linux/input/matrix_keypad.h>
2009-05-29 01:13:28 +04:00
# include <linux/leds.h>
2009-11-22 21:11:30 +03:00
# include <linux/interrupt.h>
2009-05-29 01:13:28 +04:00
# include <linux/spi/spi.h>
# include <linux/spi/ads7846.h>
2009-12-15 17:39:02 +03:00
# include <linux/i2c/twl.h>
2009-07-29 10:28:57 +04:00
# include <linux/usb/otg.h>
2009-11-22 21:11:30 +03:00
# include <linux/smsc911x.h>
2009-05-29 01:13:28 +04:00
2009-11-22 21:11:29 +03:00
# include <linux/regulator/machine.h>
2009-05-29 01:13:28 +04:00
# include <mach/hardware.h>
# include <asm/mach-types.h>
# include <asm/mach/arch.h>
# include <asm/mach/map.h>
2009-10-20 20:40:47 +04:00
# include <plat/board.h>
# include <plat/usb.h>
# include <plat/common.h>
# include <plat/mcspi.h>
2010-01-04 17:34:16 +03:00
# include <plat/display.h>
2009-05-29 01:13:28 +04:00
2009-12-12 03:16:32 +03:00
# include "mux.h"
2009-05-29 01:13:28 +04:00
# include "sdram-micron-mt46h32m32lf-6.h"
2010-02-15 21:03:34 +03:00
# include "hsmmc.h"
2009-05-29 01:13:28 +04:00
# define OMAP3_EVM_TS_GPIO 175
2009-11-22 21:11:28 +03:00
# define OMAP3_EVM_EHCI_VBUS 22
# define OMAP3_EVM_EHCI_SELECT 61
2009-05-29 01:13:28 +04:00
# define OMAP3EVM_ETHR_START 0x2c000000
# define OMAP3EVM_ETHR_SIZE 1024
2009-11-22 21:11:27 +03:00
# define OMAP3EVM_ETHR_ID_REV 0x50
2009-05-29 01:13:28 +04:00
# define OMAP3EVM_ETHR_GPIO_IRQ 176
2009-11-22 21:11:30 +03:00
# define OMAP3EVM_SMSC911X_CS 5
2009-05-29 01:13:28 +04:00
2009-11-22 21:11:27 +03:00
static u8 omap3_evm_version ;
u8 get_omap3_evm_rev ( void )
{
return omap3_evm_version ;
}
EXPORT_SYMBOL ( get_omap3_evm_rev ) ;
static void __init omap3_evm_get_revision ( void )
{
void __iomem * ioaddr ;
unsigned int smsc_id ;
/* Ethernet PHY ID is stored at ID_REV register */
ioaddr = ioremap_nocache ( OMAP3EVM_ETHR_START , SZ_1K ) ;
if ( ! ioaddr )
return ;
smsc_id = readl ( ioaddr + OMAP3EVM_ETHR_ID_REV ) & 0xFFFF0000 ;
iounmap ( ioaddr ) ;
switch ( smsc_id ) {
/*SMSC9115 chipset*/
case 0x01150000 :
omap3_evm_version = OMAP3EVM_BOARD_GEN_1 ;
break ;
/*SMSC 9220 chipset*/
case 0x92200000 :
default :
omap3_evm_version = OMAP3EVM_BOARD_GEN_2 ;
}
}
2009-11-22 21:11:30 +03:00
# if defined(CONFIG_SMSC911X) || defined(CONFIG_SMSC911X_MODULE)
static struct resource omap3evm_smsc911x_resources [ ] = {
2009-05-29 01:13:28 +04:00
[ 0 ] = {
. start = OMAP3EVM_ETHR_START ,
. end = ( OMAP3EVM_ETHR_START + OMAP3EVM_ETHR_SIZE - 1 ) ,
. flags = IORESOURCE_MEM ,
} ,
[ 1 ] = {
. start = OMAP_GPIO_IRQ ( OMAP3EVM_ETHR_GPIO_IRQ ) ,
. end = OMAP_GPIO_IRQ ( OMAP3EVM_ETHR_GPIO_IRQ ) ,
2009-11-22 21:11:30 +03:00
. flags = ( IORESOURCE_IRQ | IRQF_TRIGGER_LOW ) ,
2009-05-29 01:13:28 +04:00
} ,
} ;
2009-11-22 21:11:30 +03:00
static struct smsc911x_platform_config smsc911x_config = {
. phy_interface = PHY_INTERFACE_MODE_MII ,
. irq_polarity = SMSC911X_IRQ_POLARITY_ACTIVE_LOW ,
. irq_type = SMSC911X_IRQ_TYPE_OPEN_DRAIN ,
. flags = ( SMSC911X_USE_32BIT | SMSC911X_SAVE_MAC_ADDRESS ) ,
} ;
static struct platform_device omap3evm_smsc911x_device = {
. name = " smsc911x " ,
2009-05-29 01:13:28 +04:00
. id = - 1 ,
2009-11-22 21:11:30 +03:00
. num_resources = ARRAY_SIZE ( omap3evm_smsc911x_resources ) ,
. resource = & omap3evm_smsc911x_resources [ 0 ] ,
. dev = {
. platform_data = & smsc911x_config ,
} ,
2009-05-29 01:13:28 +04:00
} ;
2009-11-22 21:11:30 +03:00
static inline void __init omap3evm_init_smsc911x ( void )
2009-05-29 01:13:28 +04:00
{
int eth_cs ;
struct clk * l3ck ;
unsigned int rate ;
2009-11-22 21:11:30 +03:00
eth_cs = OMAP3EVM_SMSC911X_CS ;
2009-05-29 01:13:28 +04:00
l3ck = clk_get ( NULL , " l3_ck " ) ;
if ( IS_ERR ( l3ck ) )
rate = 100000000 ;
else
rate = clk_get_rate ( l3ck ) ;
2009-11-22 21:11:30 +03:00
if ( gpio_request ( OMAP3EVM_ETHR_GPIO_IRQ , " SMSC911x irq " ) < 0 ) {
printk ( KERN_ERR " Failed to request GPIO%d for smsc911x IRQ \n " ,
2009-05-29 01:13:28 +04:00
OMAP3EVM_ETHR_GPIO_IRQ ) ;
return ;
}
gpio_direction_input ( OMAP3EVM_ETHR_GPIO_IRQ ) ;
2009-11-22 21:11:30 +03:00
platform_device_register ( & omap3evm_smsc911x_device ) ;
2009-05-29 01:13:28 +04:00
}
2009-11-22 21:11:30 +03:00
# else
static inline void __init omap3evm_init_smsc911x ( void ) { return ; }
# endif
2010-01-04 17:34:16 +03:00
/*
* OMAP3EVM LCD Panel control signals
*/
# define OMAP3EVM_LCD_PANEL_LR 2
# define OMAP3EVM_LCD_PANEL_UD 3
# define OMAP3EVM_LCD_PANEL_INI 152
# define OMAP3EVM_LCD_PANEL_ENVDD 153
# define OMAP3EVM_LCD_PANEL_QVGA 154
# define OMAP3EVM_LCD_PANEL_RESB 155
# define OMAP3EVM_LCD_PANEL_BKLIGHT_GPIO 210
# define OMAP3EVM_DVI_PANEL_EN_GPIO 199
static int lcd_enabled ;
static int dvi_enabled ;
static void __init omap3_evm_display_init ( void )
{
int r ;
r = gpio_request ( OMAP3EVM_LCD_PANEL_RESB , " lcd_panel_resb " ) ;
if ( r ) {
printk ( KERN_ERR " failed to get lcd_panel_resb \n " ) ;
return ;
}
gpio_direction_output ( OMAP3EVM_LCD_PANEL_RESB , 1 ) ;
r = gpio_request ( OMAP3EVM_LCD_PANEL_INI , " lcd_panel_ini " ) ;
if ( r ) {
printk ( KERN_ERR " failed to get lcd_panel_ini \n " ) ;
goto err_1 ;
}
gpio_direction_output ( OMAP3EVM_LCD_PANEL_INI , 1 ) ;
r = gpio_request ( OMAP3EVM_LCD_PANEL_QVGA , " lcd_panel_qvga " ) ;
if ( r ) {
printk ( KERN_ERR " failed to get lcd_panel_qvga \n " ) ;
goto err_2 ;
}
gpio_direction_output ( OMAP3EVM_LCD_PANEL_QVGA , 0 ) ;
r = gpio_request ( OMAP3EVM_LCD_PANEL_LR , " lcd_panel_lr " ) ;
if ( r ) {
printk ( KERN_ERR " failed to get lcd_panel_lr \n " ) ;
goto err_3 ;
}
gpio_direction_output ( OMAP3EVM_LCD_PANEL_LR , 1 ) ;
r = gpio_request ( OMAP3EVM_LCD_PANEL_UD , " lcd_panel_ud " ) ;
if ( r ) {
printk ( KERN_ERR " failed to get lcd_panel_ud \n " ) ;
goto err_4 ;
}
gpio_direction_output ( OMAP3EVM_LCD_PANEL_UD , 1 ) ;
r = gpio_request ( OMAP3EVM_LCD_PANEL_ENVDD , " lcd_panel_envdd " ) ;
if ( r ) {
printk ( KERN_ERR " failed to get lcd_panel_envdd \n " ) ;
goto err_5 ;
}
gpio_direction_output ( OMAP3EVM_LCD_PANEL_ENVDD , 0 ) ;
return ;
err_5 :
gpio_free ( OMAP3EVM_LCD_PANEL_UD ) ;
err_4 :
gpio_free ( OMAP3EVM_LCD_PANEL_LR ) ;
err_3 :
gpio_free ( OMAP3EVM_LCD_PANEL_QVGA ) ;
err_2 :
gpio_free ( OMAP3EVM_LCD_PANEL_INI ) ;
err_1 :
gpio_free ( OMAP3EVM_LCD_PANEL_RESB ) ;
}
static int omap3_evm_enable_lcd ( struct omap_dss_device * dssdev )
{
if ( dvi_enabled ) {
printk ( KERN_ERR " cannot enable LCD, DVI is enabled \n " ) ;
return - EINVAL ;
}
gpio_set_value ( OMAP3EVM_LCD_PANEL_ENVDD , 0 ) ;
if ( get_omap3_evm_rev ( ) > = OMAP3EVM_BOARD_GEN_2 )
gpio_set_value ( OMAP3EVM_LCD_PANEL_BKLIGHT_GPIO , 0 ) ;
else
gpio_set_value ( OMAP3EVM_LCD_PANEL_BKLIGHT_GPIO , 1 ) ;
lcd_enabled = 1 ;
return 0 ;
}
static void omap3_evm_disable_lcd ( struct omap_dss_device * dssdev )
{
gpio_set_value ( OMAP3EVM_LCD_PANEL_ENVDD , 1 ) ;
if ( get_omap3_evm_rev ( ) > = OMAP3EVM_BOARD_GEN_2 )
gpio_set_value ( OMAP3EVM_LCD_PANEL_BKLIGHT_GPIO , 1 ) ;
else
gpio_set_value ( OMAP3EVM_LCD_PANEL_BKLIGHT_GPIO , 0 ) ;
lcd_enabled = 0 ;
}
static struct omap_dss_device omap3_evm_lcd_device = {
. name = " lcd " ,
. driver_name = " sharp_ls_panel " ,
. type = OMAP_DISPLAY_TYPE_DPI ,
. phy . dpi . data_lines = 18 ,
. platform_enable = omap3_evm_enable_lcd ,
. platform_disable = omap3_evm_disable_lcd ,
} ;
static int omap3_evm_enable_tv ( struct omap_dss_device * dssdev )
{
return 0 ;
}
static void omap3_evm_disable_tv ( struct omap_dss_device * dssdev )
{
}
static struct omap_dss_device omap3_evm_tv_device = {
. name = " tv " ,
. driver_name = " venc " ,
. type = OMAP_DISPLAY_TYPE_VENC ,
. phy . venc . type = OMAP_DSS_VENC_TYPE_SVIDEO ,
. platform_enable = omap3_evm_enable_tv ,
. platform_disable = omap3_evm_disable_tv ,
} ;
static int omap3_evm_enable_dvi ( struct omap_dss_device * dssdev )
{
if ( lcd_enabled ) {
printk ( KERN_ERR " cannot enable DVI, LCD is enabled \n " ) ;
return - EINVAL ;
}
gpio_set_value ( OMAP3EVM_DVI_PANEL_EN_GPIO , 1 ) ;
dvi_enabled = 1 ;
return 0 ;
}
static void omap3_evm_disable_dvi ( struct omap_dss_device * dssdev )
{
gpio_set_value ( OMAP3EVM_DVI_PANEL_EN_GPIO , 0 ) ;
dvi_enabled = 0 ;
}
static struct omap_dss_device omap3_evm_dvi_device = {
. name = " dvi " ,
. driver_name = " generic_panel " ,
. type = OMAP_DISPLAY_TYPE_DPI ,
. phy . dpi . data_lines = 24 ,
. platform_enable = omap3_evm_enable_dvi ,
. platform_disable = omap3_evm_disable_dvi ,
} ;
static struct omap_dss_device * omap3_evm_dss_devices [ ] = {
& omap3_evm_lcd_device ,
& omap3_evm_tv_device ,
& omap3_evm_dvi_device ,
} ;
static struct omap_dss_board_info omap3_evm_dss_data = {
. num_devices = ARRAY_SIZE ( omap3_evm_dss_devices ) ,
. devices = omap3_evm_dss_devices ,
. default_device = & omap3_evm_lcd_device ,
} ;
static struct platform_device omap3_evm_dss_device = {
. name = " omapdss " ,
. id = - 1 ,
. dev = {
. platform_data = & omap3_evm_dss_data ,
} ,
} ;
2009-11-22 21:11:29 +03:00
static struct regulator_consumer_supply omap3evm_vmmc1_supply = {
. supply = " vmmc " ,
} ;
static struct regulator_consumer_supply omap3evm_vsim_supply = {
. supply = " vmmc_aux " ,
} ;
/* VMMC1 for MMC1 pins CMD, CLK, DAT0..DAT3 (20 mA, plus card == max 220 mA) */
static struct regulator_init_data omap3evm_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 ,
} ,
. num_consumer_supplies = 1 ,
. consumer_supplies = & omap3evm_vmmc1_supply ,
} ;
/* VSIM for MMC1 pins DAT4..DAT7 (2 mA, plus card == max 50 mA) */
static struct regulator_init_data omap3evm_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 ,
} ,
. num_consumer_supplies = 1 ,
. consumer_supplies = & omap3evm_vsim_supply ,
} ;
2010-02-15 21:03:34 +03:00
static struct omap2_hsmmc_info mmc [ ] = {
2009-05-29 01:13:28 +04:00
{
. mmc = 1 ,
. wires = 4 ,
. gpio_cd = - EINVAL ,
. gpio_wp = 63 ,
} ,
{ } /* Terminator */
} ;
static struct gpio_led gpio_leds [ ] = {
{
. name = " omap3evm::ledb " ,
/* normally not visible (board underside) */
. default_trigger = " default-on " ,
. gpio = - EINVAL , /* gets replaced */
. active_low = true ,
} ,
} ;
static struct gpio_led_platform_data gpio_led_info = {
. leds = gpio_leds ,
. num_leds = ARRAY_SIZE ( gpio_leds ) ,
} ;
static struct platform_device leds_gpio = {
. name = " leds-gpio " ,
. id = - 1 ,
. dev = {
. platform_data = & gpio_led_info ,
} ,
} ;
static int omap3evm_twl_gpio_setup ( struct device * dev ,
unsigned gpio , unsigned ngpio )
{
/* gpio + 0 is "mmc0_cd" (input/IRQ) */
2009-12-12 03:16:32 +03:00
omap_mux_init_gpio ( 63 , OMAP_PIN_INPUT ) ;
2009-05-29 01:13:28 +04:00
mmc [ 0 ] . gpio_cd = gpio + 0 ;
2010-02-15 21:03:34 +03:00
omap2_hsmmc_init ( mmc ) ;
2009-05-29 01:13:28 +04:00
2009-11-22 21:11:29 +03:00
/* link regulators to MMC adapters */
omap3evm_vmmc1_supply . dev = mmc [ 0 ] . dev ;
omap3evm_vsim_supply . dev = mmc [ 0 ] . dev ;
2009-05-29 01:13:28 +04:00
/*
* Most GPIOs are for USB OTG . Some are mostly sent to
* the P2 connector ; notably LEDA for the LCD backlight .
*/
2010-01-04 17:34:16 +03:00
/* TWL4030_GPIO_MAX + 0 == ledA, LCD Backlight control */
gpio_request ( gpio + TWL4030_GPIO_MAX , " EN_LCD_BKL " ) ;
gpio_direction_output ( gpio + TWL4030_GPIO_MAX , 0 ) ;
/* gpio + 7 == DVI Enable */
gpio_request ( gpio + 7 , " EN_DVI " ) ;
gpio_direction_output ( gpio + 7 , 0 ) ;
2009-05-29 01:13:28 +04:00
/* TWL4030_GPIO_MAX + 1 == ledB (out, active low LED) */
gpio_leds [ 2 ] . gpio = gpio + TWL4030_GPIO_MAX + 1 ;
platform_device_register ( & leds_gpio ) ;
return 0 ;
}
static struct twl4030_gpio_platform_data omap3evm_gpio_data = {
. gpio_base = OMAP_MAX_GPIO_LINES ,
. irq_base = TWL4030_GPIO_IRQ_BASE ,
. irq_end = TWL4030_GPIO_IRQ_END ,
. use_leds = true ,
. setup = omap3evm_twl_gpio_setup ,
} ;
static struct twl4030_usb_data omap3evm_usb_data = {
. usb_mode = T2_USB_MODE_ULPI ,
} ;
2009-09-25 03:23:16 +04:00
static int board_keymap [ ] = {
2009-05-29 01:13:28 +04:00
KEY ( 0 , 0 , KEY_LEFT ) ,
2010-02-18 01:09:24 +03:00
KEY ( 0 , 1 , KEY_DOWN ) ,
KEY ( 0 , 2 , KEY_ENTER ) ,
KEY ( 0 , 3 , KEY_M ) ,
KEY ( 1 , 0 , KEY_RIGHT ) ,
2009-05-29 01:13:28 +04:00
KEY ( 1 , 1 , KEY_UP ) ,
2010-02-18 01:09:24 +03:00
KEY ( 1 , 2 , KEY_I ) ,
KEY ( 1 , 3 , KEY_N ) ,
KEY ( 2 , 0 , KEY_A ) ,
KEY ( 2 , 1 , KEY_E ) ,
2009-05-29 01:13:28 +04:00
KEY ( 2 , 2 , KEY_J ) ,
2010-02-18 01:09:24 +03:00
KEY ( 2 , 3 , KEY_O ) ,
KEY ( 3 , 0 , KEY_B ) ,
KEY ( 3 , 1 , KEY_F ) ,
KEY ( 3 , 2 , KEY_K ) ,
2009-05-29 01:13:28 +04:00
KEY ( 3 , 3 , KEY_P )
} ;
2009-09-25 03:23:16 +04:00
static struct matrix_keymap_data board_map_data = {
. keymap = board_keymap ,
. keymap_size = ARRAY_SIZE ( board_keymap ) ,
} ;
2009-05-29 01:13:28 +04:00
static struct twl4030_keypad_data omap3evm_kp_data = {
2009-09-25 03:23:16 +04:00
. keymap_data = & board_map_data ,
2009-05-29 01:13:28 +04:00
. rows = 4 ,
. cols = 4 ,
. rep = 1 ,
} ;
static struct twl4030_madc_platform_data omap3evm_madc_data = {
. irq_line = 1 ,
} ;
2009-10-22 14:26:46 +04:00
static struct twl4030_codec_audio_data omap3evm_audio_data = {
. audio_mclk = 26000000 ,
} ;
static struct twl4030_codec_data omap3evm_codec_data = {
2009-11-04 10:58:18 +03:00
. audio_mclk = 26000000 ,
2009-10-22 14:26:46 +04:00
. audio = & omap3evm_audio_data ,
} ;
2010-01-04 17:34:16 +03:00
static struct regulator_consumer_supply omap3_evm_vdda_dac_supply = {
. supply = " vdda_dac " ,
. dev = & omap3_evm_dss_device . dev ,
} ;
/* VDAC for DSS driving S-Video */
static struct regulator_init_data omap3_evm_vdac = {
. 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
| REGULATOR_CHANGE_STATUS ,
} ,
. num_consumer_supplies = 1 ,
. consumer_supplies = & omap3_evm_vdda_dac_supply ,
} ;
/* VPLL2 for digital video outputs */
static struct regulator_consumer_supply omap3_evm_vpll2_supply = {
. supply = " vdvi " ,
. dev = & omap3_evm_lcd_device . dev ,
} ;
static struct regulator_init_data omap3_evm_vpll2 = {
. constraints = {
. name = " VDVI " ,
. min_uV = 1800000 ,
. max_uV = 1800000 ,
. apply_uV = true ,
. valid_modes_mask = REGULATOR_MODE_NORMAL
| REGULATOR_MODE_STANDBY ,
. valid_ops_mask = REGULATOR_CHANGE_MODE
| REGULATOR_CHANGE_STATUS ,
} ,
. num_consumer_supplies = 1 ,
. consumer_supplies = & omap3_evm_vpll2_supply ,
} ;
2009-05-29 01:13:28 +04:00
static struct twl4030_platform_data omap3evm_twldata = {
. irq_base = TWL4030_IRQ_BASE ,
. irq_end = TWL4030_IRQ_END ,
/* platform_data for children goes here */
. keypad = & omap3evm_kp_data ,
. madc = & omap3evm_madc_data ,
. usb = & omap3evm_usb_data ,
. gpio = & omap3evm_gpio_data ,
2009-10-22 14:26:46 +04:00
. codec = & omap3evm_codec_data ,
2010-01-04 17:34:16 +03:00
. vdac = & omap3_evm_vdac ,
. vpll2 = & omap3_evm_vpll2 ,
2009-05-29 01:13:28 +04:00
} ;
static struct i2c_board_info __initdata omap3evm_i2c_boardinfo [ ] = {
{
I2C_BOARD_INFO ( " twl4030 " , 0x48 ) ,
. flags = I2C_CLIENT_WAKE ,
. irq = INT_34XX_SYS_NIRQ ,
. platform_data = & omap3evm_twldata ,
} ,
} ;
static int __init omap3_evm_i2c_init ( void )
{
2009-11-22 21:11:29 +03:00
/*
* REVISIT : These entries can be set in omap3evm_twl_data
* after a merge with MFD tree
*/
omap3evm_twldata . vmmc1 = & omap3evm_vmmc1 ;
omap3evm_twldata . vsim = & omap3evm_vsim ;
2009-05-29 01:13:28 +04:00
omap_register_i2c_bus ( 1 , 2600 , omap3evm_i2c_boardinfo ,
ARRAY_SIZE ( omap3evm_i2c_boardinfo ) ) ;
omap_register_i2c_bus ( 2 , 400 , NULL , 0 ) ;
omap_register_i2c_bus ( 3 , 400 , NULL , 0 ) ;
return 0 ;
}
static void ads7846_dev_init ( void )
{
if ( gpio_request ( OMAP3_EVM_TS_GPIO , " ADS7846 pendown " ) < 0 )
printk ( KERN_ERR " can't get ads7846 pen down GPIO \n " ) ;
gpio_direction_input ( OMAP3_EVM_TS_GPIO ) ;
omap_set_gpio_debounce ( OMAP3_EVM_TS_GPIO , 1 ) ;
omap_set_gpio_debounce_time ( OMAP3_EVM_TS_GPIO , 0xa ) ;
}
static int ads7846_get_pendown_state ( void )
{
return ! gpio_get_value ( OMAP3_EVM_TS_GPIO ) ;
}
struct ads7846_platform_data ads7846_config = {
. x_max = 0x0fff ,
. y_max = 0x0fff ,
. x_plate_ohms = 180 ,
. pressure_max = 255 ,
. debounce_max = 10 ,
. debounce_tol = 3 ,
. debounce_rep = 1 ,
. get_pendown_state = ads7846_get_pendown_state ,
. keep_vref_on = 1 ,
. settle_delay_usecs = 150 ,
2010-05-08 11:09:21 +04:00
. wakeup = true ,
2009-05-29 01:13:28 +04:00
} ;
static struct omap2_mcspi_device_config ads7846_mcspi_config = {
. turbo_mode = 0 ,
. single_channel = 1 , /* 0: slave, 1: master */
} ;
struct spi_board_info omap3evm_spi_board_info [ ] = {
[ 0 ] = {
. modalias = " ads7846 " ,
. bus_num = 1 ,
. chip_select = 0 ,
. max_speed_hz = 1500000 ,
. controller_data = & ads7846_mcspi_config ,
. irq = OMAP_GPIO_IRQ ( OMAP3_EVM_TS_GPIO ) ,
. platform_data = & ads7846_config ,
} ,
} ;
2009-09-03 21:14:02 +04:00
static struct omap_board_config_kernel omap3_evm_config [ ] __initdata = {
} ;
2009-05-29 01:13:28 +04:00
static void __init omap3_evm_init_irq ( void )
{
2009-09-03 21:14:02 +04:00
omap_board_config = omap3_evm_config ;
omap_board_config_size = ARRAY_SIZE ( omap3_evm_config ) ;
2009-07-25 05:43:25 +04:00
omap2_init_common_hw ( mt46h32m32lf6_sdrc_params , NULL ) ;
2009-05-29 01:13:28 +04:00
omap_init_irq ( ) ;
omap_gpio_init ( ) ;
}
static struct platform_device * omap3_evm_devices [ ] __initdata = {
2010-01-04 17:34:16 +03:00
& omap3_evm_dss_device ,
2009-05-29 01:13:28 +04:00
} ;
2010-03-04 10:45:53 +03:00
static struct ehci_hcd_omap_platform_data ehci_pdata __initdata = {
2009-11-22 21:11:01 +03:00
. port_mode [ 0 ] = EHCI_HCD_OMAP_MODE_UNKNOWN ,
. port_mode [ 1 ] = EHCI_HCD_OMAP_MODE_PHY ,
. port_mode [ 2 ] = EHCI_HCD_OMAP_MODE_UNKNOWN ,
. phy_reset = true ,
2009-11-22 21:11:28 +03:00
/* PHY reset GPIO will be runtime programmed based on EVM version */
2009-11-22 21:11:01 +03:00
. reset_gpio_port [ 0 ] = - EINVAL ,
2009-11-22 21:11:28 +03:00
. reset_gpio_port [ 1 ] = - EINVAL ,
2009-11-22 21:11:01 +03:00
. reset_gpio_port [ 2 ] = - EINVAL
} ;
2009-12-12 03:16:32 +03:00
# ifdef CONFIG_OMAP_MUX
static struct omap_board_mux board_mux [ ] __initdata = {
2010-02-18 01:09:23 +03:00
OMAP3_MUX ( SYS_NIRQ , OMAP_MUX_MODE0 | OMAP_PIN_INPUT_PULLUP |
2010-05-03 15:37:51 +04:00
OMAP_PIN_OFF_INPUT_PULLUP | OMAP_PIN_OFF_OUTPUT_LOW |
2010-02-18 01:09:23 +03:00
OMAP_PIN_OFF_WAKEUPENABLE ) ,
2010-02-18 01:09:24 +03:00
OMAP3_MUX ( MCSPI1_CS1 , OMAP_MUX_MODE4 | OMAP_PIN_INPUT_PULLUP |
2010-05-08 11:09:21 +04:00
OMAP_PIN_OFF_INPUT_PULLUP | OMAP_PIN_OFF_OUTPUT_LOW ) ,
2009-12-12 03:16:32 +03:00
{ . reg_offset = OMAP_MUX_TERMINATOR } ,
} ;
# else
# define board_mux NULL
# endif
2010-02-18 01:09:30 +03:00
static struct omap_musb_board_data musb_board_data = {
. interface_type = MUSB_INTERFACE_ULPI ,
. mode = MUSB_OTG ,
. power = 100 ,
} ;
2009-05-29 01:13:28 +04:00
static void __init omap3_evm_init ( void )
{
2009-11-22 21:11:27 +03:00
omap3_evm_get_revision ( ) ;
2009-12-12 03:16:32 +03:00
omap3_mux_init ( board_mux , OMAP_PACKAGE_CBB ) ;
2009-11-22 21:11:27 +03:00
2009-05-29 01:13:28 +04:00
omap3_evm_i2c_init ( ) ;
platform_add_devices ( omap3_evm_devices , ARRAY_SIZE ( omap3_evm_devices ) ) ;
spi_register_board_info ( omap3evm_spi_board_info ,
ARRAY_SIZE ( omap3evm_spi_board_info ) ) ;
omap_serial_init ( ) ;
2010-02-18 01:09:29 +03:00
2009-07-29 10:28:57 +04:00
/* OMAP3EVM uses ISP1504 phy and so register nop transceiver */
usb_nop_xceiv_register ( ) ;
2010-02-18 01:09:29 +03:00
2009-11-22 21:11:28 +03:00
if ( get_omap3_evm_rev ( ) > = OMAP3EVM_BOARD_GEN_2 ) {
/* enable EHCI VBUS using GPIO22 */
2009-12-12 03:16:32 +03:00
omap_mux_init_gpio ( 22 , OMAP_PIN_INPUT_PULLUP ) ;
2009-11-22 21:11:28 +03:00
gpio_request ( OMAP3_EVM_EHCI_VBUS , " enable EHCI VBUS " ) ;
gpio_direction_output ( OMAP3_EVM_EHCI_VBUS , 0 ) ;
gpio_set_value ( OMAP3_EVM_EHCI_VBUS , 1 ) ;
/* Select EHCI port on main board */
2009-12-12 03:16:32 +03:00
omap_mux_init_gpio ( 61 , OMAP_PIN_INPUT_PULLUP ) ;
2009-11-22 21:11:28 +03:00
gpio_request ( OMAP3_EVM_EHCI_SELECT , " select EHCI port " ) ;
gpio_direction_output ( OMAP3_EVM_EHCI_SELECT , 0 ) ;
gpio_set_value ( OMAP3_EVM_EHCI_SELECT , 0 ) ;
/* setup EHCI phy reset config */
2009-12-12 03:16:32 +03:00
omap_mux_init_gpio ( 21 , OMAP_PIN_INPUT_PULLUP ) ;
2009-11-22 21:11:28 +03:00
ehci_pdata . reset_gpio_port [ 1 ] = 21 ;
} else {
/* setup EHCI phy reset on MDC */
2009-12-12 03:16:32 +03:00
omap_mux_init_gpio ( 135 , OMAP_PIN_OUTPUT ) ;
2009-11-22 21:11:28 +03:00
ehci_pdata . reset_gpio_port [ 1 ] = 135 ;
}
2010-02-18 01:09:30 +03:00
usb_musb_init ( & musb_board_data ) ;
2009-11-22 21:11:01 +03:00
usb_ehci_init ( & ehci_pdata ) ;
2009-05-29 01:13:28 +04:00
ads7846_dev_init ( ) ;
2009-11-22 21:11:30 +03:00
omap3evm_init_smsc911x ( ) ;
2010-01-04 17:34:16 +03:00
omap3_evm_display_init ( ) ;
2009-05-29 01:13:28 +04:00
}
static void __init omap3_evm_map_io ( void )
{
omap2_set_globals_343x ( ) ;
2010-02-12 23:26:47 +03:00
omap34xx_map_common_io ( ) ;
2009-05-29 01:13:28 +04:00
}
MACHINE_START ( OMAP3EVM , " OMAP3 EVM " )
/* Maintainer: Syed Mohammed Khasim - Texas Instruments */
. phys_io = 0x48000000 ,
2009-10-20 04:25:55 +04:00
. io_pg_offst = ( ( 0xfa000000 ) > > 18 ) & 0xfffc ,
2009-05-29 01:13:28 +04:00
. boot_params = 0x80000100 ,
. map_io = omap3_evm_map_io ,
. init_irq = omap3_evm_init_irq ,
. init_machine = omap3_evm_init ,
. timer = & omap_timer ,
MACHINE_END