2006-12-06 17:13:57 -08:00
/*
* linux / arch / arm / mach - omap1 / board - palmz71 . c
*
* Modified from board - generic . c
*
* Support for the Palm Zire71 PDA .
*
* Original version : Laurent Gonzalez
*
* Modified for zire71 : Marek Vasut
*
* 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/delay.h>
# include <linux/kernel.h>
# include <linux/init.h>
# include <linux/platform_device.h>
# include <linux/notifier.h>
# include <linux/clk.h>
# include <linux/irq.h>
# include <linux/input.h>
# include <linux/interrupt.h>
# include <linux/mtd/mtd.h>
# include <linux/mtd/partitions.h>
2010-02-15 10:03:32 -08:00
# include <linux/mtd/physmap.h>
2006-12-06 17:13:57 -08:00
2008-08-05 16:14:15 +01:00
# include <mach/hardware.h>
2006-12-06 17:13:57 -08:00
# include <asm/mach-types.h>
# include <asm/mach/arch.h>
# include <asm/mach/map.h>
2008-08-05 16:14:15 +01:00
# include <mach/gpio.h>
2010-02-15 10:03:32 -08:00
# include <plat/flash.h>
2009-10-20 09:40:47 -07:00
# include <plat/mux.h>
# include <plat/usb.h>
# include <plat/dma.h>
# include <plat/tc.h>
# include <plat/board.h>
# include <plat/irda.h>
# include <plat/keypad.h>
# include <plat/common.h>
# include <plat/omap-alsa.h>
2006-12-06 17:13:57 -08:00
# include <linux/spi/spi.h>
# include <linux/spi/ads7846.h>
2009-03-23 18:07:35 -07:00
# define PALMZ71_USBDETECT_GPIO 0
# define PALMZ71_PENIRQ_GPIO 6
# define PALMZ71_MMC_WP_GPIO 8
# define PALMZ71_HDQ_GPIO 11
# define PALMZ71_HOTSYNC_GPIO OMAP_MPUIO(1)
# define PALMZ71_CABLE_GPIO OMAP_MPUIO(2)
# define PALMZ71_SLIDER_GPIO OMAP_MPUIO(3)
# define PALMZ71_MMC_IN_GPIO OMAP_MPUIO(4)
2010-12-20 21:09:22 +00:00
static const unsigned int palmz71_keymap [ ] = {
2006-12-06 17:13:57 -08:00
KEY ( 0 , 0 , KEY_F1 ) ,
2010-12-20 21:09:22 +00:00
KEY ( 1 , 0 , KEY_F2 ) ,
KEY ( 2 , 0 , KEY_F3 ) ,
KEY ( 3 , 0 , KEY_F4 ) ,
KEY ( 4 , 0 , KEY_POWER ) ,
KEY ( 0 , 1 , KEY_LEFT ) ,
2006-12-06 17:13:57 -08:00
KEY ( 1 , 1 , KEY_DOWN ) ,
2010-12-20 21:09:22 +00:00
KEY ( 2 , 1 , KEY_UP ) ,
KEY ( 3 , 1 , KEY_RIGHT ) ,
KEY ( 4 , 1 , KEY_ENTER ) ,
KEY ( 0 , 2 , KEY_CAMERA ) ,
} ;
static const struct matrix_keymap_data palmz71_keymap_data = {
. keymap = palmz71_keymap ,
. keymap_size = ARRAY_SIZE ( palmz71_keymap ) ,
2006-12-06 17:13:57 -08:00
} ;
static struct omap_kp_platform_data palmz71_kp_data = {
. rows = 8 ,
. cols = 8 ,
2010-12-20 21:09:22 +00:00
. keymap_data = & palmz71_keymap_data ,
. rep = true ,
2006-12-06 17:13:57 -08:00
. delay = 80 ,
} ;
static struct resource palmz71_kp_resources [ ] = {
[ 0 ] = {
. start = INT_KEYBOARD ,
. end = INT_KEYBOARD ,
. flags = IORESOURCE_IRQ ,
} ,
} ;
static struct platform_device palmz71_kp_device = {
. name = " omap-keypad " ,
. id = - 1 ,
. dev = {
. platform_data = & palmz71_kp_data ,
} ,
. num_resources = ARRAY_SIZE ( palmz71_kp_resources ) ,
. resource = palmz71_kp_resources ,
} ;
static struct mtd_partition palmz71_rom_partitions [ ] = {
/* PalmOS "Small ROM", contains the bootloader and the debugger */
{
. name = " smallrom " ,
. offset = 0 ,
. size = 0xa000 ,
. mask_flags = MTD_WRITEABLE ,
} ,
/* PalmOS "Big ROM", a filesystem with all the OS code and data */
{
. name = " bigrom " ,
. offset = SZ_128K ,
/*
* 0x5f0000 bytes big in the multi - language ( " EFIGS " ) version ,
* 0x7b0000 bytes in the English - only ( " enUS " ) version .
*/
. size = 0x7b0000 ,
. mask_flags = MTD_WRITEABLE ,
} ,
} ;
2010-02-15 10:03:32 -08:00
static struct physmap_flash_data palmz71_rom_data = {
2006-12-06 17:13:57 -08:00
. width = 2 ,
2010-02-15 10:03:32 -08:00
. set_vpp = omap1_set_vpp ,
2006-12-06 17:13:57 -08:00
. parts = palmz71_rom_partitions ,
. nr_parts = ARRAY_SIZE ( palmz71_rom_partitions ) ,
} ;
static struct resource palmz71_rom_resource = {
. start = OMAP_CS0_PHYS ,
. end = OMAP_CS0_PHYS + SZ_8M - 1 ,
. flags = IORESOURCE_MEM ,
} ;
static struct platform_device palmz71_rom_device = {
2010-02-15 10:03:32 -08:00
. name = " physmap-flash " ,
2006-12-06 17:13:57 -08:00
. id = - 1 ,
. dev = {
. platform_data = & palmz71_rom_data ,
} ,
. num_resources = 1 ,
. resource = & palmz71_rom_resource ,
} ;
static struct platform_device palmz71_lcd_device = {
. name = " lcd_palmz71 " ,
. id = - 1 ,
} ;
static struct omap_irda_config palmz71_irda_config = {
. transceiver_cap = IR_SIRMODE ,
. rx_channel = OMAP_DMA_UART3_RX ,
. tx_channel = OMAP_DMA_UART3_TX ,
. dest_start = UART3_THR ,
. src_start = UART3_RHR ,
. tx_trigger = 0 ,
. rx_trigger = 0 ,
} ;
static struct resource palmz71_irda_resources [ ] = {
[ 0 ] = {
. start = INT_UART3 ,
. end = INT_UART3 ,
. flags = IORESOURCE_IRQ ,
} ,
} ;
static struct platform_device palmz71_irda_device = {
. name = " omapirda " ,
. id = - 1 ,
. dev = {
. platform_data = & palmz71_irda_config ,
} ,
. num_resources = ARRAY_SIZE ( palmz71_irda_resources ) ,
. resource = palmz71_irda_resources ,
} ;
static struct platform_device palmz71_spi_device = {
. name = " spi_palmz71 " ,
. id = - 1 ,
} ;
static struct omap_backlight_config palmz71_backlight_config = {
. default_intensity = 0xa0 ,
} ;
static struct platform_device palmz71_backlight_device = {
. name = " omap-bl " ,
. id = - 1 ,
. dev = {
. platform_data = & palmz71_backlight_config ,
} ,
} ;
static struct platform_device * devices [ ] __initdata = {
& palmz71_rom_device ,
& palmz71_kp_device ,
& palmz71_lcd_device ,
& palmz71_irda_device ,
& palmz71_spi_device ,
& palmz71_backlight_device ,
} ;
static int
palmz71_get_pendown_state ( void )
{
2008-12-10 17:35:25 -08:00
return ! gpio_get_value ( PALMZ71_PENIRQ_GPIO ) ;
2006-12-06 17:13:57 -08:00
}
static const struct ads7846_platform_data palmz71_ts_info = {
. model = 7846 ,
. vref_delay_usecs = 100 , /* internal, no capacitor */
. x_plate_ohms = 419 ,
. y_plate_ohms = 486 ,
. get_pendown_state = palmz71_get_pendown_state ,
} ;
static struct spi_board_info __initdata palmz71_boardinfo [ ] = { {
/* MicroWire (bus 2) CS0 has an ads7846e */
. modalias = " ads7846 " ,
. platform_data = & palmz71_ts_info ,
. irq = OMAP_GPIO_IRQ ( PALMZ71_PENIRQ_GPIO ) ,
. max_speed_hz = 120000 /* max sample rate at 3V */
* 26 /* command + data + overhead */ ,
. bus_num = 2 ,
. chip_select = 0 ,
} } ;
static struct omap_usb_config palmz71_usb_config __initdata = {
. register_dev = 1 , /* Mini-B only receptacle */
. hmc_mode = 0 ,
. pins [ 0 ] = 2 ,
} ;
static struct omap_lcd_config palmz71_lcd_config __initdata = {
. ctrl_name = " internal " ,
} ;
2007-12-18 20:58:32 -08:00
static struct omap_board_config_kernel palmz71_config [ ] __initdata = {
2006-12-06 17:13:57 -08:00
{ OMAP_TAG_LCD , & palmz71_lcd_config } ,
} ;
static irqreturn_t
palmz71_powercable ( int irq , void * dev_id )
{
2008-12-10 17:35:25 -08:00
if ( gpio_get_value ( PALMZ71_USBDETECT_GPIO ) ) {
2006-12-06 17:13:57 -08:00
printk ( KERN_INFO " PM: Power cable connected \n " ) ;
2011-03-24 13:25:22 +01:00
irq_set_irq_type ( gpio_to_irq ( PALMZ71_USBDETECT_GPIO ) ,
IRQ_TYPE_EDGE_FALLING ) ;
2006-12-06 17:13:57 -08:00
} else {
printk ( KERN_INFO " PM: Power cable disconnected \n " ) ;
2011-03-24 13:25:22 +01:00
irq_set_irq_type ( gpio_to_irq ( PALMZ71_USBDETECT_GPIO ) ,
IRQ_TYPE_EDGE_RISING ) ;
2006-12-06 17:13:57 -08:00
}
return IRQ_HANDLED ;
}
static void __init
omap_mpu_wdt_mode ( int mode )
{
if ( mode )
omap_writew ( 0x8000 , OMAP_WDT_TIMER_MODE ) ;
else {
omap_writew ( 0x00f5 , OMAP_WDT_TIMER_MODE ) ;
omap_writew ( 0x00a0 , OMAP_WDT_TIMER_MODE ) ;
}
}
static void __init
palmz71_gpio_setup ( int early )
{
if ( early ) {
/* Only set GPIO1 so we have a working serial */
2008-12-10 17:35:26 -08:00
gpio_direction_output ( 1 , 1 ) ;
2006-12-06 17:13:57 -08:00
} else {
/* Set MMC/SD host WP pin as input */
2008-12-10 17:35:30 -08:00
if ( gpio_request ( PALMZ71_MMC_WP_GPIO , " MMC WP " ) < 0 ) {
2006-12-06 17:13:57 -08:00
printk ( KERN_ERR " Could not reserve WP GPIO! \n " ) ;
return ;
}
2008-12-10 17:35:26 -08:00
gpio_direction_input ( PALMZ71_MMC_WP_GPIO ) ;
2006-12-06 17:13:57 -08:00
/* Monitor the Power-cable-connected signal */
2008-12-10 17:35:30 -08:00
if ( gpio_request ( PALMZ71_USBDETECT_GPIO , " USB detect " ) < 0 ) {
2006-12-06 17:13:57 -08:00
printk ( KERN_ERR
" Could not reserve cable signal GPIO! \n " ) ;
return ;
}
2008-12-10 17:35:26 -08:00
gpio_direction_input ( PALMZ71_USBDETECT_GPIO ) ;
2008-12-10 17:35:26 -08:00
if ( request_irq ( gpio_to_irq ( PALMZ71_USBDETECT_GPIO ) ,
2006-12-06 17:13:57 -08:00
palmz71_powercable , IRQF_SAMPLE_RANDOM ,
" palmz71-cable " , 0 ) )
printk ( KERN_ERR
" IRQ request for power cable failed! \n " ) ;
2008-12-10 17:35:26 -08:00
palmz71_powercable ( gpio_to_irq ( PALMZ71_USBDETECT_GPIO ) , 0 ) ;
2006-12-06 17:13:57 -08:00
}
}
static void __init
omap_palmz71_init ( void )
{
2009-10-22 14:47:42 -07:00
/* mux pins for uarts */
omap_cfg_reg ( UART1_TX ) ;
omap_cfg_reg ( UART1_RTS ) ;
omap_cfg_reg ( UART2_TX ) ;
omap_cfg_reg ( UART2_RTS ) ;
omap_cfg_reg ( UART3_TX ) ;
omap_cfg_reg ( UART3_RX ) ;
2006-12-06 17:13:57 -08:00
palmz71_gpio_setup ( 1 ) ;
omap_mpu_wdt_mode ( 0 ) ;
omap_board_config = palmz71_config ;
omap_board_config_size = ARRAY_SIZE ( palmz71_config ) ;
platform_add_devices ( devices , ARRAY_SIZE ( devices ) ) ;
spi_register_board_info ( palmz71_boardinfo ,
ARRAY_SIZE ( palmz71_boardinfo ) ) ;
2010-07-05 16:31:30 +03:00
omap1_usb_init ( & palmz71_usb_config ) ;
2006-12-06 17:13:57 -08:00
omap_serial_init ( ) ;
2007-11-07 06:54:32 +02:00
omap_register_i2c_bus ( 1 , 100 , NULL , 0 ) ;
2006-12-06 17:13:57 -08:00
palmz71_gpio_setup ( 0 ) ;
}
MACHINE_START ( OMAP_PALMZ71 , " OMAP310 based Palm Zire71 " )
2011-07-05 22:38:15 -04:00
. atag_offset = 0x100 ,
2011-10-05 15:14:02 -07:00
. map_io = omap15xx_map_io ,
. init_early = omap1_init_early ,
2010-05-23 10:18:16 +01:00
. reserve = omap_reserve ,
2011-10-05 15:14:02 -07:00
. init_irq = omap1_init_irq ,
2010-05-23 10:18:16 +01:00
. init_machine = omap_palmz71_init ,
2011-03-29 15:54:48 -07:00
. timer = & omap1_timer ,
2006-12-06 17:13:57 -08:00
MACHINE_END