2010-09-27 20:05:47 +04:00
/*
* linux / arch / arm / mach - omap2 / board - omap3logic . c
*
* Copyright ( C ) 2010 Li - Pro . Net
* Stephan Linz < linz @ li - pro . net >
*
2012-05-10 01:19:15 +04:00
* Copyright ( C ) 2010 - 2012 Logic Product Development , Inc .
2010-09-27 20:05:47 +04:00
* Peter Barada < peter . barada @ logicpd . com >
2012-05-10 01:19:15 +04:00
* Ashwin BIhari < ashwin . bihari @ logicpd . com >
2010-09-27 20:05:47 +04:00
*
* Modified from Beagle , EVM , and RX51
*
* 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/io.h>
# include <linux/gpio.h>
2012-03-23 13:21:37 +04:00
# include <linux/regulator/fixed.h>
2010-09-27 20:05:47 +04:00
# include <linux/regulator/machine.h>
# include <linux/i2c/twl.h>
2010-09-27 20:05:48 +04:00
# include <linux/mmc/host.h>
2010-09-27 20:05:47 +04:00
# include <mach/hardware.h>
# include <asm/mach-types.h>
# include <asm/mach/arch.h>
# include <asm/mach/map.h>
# include "mux.h"
2010-09-27 20:05:48 +04:00
# include "hsmmc.h"
2010-10-08 21:40:20 +04:00
# include "control.h"
2011-04-25 02:09:06 +04:00
# include "common-board-devices.h"
2010-09-27 20:05:47 +04:00
# include <plat/mux.h>
# include <plat/board.h>
2011-11-11 01:45:17 +04:00
# include "common.h"
2010-09-27 20:05:50 +04:00
# include <plat/gpmc-smsc911x.h>
2010-09-27 20:05:47 +04:00
# include <plat/gpmc.h>
# include <plat/sdrc.h>
2012-05-10 01:19:15 +04:00
# include <plat/usb.h>
2010-09-27 20:05:47 +04:00
# define OMAP3LOGIC_SMSC911X_CS 1
# define OMAP3530_LV_SOM_MMC_GPIO_CD 110
# define OMAP3530_LV_SOM_MMC_GPIO_WP 126
# define OMAP3530_LV_SOM_SMSC911X_GPIO_IRQ 152
# define OMAP3_TORPEDO_MMC_GPIO_CD 127
# define OMAP3_TORPEDO_SMSC911X_GPIO_IRQ 129
2011-06-06 22:57:07 +04:00
static struct regulator_consumer_supply omap3logic_vmmc1_supply [ ] = {
REGULATOR_SUPPLY ( " vmmc " , " omap_hsmmc.0 " ) ,
2010-09-27 20:05:47 +04:00
} ;
/* VMMC1 for MMC1 pins CMD, CLK, DAT0..DAT3 (20 mA, plus card == max 220 mA) */
static struct regulator_init_data omap3logic_vmmc1 = {
. constraints = {
. name = " VMMC1 " ,
. 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 22:57:07 +04:00
. num_consumer_supplies = ARRAY_SIZE ( omap3logic_vmmc1_supply ) ,
. consumer_supplies = omap3logic_vmmc1_supply ,
2010-09-27 20:05:47 +04:00
} ;
static struct twl4030_gpio_platform_data omap3logic_gpio_data = {
. gpio_base = OMAP_MAX_GPIO_LINES ,
. irq_base = TWL4030_GPIO_IRQ_BASE ,
. irq_end = TWL4030_GPIO_IRQ_END ,
. use_leds = true ,
. pullups = BIT ( 1 ) ,
. pulldowns = BIT ( 2 ) | BIT ( 6 ) | BIT ( 7 ) | BIT ( 8 )
| BIT ( 13 ) | BIT ( 15 ) | BIT ( 16 ) | BIT ( 17 ) ,
} ;
2012-05-10 01:19:15 +04:00
static struct twl4030_usb_data omap3logic_usb_data = {
. usb_mode = T2_USB_MODE_ULPI ,
} ;
2010-09-27 20:05:47 +04:00
static struct twl4030_platform_data omap3logic_twldata = {
/* platform_data for children goes here */
. gpio = & omap3logic_gpio_data ,
2010-09-27 20:05:48 +04:00
. vmmc1 = & omap3logic_vmmc1 ,
2012-05-10 01:19:15 +04:00
. usb = & omap3logic_usb_data ,
2010-09-27 20:05:47 +04:00
} ;
static int __init omap3logic_i2c_init ( void )
{
2011-04-25 02:09:06 +04:00
omap3_pmic_init ( " twl4030 " , & omap3logic_twldata ) ;
2010-09-27 20:05:47 +04:00
return 0 ;
}
2010-09-27 20:05:48 +04:00
static struct omap2_hsmmc_info __initdata board_mmc_info [ ] = {
{
. name = " external " ,
. mmc = 1 ,
. caps = MMC_CAP_4_BIT_DATA ,
. gpio_cd = - EINVAL ,
. gpio_wp = - EINVAL ,
} ,
{ } /* Terminator */
} ;
static void __init board_mmc_init ( void )
{
if ( machine_is_omap3530_lv_som ( ) ) {
/* OMAP3530 LV SOM board */
board_mmc_info [ 0 ] . gpio_cd = OMAP3530_LV_SOM_MMC_GPIO_CD ;
board_mmc_info [ 0 ] . gpio_wp = OMAP3530_LV_SOM_MMC_GPIO_WP ;
omap_mux_init_signal ( " gpio_110 " , OMAP_PIN_OUTPUT ) ;
omap_mux_init_signal ( " gpio_126 " , OMAP_PIN_OUTPUT ) ;
} else if ( machine_is_omap3_torpedo ( ) ) {
/* OMAP3 Torpedo board */
board_mmc_info [ 0 ] . gpio_cd = OMAP3_TORPEDO_MMC_GPIO_CD ;
omap_mux_init_signal ( " gpio_127 " , OMAP_PIN_OUTPUT ) ;
} else {
/* unsupported board */
printk ( KERN_ERR " %s(): unknown machine type \n " , __func__ ) ;
return ;
}
2012-02-20 21:43:29 +04:00
omap_hsmmc_init ( board_mmc_info ) ;
2010-09-27 20:05:48 +04:00
}
2010-09-27 20:05:50 +04:00
static struct omap_smsc911x_platform_data __initdata board_smsc911x_data = {
. cs = OMAP3LOGIC_SMSC911X_CS ,
. gpio_irq = - EINVAL ,
. gpio_reset = - EINVAL ,
} ;
/* TODO/FIXME (comment by Peter Barada, LogicPD):
* Fix the PBIAS voltage for Torpedo MMC1 pins that
* are used for other needs ( IRQs , etc ) . */
static void omap3torpedo_fix_pbias_voltage ( void )
{
u16 control_pbias_offset = OMAP343X_CONTROL_PBIAS_LITE ;
u32 reg ;
if ( machine_is_omap3_torpedo ( ) )
{
/* Set the bias for the pin */
reg = omap_ctrl_readl ( control_pbias_offset ) ;
reg & = ~ OMAP343X_PBIASLITEPWRDNZ1 ;
omap_ctrl_writel ( reg , control_pbias_offset ) ;
/* 100ms delay required for PBIAS configuration */
msleep ( 100 ) ;
reg | = OMAP343X_PBIASLITEVMODE1 ;
reg | = OMAP343X_PBIASLITEPWRDNZ1 ;
omap_ctrl_writel ( reg | 0x300 , control_pbias_offset ) ;
}
}
static inline void __init board_smsc911x_init ( void )
{
if ( machine_is_omap3530_lv_som ( ) ) {
/* OMAP3530 LV SOM board */
board_smsc911x_data . gpio_irq =
OMAP3530_LV_SOM_SMSC911X_GPIO_IRQ ;
omap_mux_init_signal ( " gpio_152 " , OMAP_PIN_INPUT ) ;
} else if ( machine_is_omap3_torpedo ( ) ) {
/* OMAP3 Torpedo board */
board_smsc911x_data . gpio_irq = OMAP3_TORPEDO_SMSC911X_GPIO_IRQ ;
omap_mux_init_signal ( " gpio_129 " , OMAP_PIN_INPUT ) ;
} else {
/* unsupported board */
printk ( KERN_ERR " %s(): unknown machine type \n " , __func__ ) ;
return ;
}
gpmc_smsc911x_init ( & board_smsc911x_data ) ;
}
# ifdef CONFIG_OMAP_MUX
static struct omap_board_mux board_mux [ ] __initdata = {
2012-05-10 01:19:15 +04:00
/* 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 ) ,
2010-09-27 20:05:50 +04:00
{ . reg_offset = OMAP_MUX_TERMINATOR } ,
} ;
# endif
2012-03-23 13:21:37 +04:00
static struct regulator_consumer_supply dummy_supplies [ ] = {
REGULATOR_SUPPLY ( " vddvario " , " smsc911x.0 " ) ,
REGULATOR_SUPPLY ( " vdd33a " , " smsc911x.0 " ) ,
} ;
2010-09-27 20:05:47 +04:00
static void __init omap3logic_init ( void )
{
2012-03-23 13:21:37 +04:00
regulator_register_fixed ( 0 , dummy_supplies , ARRAY_SIZE ( dummy_supplies ) ) ;
2010-09-27 20:05:50 +04:00
omap3_mux_init ( board_mux , OMAP_PACKAGE_CBB ) ;
omap3torpedo_fix_pbias_voltage ( ) ;
2010-09-27 20:05:47 +04:00
omap3logic_i2c_init ( ) ;
omap_serial_init ( ) ;
2011-08-23 10:57:23 +04:00
omap_sdrc_init ( NULL , NULL ) ;
2010-09-27 20:05:48 +04:00
board_mmc_init ( ) ;
2010-09-27 20:05:50 +04:00
board_smsc911x_init ( ) ;
2012-05-10 01:19:15 +04:00
usb_musb_init ( NULL ) ;
2010-09-27 20:05:47 +04:00
/* Ensure SDRC pins are mux'd for self-refresh */
omap_mux_init_signal ( " sdrc_cke0 " , OMAP_PIN_OUTPUT ) ;
omap_mux_init_signal ( " sdrc_cke1 " , OMAP_PIN_OUTPUT ) ;
}
MACHINE_START ( OMAP3_TORPEDO , " Logic OMAP3 Torpedo board " )
2011-07-06 06:38:15 +04:00
. atag_offset = 0x100 ,
2012-03-05 23:08:35 +04:00
. reserve = omap_reserve ,
2010-09-27 20:05:47 +04:00
. map_io = omap3_map_io ,
2011-08-23 10:57:24 +04:00
. init_early = omap35xx_init_early ,
2011-05-17 14:51:26 +04:00
. init_irq = omap3_init_irq ,
2011-09-06 13:23:45 +04:00
. handle_irq = omap3_intc_handle_irq ,
2010-09-27 20:05:47 +04:00
. init_machine = omap3logic_init ,
2012-04-26 12:06:50 +04:00
. init_late = omap35xx_init_late ,
2011-03-30 02:54:48 +04:00
. timer = & omap3_timer ,
2011-11-05 21:06:28 +04:00
. restart = omap_prcm_restart ,
2010-09-27 20:05:47 +04:00
MACHINE_END
MACHINE_START ( OMAP3530_LV_SOM , " OMAP Logic 3530 LV SOM board " )
2011-07-06 06:38:15 +04:00
. atag_offset = 0x100 ,
2012-03-05 23:08:35 +04:00
. reserve = omap_reserve ,
2010-09-27 20:05:47 +04:00
. map_io = omap3_map_io ,
2011-08-23 10:57:24 +04:00
. init_early = omap35xx_init_early ,
2011-05-17 14:51:26 +04:00
. init_irq = omap3_init_irq ,
2011-09-06 13:23:45 +04:00
. handle_irq = omap3_intc_handle_irq ,
2010-09-27 20:05:47 +04:00
. init_machine = omap3logic_init ,
2012-04-26 12:06:50 +04:00
. init_late = omap35xx_init_late ,
2011-03-30 02:54:48 +04:00
. timer = & omap3_timer ,
2011-11-05 21:06:28 +04:00
. restart = omap_prcm_restart ,
2010-09-27 20:05:47 +04:00
MACHINE_END