Path: blob/master/arch/arm/mach-davinci/board-tnetv107x-evm.c
10699 views
/*1* Texas Instruments TNETV107X EVM Board Support2*3* Copyright (C) 2010 Texas Instruments4*5* This program is free software; you can redistribute it and/or6* modify it under the terms of the GNU General Public License as7* published by the Free Software Foundation version 2.8*9* This program is distributed "as is" WITHOUT ANY WARRANTY of any10* kind, whether express or implied; without even the implied warranty11* of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the12* GNU General Public License for more details.13*/14#include <linux/kernel.h>15#include <linux/init.h>16#include <linux/console.h>17#include <linux/dma-mapping.h>18#include <linux/interrupt.h>19#include <linux/gpio.h>20#include <linux/delay.h>21#include <linux/platform_device.h>22#include <linux/ratelimit.h>23#include <linux/mtd/mtd.h>24#include <linux/mtd/partitions.h>25#include <linux/input.h>26#include <linux/input/matrix_keypad.h>27#include <linux/spi/spi.h>2829#include <asm/mach/arch.h>30#include <asm/mach-types.h>3132#include <mach/irqs.h>33#include <mach/edma.h>34#include <mach/mux.h>35#include <mach/cp_intc.h>36#include <mach/tnetv107x.h>3738#define EVM_MMC_WP_GPIO 2139#define EVM_MMC_CD_GPIO 2440#define EVM_SPI_CS_GPIO 544142static int initialize_gpio(int gpio, char *desc)43{44int ret;4546ret = gpio_request(gpio, desc);47if (ret < 0) {48pr_err_ratelimited("cannot open %s gpio\n", desc);49return -ENOSYS;50}51gpio_direction_input(gpio);52return gpio;53}5455static int mmc_get_cd(int index)56{57static int gpio;5859if (!gpio)60gpio = initialize_gpio(EVM_MMC_CD_GPIO, "mmc card detect");6162if (gpio < 0)63return gpio;6465return gpio_get_value(gpio) ? 0 : 1;66}6768static int mmc_get_ro(int index)69{70static int gpio;7172if (!gpio)73gpio = initialize_gpio(EVM_MMC_WP_GPIO, "mmc write protect");7475if (gpio < 0)76return gpio;7778return gpio_get_value(gpio) ? 1 : 0;79}8081static struct davinci_mmc_config mmc_config = {82.get_cd = mmc_get_cd,83.get_ro = mmc_get_ro,84.wires = 4,85.max_freq = 50000000,86.caps = MMC_CAP_MMC_HIGHSPEED | MMC_CAP_SD_HIGHSPEED,87.version = MMC_CTLR_VERSION_1,88};8990static const short sdio1_pins[] __initdata = {91TNETV107X_SDIO1_CLK_1, TNETV107X_SDIO1_CMD_1,92TNETV107X_SDIO1_DATA0_1, TNETV107X_SDIO1_DATA1_1,93TNETV107X_SDIO1_DATA2_1, TNETV107X_SDIO1_DATA3_1,94TNETV107X_GPIO21, TNETV107X_GPIO24,95-196};9798static const short uart1_pins[] __initdata = {99TNETV107X_UART1_RD, TNETV107X_UART1_TD,100-1101};102103static const short ssp_pins[] __initdata = {104TNETV107X_SSP0_0, TNETV107X_SSP0_1, TNETV107X_SSP0_2,105TNETV107X_SSP1_0, TNETV107X_SSP1_1, TNETV107X_SSP1_2,106TNETV107X_SSP1_3, -1107};108109static struct mtd_partition nand_partitions[] = {110/* bootloader (U-Boot, etc) in first 12 sectors */111{112.name = "bootloader",113.offset = 0,114.size = (12*SZ_128K),115.mask_flags = MTD_WRITEABLE, /* force read-only */116},117/* bootloader params in the next sector */118{119.name = "params",120.offset = MTDPART_OFS_NXTBLK,121.size = SZ_128K,122.mask_flags = MTD_WRITEABLE, /* force read-only */123},124/* kernel */125{126.name = "kernel",127.offset = MTDPART_OFS_NXTBLK,128.size = SZ_4M,129.mask_flags = 0,130},131/* file system */132{133.name = "filesystem",134.offset = MTDPART_OFS_NXTBLK,135.size = MTDPART_SIZ_FULL,136.mask_flags = 0,137}138};139140static struct davinci_nand_pdata nand_config = {141.mask_cle = 0x4000,142.mask_ale = 0x2000,143.parts = nand_partitions,144.nr_parts = ARRAY_SIZE(nand_partitions),145.ecc_mode = NAND_ECC_HW,146.options = NAND_USE_FLASH_BBT,147.ecc_bits = 1,148};149150static struct davinci_uart_config serial_config __initconst = {151.enabled_uarts = BIT(1),152};153154static const uint32_t keymap[] = {155KEY(0, 0, KEY_NUMERIC_1),156KEY(0, 1, KEY_NUMERIC_2),157KEY(0, 2, KEY_NUMERIC_3),158KEY(0, 3, KEY_FN_F1),159KEY(0, 4, KEY_MENU),160161KEY(1, 0, KEY_NUMERIC_4),162KEY(1, 1, KEY_NUMERIC_5),163KEY(1, 2, KEY_NUMERIC_6),164KEY(1, 3, KEY_UP),165KEY(1, 4, KEY_FN_F2),166167KEY(2, 0, KEY_NUMERIC_7),168KEY(2, 1, KEY_NUMERIC_8),169KEY(2, 2, KEY_NUMERIC_9),170KEY(2, 3, KEY_LEFT),171KEY(2, 4, KEY_ENTER),172173KEY(3, 0, KEY_NUMERIC_STAR),174KEY(3, 1, KEY_NUMERIC_0),175KEY(3, 2, KEY_NUMERIC_POUND),176KEY(3, 3, KEY_DOWN),177KEY(3, 4, KEY_RIGHT),178179KEY(4, 0, KEY_FN_F3),180KEY(4, 1, KEY_FN_F4),181KEY(4, 2, KEY_MUTE),182KEY(4, 3, KEY_HOME),183KEY(4, 4, KEY_BACK),184185KEY(5, 0, KEY_VOLUMEDOWN),186KEY(5, 1, KEY_VOLUMEUP),187KEY(5, 2, KEY_F1),188KEY(5, 3, KEY_F2),189KEY(5, 4, KEY_F3),190};191192static const struct matrix_keymap_data keymap_data = {193.keymap = keymap,194.keymap_size = ARRAY_SIZE(keymap),195};196197static struct matrix_keypad_platform_data keypad_config = {198.keymap_data = &keymap_data,199.num_row_gpios = 6,200.num_col_gpios = 5,201.debounce_ms = 0, /* minimum */202.active_low = 0, /* pull up realization */203.no_autorepeat = 0,204};205206static void spi_select_device(int cs)207{208static int gpio;209210if (!gpio) {211int ret;212ret = gpio_request(EVM_SPI_CS_GPIO, "spi chipsel");213if (ret < 0) {214pr_err("cannot open spi chipsel gpio\n");215gpio = -ENOSYS;216return;217} else {218gpio = EVM_SPI_CS_GPIO;219gpio_direction_output(gpio, 0);220}221}222223if (gpio < 0)224return;225226return gpio_set_value(gpio, cs ? 1 : 0);227}228229static struct ti_ssp_spi_data spi_master_data = {230.num_cs = 2,231.select = spi_select_device,232.iosel = SSP_PIN_SEL(0, SSP_CLOCK) | SSP_PIN_SEL(1, SSP_DATA) |233SSP_PIN_SEL(2, SSP_CHIPSEL) | SSP_PIN_SEL(3, SSP_IN) |234SSP_INPUT_SEL(3),235};236237static struct ti_ssp_data ssp_config = {238.out_clock = 250 * 1000,239.dev_data = {240[1] = {241.dev_name = "ti-ssp-spi",242.pdata = &spi_master_data,243.pdata_size = sizeof(spi_master_data),244},245},246};247248static struct tnetv107x_device_info evm_device_info __initconst = {249.serial_config = &serial_config,250.mmc_config[1] = &mmc_config, /* controller 1 */251.nand_config[0] = &nand_config, /* chip select 0 */252.keypad_config = &keypad_config,253.ssp_config = &ssp_config,254};255256static struct spi_board_info spi_info[] __initconst = {257};258259static __init void tnetv107x_evm_board_init(void)260{261davinci_cfg_reg_list(sdio1_pins);262davinci_cfg_reg_list(uart1_pins);263davinci_cfg_reg_list(ssp_pins);264265tnetv107x_devices_init(&evm_device_info);266267spi_register_board_info(spi_info, ARRAY_SIZE(spi_info));268}269270#ifdef CONFIG_SERIAL_8250_CONSOLE271static int __init tnetv107x_evm_console_init(void)272{273return add_preferred_console("ttyS", 0, "115200");274}275console_initcall(tnetv107x_evm_console_init);276#endif277278MACHINE_START(TNETV107X, "TNETV107X EVM")279.boot_params = (TNETV107X_DDR_BASE + 0x100),280.map_io = tnetv107x_init,281.init_irq = cp_intc_init,282.timer = &davinci_timer,283.init_machine = tnetv107x_evm_board_init,284MACHINE_END285286287