2010-10-12 16:12:36 +02:00
/*
* Copyright ( C ) 2010 Eric Benard - eric @ eukrea . com
*
* Based on pcm970 - baseboard . c which is :
* Copyright ( C ) 2008 Juergen Beisert ( kernel @ pengutronix . de )
*
* This program is free software ; you can redistribute it and / or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation ; either version 2
* of the License , or ( at your option ) any later version .
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License
* along with this program ; if not , write to the Free Software
* Foundation , Inc . , 51 Franklin Street , Fifth Floor , Boston ,
* MA 02110 - 1301 , USA .
*/
# include <linux/types.h>
# include <linux/init.h>
# include <linux/gpio.h>
# include <linux/interrupt.h>
# include <linux/leds.h>
# include <linux/platform_device.h>
# include <linux/input.h>
# include <linux/i2c.h>
2012-05-08 09:20:24 +02:00
# include <video/platform_lcd.h>
# include <linux/backlight.h>
2010-10-12 16:12:36 +02:00
# include <asm/mach-types.h>
# include <asm/mach/arch.h>
# include <asm/mach/time.h>
# include <asm/mach/map.h>
2012-09-13 21:01:00 +08:00
# include "common.h"
2010-10-12 16:12:36 +02:00
# include "devices-imx51.h"
2012-09-14 14:14:45 +08:00
# include "hardware.h"
2012-09-13 13:26:00 +08:00
# include "iomux-mx51.h"
2010-10-12 16:12:36 +02:00
2012-05-08 09:20:27 +02:00
static iomux_v3_cfg_t eukrea_mbimxsd51_pads [ ] = {
2010-10-12 16:12:36 +02:00
/* LED */
2010-12-15 09:56:35 +01:00
MX51_PAD_NANDF_D10__GPIO3_30 ,
2010-10-12 16:12:36 +02:00
/* SWITCH */
2011-08-13 12:51:41 -07:00
NEW_PAD_CTRL ( MX51_PAD_NANDF_D9__GPIO3_31 , PAD_CTL_PUS_22K_UP |
2010-12-15 09:56:35 +01:00
PAD_CTL_PKE | PAD_CTL_SRE_FAST |
PAD_CTL_DSE_HIGH | PAD_CTL_PUE | PAD_CTL_HYS ) ,
2010-10-12 16:12:36 +02:00
/* UART2 */
MX51_PAD_UART2_RXD__UART2_RXD ,
MX51_PAD_UART2_TXD__UART2_TXD ,
/* UART 3 */
MX51_PAD_UART3_RXD__UART3_RXD ,
MX51_PAD_UART3_TXD__UART3_TXD ,
MX51_PAD_KEY_COL4__UART3_RTS ,
MX51_PAD_KEY_COL5__UART3_CTS ,
/* SD */
MX51_PAD_SD1_CMD__SD1_CMD ,
MX51_PAD_SD1_CLK__SD1_CLK ,
MX51_PAD_SD1_DATA0__SD1_DATA0 ,
MX51_PAD_SD1_DATA1__SD1_DATA1 ,
MX51_PAD_SD1_DATA2__SD1_DATA2 ,
MX51_PAD_SD1_DATA3__SD1_DATA3 ,
2011-02-25 14:38:31 +01:00
/* SD1 CD */
2011-08-13 12:51:41 -07:00
NEW_PAD_CTRL ( MX51_PAD_GPIO1_0__SD1_CD , PAD_CTL_PUS_22K_UP |
2011-02-25 14:38:31 +01:00
PAD_CTL_PKE | PAD_CTL_SRE_FAST |
PAD_CTL_DSE_HIGH | PAD_CTL_PUE | PAD_CTL_HYS ) ,
2012-05-08 09:20:22 +02:00
/* SSI */
MX51_PAD_AUD3_BB_TXD__AUD3_TXD ,
MX51_PAD_AUD3_BB_RXD__AUD3_RXD ,
MX51_PAD_AUD3_BB_CK__AUD3_TXC ,
MX51_PAD_AUD3_BB_FS__AUD3_TXFS ,
2012-05-08 09:20:24 +02:00
/* LCD Backlight */
MX51_PAD_DI1_D1_CS__GPIO3_4 ,
/* LCD RST */
MX51_PAD_CSI1_D9__GPIO3_13 ,
2010-10-12 16:12:36 +02:00
} ;
2010-11-26 15:20:52 +01:00
# define GPIO_LED1 IMX_GPIO_NR(3, 30)
# define GPIO_SWITCH1 IMX_GPIO_NR(3, 31)
2012-05-08 09:20:24 +02:00
# define GPIO_LCDRST IMX_GPIO_NR(3, 13)
# define GPIO_LCDBL IMX_GPIO_NR(3, 4)
static void eukrea_mbimxsd51_lcd_power_set ( struct plat_lcd_data * pd ,
unsigned int power )
{
if ( power )
gpio_direction_output ( GPIO_LCDRST , 1 ) ;
else
gpio_direction_output ( GPIO_LCDRST , 0 ) ;
}
static struct plat_lcd_data eukrea_mbimxsd51_lcd_power_data = {
. set_power = eukrea_mbimxsd51_lcd_power_set ,
} ;
static struct platform_device eukrea_mbimxsd51_lcd_powerdev = {
. name = " platform-lcd " ,
. dev . platform_data = & eukrea_mbimxsd51_lcd_power_data ,
} ;
static void eukrea_mbimxsd51_bl_set_intensity ( int intensity )
{
if ( intensity )
gpio_direction_output ( GPIO_LCDBL , 1 ) ;
else
gpio_direction_output ( GPIO_LCDBL , 0 ) ;
}
static struct generic_bl_info eukrea_mbimxsd51_bl_info = {
. name = " eukrea_mbimxsd51-bl " ,
. max_intensity = 0xff ,
. default_intensity = 0xff ,
. set_bl_intensity = eukrea_mbimxsd51_bl_set_intensity ,
} ;
static struct platform_device eukrea_mbimxsd51_bl_dev = {
. name = " generic-bl " ,
. id = 1 ,
. dev = {
. platform_data = & eukrea_mbimxsd51_bl_info ,
} ,
} ;
2010-10-12 16:12:36 +02:00
2012-05-08 09:20:27 +02:00
static const struct gpio_led eukrea_mbimxsd51_leds [ ] __initconst = {
2010-10-12 16:12:36 +02:00
{
. name = " led1 " ,
. default_trigger = " heartbeat " ,
. active_low = 1 ,
. gpio = GPIO_LED1 ,
} ,
} ;
2011-05-28 21:05:02 +02:00
static const struct gpio_led_platform_data
2012-05-08 09:20:27 +02:00
eukrea_mbimxsd51_led_info __initconst = {
. leds = eukrea_mbimxsd51_leds ,
. num_leds = ARRAY_SIZE ( eukrea_mbimxsd51_leds ) ,
2010-10-12 16:12:36 +02:00
} ;
2012-05-08 09:20:27 +02:00
static struct gpio_keys_button eukrea_mbimxsd51_gpio_buttons [ ] = {
2010-10-12 16:12:36 +02:00
{
. gpio = GPIO_SWITCH1 ,
. code = BTN_0 ,
. desc = " BP1 " ,
. active_low = 1 ,
. wakeup = 1 ,
} ,
} ;
2011-02-28 18:04:33 +01:00
static const struct gpio_keys_platform_data
2012-05-08 09:20:27 +02:00
eukrea_mbimxsd51_button_data __initconst = {
. buttons = eukrea_mbimxsd51_gpio_buttons ,
. nbuttons = ARRAY_SIZE ( eukrea_mbimxsd51_gpio_buttons ) ,
2010-10-12 16:12:36 +02:00
} ;
static const struct imxuart_platform_data uart_pdata __initconst = {
. flags = IMXUART_HAVE_RTSCTS ,
} ;
2012-05-08 09:20:27 +02:00
static struct i2c_board_info eukrea_mbimxsd51_i2c_devices [ ] = {
2010-10-12 16:12:36 +02:00
{
I2C_BOARD_INFO ( " tlv320aic23 " , 0x1a ) ,
} ,
} ;
2012-05-08 09:20:22 +02:00
static const
2012-05-08 09:20:27 +02:00
struct imx_ssi_platform_data eukrea_mbimxsd51_ssi_pdata __initconst = {
2012-05-08 09:20:22 +02:00
. flags = IMX_SSI_SYN | IMX_SSI_NET | IMX_SSI_USE_I2S_SLAVE ,
} ;
2012-05-08 09:20:24 +02:00
static int screen_type ;
static int __init eukrea_mbimxsd51_screen_type ( char * options )
{
if ( ! strcmp ( options , " dvi " ) )
screen_type = 1 ;
else if ( ! strcmp ( options , " tft " ) )
screen_type = 0 ;
return 0 ;
}
__setup ( " screen_type= " , eukrea_mbimxsd51_screen_type ) ;
2010-10-12 16:12:36 +02:00
/*
* system init for baseboard usage . Will be called by cpuimx51sd init .
*
* Add platform devices present on this baseboard and init
* them from CPU side as far as required to use them later on
*/
void __init eukrea_mbimxsd51_baseboard_init ( void )
{
2012-05-08 09:20:27 +02:00
if ( mxc_iomux_v3_setup_multiple_pads ( eukrea_mbimxsd51_pads ,
ARRAY_SIZE ( eukrea_mbimxsd51_pads ) ) )
2010-10-12 16:12:36 +02:00
printk ( KERN_ERR " error setting mbimxsd pads ! \n " ) ;
imx51_add_imx_uart ( 1 , NULL ) ;
imx51_add_imx_uart ( 2 , & uart_pdata ) ;
2010-11-19 21:03:33 +01:00
imx51_add_sdhci_esdhc_imx ( 0 , NULL ) ;
2010-10-12 16:12:36 +02:00
2012-05-08 09:20:27 +02:00
imx51_add_imx_ssi ( 0 , & eukrea_mbimxsd51_ssi_pdata ) ;
2012-05-08 09:20:22 +02:00
2010-10-12 16:12:36 +02:00
gpio_request ( GPIO_LED1 , " LED1 " ) ;
gpio_direction_output ( GPIO_LED1 , 1 ) ;
gpio_free ( GPIO_LED1 ) ;
gpio_request ( GPIO_SWITCH1 , " SWITCH1 " ) ;
gpio_direction_input ( GPIO_SWITCH1 ) ;
gpio_free ( GPIO_SWITCH1 ) ;
2012-05-08 09:20:24 +02:00
gpio_request ( GPIO_LCDRST , " LCDRST " ) ;
gpio_direction_output ( GPIO_LCDRST , 0 ) ;
gpio_request ( GPIO_LCDBL , " LCDBL " ) ;
gpio_direction_output ( GPIO_LCDBL , 0 ) ;
if ( ! screen_type ) {
platform_device_register ( & eukrea_mbimxsd51_bl_dev ) ;
platform_device_register ( & eukrea_mbimxsd51_lcd_powerdev ) ;
} else {
gpio_free ( GPIO_LCDRST ) ;
gpio_free ( GPIO_LCDBL ) ;
}
2012-05-08 09:20:27 +02:00
i2c_register_board_info ( 0 , eukrea_mbimxsd51_i2c_devices ,
ARRAY_SIZE ( eukrea_mbimxsd51_i2c_devices ) ) ;
2010-10-12 16:12:36 +02:00
2012-05-08 09:20:27 +02:00
gpio_led_register_device ( - 1 , & eukrea_mbimxsd51_led_info ) ;
imx_add_gpio_keys ( & eukrea_mbimxsd51_button_data ) ;
2012-09-22 12:27:31 -03:00
imx_add_platform_device ( " eukrea_tlv320 " , 0 , NULL , 0 , NULL , 0 ) ;
2010-10-12 16:12:36 +02:00
}