blob: da0e37d408237076ae8dda8255fa00e085f325e5 [file] [log] [blame]
Felipe Balbi138ab9f2007-11-27 00:01:45 -04001/*
2 * linux/arch/arm/mach-omap1/board-h2-mmc.c
3 *
4 * Copyright (C) 2007 Instituto Nokia de Tecnologia - INdT
5 * Author: Felipe Balbi <felipe.lima@indt.org.br>
6 *
7 * This code is based on linux/arch/arm/mach-omap2/board-n800-mmc.c, which is:
8 * Copyright (C) 2006 Nokia Corporation
9 *
10 * This program is free software; you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License version 2 as
12 * published by the Free Software Foundation.
13 */
Russell King2f8163b2011-07-26 10:53:52 +010014#include <linux/gpio.h>
Tony Lindgrend8874662008-12-10 17:37:16 -080015#include <linux/platform_device.h>
16
17#include <linux/i2c/tps65010.h>
18
Tony Lindgrence491cf2009-10-20 09:40:47 -070019#include <plat/mmc.h>
Felipe Balbi138ab9f2007-11-27 00:01:45 -040020
Tony Lindgreneb6b0b12009-03-23 18:07:33 -070021#include "board-h2.h"
22
Tony Lindgrend8874662008-12-10 17:37:16 -080023#if defined(CONFIG_MMC_OMAP) || defined(CONFIG_MMC_OMAP_MODULE)
24
25static int mmc_set_power(struct device *dev, int slot, int power_on,
26 int vdd)
27{
Ladislav Michl6a326072009-04-23 11:10:47 -070028 gpio_set_value(H2_TPS_GPIO_MMC_PWR_EN, power_on);
Tony Lindgrend8874662008-12-10 17:37:16 -080029 return 0;
30}
31
32static int mmc_late_init(struct device *dev)
33{
Ladislav Michl6a326072009-04-23 11:10:47 -070034 int ret = gpio_request(H2_TPS_GPIO_MMC_PWR_EN, "MMC power");
Tony Lindgrend8874662008-12-10 17:37:16 -080035 if (ret < 0)
36 return ret;
37
38 gpio_direction_output(H2_TPS_GPIO_MMC_PWR_EN, 0);
39
40 return ret;
41}
42
Ladislav Michl6a326072009-04-23 11:10:47 -070043static void mmc_cleanup(struct device *dev)
Tony Lindgrend8874662008-12-10 17:37:16 -080044{
45 gpio_free(H2_TPS_GPIO_MMC_PWR_EN);
46}
47
48/*
49 * H2 could use the following functions tested:
50 * - mmc_get_cover_state that uses OMAP_MPUIO(1)
51 * - mmc_get_wp that uses OMAP_MPUIO(3)
52 */
53static struct omap_mmc_platform_data mmc1_data = {
54 .nr_slots = 1,
55 .init = mmc_late_init,
Ladislav Michl6a326072009-04-23 11:10:47 -070056 .cleanup = mmc_cleanup,
Tony Lindgrend8874662008-12-10 17:37:16 -080057 .dma_mask = 0xffffffff,
58 .slots[0] = {
59 .set_power = mmc_set_power,
Tony Lindgren2a124002010-10-12 16:07:51 -070060 .ocr_mask = MMC_VDD_32_33 | MMC_VDD_33_34,
Tony Lindgrend8874662008-12-10 17:37:16 -080061 .name = "mmcblk",
62 },
63};
64
65static struct omap_mmc_platform_data *mmc_data[OMAP16XX_NR_MMC];
66
67void __init h2_mmc_init(void)
68{
69 mmc_data[0] = &mmc1_data;
70 omap1_init_mmc(mmc_data, OMAP16XX_NR_MMC);
71}
72
73#else
74
Felipe Balbi138ab9f2007-11-27 00:01:45 -040075void __init h2_mmc_init(void)
76{
77}
78
Tony Lindgrend8874662008-12-10 17:37:16 -080079#endif