Path: blob/master/arch/arm/mach-omap1/board-nokia770.c
10817 views
/*1* linux/arch/arm/mach-omap1/board-nokia770.c2*3* Modified from board-generic.c4*5* This program is free software; you can redistribute it and/or modify6* it under the terms of the GNU General Public License version 2 as7* published by the Free Software Foundation.8*/910#include <linux/kernel.h>11#include <linux/init.h>12#include <linux/mutex.h>13#include <linux/platform_device.h>14#include <linux/input.h>15#include <linux/clk.h>16#include <linux/omapfb.h>1718#include <linux/spi/spi.h>19#include <linux/spi/ads7846.h>20#include <linux/workqueue.h>21#include <linux/delay.h>2223#include <mach/hardware.h>24#include <asm/mach-types.h>25#include <asm/mach/arch.h>26#include <asm/mach/map.h>2728#include <mach/gpio.h>29#include <plat/mux.h>30#include <plat/usb.h>31#include <plat/board.h>32#include <plat/keypad.h>33#include <plat/common.h>34#include <plat/hwa742.h>35#include <plat/lcd_mipid.h>36#include <plat/mmc.h>37#include <plat/clock.h>3839#define ADS7846_PENDOWN_GPIO 154041static void __init omap_nokia770_init_irq(void)42{43/* On Nokia 770, the SleepX signal is masked with an44* MPUIO line by default. It has to be unmasked for it45* to become functional */4647/* SleepX mask direction */48omap_writew((omap_readw(0xfffb5008) & ~2), 0xfffb5008);49/* Unmask SleepX signal */50omap_writew((omap_readw(0xfffb5004) & ~2), 0xfffb5004);5152omap1_init_common_hw();53omap_init_irq();54}5556static const unsigned int nokia770_keymap[] = {57KEY(1, 0, GROUP_0 | KEY_UP),58KEY(2, 0, GROUP_1 | KEY_F5),59KEY(0, 1, GROUP_0 | KEY_LEFT),60KEY(1, 1, GROUP_0 | KEY_ENTER),61KEY(2, 1, GROUP_0 | KEY_RIGHT),62KEY(0, 2, GROUP_1 | KEY_ESC),63KEY(1, 2, GROUP_0 | KEY_DOWN),64KEY(2, 2, GROUP_1 | KEY_F4),65KEY(0, 3, GROUP_2 | KEY_F7),66KEY(1, 3, GROUP_2 | KEY_F8),67KEY(2, 3, GROUP_2 | KEY_F6),68};6970static struct resource nokia770_kp_resources[] = {71[0] = {72.start = INT_KEYBOARD,73.end = INT_KEYBOARD,74.flags = IORESOURCE_IRQ,75},76};7778static const struct matrix_keymap_data nokia770_keymap_data = {79.keymap = nokia770_keymap,80.keymap_size = ARRAY_SIZE(nokia770_keymap),81};8283static struct omap_kp_platform_data nokia770_kp_data = {84.rows = 8,85.cols = 8,86.keymap_data = &nokia770_keymap_data,87.delay = 4,88};8990static struct platform_device nokia770_kp_device = {91.name = "omap-keypad",92.id = -1,93.dev = {94.platform_data = &nokia770_kp_data,95},96.num_resources = ARRAY_SIZE(nokia770_kp_resources),97.resource = nokia770_kp_resources,98};99100static struct platform_device *nokia770_devices[] __initdata = {101&nokia770_kp_device,102};103104static void mipid_shutdown(struct mipid_platform_data *pdata)105{106if (pdata->nreset_gpio != -1) {107printk(KERN_INFO "shutdown LCD\n");108gpio_set_value(pdata->nreset_gpio, 0);109msleep(120);110}111}112113static struct mipid_platform_data nokia770_mipid_platform_data = {114.shutdown = mipid_shutdown,115};116117static void __init mipid_dev_init(void)118{119const struct omap_lcd_config *conf;120121conf = omap_get_config(OMAP_TAG_LCD, struct omap_lcd_config);122if (conf != NULL) {123nokia770_mipid_platform_data.nreset_gpio = conf->nreset_gpio;124nokia770_mipid_platform_data.data_lines = conf->data_lines;125}126}127128static void __init ads7846_dev_init(void)129{130if (gpio_request(ADS7846_PENDOWN_GPIO, "ADS7846 pendown") < 0)131printk(KERN_ERR "can't get ads7846 pen down GPIO\n");132}133134static int ads7846_get_pendown_state(void)135{136return !gpio_get_value(ADS7846_PENDOWN_GPIO);137}138139static struct ads7846_platform_data nokia770_ads7846_platform_data __initdata = {140.x_max = 0x0fff,141.y_max = 0x0fff,142.x_plate_ohms = 180,143.pressure_max = 255,144.debounce_max = 10,145.debounce_tol = 3,146.debounce_rep = 1,147.get_pendown_state = ads7846_get_pendown_state,148};149150static struct spi_board_info nokia770_spi_board_info[] __initdata = {151[0] = {152.modalias = "lcd_mipid",153.bus_num = 2,154.chip_select = 3,155.max_speed_hz = 12000000,156.platform_data = &nokia770_mipid_platform_data,157},158[1] = {159.modalias = "ads7846",160.bus_num = 2,161.chip_select = 0,162.max_speed_hz = 2500000,163.irq = OMAP_GPIO_IRQ(15),164.platform_data = &nokia770_ads7846_platform_data,165},166};167168static struct hwa742_platform_data nokia770_hwa742_platform_data = {169.te_connected = 1,170};171172static void __init hwa742_dev_init(void)173{174clk_add_alias("hwa_sys_ck", NULL, "bclk", NULL);175omapfb_set_ctrl_platform_data(&nokia770_hwa742_platform_data);176}177178/* assume no Mini-AB port */179180static struct omap_usb_config nokia770_usb_config __initdata = {181.otg = 1,182.register_host = 1,183.register_dev = 1,184.hmc_mode = 16,185.pins[0] = 6,186};187188#if defined(CONFIG_MMC_OMAP) || defined(CONFIG_MMC_OMAP_MODULE)189190#define NOKIA770_GPIO_MMC_POWER 41191#define NOKIA770_GPIO_MMC_SWITCH 23192193static int nokia770_mmc_set_power(struct device *dev, int slot, int power_on,194int vdd)195{196gpio_set_value(NOKIA770_GPIO_MMC_POWER, power_on);197return 0;198}199200static int nokia770_mmc_get_cover_state(struct device *dev, int slot)201{202return gpio_get_value(NOKIA770_GPIO_MMC_SWITCH);203}204205static struct omap_mmc_platform_data nokia770_mmc2_data = {206.nr_slots = 1,207.dma_mask = 0xffffffff,208.max_freq = 12000000,209.slots[0] = {210.set_power = nokia770_mmc_set_power,211.get_cover_state = nokia770_mmc_get_cover_state,212.ocr_mask = MMC_VDD_32_33|MMC_VDD_33_34,213.name = "mmcblk",214},215};216217static struct omap_mmc_platform_data *nokia770_mmc_data[OMAP16XX_NR_MMC];218219static void __init nokia770_mmc_init(void)220{221int ret;222223ret = gpio_request(NOKIA770_GPIO_MMC_POWER, "MMC power");224if (ret < 0)225return;226gpio_direction_output(NOKIA770_GPIO_MMC_POWER, 0);227228ret = gpio_request(NOKIA770_GPIO_MMC_SWITCH, "MMC cover");229if (ret < 0) {230gpio_free(NOKIA770_GPIO_MMC_POWER);231return;232}233gpio_direction_input(NOKIA770_GPIO_MMC_SWITCH);234235/* Only the second MMC controller is used */236nokia770_mmc_data[1] = &nokia770_mmc2_data;237omap1_init_mmc(nokia770_mmc_data, OMAP16XX_NR_MMC);238}239240#else241static inline void nokia770_mmc_init(void)242{243}244#endif245246static void __init omap_nokia770_init(void)247{248platform_add_devices(nokia770_devices, ARRAY_SIZE(nokia770_devices));249spi_register_board_info(nokia770_spi_board_info,250ARRAY_SIZE(nokia770_spi_board_info));251omap_serial_init();252omap_register_i2c_bus(1, 100, NULL, 0);253hwa742_dev_init();254ads7846_dev_init();255mipid_dev_init();256omap1_usb_init(&nokia770_usb_config);257nokia770_mmc_init();258}259260static void __init omap_nokia770_map_io(void)261{262omap1_map_common_io();263}264265MACHINE_START(NOKIA770, "Nokia 770")266.boot_params = 0x10000100,267.map_io = omap_nokia770_map_io,268.reserve = omap_reserve,269.init_irq = omap_nokia770_init_irq,270.init_machine = omap_nokia770_init,271.timer = &omap_timer,272MACHINE_END273274275