18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-only
28c2ecf20Sopenharmony_ci/*
38c2ecf20Sopenharmony_ci * linux/arch/arm/mach-omap1/board-sx1-mmc.c
48c2ecf20Sopenharmony_ci *
58c2ecf20Sopenharmony_ci * Copyright (C) 2007 Instituto Nokia de Tecnologia - INdT
68c2ecf20Sopenharmony_ci * Author: Carlos Eduardo Aguiar <carlos.aguiar@indt.org.br>
78c2ecf20Sopenharmony_ci *
88c2ecf20Sopenharmony_ci * This code is based on linux/arch/arm/mach-omap1/board-h2-mmc.c, which is:
98c2ecf20Sopenharmony_ci * Copyright (C) 2007 Instituto Nokia de Tecnologia - INdT
108c2ecf20Sopenharmony_ci */
118c2ecf20Sopenharmony_ci
128c2ecf20Sopenharmony_ci#include <linux/gpio.h>
138c2ecf20Sopenharmony_ci#include <linux/platform_device.h>
148c2ecf20Sopenharmony_ci
158c2ecf20Sopenharmony_ci#include <mach/hardware.h>
168c2ecf20Sopenharmony_ci#include "board-sx1.h"
178c2ecf20Sopenharmony_ci
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	int err;
268c2ecf20Sopenharmony_ci	u8 dat = 0;
278c2ecf20Sopenharmony_ci
288c2ecf20Sopenharmony_ci	err = sx1_i2c_read_byte(SOFIA_I2C_ADDR, SOFIA_POWER1_REG, &dat);
298c2ecf20Sopenharmony_ci	if (err < 0)
308c2ecf20Sopenharmony_ci		return err;
318c2ecf20Sopenharmony_ci
328c2ecf20Sopenharmony_ci	if (power_on)
338c2ecf20Sopenharmony_ci		dat |= SOFIA_MMC_POWER;
348c2ecf20Sopenharmony_ci	else
358c2ecf20Sopenharmony_ci		dat &= ~SOFIA_MMC_POWER;
368c2ecf20Sopenharmony_ci
378c2ecf20Sopenharmony_ci	return sx1_i2c_write_byte(SOFIA_I2C_ADDR, SOFIA_POWER1_REG, dat);
388c2ecf20Sopenharmony_ci}
398c2ecf20Sopenharmony_ci
408c2ecf20Sopenharmony_ci/* Cover switch is at OMAP_MPUIO(3) */
418c2ecf20Sopenharmony_cistatic struct omap_mmc_platform_data mmc1_data = {
428c2ecf20Sopenharmony_ci	.nr_slots                       = 1,
438c2ecf20Sopenharmony_ci	.slots[0]       = {
448c2ecf20Sopenharmony_ci		.set_power              = mmc_set_power,
458c2ecf20Sopenharmony_ci		.ocr_mask               = MMC_VDD_32_33 | MMC_VDD_33_34,
468c2ecf20Sopenharmony_ci		.name                   = "mmcblk",
478c2ecf20Sopenharmony_ci	},
488c2ecf20Sopenharmony_ci};
498c2ecf20Sopenharmony_ci
508c2ecf20Sopenharmony_cistatic struct omap_mmc_platform_data *mmc_data[OMAP15XX_NR_MMC];
518c2ecf20Sopenharmony_ci
528c2ecf20Sopenharmony_civoid __init sx1_mmc_init(void)
538c2ecf20Sopenharmony_ci{
548c2ecf20Sopenharmony_ci	mmc_data[0] = &mmc1_data;
558c2ecf20Sopenharmony_ci	omap1_init_mmc(mmc_data, OMAP15XX_NR_MMC);
568c2ecf20Sopenharmony_ci}
578c2ecf20Sopenharmony_ci
588c2ecf20Sopenharmony_ci#else
598c2ecf20Sopenharmony_ci
608c2ecf20Sopenharmony_civoid __init sx1_mmc_init(void)
618c2ecf20Sopenharmony_ci{
628c2ecf20Sopenharmony_ci}
638c2ecf20Sopenharmony_ci
648c2ecf20Sopenharmony_ci#endif
65