18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-only
28c2ecf20Sopenharmony_ci/*
38c2ecf20Sopenharmony_ci * linux/arch/arm/mach-omap1/board-h3-mmc.c
48c2ecf20Sopenharmony_ci *
58c2ecf20Sopenharmony_ci * Copyright (C) 2007 Instituto Nokia de Tecnologia - INdT
68c2ecf20Sopenharmony_ci * Author: Felipe Balbi <felipe.lima@indt.org.br>
78c2ecf20Sopenharmony_ci *
88c2ecf20Sopenharmony_ci * This code is based on linux/arch/arm/mach-omap2/board-n800-mmc.c, which is:
98c2ecf20Sopenharmony_ci * Copyright (C) 2006 Nokia Corporation
108c2ecf20Sopenharmony_ci */
118c2ecf20Sopenharmony_ci#include <linux/gpio.h>
128c2ecf20Sopenharmony_ci#include <linux/platform_device.h>
138c2ecf20Sopenharmony_ci
148c2ecf20Sopenharmony_ci#include <linux/mfd/tps65010.h>
158c2ecf20Sopenharmony_ci
168c2ecf20Sopenharmony_ci#include "common.h"
178c2ecf20Sopenharmony_ci#include "board-h3.h"
188c2ecf20Sopenharmony_ci#include "mmc.h"
198c2ecf20Sopenharmony_ci
208c2ecf20Sopenharmony_ci#if IS_ENABLED(CONFIG_MMC_OMAP)
218c2ecf20Sopenharmony_ci
228c2ecf20Sopenharmony_cistatic int mmc_set_power(struct device *dev, int slot, int power_on,
238c2ecf20Sopenharmony_ci				int vdd)
248c2ecf20Sopenharmony_ci{
258c2ecf20Sopenharmony_ci	gpio_set_value(H3_TPS_GPIO_MMC_PWR_EN, power_on);
268c2ecf20Sopenharmony_ci	return 0;
278c2ecf20Sopenharmony_ci}
288c2ecf20Sopenharmony_ci
298c2ecf20Sopenharmony_ci/*
308c2ecf20Sopenharmony_ci * H3 could use the following functions tested:
318c2ecf20Sopenharmony_ci * - mmc_get_cover_state that uses OMAP_MPUIO(1)
328c2ecf20Sopenharmony_ci * - mmc_get_wp that maybe uses OMAP_MPUIO(3)
338c2ecf20Sopenharmony_ci */
348c2ecf20Sopenharmony_cistatic struct omap_mmc_platform_data mmc1_data = {
358c2ecf20Sopenharmony_ci	.nr_slots                       = 1,
368c2ecf20Sopenharmony_ci	.slots[0]       = {
378c2ecf20Sopenharmony_ci		.set_power              = mmc_set_power,
388c2ecf20Sopenharmony_ci		.ocr_mask               = MMC_VDD_32_33 | MMC_VDD_33_34,
398c2ecf20Sopenharmony_ci		.name                   = "mmcblk",
408c2ecf20Sopenharmony_ci	},
418c2ecf20Sopenharmony_ci};
428c2ecf20Sopenharmony_ci
438c2ecf20Sopenharmony_cistatic struct omap_mmc_platform_data *mmc_data[OMAP16XX_NR_MMC];
448c2ecf20Sopenharmony_ci
458c2ecf20Sopenharmony_civoid __init h3_mmc_init(void)
468c2ecf20Sopenharmony_ci{
478c2ecf20Sopenharmony_ci	int ret;
488c2ecf20Sopenharmony_ci
498c2ecf20Sopenharmony_ci	ret = gpio_request(H3_TPS_GPIO_MMC_PWR_EN, "MMC power");
508c2ecf20Sopenharmony_ci	if (ret < 0)
518c2ecf20Sopenharmony_ci		return;
528c2ecf20Sopenharmony_ci	gpio_direction_output(H3_TPS_GPIO_MMC_PWR_EN, 0);
538c2ecf20Sopenharmony_ci
548c2ecf20Sopenharmony_ci	mmc_data[0] = &mmc1_data;
558c2ecf20Sopenharmony_ci	omap1_init_mmc(mmc_data, OMAP16XX_NR_MMC);
568c2ecf20Sopenharmony_ci}
578c2ecf20Sopenharmony_ci
588c2ecf20Sopenharmony_ci#else
598c2ecf20Sopenharmony_ci
608c2ecf20Sopenharmony_civoid __init h3_mmc_init(void)
618c2ecf20Sopenharmony_ci{
628c2ecf20Sopenharmony_ci}
638c2ecf20Sopenharmony_ci
648c2ecf20Sopenharmony_ci#endif
65