summaryrefslogtreecommitdiffstats
path: root/drivers/mci/tegra-sdmmc.c
diff options
context:
space:
mode:
authorLucas Stach <dev@lynxeye.de>2014-05-14 22:45:32 +0200
committerSascha Hauer <s.hauer@pengutronix.de>2014-05-15 14:17:12 +0200
commit17a72b1f16445cde1e78604f97b81b5a89e9b3b3 (patch)
treee145e4958892a898b637be6aa265c50568bdb4a8 /drivers/mci/tegra-sdmmc.c
parentee493a6152a57ca56cace80fada726e5bf4f4bd5 (diff)
downloadbarebox-17a72b1f16445cde1e78604f97b81b5a89e9b3b3.tar.gz
barebox-17a72b1f16445cde1e78604f97b81b5a89e9b3b3.tar.xz
mci: tegra: add reset control
Enable the driver to reset the device itself. Signed-off-by: Lucas Stach <dev@lynxeye.de> Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
Diffstat (limited to 'drivers/mci/tegra-sdmmc.c')
-rw-r--r--drivers/mci/tegra-sdmmc.c9
1 files changed, 9 insertions, 0 deletions
diff --git a/drivers/mci/tegra-sdmmc.c b/drivers/mci/tegra-sdmmc.c
index e4d82197bd..0ea0b5ca4a 100644
--- a/drivers/mci/tegra-sdmmc.c
+++ b/drivers/mci/tegra-sdmmc.c
@@ -28,6 +28,7 @@
#include <mci.h>
#include <of_gpio.h>
#include <linux/clk.h>
+#include <linux/reset.h>
#include "sdhci.h"
@@ -62,6 +63,7 @@ struct tegra_sdmmc_host {
struct mci_host mci;
void __iomem *regs;
struct clk *clk;
+ struct reset_control *reset;
int gpio_cd, gpio_pwr;
};
#define to_tegra_sdmmc_host(mci) container_of(mci, struct tegra_sdmmc_host, mci)
@@ -400,6 +402,10 @@ static int tegra_sdmmc_probe(struct device_d *dev)
if (IS_ERR(host->clk))
return PTR_ERR(host->clk);
+ host->reset = reset_control_get(dev, NULL);
+ if (IS_ERR(host->reset))
+ return PTR_ERR(host->reset);
+
host->regs = dev_request_mem_region(dev, 0);
if (!host->regs) {
dev_err(dev, "could not get iomem region\n");
@@ -430,6 +436,9 @@ static int tegra_sdmmc_probe(struct device_d *dev)
}
clk_enable(host->clk);
+ reset_control_assert(host->reset);
+ udelay(2);
+ reset_control_deassert(host->reset);
mci->init = tegra_sdmmc_init;
mci->card_present = tegra_sdmmc_card_present;