2011-04-29 15:06:39 +02:00
/*
* board setup for STMP378x - Development - Board
*
* based on mx23evk board setup and information gained form the original
* plat - stmp based board setup , now converted to mach - mxs .
*
* Copyright 2010 Freescale Semiconductor , Inc . All Rights Reserved .
* Copyright ( C ) 2011 Wolfram Sang , Pengutronix e . K .
*
* 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 ; version 2 of the License .
*
* 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/platform_device.h>
# include <linux/gpio.h>
# include <linux/spi/spi.h>
# include <asm/mach-types.h>
# include <asm/mach/arch.h>
# include <asm/mach/time.h>
# include <mach/common.h>
# include <mach/iomux-mx23.h>
# include "devices-mx23.h"
# define STMP378X_DEVB_MMC0_WRITE_PROTECT MXS_GPIO_NR(1, 30)
# define STMP378X_DEVB_MMC0_SLOT_POWER MXS_GPIO_NR(1, 29)
# define STMP378X_DEVB_PAD_AUART (MXS_PAD_4MA | MXS_PAD_1V8 | MXS_PAD_NOPULL)
static const iomux_cfg_t stmp378x_dvb_pads [ ] __initconst = {
/* duart (extended setup missing in old boardcode, too */
MX23_PAD_PWM0__DUART_RX ,
MX23_PAD_PWM1__DUART_TX ,
/* auart */
MX23_PAD_AUART1_RX__AUART1_RX | STMP378X_DEVB_PAD_AUART ,
MX23_PAD_AUART1_TX__AUART1_TX | STMP378X_DEVB_PAD_AUART ,
MX23_PAD_AUART1_CTS__AUART1_CTS | STMP378X_DEVB_PAD_AUART ,
MX23_PAD_AUART1_RTS__AUART1_RTS | STMP378X_DEVB_PAD_AUART ,
/* mmc */
MX23_PAD_SSP1_DATA0__SSP1_DATA0 |
( MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP ) ,
MX23_PAD_SSP1_DATA1__SSP1_DATA1 |
( MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP ) ,
MX23_PAD_SSP1_DATA2__SSP1_DATA2 |
( MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP ) ,
MX23_PAD_SSP1_DATA3__SSP1_DATA3 |
( MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP ) ,
MX23_PAD_SSP1_CMD__SSP1_CMD |
( MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP ) ,
MX23_PAD_SSP1_DETECT__SSP1_DETECT |
( MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_NOPULL ) ,
MX23_PAD_SSP1_SCK__SSP1_SCK |
( MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_NOPULL ) ,
MX23_PAD_PWM4__GPIO_1_30 | MXS_PAD_CTRL , /* write protect */
MX23_PAD_PWM3__GPIO_1_29 | MXS_PAD_CTRL , /* power enable */
} ;
static struct mxs_mmc_platform_data stmp378x_dvb_mmc_pdata __initdata = {
. wp_gpio = STMP378X_DEVB_MMC0_WRITE_PROTECT ,
} ;
static struct spi_board_info spi_board_info [ ] __initdata = {
# if defined(CONFIG_ENC28J60) || defined(CONFIG_ENC28J60_MODULE)
{
. modalias = " enc28j60 " ,
. max_speed_hz = 6 * 1000 * 1000 ,
. bus_num = 1 ,
. chip_select = 0 ,
. platform_data = NULL ,
} ,
# endif
} ;
static void __init stmp378x_dvb_init ( void )
{
int ret ;
mxs_iomux_setup_multiple_pads ( stmp378x_dvb_pads ,
ARRAY_SIZE ( stmp378x_dvb_pads ) ) ;
mx23_add_duart ( ) ;
mx23_add_auart0 ( ) ;
2011-05-02 16:26:48 +02:00
mx23_add_rtc_stmp3xxx ( ) ;
2011-04-29 15:06:39 +02:00
/* power on mmc slot */
ret = gpio_request_one ( STMP378X_DEVB_MMC0_SLOT_POWER ,
GPIOF_OUT_INIT_LOW , " mmc0-slot-power " ) ;
if ( ret )
pr_warn ( " could not power mmc (%d) \n " , ret ) ;
mx23_add_mxs_mmc ( 0 , & stmp378x_dvb_mmc_pdata ) ;
spi_register_board_info ( spi_board_info , ARRAY_SIZE ( spi_board_info ) ) ;
}
static void __init stmp378x_dvb_timer_init ( void )
{
mx23_clocks_init ( ) ;
}
static struct sys_timer stmp378x_dvb_timer = {
. init = stmp378x_dvb_timer_init ,
} ;
MACHINE_START ( STMP378X , " STMP378X " )
. map_io = mx23_map_io ,
. init_irq = mx23_init_irq ,
. timer = & stmp378x_dvb_timer ,
2011-11-21 10:55:55 +02:00
. init_machine = stmp378x_dvb_init ,
2011-11-05 15:43:30 +00:00
. restart = mxs_restart ,
2011-04-29 15:06:39 +02:00
MACHINE_END