blob: 7119ef28e0adf2e7869da0d4238fe0b30ea677c7 [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>
Tony Lindgren68f39e72012-10-15 12:09:43 -070016#include <linux/platform_data/gpio-omap.h>
Tony Lindgrend8874662008-12-10 17:37:16 -080017#include <linux/i2c/tps65010.h>
18
Tony Lindgreneb6b0b12009-03-23 18:07:33 -070019#include "board-h2.h"
Tony Lindgren68f39e72012-10-15 12:09:43 -070020#include "mmc.h"
Tony Lindgreneb6b0b12009-03-23 18:07:33 -070021
Tony Lindgrend8874662008-12-10 17:37:16 -080022#if defined(CONFIG_MMC_OMAP) || defined(CONFIG_MMC_OMAP_MODULE)
23
24static int mmc_set_power(struct device *dev, int slot, int power_on,
25 int vdd)
26{
Ladislav Michl6a326072009-04-23 11:10:47 -070027 gpio_set_value(H2_TPS_GPIO_MMC_PWR_EN, power_on);
Tony Lindgrend8874662008-12-10 17:37:16 -080028 return 0;
29}
30
31static int mmc_late_init(struct device *dev)
32{
Ladislav Michl6a326072009-04-23 11:10:47 -070033 int ret = gpio_request(H2_TPS_GPIO_MMC_PWR_EN, "MMC power");
Tony Lindgrend8874662008-12-10 17:37:16 -080034 if (ret < 0)
35 return ret;
36
37 gpio_direction_output(H2_TPS_GPIO_MMC_PWR_EN, 0);
38
39 return ret;
40}
41
Ladislav Michl6a326072009-04-23 11:10:47 -070042static void mmc_cleanup(struct device *dev)
Tony Lindgrend8874662008-12-10 17:37:16 -080043{
44 gpio_free(H2_TPS_GPIO_MMC_PWR_EN);
45}
46
47/*
48 * H2 could use the following functions tested:
49 * - mmc_get_cover_state that uses OMAP_MPUIO(1)
50 * - mmc_get_wp that uses OMAP_MPUIO(3)
51 */
52static struct omap_mmc_platform_data mmc1_data = {
53 .nr_slots = 1,
54 .init = mmc_late_init,
Ladislav Michl6a326072009-04-23 11:10:47 -070055 .cleanup = mmc_cleanup,
Tony Lindgrend8874662008-12-10 17:37:16 -080056 .slots[0] = {
57 .set_power = mmc_set_power,
Tony Lindgren2a124002010-10-12 16:07:51 -070058 .ocr_mask = MMC_VDD_32_33 | MMC_VDD_33_34,
Tony Lindgrend8874662008-12-10 17:37:16 -080059 .name = "mmcblk",
60 },
61};
62
63static struct omap_mmc_platform_data *mmc_data[OMAP16XX_NR_MMC];
64
65void __init h2_mmc_init(void)
66{
67 mmc_data[0] = &mmc1_data;
68 omap1_init_mmc(mmc_data, OMAP16XX_NR_MMC);
69}
70
71#else
72
Felipe Balbi138ab9f2007-11-27 00:01:45 -040073void __init h2_mmc_init(void)
74{
75}
76
Tony Lindgrend8874662008-12-10 17:37:16 -080077#endif