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