Path: blob/master/arch/arm/mach-mxs/mach-mx23evk.c
10817 views
/*1* Copyright 2010 Freescale Semiconductor, Inc. All Rights Reserved.2*3* This program is free software; you can redistribute it and/or modify4* it under the terms of the GNU General Public License as published by5* the Free Software Foundation; either version 2 of the License, or6* (at your option) any later version.7*8* This program is distributed in the hope that it will be useful,9* but WITHOUT ANY WARRANTY; without even the implied warranty of10* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the11* GNU General Public License for more details.12*/1314#include <linux/delay.h>15#include <linux/platform_device.h>16#include <linux/gpio.h>17#include <linux/irq.h>1819#include <asm/mach-types.h>20#include <asm/mach/arch.h>21#include <asm/mach/time.h>2223#include <mach/common.h>24#include <mach/iomux-mx23.h>2526#include "devices-mx23.h"2728#define MX23EVK_LCD_ENABLE MXS_GPIO_NR(1, 18)29#define MX23EVK_BL_ENABLE MXS_GPIO_NR(1, 28)30#define MX23EVK_MMC0_WRITE_PROTECT MXS_GPIO_NR(1, 30)31#define MX23EVK_MMC0_SLOT_POWER MXS_GPIO_NR(1, 29)3233static const iomux_cfg_t mx23evk_pads[] __initconst = {34/* duart */35MX23_PAD_PWM0__DUART_RX | MXS_PAD_CTRL,36MX23_PAD_PWM1__DUART_TX | MXS_PAD_CTRL,3738/* auart */39MX23_PAD_AUART1_RX__AUART1_RX | MXS_PAD_CTRL,40MX23_PAD_AUART1_TX__AUART1_TX | MXS_PAD_CTRL,41MX23_PAD_AUART1_CTS__AUART1_CTS | MXS_PAD_CTRL,42MX23_PAD_AUART1_RTS__AUART1_RTS | MXS_PAD_CTRL,4344/* mxsfb (lcdif) */45MX23_PAD_LCD_D00__LCD_D00 | MXS_PAD_CTRL,46MX23_PAD_LCD_D01__LCD_D01 | MXS_PAD_CTRL,47MX23_PAD_LCD_D02__LCD_D02 | MXS_PAD_CTRL,48MX23_PAD_LCD_D03__LCD_D03 | MXS_PAD_CTRL,49MX23_PAD_LCD_D04__LCD_D04 | MXS_PAD_CTRL,50MX23_PAD_LCD_D05__LCD_D05 | MXS_PAD_CTRL,51MX23_PAD_LCD_D06__LCD_D06 | MXS_PAD_CTRL,52MX23_PAD_LCD_D07__LCD_D07 | MXS_PAD_CTRL,53MX23_PAD_LCD_D08__LCD_D08 | MXS_PAD_CTRL,54MX23_PAD_LCD_D09__LCD_D09 | MXS_PAD_CTRL,55MX23_PAD_LCD_D10__LCD_D10 | MXS_PAD_CTRL,56MX23_PAD_LCD_D11__LCD_D11 | MXS_PAD_CTRL,57MX23_PAD_LCD_D12__LCD_D12 | MXS_PAD_CTRL,58MX23_PAD_LCD_D13__LCD_D13 | MXS_PAD_CTRL,59MX23_PAD_LCD_D14__LCD_D14 | MXS_PAD_CTRL,60MX23_PAD_LCD_D15__LCD_D15 | MXS_PAD_CTRL,61MX23_PAD_LCD_D16__LCD_D16 | MXS_PAD_CTRL,62MX23_PAD_LCD_D17__LCD_D17 | MXS_PAD_CTRL,63MX23_PAD_GPMI_D08__LCD_D18 | MXS_PAD_CTRL,64MX23_PAD_GPMI_D09__LCD_D19 | MXS_PAD_CTRL,65MX23_PAD_GPMI_D10__LCD_D20 | MXS_PAD_CTRL,66MX23_PAD_GPMI_D11__LCD_D21 | MXS_PAD_CTRL,67MX23_PAD_GPMI_D12__LCD_D22 | MXS_PAD_CTRL,68MX23_PAD_GPMI_D13__LCD_D23 | MXS_PAD_CTRL,69MX23_PAD_LCD_VSYNC__LCD_VSYNC | MXS_PAD_CTRL,70MX23_PAD_LCD_HSYNC__LCD_HSYNC | MXS_PAD_CTRL,71MX23_PAD_LCD_DOTCK__LCD_DOTCK | MXS_PAD_CTRL,72MX23_PAD_LCD_ENABLE__LCD_ENABLE | MXS_PAD_CTRL,73/* LCD panel enable */74MX23_PAD_LCD_RESET__GPIO_1_18 | MXS_PAD_CTRL,75/* backlight control */76MX23_PAD_PWM2__GPIO_1_28 | MXS_PAD_CTRL,7778/* mmc */79MX23_PAD_SSP1_DATA0__SSP1_DATA0 |80(MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP),81MX23_PAD_SSP1_DATA1__SSP1_DATA1 |82(MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP),83MX23_PAD_SSP1_DATA2__SSP1_DATA2 |84(MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP),85MX23_PAD_SSP1_DATA3__SSP1_DATA3 |86(MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP),87MX23_PAD_GPMI_D08__SSP1_DATA4 |88(MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP),89MX23_PAD_GPMI_D09__SSP1_DATA5 |90(MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP),91MX23_PAD_GPMI_D10__SSP1_DATA6 |92(MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP),93MX23_PAD_GPMI_D11__SSP1_DATA7 |94(MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP),95MX23_PAD_SSP1_CMD__SSP1_CMD |96(MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP),97MX23_PAD_SSP1_DETECT__SSP1_DETECT |98(MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_NOPULL),99MX23_PAD_SSP1_SCK__SSP1_SCK |100(MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_NOPULL),101/* write protect */102MX23_PAD_PWM4__GPIO_1_30 |103(MXS_PAD_4MA | MXS_PAD_3V3 | MXS_PAD_NOPULL),104/* slot power enable */105MX23_PAD_PWM3__GPIO_1_29 |106(MXS_PAD_4MA | MXS_PAD_3V3 | MXS_PAD_NOPULL),107};108109/* mxsfb (lcdif) */110static struct fb_videomode mx23evk_video_modes[] = {111{112.name = "Samsung-LMS430HF02",113.refresh = 60,114.xres = 480,115.yres = 272,116.pixclock = 108096, /* picosecond (9.2 MHz) */117.left_margin = 15,118.right_margin = 8,119.upper_margin = 12,120.lower_margin = 4,121.hsync_len = 1,122.vsync_len = 1,123.sync = FB_SYNC_DATA_ENABLE_HIGH_ACT |124FB_SYNC_DOTCLK_FAILING_ACT,125},126};127128static const struct mxsfb_platform_data mx23evk_mxsfb_pdata __initconst = {129.mode_list = mx23evk_video_modes,130.mode_count = ARRAY_SIZE(mx23evk_video_modes),131.default_bpp = 32,132.ld_intf_width = STMLCDIF_24BIT,133};134135static struct mxs_mmc_platform_data mx23evk_mmc_pdata __initdata = {136.wp_gpio = MX23EVK_MMC0_WRITE_PROTECT,137.flags = SLOTF_8_BIT_CAPABLE,138};139140static void __init mx23evk_init(void)141{142int ret;143144mxs_iomux_setup_multiple_pads(mx23evk_pads, ARRAY_SIZE(mx23evk_pads));145146mx23_add_duart();147mx23_add_auart0();148149/* power on mmc slot by writing 0 to the gpio */150ret = gpio_request_one(MX23EVK_MMC0_SLOT_POWER, GPIOF_OUT_INIT_LOW,151"mmc0-slot-power");152if (ret)153pr_warn("failed to request gpio mmc0-slot-power: %d\n", ret);154mx23_add_mxs_mmc(0, &mx23evk_mmc_pdata);155156ret = gpio_request_one(MX23EVK_LCD_ENABLE, GPIOF_DIR_OUT, "lcd-enable");157if (ret)158pr_warn("failed to request gpio lcd-enable: %d\n", ret);159else160gpio_set_value(MX23EVK_LCD_ENABLE, 1);161162ret = gpio_request_one(MX23EVK_BL_ENABLE, GPIOF_DIR_OUT, "bl-enable");163if (ret)164pr_warn("failed to request gpio bl-enable: %d\n", ret);165else166gpio_set_value(MX23EVK_BL_ENABLE, 1);167168mx23_add_mxsfb(&mx23evk_mxsfb_pdata);169}170171static void __init mx23evk_timer_init(void)172{173mx23_clocks_init();174}175176static struct sys_timer mx23evk_timer = {177.init = mx23evk_timer_init,178};179180MACHINE_START(MX23EVK, "Freescale MX23 EVK")181/* Maintainer: Freescale Semiconductor, Inc. */182.map_io = mx23_map_io,183.init_irq = mx23_init_irq,184.init_machine = mx23evk_init,185.timer = &mx23evk_timer,186MACHINE_END187188189