aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/mmc/host/sdhci-dove.c
diff options
context:
space:
mode:
authorKevin Hao <haokexin@gmail.com>2015-02-27 02:47:26 -0500
committerUlf Hansson <ulf.hansson@linaro.org>2015-03-23 09:13:33 -0400
commit35daeede227051e7fe91aee33d57dd7b0077e660 (patch)
treee70d00ef8d61cab8cd528e15c4aa3027dadf05d5 /drivers/mmc/host/sdhci-dove.c
parent6a4a34a413d896d1efe5a582a3bb8e435da65c1a (diff)
mmc: sdhci-dove: kill the driver specific private struct
There is only one "clk" member in this driver specific private struct. Actually we can use the "clk" member in the struct sdhci_pltfm_host, and then kill this struct completely. Signed-off-by: Kevin Hao <haokexin@gmail.com> Signed-off-by: Ulf Hansson <ulf.hansson@linaro.org>
Diffstat (limited to 'drivers/mmc/host/sdhci-dove.c')
-rw-r--r--drivers/mmc/host/sdhci-dove.c26
1 files changed, 5 insertions, 21 deletions
diff --git a/drivers/mmc/host/sdhci-dove.c b/drivers/mmc/host/sdhci-dove.c
index 0a7aeb162497..f78440ef1ba4 100644
--- a/drivers/mmc/host/sdhci-dove.c
+++ b/drivers/mmc/host/sdhci-dove.c
@@ -28,10 +28,6 @@
28 28
29#include "sdhci-pltfm.h" 29#include "sdhci-pltfm.h"
30 30
31struct sdhci_dove_priv {
32 struct clk *clk;
33};
34
35static u16 sdhci_dove_readw(struct sdhci_host *host, int reg) 31static u16 sdhci_dove_readw(struct sdhci_host *host, int reg)
36{ 32{
37 u16 ret; 33 u16 ret;
@@ -84,27 +80,17 @@ static int sdhci_dove_probe(struct platform_device *pdev)
84{ 80{
85 struct sdhci_host *host; 81 struct sdhci_host *host;
86 struct sdhci_pltfm_host *pltfm_host; 82 struct sdhci_pltfm_host *pltfm_host;
87 struct sdhci_dove_priv *priv;
88 int ret; 83 int ret;
89 84
90 priv = devm_kzalloc(&pdev->dev, sizeof(struct sdhci_dove_priv),
91 GFP_KERNEL);
92 if (!priv) {
93 dev_err(&pdev->dev, "unable to allocate private data");
94 return -ENOMEM;
95 }
96
97 priv->clk = devm_clk_get(&pdev->dev, NULL);
98
99 host = sdhci_pltfm_init(pdev, &sdhci_dove_pdata, 0); 85 host = sdhci_pltfm_init(pdev, &sdhci_dove_pdata, 0);
100 if (IS_ERR(host)) 86 if (IS_ERR(host))
101 return PTR_ERR(host); 87 return PTR_ERR(host);
102 88
103 pltfm_host = sdhci_priv(host); 89 pltfm_host = sdhci_priv(host);
104 pltfm_host->priv = priv; 90 pltfm_host->clk = devm_clk_get(&pdev->dev, NULL);
105 91
106 if (!IS_ERR(priv->clk)) 92 if (!IS_ERR(pltfm_host->clk))
107 clk_prepare_enable(priv->clk); 93 clk_prepare_enable(pltfm_host->clk);
108 94
109 ret = mmc_of_parse(host->mmc); 95 ret = mmc_of_parse(host->mmc);
110 if (ret) 96 if (ret)
@@ -117,7 +103,7 @@ static int sdhci_dove_probe(struct platform_device *pdev)
117 return 0; 103 return 0;
118 104
119err_sdhci_add: 105err_sdhci_add:
120 clk_disable_unprepare(priv->clk); 106 clk_disable_unprepare(pltfm_host->clk);
121 sdhci_pltfm_free(pdev); 107 sdhci_pltfm_free(pdev);
122 return ret; 108 return ret;
123} 109}
@@ -126,12 +112,10 @@ static int sdhci_dove_remove(struct platform_device *pdev)
126{ 112{
127 struct sdhci_host *host = platform_get_drvdata(pdev); 113 struct sdhci_host *host = platform_get_drvdata(pdev);
128 struct sdhci_pltfm_host *pltfm_host = sdhci_priv(host); 114 struct sdhci_pltfm_host *pltfm_host = sdhci_priv(host);
129 struct sdhci_dove_priv *priv = pltfm_host->priv;
130 115
116 clk_disable_unprepare(pltfm_host->clk);
131 sdhci_pltfm_unregister(pdev); 117 sdhci_pltfm_unregister(pdev);
132 118
133 clk_disable_unprepare(priv->clk);
134
135 return 0; 119 return 0;
136} 120}
137 121