2005-04-16 15:20:36 -07:00
/*
* linux / arch / arm / mach - pxa / idp . c
*
* 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 .
*
* Copyright ( c ) 2001 Cliff Brake , Accelent Systems Inc .
*
* 2001 - 09 - 13 : Cliff Brake < cbrake @ accelent . com >
* Initial code
*
* 2005 - 02 - 15 : Cliff Brake < cliff . brake @ gmail . com >
* < http : //www.vibren.com> <http://bec-systems.com>
* Updated for 2.6 kernel
*
*/
# include <linux/init.h>
# include <linux/interrupt.h>
2006-07-01 22:32:20 +01:00
# include <linux/irq.h>
2005-10-29 19:07:23 +01:00
# include <linux/platform_device.h>
2005-04-16 15:20:36 -07:00
# include <linux/fb.h>
# include <asm/setup.h>
# include <asm/memory.h>
# include <asm/mach-types.h>
2008-08-05 16:14:15 +01:00
# include <mach/hardware.h>
2005-04-16 15:20:36 -07:00
# include <asm/irq.h>
# include <asm/mach/arch.h>
# include <asm/mach/map.h>
2008-08-05 16:14:15 +01:00
# include <mach/pxa-regs.h>
# include <mach/pxa2xx-gpio.h>
# include <mach/idp.h>
# include <mach/pxafb.h>
# include <mach/bitfield.h>
# include <mach/mmc.h>
2005-04-16 15:20:36 -07:00
# include "generic.h"
2007-05-15 15:39:36 +01:00
# include "devices.h"
2005-04-16 15:20:36 -07:00
/* TODO:
* - add pxa2xx_audio_ops_t device structure
* - Ethernet interrupt
*/
static struct resource smc91x_resources [ ] = {
[ 0 ] = {
. start = ( IDP_ETH_PHYS + 0x300 ) ,
. end = ( IDP_ETH_PHYS + 0xfffff ) ,
. flags = IORESOURCE_MEM ,
} ,
[ 1 ] = {
. start = IRQ_GPIO ( 4 ) ,
. end = IRQ_GPIO ( 4 ) ,
2008-01-14 22:30:10 +00:00
. flags = IORESOURCE_IRQ | IORESOURCE_IRQ_HIGHEDGE ,
2005-04-16 15:20:36 -07:00
}
} ;
static struct platform_device smc91x_device = {
. name = " smc91x " ,
. id = 0 ,
. num_resources = ARRAY_SIZE ( smc91x_resources ) ,
. resource = smc91x_resources ,
} ;
static void idp_backlight_power ( int on )
{
if ( on ) {
IDP_CPLD_LCD | = ( 1 < < 1 ) ;
} else {
IDP_CPLD_LCD & = ~ ( 1 < < 1 ) ;
}
}
static void idp_vlcd ( int on )
{
if ( on ) {
IDP_CPLD_LCD | = ( 1 < < 2 ) ;
} else {
IDP_CPLD_LCD & = ~ ( 1 < < 2 ) ;
}
}
2006-09-20 22:54:21 +01:00
static void idp_lcd_power ( int on , struct fb_var_screeninfo * var )
2005-04-16 15:20:36 -07:00
{
if ( on ) {
IDP_CPLD_LCD | = ( 1 < < 0 ) ;
} else {
IDP_CPLD_LCD & = ~ ( 1 < < 0 ) ;
}
/* call idp_vlcd for now as core driver does not support
* both power and vlcd hooks . Note , this is not technically
* the correct sequence , but seems to work . Disclaimer :
* this may eventually damage the display .
*/
idp_vlcd ( on ) ;
}
2006-09-20 22:54:21 +01:00
static struct pxafb_mode_info sharp_lm8v31_mode = {
2005-04-16 15:20:36 -07:00
. pixclock = 270000 ,
. xres = 640 ,
. yres = 480 ,
. bpp = 16 ,
. hsync_len = 1 ,
. left_margin = 3 ,
. right_margin = 3 ,
. vsync_len = 1 ,
. upper_margin = 0 ,
. lower_margin = 0 ,
. sync = FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT ,
. cmap_greyscale = 0 ,
2006-09-20 22:54:21 +01:00
} ;
static struct pxafb_mach_info sharp_lm8v31 = {
. modes = & sharp_lm8v31_mode ,
. num_modes = 1 ,
2005-04-16 15:20:36 -07:00
. cmap_inverse = 0 ,
. cmap_static = 0 ,
. lccr0 = LCCR0_SDS ,
. lccr3 = LCCR3_PCP | LCCR3_Acb ( 255 ) ,
. pxafb_backlight_power = & idp_backlight_power ,
. pxafb_lcd_power = & idp_lcd_power
} ;
2006-10-09 12:19:47 +01:00
static int idp_mci_init ( struct device * dev , irq_handler_t idp_detect_int , void * data )
2005-04-16 15:20:36 -07:00
{
/* setup GPIO for PXA25x MMC controller */
pxa_gpio_mode ( GPIO6_MMCCLK_MD ) ;
pxa_gpio_mode ( GPIO8_MMCCS0_MD ) ;
return 0 ;
}
static struct pxamci_platform_data idp_mci_platform_data = {
. ocr_mask = MMC_VDD_32_33 | MMC_VDD_33_34 ,
. init = idp_mci_init ,
} ;
static void __init idp_init ( void )
{
printk ( " idp_init() \n " ) ;
platform_device_register ( & smc91x_device ) ;
//platform_device_register(&mst_audio_device);
set_pxa_fb_info ( & sharp_lm8v31 ) ;
pxa_set_mci_info ( & idp_mci_platform_data ) ;
}
static void __init idp_init_irq ( void )
{
2007-06-22 04:14:09 +01:00
pxa25x_init_irq ( ) ;
2005-04-16 15:20:36 -07:00
set_irq_type ( TOUCH_PANEL_IRQ , TOUCH_PANEL_IRQ_EDGE ) ;
}
static struct map_desc idp_io_desc [ ] __initdata = {
2005-10-28 15:19:01 +01:00
{
. virtual = IDP_COREVOLT_VIRT ,
. pfn = __phys_to_pfn ( IDP_COREVOLT_PHYS ) ,
. length = IDP_COREVOLT_SIZE ,
. type = MT_DEVICE
} , {
. virtual = IDP_CPLD_VIRT ,
. pfn = __phys_to_pfn ( IDP_CPLD_PHYS ) ,
. length = IDP_CPLD_SIZE ,
. type = MT_DEVICE
}
2005-04-16 15:20:36 -07:00
} ;
static void __init idp_map_io ( void )
{
pxa_map_io ( ) ;
iotable_init ( idp_io_desc , ARRAY_SIZE ( idp_io_desc ) ) ;
// serial ports 2 & 3
pxa_gpio_mode ( GPIO42_BTRXD_MD ) ;
pxa_gpio_mode ( GPIO43_BTTXD_MD ) ;
pxa_gpio_mode ( GPIO44_BTCTS_MD ) ;
pxa_gpio_mode ( GPIO45_BTRTS_MD ) ;
pxa_gpio_mode ( GPIO46_STRXD_MD ) ;
pxa_gpio_mode ( GPIO47_STTXD_MD ) ;
}
MACHINE_START ( PXA_IDP , " Vibren PXA255 IDP " )
2005-07-03 17:38:58 +01:00
/* Maintainer: Vibren Technologies */
. phys_io = 0x40000000 ,
2005-07-04 10:44:34 +01:00
. io_pg_offst = ( io_p2v ( 0x40000000 ) > > 18 ) & 0xfffc ,
2005-07-03 17:38:58 +01:00
. map_io = idp_map_io ,
. init_irq = idp_init_irq ,
2005-04-16 15:20:36 -07:00
. timer = & pxa_timer ,
2005-07-03 17:38:58 +01:00
. init_machine = idp_init ,
2005-04-16 15:20:36 -07:00
MACHINE_END