Skip to content
Snippets Groups Projects
Commit 5f256fe7 authored by Patrice Chotard's avatar Patrice Chotard Committed by Tom Rini
Browse files

mmc: arm_pl180_mmci: add clock support


Allow to get and enable MMC related clock

Signed-off-by: default avatarPatrice Chotard <patrice.chotard@st.com>
parent 9035bb74
No related branches found
No related tags found
No related merge requests found
......@@ -13,6 +13,7 @@
/* #define DEBUG */
#include "common.h"
#include <clk.h>
#include <errno.h>
#include <malloc.h>
#include <mmc.h>
......@@ -408,17 +409,28 @@ static int arm_pl180_mmc_probe(struct udevice *dev)
struct mmc_uclass_priv *upriv = dev_get_uclass_priv(dev);
struct mmc *mmc = &pdata->mmc;
struct pl180_mmc_host *host = mmc->priv;
struct clk clk;
u32 bus_width;
int ret;
ret = clk_get_by_index(dev, 0, &clk);
if (ret < 0)
return ret;
ret = clk_enable(&clk);
if (ret) {
dev_err(dev, "failed to enable clock\n");
return ret;
}
strcpy(host->name, "MMC");
host->pwr_init = INIT_PWR;
host->clkdiv_init = SDI_CLKCR_CLKDIV_INIT_V1 | SDI_CLKCR_CLKEN |
SDI_CLKCR_HWFC_EN;
host->voltages = VOLTAGE_WINDOW_SD;
host->caps = 0;
host->clock_in = MMC_CLOCK_MAX;
host->clock_min = MMC_CLOCK_MIN;
host->clock_in = clk_get_rate(&clk);
host->clock_min = host->clock_in / (2 * (SDI_CLKCR_CLKDIV_INIT_V1 + 1));
host->clock_max = dev_read_u32_default(dev, "max-frequency",
MMC_CLOCK_MAX);
host->version2 = dev_get_driver_data(dev);
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment