2008-07-05 10:03:00 +02:00
/*
* Copyright ( C ) 2000 Deep Blue Solutions Ltd
* Copyright ( C ) 2002 Shane Nay ( shane @ minirl . com )
* Copyright 2006 - 2007 Freescale Semiconductor , Inc . All Rights Reserved .
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation ; either version 2 of the License , or
* ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*/
# include <linux/platform_device.h>
# include <linux/mtd/mtd.h>
# include <linux/mtd/map.h>
# include <linux/mtd/partitions.h>
# include <linux/mtd/physmap.h>
2009-04-29 04:00:50 +04:00
# include <linux/i2c.h>
2009-04-30 15:31:20 +04:00
# include <linux/irq.h>
2008-08-05 16:14:15 +01:00
# include <mach/common.h>
# include <mach/hardware.h>
2008-07-05 10:03:00 +02:00
# include <asm/mach-types.h>
# include <asm/mach/arch.h>
# include <asm/mach/time.h>
# include <asm/mach/map.h>
2008-08-05 16:14:15 +01:00
# include <mach/gpio.h>
2010-02-16 11:07:49 +01:00
# include <mach/iomux-mx27.h>
2009-04-29 04:00:49 +04:00
# include <mach/mxc_nand.h>
2009-04-29 04:00:51 +04:00
# include <mach/imxfb.h>
2009-04-30 15:31:20 +04:00
# include <mach/mmc.h>
2008-07-05 10:03:00 +02:00
2010-06-16 07:35:31 +02:00
# include "devices-imx27.h"
2008-09-09 10:19:41 +02:00
# include "devices.h"
2010-03-08 16:07:30 +01:00
/*
* Base address of PBC controller , CS4
*/
# define PBC_BASE_ADDRESS 0xf4300000
# define PBC_REG_ADDR(offset) (void __force __iomem *) \
( PBC_BASE_ADDRESS + ( offset ) )
/* When the PBC address connection is fixed in h/w, defined as 1 */
# define PBC_ADDR_SH 0
/* Offsets for the PBC Controller register */
/*
* PBC Board version register offset
*/
# define PBC_VERSION_REG PBC_REG_ADDR(0x00000 >> PBC_ADDR_SH)
/*
* PBC Board control register 1 set address .
*/
# define PBC_BCTRL1_SET_REG PBC_REG_ADDR(0x00008 >> PBC_ADDR_SH)
/*
* PBC Board control register 1 clear address .
*/
# define PBC_BCTRL1_CLEAR_REG PBC_REG_ADDR(0x0000C >> PBC_ADDR_SH)
/* PBC Board Control Register 1 bit definitions */
# define PBC_BCTRL1_LCDON 0x0800 /* Enable the LCD */
/* to determine the correct external crystal reference */
# define CKIH_27MHZ_BIT_SET (1 << 3)
2010-09-28 21:53:31 +02:00
static const int mx27ads_pins [ ] __initconst = {
2009-04-29 04:00:48 +04:00
/* UART0 */
2008-07-05 10:03:00 +02:00
PE12_PF_UART1_TXD ,
PE13_PF_UART1_RXD ,
PE14_PF_UART1_CTS ,
2009-04-29 04:00:48 +04:00
PE15_PF_UART1_RTS ,
/* UART1 */
2008-07-05 10:03:00 +02:00
PE3_PF_UART2_CTS ,
PE4_PF_UART2_RTS ,
PE6_PF_UART2_TXD ,
2009-04-29 04:00:48 +04:00
PE7_PF_UART2_RXD ,
/* UART2 */
2008-07-05 10:03:00 +02:00
PE8_PF_UART3_TXD ,
PE9_PF_UART3_RXD ,
PE10_PF_UART3_CTS ,
2009-04-29 04:00:48 +04:00
PE11_PF_UART3_RTS ,
/* UART3 */
2008-07-05 10:03:00 +02:00
PB26_AF_UART4_RTS ,
PB28_AF_UART4_TXD ,
PB29_AF_UART4_CTS ,
2009-04-29 04:00:48 +04:00
PB31_AF_UART4_RXD ,
/* UART4 */
2008-07-05 10:03:00 +02:00
PB18_AF_UART5_TXD ,
PB19_AF_UART5_RXD ,
PB20_AF_UART5_CTS ,
2009-04-29 04:00:48 +04:00
PB21_AF_UART5_RTS ,
/* UART5 */
2008-07-05 10:03:00 +02:00
PB10_AF_UART6_TXD ,
PB12_AF_UART6_CTS ,
PB11_AF_UART6_RXD ,
2009-04-29 04:00:48 +04:00
PB13_AF_UART6_RTS ,
/* FEC */
2008-07-05 10:03:00 +02:00
PD0_AIN_FEC_TXD0 ,
PD1_AIN_FEC_TXD1 ,
PD2_AIN_FEC_TXD2 ,
PD3_AIN_FEC_TXD3 ,
PD4_AOUT_FEC_RX_ER ,
PD5_AOUT_FEC_RXD1 ,
PD6_AOUT_FEC_RXD2 ,
PD7_AOUT_FEC_RXD3 ,
PD8_AF_FEC_MDIO ,
PD9_AIN_FEC_MDC ,
PD10_AOUT_FEC_CRS ,
PD11_AOUT_FEC_TX_CLK ,
PD12_AOUT_FEC_RXD0 ,
PD13_AOUT_FEC_RX_DV ,
2009-01-29 10:07:50 +01:00
PD14_AOUT_FEC_RX_CLK ,
2008-07-05 10:03:00 +02:00
PD15_AOUT_FEC_COL ,
PD16_AIN_FEC_TX_ER ,
2009-04-29 04:00:48 +04:00
PF23_AIN_FEC_TX_EN ,
2009-04-29 04:00:50 +04:00
/* I2C2 */
PC5_PF_I2C2_SDA ,
PC6_PF_I2C2_SCL ,
2009-04-29 04:00:51 +04:00
/* FB */
PA5_PF_LSCLK ,
PA6_PF_LD0 ,
PA7_PF_LD1 ,
PA8_PF_LD2 ,
PA9_PF_LD3 ,
PA10_PF_LD4 ,
PA11_PF_LD5 ,
PA12_PF_LD6 ,
PA13_PF_LD7 ,
PA14_PF_LD8 ,
PA15_PF_LD9 ,
PA16_PF_LD10 ,
PA17_PF_LD11 ,
PA18_PF_LD12 ,
PA19_PF_LD13 ,
PA20_PF_LD14 ,
PA21_PF_LD15 ,
PA22_PF_LD16 ,
PA23_PF_LD17 ,
PA24_PF_REV ,
PA25_PF_CLS ,
PA26_PF_PS ,
PA27_PF_SPL_SPR ,
PA28_PF_HSYNC ,
PA29_PF_VSYNC ,
PA30_PF_CONTRAST ,
PA31_PF_OE_ACD ,
2009-04-29 04:00:52 +04:00
/* OWIRE */
PE16_AF_OWIRE ,
2009-04-30 15:31:20 +04:00
/* SDHC1*/
PE18_PF_SD1_D0 ,
PE19_PF_SD1_D1 ,
PE20_PF_SD1_D2 ,
PE21_PF_SD1_D3 ,
PE22_PF_SD1_CMD ,
PE23_PF_SD1_CLK ,
/* SDHC2*/
PB4_PF_SD2_D0 ,
PB5_PF_SD2_D1 ,
PB6_PF_SD2_D2 ,
PB7_PF_SD2_D3 ,
PB8_PF_SD2_CMD ,
PB9_PF_SD2_CLK ,
2008-07-05 10:03:00 +02:00
} ;
2010-06-16 07:35:31 +02:00
static const struct mxc_nand_platform_data
mx27ads_nand_board_info __initconst = {
2009-04-29 04:00:49 +04:00
. width = 1 ,
. hw_ecc = 1 ,
} ;
2009-04-29 04:00:48 +04:00
/* ADS's NOR flash */
static struct physmap_flash_data mx27ads_flash_data = {
. width = 2 ,
} ;
static struct resource mx27ads_flash_resource = {
. start = 0xc0000000 ,
. end = 0xc0000000 + 0x02000000 - 1 ,
. flags = IORESOURCE_MEM ,
} ;
static struct platform_device mx27ads_nor_mtd_device = {
. name = " physmap-flash " ,
. id = 0 ,
. dev = {
. platform_data = & mx27ads_flash_data ,
} ,
. num_resources = 1 ,
. resource = & mx27ads_flash_resource ,
} ;
2010-06-16 17:25:40 +02:00
static const struct imxi2c_platform_data mx27ads_i2c1_data __initconst = {
2009-04-29 04:00:50 +04:00
. bitrate = 100000 ,
} ;
static struct i2c_board_info mx27ads_i2c_devices [ ] = {
} ;
2009-04-29 04:00:51 +04:00
void lcd_power ( int on )
{
if ( on )
__raw_writew ( PBC_BCTRL1_LCDON , PBC_BCTRL1_SET_REG ) ;
else
__raw_writew ( PBC_BCTRL1_LCDON , PBC_BCTRL1_CLEAR_REG ) ;
}
2009-03-19 08:25:41 +01:00
static struct imx_fb_videomode mx27ads_modes [ ] = {
{
. mode = {
. name = " Sharp-LQ035Q7 " ,
. refresh = 60 ,
. xres = 240 ,
. yres = 320 ,
. pixclock = 188679 , /* in ps (5.3MHz) */
. hsync_len = 1 ,
. left_margin = 9 ,
. right_margin = 16 ,
. vsync_len = 1 ,
. upper_margin = 7 ,
. lower_margin = 9 ,
} ,
. bpp = 16 ,
. pcr = 0xFB008BC0 ,
} ,
} ;
2009-04-29 04:00:51 +04:00
2009-03-19 08:25:41 +01:00
static struct imx_fb_platform_data mx27ads_fb_data = {
. mode = mx27ads_modes ,
. num_modes = ARRAY_SIZE ( mx27ads_modes ) ,
2009-04-29 04:00:51 +04:00
/*
* - HSYNC active high
* - VSYNC active high
* - clk notenabled while idle
* - clock inverted
* - data not inverted
* - data enable low active
* - enable sharp mode
*/
. pwmr = 0x00A903FF ,
. lscr1 = 0x00120300 ,
. dmacr = 0x00020010 ,
. lcd_power = lcd_power ,
} ;
2009-04-30 15:31:20 +04:00
static int mx27ads_sdhc1_init ( struct device * dev , irq_handler_t detect_irq ,
void * data )
{
return request_irq ( IRQ_GPIOE ( 21 ) , detect_irq , IRQF_TRIGGER_RISING ,
" sdhc1-card-detect " , data ) ;
}
static int mx27ads_sdhc2_init ( struct device * dev , irq_handler_t detect_irq ,
void * data )
{
return request_irq ( IRQ_GPIOB ( 7 ) , detect_irq , IRQF_TRIGGER_RISING ,
" sdhc2-card-detect " , data ) ;
}
static void mx27ads_sdhc1_exit ( struct device * dev , void * data )
{
free_irq ( IRQ_GPIOE ( 21 ) , data ) ;
}
static void mx27ads_sdhc2_exit ( struct device * dev , void * data )
{
free_irq ( IRQ_GPIOB ( 7 ) , data ) ;
}
static struct imxmmc_platform_data sdhc1_pdata = {
. init = mx27ads_sdhc1_init ,
. exit = mx27ads_sdhc1_exit ,
} ;
static struct imxmmc_platform_data sdhc2_pdata = {
. init = mx27ads_sdhc2_init ,
. exit = mx27ads_sdhc2_exit ,
} ;
2009-04-29 04:00:48 +04:00
static struct platform_device * platform_devices [ ] __initdata = {
& mx27ads_nor_mtd_device ,
2009-04-29 04:00:52 +04:00
& mxc_w1_master_device ,
2009-04-29 04:00:48 +04:00
} ;
2008-07-05 10:03:00 +02:00
2010-06-23 09:36:01 +02:00
static const struct imxuart_platform_data uart_pdata __initconst = {
. flags = IMXUART_HAVE_RTSCTS ,
2008-07-05 10:03:00 +02:00
} ;
static void __init mx27ads_board_init ( void )
{
2009-04-29 04:00:48 +04:00
mxc_gpio_setup_multiple_pins ( mx27ads_pins , ARRAY_SIZE ( mx27ads_pins ) ,
" mx27ads " ) ;
2008-07-05 10:03:00 +02:00
2010-06-23 09:36:01 +02:00
imx27_add_imx_uart0 ( & uart_pdata ) ;
imx27_add_imx_uart1 ( & uart_pdata ) ;
imx27_add_imx_uart2 ( & uart_pdata ) ;
imx27_add_imx_uart3 ( & uart_pdata ) ;
imx27_add_imx_uart4 ( & uart_pdata ) ;
imx27_add_imx_uart5 ( & uart_pdata ) ;
2010-06-16 07:35:31 +02:00
imx27_add_mxc_nand ( & mx27ads_nand_board_info ) ;
2009-04-29 04:00:50 +04:00
/* only the i2c master 1 is used on this CPU card */
i2c_register_board_info ( 1 , mx27ads_i2c_devices ,
ARRAY_SIZE ( mx27ads_i2c_devices ) ) ;
2010-08-25 12:19:50 +02:00
imx27_add_imx_i2c ( 1 , & mx27ads_i2c1_data ) ;
2009-04-29 04:00:51 +04:00
mxc_register_device ( & mxc_fb_device , & mx27ads_fb_data ) ;
2009-04-30 15:31:20 +04:00
mxc_register_device ( & mxc_sdhc_device0 , & sdhc1_pdata ) ;
mxc_register_device ( & mxc_sdhc_device1 , & sdhc2_pdata ) ;
2008-07-05 10:03:00 +02:00
2010-10-06 12:00:18 +02:00
imx27_add_fec ( NULL ) ;
2008-07-05 10:03:00 +02:00
platform_add_devices ( platform_devices , ARRAY_SIZE ( platform_devices ) ) ;
}
static void __init mx27ads_timer_init ( void )
{
unsigned long fref = 26000000 ;
if ( ( __raw_readw ( PBC_VERSION_REG ) & CKIH_27MHZ_BIT_SET ) = = 0 )
fref = 27000000 ;
2009-02-16 14:36:49 +01:00
mx27_clocks_init ( fref ) ;
2008-07-05 10:03:00 +02:00
}
2009-01-26 16:34:51 +01:00
static struct sys_timer mx27ads_timer = {
2008-07-05 10:03:00 +02:00
. init = mx27ads_timer_init ,
} ;
static struct map_desc mx27ads_io_desc [ ] __initdata = {
{
. virtual = PBC_BASE_ADDRESS ,
2009-12-09 11:32:11 +01:00
. pfn = __phys_to_pfn ( MX27_CS4_BASE_ADDR ) ,
2008-07-05 10:03:00 +02:00
. length = SZ_1M ,
. type = MT_DEVICE ,
} ,
} ;
2009-01-26 16:34:51 +01:00
static void __init mx27ads_map_io ( void )
2008-07-05 10:03:00 +02:00
{
2009-04-02 22:32:10 +02:00
mx27_map_io ( ) ;
2008-07-05 10:03:00 +02:00
iotable_init ( mx27ads_io_desc , ARRAY_SIZE ( mx27ads_io_desc ) ) ;
}
MACHINE_START ( MX27ADS , " Freescale i.MX27ADS " )
/* maintainer: Freescale Semiconductor, Inc. */
2010-01-29 17:36:05 +01:00
. boot_params = MX27_PHYS_OFFSET + 0x100 ,
2008-07-05 10:03:00 +02:00
. map_io = mx27ads_map_io ,
2009-05-25 17:36:19 +02:00
. init_irq = mx27_init_irq ,
2008-07-05 10:03:00 +02:00
. init_machine = mx27ads_board_init ,
. timer = & mx27ads_timer ,
MACHINE_END