2005-04-17 02:20:36 +04:00
/*
2005-07-10 22:58:11 +04:00
* linux / arch / arm / mach - omap1 / board - h3 . c
2005-04-17 02:20:36 +04:00
*
* This file contains OMAP1710 H3 specific code .
*
* Copyright ( C ) 2004 Texas Instruments , Inc .
* Copyright ( C ) 2002 MontaVista Software , Inc .
* Copyright ( C ) 2001 RidgeRun , Inc .
* Author : RidgeRun , Inc .
* Greg Lonnon ( glonnon @ ridgerun . com ) or info @ ridgerun . com
*
* 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/types.h>
# include <linux/init.h>
# include <linux/major.h>
# include <linux/kernel.h>
2005-10-29 22:07:23 +04:00
# include <linux/platform_device.h>
2005-04-17 02:20:36 +04:00
# include <linux/errno.h>
2006-04-02 20:46:30 +04:00
# include <linux/workqueue.h>
2007-10-14 01:56:30 +04:00
# include <linux/i2c.h>
2005-04-17 02:20:36 +04:00
# include <linux/mtd/mtd.h>
2006-04-02 20:46:30 +04:00
# include <linux/mtd/nand.h>
2005-04-17 02:20:36 +04:00
# include <linux/mtd/partitions.h>
2006-04-02 20:46:30 +04:00
# include <linux/input.h>
2008-02-29 01:44:08 +03:00
# include <linux/spi/spi.h>
2008-01-27 20:14:49 +03:00
# include <linux/i2c/tps65010.h>
2009-12-12 03:16:33 +03:00
# include <linux/smc91x.h>
2005-04-17 02:20:36 +04:00
# include <asm/setup.h>
# include <asm/page.h>
2008-08-05 19:14:15 +04:00
# include <mach/hardware.h>
2007-10-14 01:56:30 +04:00
# include <asm/gpio.h>
2005-04-17 02:20:36 +04:00
# include <asm/mach-types.h>
# include <asm/mach/arch.h>
# include <asm/mach/flash.h>
# include <asm/mach/map.h>
2008-08-05 19:14:15 +04:00
# include <mach/irqs.h>
2009-10-20 20:40:47 +04:00
# include <plat/mux.h>
# include <plat/tc.h>
# include <plat/usb.h>
# include <plat/keypad.h>
# include <plat/dma.h>
# include <plat/common.h>
2005-04-17 02:20:36 +04:00
2009-03-24 04:07:33 +03:00
# include "board-h3.h"
/* In OMAP1710 H3 the Ethernet is directly connected to CS1 */
# define OMAP1710_ETHR_START 0x04000300
2008-02-29 01:44:08 +03:00
# define H3_TS_GPIO 48
2006-04-02 20:46:30 +04:00
static int h3_keymap [ ] = {
KEY ( 0 , 0 , KEY_LEFT ) ,
KEY ( 0 , 1 , KEY_RIGHT ) ,
KEY ( 0 , 2 , KEY_3 ) ,
KEY ( 0 , 3 , KEY_F10 ) ,
KEY ( 0 , 4 , KEY_F5 ) ,
KEY ( 0 , 5 , KEY_9 ) ,
KEY ( 1 , 0 , KEY_DOWN ) ,
KEY ( 1 , 1 , KEY_UP ) ,
KEY ( 1 , 2 , KEY_2 ) ,
KEY ( 1 , 3 , KEY_F9 ) ,
KEY ( 1 , 4 , KEY_F7 ) ,
KEY ( 1 , 5 , KEY_0 ) ,
KEY ( 2 , 0 , KEY_ENTER ) ,
KEY ( 2 , 1 , KEY_6 ) ,
KEY ( 2 , 2 , KEY_1 ) ,
KEY ( 2 , 3 , KEY_F2 ) ,
KEY ( 2 , 4 , KEY_F6 ) ,
KEY ( 2 , 5 , KEY_HOME ) ,
KEY ( 3 , 0 , KEY_8 ) ,
KEY ( 3 , 1 , KEY_5 ) ,
KEY ( 3 , 2 , KEY_F12 ) ,
KEY ( 3 , 3 , KEY_F3 ) ,
KEY ( 3 , 4 , KEY_F8 ) ,
KEY ( 3 , 5 , KEY_END ) ,
KEY ( 4 , 0 , KEY_7 ) ,
KEY ( 4 , 1 , KEY_4 ) ,
KEY ( 4 , 2 , KEY_F11 ) ,
KEY ( 4 , 3 , KEY_F1 ) ,
KEY ( 4 , 4 , KEY_F4 ) ,
KEY ( 4 , 5 , KEY_ESC ) ,
KEY ( 5 , 0 , KEY_F13 ) ,
KEY ( 5 , 1 , KEY_F14 ) ,
KEY ( 5 , 2 , KEY_F15 ) ,
KEY ( 5 , 3 , KEY_F16 ) ,
KEY ( 5 , 4 , KEY_SLEEP ) ,
0
} ;
static struct mtd_partition nor_partitions [ ] = {
2005-04-17 02:20:36 +04:00
/* bootloader (U-Boot, etc) in first sector */
{
. name = " bootloader " ,
. offset = 0 ,
. size = SZ_128K ,
. mask_flags = MTD_WRITEABLE , /* force read-only */
} ,
/* bootloader params in the next sector */
{
. name = " params " ,
. offset = MTDPART_OFS_APPEND ,
. size = SZ_128K ,
. mask_flags = 0 ,
} ,
/* kernel */
{
. name = " kernel " ,
. offset = MTDPART_OFS_APPEND ,
. size = SZ_2M ,
. mask_flags = 0
} ,
/* file system */
{
. name = " filesystem " ,
. offset = MTDPART_OFS_APPEND ,
. size = MTDPART_SIZ_FULL ,
. mask_flags = 0
}
} ;
2006-04-02 20:46:30 +04:00
static struct flash_platform_data nor_data = {
2005-04-17 02:20:36 +04:00
. map_name = " cfi_probe " ,
. width = 2 ,
2006-04-02 20:46:30 +04:00
. parts = nor_partitions ,
. nr_parts = ARRAY_SIZE ( nor_partitions ) ,
2005-04-17 02:20:36 +04:00
} ;
2006-04-02 20:46:30 +04:00
static struct resource nor_resource = {
2005-09-09 02:07:38 +04:00
/* This is on CS3, wherever it's mapped */
2005-04-17 02:20:36 +04:00
. flags = IORESOURCE_MEM ,
} ;
2006-04-02 20:46:30 +04:00
static struct platform_device nor_device = {
2005-04-17 02:20:36 +04:00
. name = " omapflash " ,
. id = 0 ,
. dev = {
2006-04-02 20:46:30 +04:00
. platform_data = & nor_data ,
} ,
. num_resources = 1 ,
. resource = & nor_resource ,
} ;
static struct mtd_partition nand_partitions [ ] = {
#if 0
/* REVISIT: enable these partitions if you make NAND BOOT work */
{
. name = " xloader " ,
. offset = 0 ,
. size = 64 * 1024 ,
. mask_flags = MTD_WRITEABLE , /* force read-only */
} ,
{
. name = " bootloader " ,
. offset = MTDPART_OFS_APPEND ,
. size = 256 * 1024 ,
. mask_flags = MTD_WRITEABLE , /* force read-only */
} ,
{
. name = " params " ,
. offset = MTDPART_OFS_APPEND ,
. size = 192 * 1024 ,
} ,
{
. name = " kernel " ,
. offset = MTDPART_OFS_APPEND ,
. size = 2 * SZ_1M ,
} ,
# endif
{
. name = " filesystem " ,
. size = MTDPART_SIZ_FULL ,
. offset = MTDPART_OFS_APPEND ,
} ,
} ;
2009-12-12 03:16:33 +03:00
static void nand_cmd_ctl ( struct mtd_info * mtd , int cmd , unsigned int ctrl )
{
struct nand_chip * this = mtd - > priv ;
unsigned long mask ;
if ( cmd = = NAND_CMD_NONE )
return ;
mask = ( ctrl & NAND_CLE ) ? 0x02 : 0 ;
if ( ctrl & NAND_ALE )
mask | = 0x04 ;
writeb ( cmd , ( unsigned long ) this - > IO_ADDR_W | mask ) ;
}
# define H3_NAND_RB_GPIO_PIN 10
static int nand_dev_ready ( struct mtd_info * mtd )
{
return gpio_get_value ( H3_NAND_RB_GPIO_PIN ) ;
}
static const char * part_probes [ ] = { " cmdlinepart " , NULL } ;
struct platform_nand_data nand_platdata = {
. chip = {
. nr_chips = 1 ,
. chip_offset = 0 ,
. nr_partitions = ARRAY_SIZE ( nand_partitions ) ,
. partitions = nand_partitions ,
. options = NAND_SAMSUNG_LP_OPTIONS ,
. part_probe_types = part_probes ,
} ,
. ctrl = {
. cmd_ctrl = nand_cmd_ctl ,
. dev_ready = nand_dev_ready ,
} ,
2006-04-02 20:46:30 +04:00
} ;
static struct resource nand_resource = {
. flags = IORESOURCE_MEM ,
} ;
static struct platform_device nand_device = {
2009-12-12 03:16:33 +03:00
. name = " gen_nand " ,
2006-04-02 20:46:30 +04:00
. id = 0 ,
. dev = {
2009-12-12 03:16:33 +03:00
. platform_data = & nand_platdata ,
2005-04-17 02:20:36 +04:00
} ,
. num_resources = 1 ,
2006-04-02 20:46:30 +04:00
. resource = & nand_resource ,
2005-04-17 02:20:36 +04:00
} ;
2009-12-12 03:16:33 +03:00
static struct smc91x_platdata smc91x_info = {
. flags = SMC91X_USE_16BIT | SMC91X_NOWAIT ,
. leda = RPC_LED_100_10 ,
. ledb = RPC_LED_TX_RX ,
} ;
2005-04-17 02:20:36 +04:00
static struct resource smc91x_resources [ ] = {
[ 0 ] = {
. start = OMAP1710_ETHR_START , /* Physical */
. end = OMAP1710_ETHR_START + 0xf ,
. flags = IORESOURCE_MEM ,
} ,
[ 1 ] = {
. start = OMAP_GPIO_IRQ ( 40 ) ,
. end = OMAP_GPIO_IRQ ( 40 ) ,
2008-01-15 01:30:10 +03:00
. flags = IORESOURCE_IRQ | IORESOURCE_IRQ_LOWEDGE ,
2005-04-17 02:20:36 +04:00
} ,
} ;
static struct platform_device smc91x_device = {
. name = " smc91x " ,
. id = 0 ,
2009-12-12 03:16:33 +03:00
. dev = {
. platform_data = & smc91x_info ,
} ,
2005-04-17 02:20:36 +04:00
. num_resources = ARRAY_SIZE ( smc91x_resources ) ,
. resource = smc91x_resources ,
} ;
# define GPTIMER_BASE 0xFFFB1400
# define GPTIMER_REGS(x) (0xFFFB1400 + (x * 0x800))
# define GPTIMER_REGS_SIZE 0x46
static struct resource intlat_resources [ ] = {
[ 0 ] = {
. start = GPTIMER_REGS ( 0 ) , /* Physical */
. end = GPTIMER_REGS ( 0 ) + GPTIMER_REGS_SIZE ,
. flags = IORESOURCE_MEM ,
} ,
[ 1 ] = {
. start = INT_1610_GPTIMER1 ,
. end = INT_1610_GPTIMER1 ,
. flags = IORESOURCE_IRQ ,
} ,
} ;
static struct platform_device intlat_device = {
. name = " omap_intlat " ,
. id = 0 ,
. num_resources = ARRAY_SIZE ( intlat_resources ) ,
. resource = intlat_resources ,
} ;
2006-04-02 20:46:30 +04:00
static struct resource h3_kp_resources [ ] = {
[ 0 ] = {
. start = INT_KEYBOARD ,
. end = INT_KEYBOARD ,
. flags = IORESOURCE_IRQ ,
} ,
} ;
static struct omap_kp_platform_data h3_kp_data = {
2006-09-29 12:59:20 +04:00
. rows = 8 ,
. cols = 8 ,
. keymap = h3_keymap ,
. keymapsize = ARRAY_SIZE ( h3_keymap ) ,
. rep = 1 ,
. delay = 9 ,
. dbounce = 1 ,
2006-04-02 20:46:30 +04:00
} ;
static struct platform_device h3_kp_device = {
. name = " omap-keypad " ,
. id = - 1 ,
. dev = {
. platform_data = & h3_kp_data ,
} ,
. num_resources = ARRAY_SIZE ( h3_kp_resources ) ,
. resource = h3_kp_resources ,
} ;
static struct platform_device h3_lcd_device = {
. name = " lcd_h3 " ,
. id = - 1 ,
} ;
2008-02-29 01:44:08 +03:00
static struct spi_board_info h3_spi_board_info [ ] __initdata = {
[ 0 ] = {
. modalias = " tsc2101 " ,
. bus_num = 2 ,
. chip_select = 0 ,
. irq = OMAP_GPIO_IRQ ( H3_TS_GPIO ) ,
. max_speed_hz = 16000000 ,
/* .platform_data = &tsc_platform_data, */
} ,
} ;
2005-04-17 02:20:36 +04:00
static struct platform_device * devices [ ] __initdata = {
2006-04-02 20:46:30 +04:00
& nor_device ,
& nand_device ,
2005-04-17 02:20:36 +04:00
& smc91x_device ,
& intlat_device ,
2006-04-02 20:46:30 +04:00
& h3_kp_device ,
& h3_lcd_device ,
2005-04-17 02:20:36 +04:00
} ;
static struct omap_usb_config h3_usb_config __initdata = {
/* usb1 has a Mini-AB port and external isp1301 transceiver */
. otg = 2 ,
# ifdef CONFIG_USB_GADGET_OMAP
. hmc_mode = 19 , /* 0:host(off) 1:dev|otg 2:disabled */
# elif defined(CONFIG_USB_OHCI_HCD) || defined(CONFIG_USB_OHCI_HCD_MODULE)
/* NONSTANDARD CABLE NEEDED (B-to-Mini-B) */
. hmc_mode = 20 , /* 1:dev|otg(off) 1:host 2:disabled */
# endif
. pins [ 1 ] = 3 ,
} ;
2005-11-10 17:26:48 +03:00
static struct omap_lcd_config h3_lcd_config __initdata = {
. ctrl_name = " internal " ,
} ;
2007-12-19 07:58:32 +03:00
static struct omap_board_config_kernel h3_config [ ] __initdata = {
2005-11-10 17:26:48 +03:00
{ OMAP_TAG_LCD , & h3_lcd_config } ,
2005-04-17 02:20:36 +04:00
} ;
2008-02-29 01:44:08 +03:00
static struct i2c_board_info __initdata h3_i2c_board_info [ ] = {
{
2008-04-30 01:11:40 +04:00
I2C_BOARD_INFO ( " tps65013 " , 0x48 ) ,
2008-02-29 01:44:08 +03:00
/* .irq = OMAP_GPIO_IRQ(??), */
} ,
2008-10-14 19:30:02 +04:00
{
I2C_BOARD_INFO ( " isp1301_omap " , 0x2d ) ,
. irq = OMAP_GPIO_IRQ ( 14 ) ,
} ,
2008-02-29 01:44:08 +03:00
} ;
2005-04-17 02:20:36 +04:00
static void __init h3_init ( void )
{
2006-04-02 20:46:30 +04:00
/* Here we assume the NOR boot config: NOR on CS3 (possibly swapped
* to address 0 by a dip switch ) , NAND on CS2B . The NAND driver will
* notice whether a NAND chip is enabled at probe time .
*
* H3 support NAND - boot , with a dip switch to put NOR on CS2B and NAND
* ( which on H2 may be 16 bit ) on CS3 . Try detecting that in code here ,
* to avoid probing every possible flash configuration . . .
*/
nor_resource . end = nor_resource . start = omap_cs3_phys ( ) ;
nor_resource . end + = SZ_32M - 1 ;
nand_resource . end = nand_resource . start = OMAP_CS2B_PHYS ;
nand_resource . end + = SZ_4K - 1 ;
2008-12-11 04:35:30 +03:00
if ( gpio_request ( H3_NAND_RB_GPIO_PIN , " NAND ready " ) < 0 )
BUG ( ) ;
2009-12-12 03:16:33 +03:00
gpio_direction_input ( H3_NAND_RB_GPIO_PIN ) ;
2006-04-02 20:46:30 +04:00
/* GPIO10 Func_MUX_CTRL reg bit 29:27, Configure V2 to mode1 as GPIO */
/* GPIO10 pullup/down register, Enable pullup on GPIO10 */
omap_cfg_reg ( V2_1710_GPIO10 ) ;
platform_add_devices ( devices , ARRAY_SIZE ( devices ) ) ;
2007-12-19 07:58:32 +03:00
spi_register_board_info ( h3_spi_board_info ,
ARRAY_SIZE ( h3_spi_board_info ) ) ;
2005-09-09 02:07:38 +04:00
omap_board_config = h3_config ;
omap_board_config_size = ARRAY_SIZE ( h3_config ) ;
2005-11-10 17:26:48 +03:00
omap_serial_init ( ) ;
2007-11-07 07:54:32 +03:00
omap_register_i2c_bus ( 1 , 100 , h3_i2c_board_info ,
ARRAY_SIZE ( h3_i2c_board_info ) ) ;
2009-03-24 04:07:49 +03:00
omap_usb_init ( & h3_usb_config ) ;
2007-11-27 07:01:45 +03:00
h3_mmc_init ( ) ;
2005-04-17 02:20:36 +04:00
}
static void __init h3_init_smc91x ( void )
{
omap_cfg_reg ( W15_1710_GPIO40 ) ;
2008-12-11 04:35:30 +03:00
if ( gpio_request ( 40 , " SMC91x irq " ) < 0 ) {
2005-04-17 02:20:36 +04:00
printk ( " Error requesting gpio 40 for smc91x irq \n " ) ;
return ;
}
}
2006-12-07 04:13:59 +03:00
static void __init h3_init_irq ( void )
2005-04-17 02:20:36 +04:00
{
2006-02-09 01:06:46 +03:00
omap1_init_common_hw ( ) ;
2005-04-17 02:20:36 +04:00
omap_init_irq ( ) ;
omap_gpio_init ( ) ;
h3_init_smc91x ( ) ;
}
static void __init h3_map_io ( void )
{
2006-02-09 01:06:46 +03:00
omap1_map_common_io ( ) ;
2005-04-17 02:20:36 +04:00
}
MACHINE_START ( OMAP_H3 , " TI OMAP1710 H3 board " )
2005-07-03 20:38:58 +04:00
/* Maintainer: Texas Instruments, Inc. */
. phys_io = 0xfff00000 ,
. io_pg_offst = ( ( 0xfef00000 ) > > 18 ) & 0xfffc ,
. boot_params = 0x10000100 ,
. map_io = h3_map_io ,
. init_irq = h3_init_irq ,
. init_machine = h3_init ,
2005-04-17 02:20:36 +04:00
. timer = & omap_timer ,
MACHINE_END