2008-10-09 17:51:42 +03:00
/*
* linux / arch / arm / mach - omap2 / board - omap3beagle . 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/io.h>
# include <linux/leds.h>
# include <linux/gpio.h>
# include <linux/input.h>
# include <linux/gpio_keys.h>
2011-01-07 09:41:13 -06:00
# include <linux/opp.h>
2008-10-09 17:51:42 +03:00
# include <linux/mtd/mtd.h>
# include <linux/mtd/partitions.h>
# include <linux/mtd/nand.h>
2010-09-15 14:49:23 +00:00
# include <linux/mmc/host.h>
2008-10-09 17:51:42 +03:00
2009-05-28 14:04:03 -07:00
# include <linux/regulator/machine.h>
2009-12-13 20:05:51 +01:00
# include <linux/i2c/twl.h>
2009-01-15 13:09:53 +02:00
2008-10-09 17:51:42 +03:00
# include <mach/hardware.h>
# include <asm/mach-types.h>
# include <asm/mach/arch.h>
# include <asm/mach/map.h>
# include <asm/mach/flash.h>
2009-10-20 09:40:47 -07:00
# include <plat/board.h>
2011-11-10 22:45:17 +01:00
# include "common.h"
2011-05-11 14:05:07 +03:00
# include <video/omapdss.h>
2011-12-22 11:12:13 +02:00
# include <video/omap-panel-tfp410.h>
2009-10-20 09:40:47 -07:00
# include <plat/gpmc.h>
# include <plat/nand.h>
# include <plat/usb.h>
2011-01-07 09:41:13 -06:00
# include <plat/omap_device.h>
2008-10-09 17:51:42 +03:00
2009-12-11 16:16:32 -08:00
# include "mux.h"
2010-02-15 10:03:34 -08:00
# include "hsmmc.h"
2011-01-07 09:41:13 -06:00
# include "pm.h"
2011-04-25 01:09:06 +03:00
# include "common-board-devices.h"
2008-10-09 17:51:42 +03:00
2010-09-23 18:22:47 -07:00
/*
* OMAP3 Beagle revision
* Run time detection of Beagle revision is done by reading GPIO .
* GPIO ID -
* AXBX = GPIO173 , GPIO172 , GPIO171 : 1 1 1
* C1_3 = GPIO173 , GPIO172 , GPIO171 : 1 1 0
* C4 = GPIO173 , GPIO172 , GPIO171 : 1 0 1
2011-07-05 03:38:22 -07:00
* XMA / XMB = GPIO173 , GPIO172 , GPIO171 : 0 0 0
* XMC = GPIO173 , GPIO172 , GPIO171 : 0 1 0
2010-09-23 18:22:47 -07:00
*/
enum {
OMAP3BEAGLE_BOARD_UNKN = 0 ,
OMAP3BEAGLE_BOARD_AXBX ,
OMAP3BEAGLE_BOARD_C1_3 ,
OMAP3BEAGLE_BOARD_C4 ,
OMAP3BEAGLE_BOARD_XM ,
2011-07-05 03:38:22 -07:00
OMAP3BEAGLE_BOARD_XMC ,
2010-09-23 18:22:47 -07:00
} ;
static u8 omap3_beagle_version ;
2011-07-05 03:38:22 -07:00
/*
* Board - specific configuration
* Defaults to BeagleBoard - xMC
*/
static struct {
int mmc1_gpio_wp ;
int usb_pwr_level ;
int reset_gpio ;
int usr_button_gpio ;
2012-05-09 14:19:15 -07:00
int mmc_caps ;
2011-07-05 03:38:22 -07:00
} beagle_config = {
. mmc1_gpio_wp = - EINVAL ,
. usb_pwr_level = GPIOF_OUT_INIT_LOW ,
. reset_gpio = 129 ,
. usr_button_gpio = 4 ,
2012-05-09 14:19:15 -07:00
. mmc_caps = MMC_CAP_4_BIT_DATA | MMC_CAP_8_BIT_DATA ,
2011-07-05 03:38:22 -07:00
} ;
2010-09-23 18:22:47 -07:00
2011-05-03 18:22:09 +03:00
static struct gpio omap3_beagle_rev_gpios [ ] __initdata = {
{ 171 , GPIOF_IN , " rev_id_0 " } ,
{ 172 , GPIOF_IN , " rev_id_1 " } ,
{ 173 , GPIOF_IN , " rev_id_2 " } ,
} ;
2010-09-23 18:22:47 -07:00
static void __init omap3_beagle_init_rev ( void )
{
int ret ;
u16 beagle_rev = 0 ;
omap_mux_init_gpio ( 171 , OMAP_PIN_INPUT_PULLUP ) ;
omap_mux_init_gpio ( 172 , OMAP_PIN_INPUT_PULLUP ) ;
omap_mux_init_gpio ( 173 , OMAP_PIN_INPUT_PULLUP ) ;
2011-05-03 18:22:09 +03:00
ret = gpio_request_array ( omap3_beagle_rev_gpios ,
ARRAY_SIZE ( omap3_beagle_rev_gpios ) ) ;
if ( ret < 0 ) {
printk ( KERN_ERR " Unable to get revision detection GPIO pins \n " ) ;
omap3_beagle_version = OMAP3BEAGLE_BOARD_UNKN ;
return ;
}
2010-09-23 18:22:47 -07:00
beagle_rev = gpio_get_value ( 171 ) | ( gpio_get_value ( 172 ) < < 1 )
| ( gpio_get_value ( 173 ) < < 2 ) ;
2011-05-31 04:58:56 -07:00
gpio_free_array ( omap3_beagle_rev_gpios ,
ARRAY_SIZE ( omap3_beagle_rev_gpios ) ) ;
2010-09-23 18:22:47 -07:00
switch ( beagle_rev ) {
case 7 :
printk ( KERN_INFO " OMAP3 Beagle Rev: Ax/Bx \n " ) ;
omap3_beagle_version = OMAP3BEAGLE_BOARD_AXBX ;
2011-07-05 03:38:22 -07:00
beagle_config . mmc1_gpio_wp = 29 ;
beagle_config . reset_gpio = 170 ;
beagle_config . usr_button_gpio = 7 ;
2010-09-23 18:22:47 -07:00
break ;
case 6 :
printk ( KERN_INFO " OMAP3 Beagle Rev: C1/C2/C3 \n " ) ;
omap3_beagle_version = OMAP3BEAGLE_BOARD_C1_3 ;
2011-07-05 03:38:22 -07:00
beagle_config . mmc1_gpio_wp = 23 ;
beagle_config . reset_gpio = 170 ;
beagle_config . usr_button_gpio = 7 ;
2010-09-23 18:22:47 -07:00
break ;
case 5 :
printk ( KERN_INFO " OMAP3 Beagle Rev: C4 \n " ) ;
omap3_beagle_version = OMAP3BEAGLE_BOARD_C4 ;
2011-07-05 03:38:22 -07:00
beagle_config . mmc1_gpio_wp = 23 ;
beagle_config . reset_gpio = 170 ;
beagle_config . usr_button_gpio = 7 ;
2010-09-23 18:22:47 -07:00
break ;
case 0 :
2011-07-05 03:38:22 -07:00
printk ( KERN_INFO " OMAP3 Beagle Rev: xM Ax/Bx \n " ) ;
2010-09-23 18:22:47 -07:00
omap3_beagle_version = OMAP3BEAGLE_BOARD_XM ;
2011-07-05 03:38:22 -07:00
beagle_config . usb_pwr_level = GPIOF_OUT_INIT_HIGH ;
2012-05-09 14:19:15 -07:00
beagle_config . mmc_caps & = ~ MMC_CAP_8_BIT_DATA ;
2011-07-05 03:38:22 -07:00
break ;
case 2 :
printk ( KERN_INFO " OMAP3 Beagle Rev: xM C \n " ) ;
omap3_beagle_version = OMAP3BEAGLE_BOARD_XMC ;
2012-05-09 14:19:15 -07:00
beagle_config . mmc_caps & = ~ MMC_CAP_8_BIT_DATA ;
2010-09-23 18:22:47 -07:00
break ;
default :
printk ( KERN_INFO " OMAP3 Beagle Rev: unknown %hd \n " , beagle_rev ) ;
omap3_beagle_version = OMAP3BEAGLE_BOARD_UNKN ;
}
}
2008-10-09 17:51:42 +03:00
static struct mtd_partition omap3beagle_nand_partitions [ ] = {
/* All the partition sizes are listed in terms of NAND block size */
{
. name = " X-Loader " ,
. offset = 0 ,
. size = 4 * NAND_BLOCK_SIZE ,
. mask_flags = MTD_WRITEABLE , /* force read-only */
} ,
{
. name = " U-Boot " ,
. offset = MTDPART_OFS_APPEND , /* Offset = 0x80000 */
. size = 15 * NAND_BLOCK_SIZE ,
. mask_flags = MTD_WRITEABLE , /* force read-only */
} ,
{
. name = " U-Boot Env " ,
. offset = MTDPART_OFS_APPEND , /* Offset = 0x260000 */
. size = 1 * NAND_BLOCK_SIZE ,
} ,
{
. name = " Kernel " ,
. offset = MTDPART_OFS_APPEND , /* Offset = 0x280000 */
. size = 32 * NAND_BLOCK_SIZE ,
} ,
{
. name = " File System " ,
. offset = MTDPART_OFS_APPEND , /* Offset = 0x680000 */
. size = MTDPART_SIZ_FULL ,
} ,
} ;
2010-04-22 10:23:42 +02:00
/* DSS */
2012-03-05 14:29:28 +02:00
static struct tfp410_platform_data dvi_panel = {
2011-08-29 17:48:19 +03:00
. i2c_bus_num = 3 ,
2012-02-17 13:30:27 +02:00
. power_down_gpio = - 1 ,
2010-11-17 13:34:34 +00:00
} ;
2010-04-22 10:23:42 +02:00
static struct omap_dss_device beagle_dvi_device = {
. type = OMAP_DISPLAY_TYPE_DPI ,
. name = " dvi " ,
2012-03-05 14:29:28 +02:00
. driver_name = " tfp410 " ,
2010-11-17 13:34:34 +00:00
. data = & dvi_panel ,
2010-04-22 10:23:42 +02:00
. phy . dpi . data_lines = 24 ,
} ;
static struct omap_dss_device beagle_tv_device = {
. name = " tv " ,
. driver_name = " venc " ,
. type = OMAP_DISPLAY_TYPE_VENC ,
. phy . venc . type = OMAP_DSS_VENC_TYPE_SVIDEO ,
} ;
static struct omap_dss_device * beagle_dss_devices [ ] = {
& beagle_dvi_device ,
& beagle_tv_device ,
} ;
static struct omap_dss_board_info beagle_dss_data = {
. num_devices = ARRAY_SIZE ( beagle_dss_devices ) ,
. devices = beagle_dss_devices ,
. default_device = & beagle_dvi_device ,
} ;
2009-05-28 14:03:59 -07:00
# include "sdram-micron-mt46h32m32lf-6.h"
2010-02-15 10:03:34 -08:00
static struct omap2_hsmmc_info mmc [ ] = {
2008-12-10 17:37:17 -08:00
{
. mmc = 1 ,
2012-05-09 14:19:15 -07:00
. caps = MMC_CAP_4_BIT_DATA ,
2011-07-05 03:38:22 -07:00
. gpio_wp = - EINVAL ,
2012-02-20 09:43:29 -08:00
. deferred = true ,
2008-12-10 17:37:17 -08:00
} ,
{ } /* Terminator */
} ;
2011-06-06 18:57:07 +00:00
static struct regulator_consumer_supply beagle_vmmc1_supply [ ] = {
REGULATOR_SUPPLY ( " vmmc " , " omap_hsmmc.0 " ) ,
2009-05-28 14:04:03 -07:00
} ;
2011-06-06 18:57:07 +00:00
static struct regulator_consumer_supply beagle_vsim_supply [ ] = {
REGULATOR_SUPPLY ( " vmmc_aux " , " omap_hsmmc.0 " ) ,
2009-05-28 14:04:03 -07:00
} ;
2008-12-10 17:37:17 -08:00
static struct gpio_led gpio_leds [ ] ;
static int beagle_twl_gpio_setup ( struct device * dev ,
unsigned gpio , unsigned ngpio )
{
2011-07-05 03:38:22 -07:00
int r ;
mmc [ 0 ] . gpio_wp = beagle_config . mmc1_gpio_wp ;
2008-12-10 17:37:17 -08:00
/* gpio + 0 is "mmc0_cd" (input/IRQ) */
2009-01-15 13:09:53 +02:00
mmc [ 0 ] . gpio_cd = gpio + 0 ;
2012-02-20 09:43:29 -08:00
omap_hsmmc_late_init ( mmc ) ;
2008-12-10 17:37:17 -08:00
2011-01-11 17:13:35 +00:00
/*
* TWL4030_GPIO_MAX + 0 = = ledA , EHCI nEN_USB_PWR ( out , XM active
* high / others active low )
2011-05-03 18:22:09 +03:00
* DVI reset GPIO is different between beagle revisions
2011-01-12 00:23:29 +00:00
*/
2011-07-05 03:38:22 -07:00
/* Valid for all -xM revisions */
if ( cpu_is_omap3630 ( ) ) {
2011-05-03 18:22:09 +03:00
/*
* gpio + 1 on Xm controls the TFP410 ' s enable line ( active low )
* gpio + 2 control varies depending on the board rev as below :
* P7 / P8 revisions ( prototype ) : Camera EN
* A2 + revisions ( production ) : LDO ( DVI , serial , led blocks )
*/
r = gpio_request_one ( gpio + 1 , GPIOF_OUT_INIT_LOW ,
" nDVI_PWR_EN " ) ;
2011-01-12 00:23:29 +00:00
if ( r )
pr_err ( " %s: unable to configure nDVI_PWR_EN \n " ,
__func__ ) ;
2011-05-03 18:22:09 +03:00
r = gpio_request_one ( gpio + 2 , GPIOF_OUT_INIT_HIGH ,
" DVI_LDO_EN " ) ;
2011-01-12 00:23:29 +00:00
if ( r )
pr_err ( " %s: unable to configure DVI_LDO_EN \n " ,
__func__ ) ;
2011-05-03 18:22:09 +03:00
} else {
/*
* REVISIT : need ehci - omap hooks for external VBUS
* power switch and overcurrent detect
*/
if ( gpio_request_one ( gpio + 1 , GPIOF_IN , " EHCI_nOC " ) )
pr_err ( " %s: unable to configure EHCI_nOC \n " , __func__ ) ;
2011-01-12 00:23:29 +00:00
}
2012-02-17 13:30:27 +02:00
dvi_panel . power_down_gpio = beagle_config . reset_gpio ;
2011-01-12 00:23:29 +00:00
2011-07-05 03:38:22 -07:00
gpio_request_one ( gpio + TWL4030_GPIO_MAX , beagle_config . usb_pwr_level ,
" nEN_USB_PWR " ) ;
2011-05-03 18:22:09 +03:00
/* TWL4030_GPIO_MAX + 1 == ledB, PMU_STAT (out, active low LED) */
gpio_leds [ 2 ] . gpio = gpio + TWL4030_GPIO_MAX + 1 ;
2008-12-10 17:37:17 -08:00
return 0 ;
}
static struct twl4030_gpio_platform_data beagle_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 ) ,
. setup = beagle_twl_gpio_setup ,
} ;
2009-05-28 14:04:03 -07:00
/* VMMC1 for MMC1 pins CMD, CLK, DAT0..DAT3 (20 mA, plus card == max 220 mA) */
static struct regulator_init_data beagle_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 ( beagle_vmmc1_supply ) ,
. consumer_supplies = beagle_vmmc1_supply ,
2009-05-28 14:04:03 -07:00
} ;
/* VSIM for MMC1 pins DAT4..DAT7 (2 mA, plus card == max 50 mA) */
static struct regulator_init_data beagle_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 ( beagle_vsim_supply ) ,
. consumer_supplies = beagle_vsim_supply ,
2009-05-28 14:04:03 -07:00
} ;
2008-12-10 17:37:17 -08:00
static struct twl4030_platform_data beagle_twldata = {
/* platform_data for children goes here */
. gpio = & beagle_gpio_data ,
2009-05-28 14:04:03 -07:00
. vmmc1 = & beagle_vmmc1 ,
. vsim = & beagle_vsim ,
2008-12-10 17:37:17 -08:00
} ;
2010-09-23 18:22:48 -07:00
static struct i2c_board_info __initdata beagle_i2c_eeprom [ ] = {
{
I2C_BOARD_INFO ( " eeprom " , 0x50 ) ,
} ,
} ;
2008-12-10 17:37:17 -08:00
static int __init omap3_beagle_i2c_init ( void )
{
2011-06-07 10:28:54 +03:00
omap3_pmic_get_config ( & beagle_twldata ,
2011-08-11 22:33:15 -05:00
TWL_COMMON_PDATA_USB | TWL_COMMON_PDATA_MADC |
TWL_COMMON_PDATA_AUDIO ,
2011-06-07 11:38:24 +03:00
TWL_COMMON_REGULATOR_VDAC | TWL_COMMON_REGULATOR_VPLL2 ) ;
beagle_twldata . vpll2 - > constraints . name = " VDVI " ;
2011-04-25 01:09:06 +03:00
omap3_pmic_init ( " twl4030 " , & beagle_twldata ) ;
2009-03-04 10:07:42 -08:00
/* Bus 3 is attached to the DVI port where devices like the pico DLP
* projector don ' t work reliably with 400 kHz */
2010-09-23 18:22:48 -07:00
omap_register_i2c_bus ( 3 , 100 , beagle_i2c_eeprom , ARRAY_SIZE ( beagle_i2c_eeprom ) ) ;
2008-12-10 17:37:17 -08:00
return 0 ;
}
2008-10-09 17:51:42 +03:00
static struct gpio_led gpio_leds [ ] = {
{
. name = " beagleboard::usr0 " ,
. default_trigger = " heartbeat " ,
. gpio = 150 ,
} ,
{
. name = " beagleboard::usr1 " ,
. default_trigger = " mmc0 " ,
. gpio = 149 ,
} ,
2008-12-10 17:37:17 -08:00
{
. name = " beagleboard::pmu_stat " ,
. gpio = - EINVAL , /* gets replaced */
. active_low = true ,
} ,
2008-10-09 17:51:42 +03:00
} ;
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 struct gpio_keys_button gpio_buttons [ ] = {
{
. code = BTN_EXTRA ,
2011-07-05 03:38:22 -07:00
/* Dynamically assigned depending on board */
. gpio = - EINVAL ,
2008-10-09 17:51:42 +03:00
. desc = " user " ,
. wakeup = 1 ,
} ,
} ;
static struct gpio_keys_platform_data gpio_key_info = {
. buttons = gpio_buttons ,
. nbuttons = ARRAY_SIZE ( gpio_buttons ) ,
} ;
static struct platform_device keys_gpio = {
. name = " gpio-keys " ,
. id = - 1 ,
. dev = {
. platform_data = & gpio_key_info ,
} ,
} ;
2011-08-11 22:33:15 -05:00
static struct platform_device madc_hwmon = {
. name = " twl4030_madc_hwmon " ,
. id = - 1 ,
} ;
2008-10-09 17:51:42 +03:00
static struct platform_device * omap3_beagle_devices [ ] __initdata = {
& leds_gpio ,
& keys_gpio ,
2011-08-11 22:33:15 -05:00
& madc_hwmon ,
2008-10-09 17:51:42 +03:00
} ;
2011-03-01 20:08:16 +05:30
static const struct usbhs_omap_board_data usbhs_bdata __initconst = {
2009-11-22 10:11:01 -08:00
2011-03-01 20:08:16 +05:30
. 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-22 10:11:01 -08:00
. phy_reset = true ,
. reset_gpio_port [ 0 ] = - EINVAL ,
. reset_gpio_port [ 1 ] = 147 ,
. reset_gpio_port [ 2 ] = - EINVAL
} ;
2009-12-11 16:16:32 -08:00
# ifdef CONFIG_OMAP_MUX
static struct omap_board_mux board_mux [ ] __initdata = {
{ . reg_offset = OMAP_MUX_TERMINATOR } ,
} ;
# endif
2011-01-07 09:41:13 -06:00
static void __init beagle_opp_init ( void )
{
int r = 0 ;
/* Initialize the omap3 opp table */
if ( omap3_opp_init ( ) ) {
pr_err ( " %s: opp default init failed \n " , __func__ ) ;
return ;
}
2011-07-05 03:38:22 -07:00
/* Custom OPP enabled for all xM versions */
if ( cpu_is_omap3630 ( ) ) {
2011-07-21 11:43:48 -07:00
struct device * mpu_dev , * iva_dev ;
2011-01-07 09:41:13 -06:00
2011-08-16 14:01:23 +02:00
mpu_dev = omap_device_get_by_hwmod_name ( " mpu " ) ;
iva_dev = omap_device_get_by_hwmod_name ( " iva " ) ;
2011-07-21 11:43:48 -07:00
if ( ! mpu_dev | | ! iva_dev ) {
2011-01-07 09:41:13 -06:00
pr_err ( " %s: Aiee.. no mpu/dsp devices? %p %p \n " ,
2011-07-21 11:43:48 -07:00
__func__ , mpu_dev , iva_dev ) ;
2011-01-07 09:41:13 -06:00
return ;
}
/* Enable MPU 1GHz and lower opps */
2011-07-21 11:43:48 -07:00
r = opp_enable ( mpu_dev , 800000000 ) ;
2011-01-07 09:41:13 -06:00
/* TODO: MPU 1GHz needs SR and ABB */
/* Enable IVA 800MHz and lower opps */
2011-07-21 11:43:48 -07:00
r | = opp_enable ( iva_dev , 660000000 ) ;
2011-01-07 09:41:13 -06:00
/* TODO: DSP 800MHz needs SR and ABB */
if ( r ) {
pr_err ( " %s: failed to enable higher opp %d \n " ,
__func__ , r ) ;
/*
* Cleanup - disable the higher freqs - we dont care
* about the results
*/
2011-07-21 11:43:48 -07:00
opp_disable ( mpu_dev , 800000000 ) ;
opp_disable ( iva_dev , 660000000 ) ;
2011-01-07 09:41:13 -06:00
}
}
return ;
}
2008-10-09 17:51:42 +03:00
static void __init omap3_beagle_init ( void )
{
2009-12-11 16:16:32 -08:00
omap3_mux_init ( board_mux , OMAP_PACKAGE_CBB ) ;
2010-09-23 18:22:47 -07:00
omap3_beagle_init_rev ( ) ;
2012-02-20 09:43:30 -08:00
if ( beagle_config . mmc1_gpio_wp ! = - EINVAL )
omap_mux_init_gpio ( beagle_config . mmc1_gpio_wp , OMAP_PIN_INPUT ) ;
2012-05-09 14:19:15 -07:00
mmc [ 0 ] . caps = beagle_config . mmc_caps ;
2012-02-20 09:43:29 -08:00
omap_hsmmc_init ( mmc ) ;
2012-02-20 09:43:30 -08:00
2008-12-10 17:37:17 -08:00
omap3_beagle_i2c_init ( ) ;
2011-07-05 03:38:22 -07:00
gpio_buttons [ 0 ] . gpio = beagle_config . usr_button_gpio ;
2008-10-09 17:51:42 +03:00
platform_add_devices ( omap3_beagle_devices ,
ARRAY_SIZE ( omap3_beagle_devices ) ) ;
2011-02-22 11:24:50 +02:00
omap_display_init ( & beagle_dss_data ) ;
2008-10-09 17:51:42 +03:00
omap_serial_init ( ) ;
2011-08-22 23:57:23 -07:00
omap_sdrc_init ( mt46h32m32lf6_sdrc_params ,
mt46h32m32lf6_sdrc_params ) ;
2008-12-10 17:37:17 -08:00
2009-12-11 16:16:32 -08:00
omap_mux_init_gpio ( 170 , OMAP_PIN_INPUT ) ;
2008-12-10 17:37:17 -08:00
/* REVISIT leave DVI powered down until it's needed ... */
2011-05-03 18:22:09 +03:00
gpio_request_one ( 170 , GPIOF_OUT_INIT_HIGH , " DVI_nPD " ) ;
2008-12-10 17:37:17 -08:00
2011-04-27 11:56:12 +03:00
usb_musb_init ( NULL ) ;
2011-03-01 20:08:19 +05:30
usbhs_init ( & usbhs_bdata ) ;
2011-04-25 01:09:07 +03:00
omap_nand_flash_init ( NAND_BUSWIDTH_16 , omap3beagle_nand_partitions ,
ARRAY_SIZE ( omap3beagle_nand_partitions ) ) ;
2009-07-24 19:43:25 -06:00
2011-04-05 15:40:08 +02:00
/* Ensure msecure is mux'd to be able to set the RTC. */
omap_mux_init_signal ( " sys_drm_msecure " , OMAP_PIN_OFF_OUTPUT_HIGH ) ;
2009-07-24 19:43:25 -06:00
/* Ensure SDRC pins are mux'd for self-refresh */
2009-12-11 16:16:32 -08:00
omap_mux_init_signal ( " sdrc_cke0 " , OMAP_PIN_OUTPUT ) ;
omap_mux_init_signal ( " sdrc_cke1 " , OMAP_PIN_OUTPUT ) ;
2010-04-22 10:23:42 +02:00
2011-01-07 09:41:13 -06:00
beagle_opp_init ( ) ;
2008-10-09 17:51:42 +03:00
}
MACHINE_START ( OMAP3_BEAGLE , " OMAP3 Beagle Board " )
/* Maintainer: Syed Mohammed Khasim - http://beagleboard.org */
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-10-04 18:26:28 -07:00
. init_early = omap3_init_early ,
2011-09-26 15:25:22 -07:00
. init_irq = omap3_init_irq ,
2011-09-06 10:23:45 +01:00
. handle_irq = omap3_intc_handle_irq ,
2008-10-09 17:51:42 +03:00
. init_machine = omap3_beagle_init ,
2012-04-26 16:06:50 +08:00
. init_late = omap3_init_late ,
2011-03-29 15:54:48 -07:00
. timer = & omap3_secure_timer ,
2011-11-05 17:06:28 +00:00
. restart = omap_prcm_restart ,
2008-10-09 17:51:42 +03:00
MACHINE_END