* [PATCH 1/3 v2] sh_mobile_meram: Add clock enable/disble hooks via runtime PM
@ 2011-05-24 7:16 Damian Hobson-Garcia
2011-05-24 7:37 ` Paul Mundt
0 siblings, 1 reply; 2+ messages in thread
From: Damian Hobson-Garcia @ 2011-05-24 7:16 UTC (permalink / raw)
To: linux-sh
Signed-off-by: Damian Hobson-Garcia <dhobsong@igel.co.jp>
---
Changed from v1
==* changed pm_runtime_get()/pm_runtime_put() calls to the _sync versions
drivers/video/sh_mobile_meram.c | 27 +++++++++++++++++++++++++++
include/video/sh_mobile_meram.h | 6 ++++++
2 files changed, 33 insertions(+), 0 deletions(-)
diff --git a/drivers/video/sh_mobile_meram.c b/drivers/video/sh_mobile_meram.c
index 9170c82..25b4a88 100644
--- a/drivers/video/sh_mobile_meram.c
+++ b/drivers/video/sh_mobile_meram.c
@@ -12,6 +12,7 @@
#include <linux/kernel.h>
#include <linux/module.h>
#include <linux/device.h>
+#include <linux/pm_runtime.h>
#include <linux/io.h>
#include <linux/slab.h>
#include <linux/platform_device.h>
@@ -460,11 +461,33 @@ static int sh_mobile_meram_update(struct sh_mobile_meram_info *pdata,
return 0;
}
+int sh_mobile_meram_clk_on(struct sh_mobile_meram_info *pdata)
+{
+ if (!pdata || !pdata->pdev)
+ return -EINVAL;
+
+ dev_dbg(&pdata->pdev->dev, "Enabling sh_mobile_meram clock.");
+ pm_runtime_get_sync(&pdata->pdev->dev);
+ return 0;
+}
+
+int sh_mobile_meram_clk_off(struct sh_mobile_meram_info *pdata)
+{
+ if (!pdata || !pdata->pdev)
+ return -EINVAL;
+
+ dev_dbg(&pdata->pdev->dev, "Disabling sh_mobile_meram clock.");
+ pm_runtime_put_sync(&pdata->pdev->dev);
+ return 0;
+}
+
static struct sh_mobile_meram_ops sh_mobile_meram_ops = {
.module = THIS_MODULE,
.meram_register = sh_mobile_meram_register,
.meram_unregister = sh_mobile_meram_unregister,
.meram_update = sh_mobile_meram_update,
+ .meram_clk_off = sh_mobile_meram_clk_off,
+ .meram_clk_on = sh_mobile_meram_clk_on,
};
/*
@@ -515,6 +538,8 @@ static int __devinit sh_mobile_meram_probe(struct platform_device *pdev)
if (pdata->addr_mode = SH_MOBILE_MERAM_MODE1)
meram_write_reg(priv->base, MEVCR1, 1 << 29);
+ pm_runtime_enable(&pdev->dev);
+
dev_info(&pdev->dev, "sh_mobile_meram initialized.");
return 0;
@@ -530,6 +555,8 @@ static int sh_mobile_meram_remove(struct platform_device *pdev)
{
struct sh_mobile_meram_priv *priv = platform_get_drvdata(pdev);
+ pm_runtime_disable(&pdev->dev);
+
if (priv->base)
iounmap(priv->base);
diff --git a/include/video/sh_mobile_meram.h b/include/video/sh_mobile_meram.h
index af602d6..3605874 100644
--- a/include/video/sh_mobile_meram.h
+++ b/include/video/sh_mobile_meram.h
@@ -63,6 +63,12 @@ struct sh_mobile_meram_ops {
unsigned long base_addr_c,
unsigned long *icb_addr_y,
unsigned long *icb_addr_c);
+
+ /* enable meram clock */
+ int (*meram_clk_on)(struct sh_mobile_meram_info *meram_dev);
+
+ /* disable meram clock */
+ int (*meram_clk_off)(struct sh_mobile_meram_info *meram_dev);
};
#endif /* __VIDEO_SH_MOBILE_MERAM_H__ */
--
1.7.1
^ permalink raw reply related [flat|nested] 2+ messages in thread* Re: [PATCH 1/3 v2] sh_mobile_meram: Add clock enable/disble hooks via runtime PM
2011-05-24 7:16 [PATCH 1/3 v2] sh_mobile_meram: Add clock enable/disble hooks via runtime PM Damian Hobson-Garcia
@ 2011-05-24 7:37 ` Paul Mundt
0 siblings, 0 replies; 2+ messages in thread
From: Paul Mundt @ 2011-05-24 7:37 UTC (permalink / raw)
To: linux-sh
On Tue, May 24, 2011 at 04:16:19PM +0900, Damian Hobson-Garcia wrote:
> @@ -460,11 +461,33 @@ static int sh_mobile_meram_update(struct sh_mobile_meram_info *pdata,
> +int sh_mobile_meram_clk_on(struct sh_mobile_meram_info *pdata)
> +int sh_mobile_meram_clk_off(struct sh_mobile_meram_info *pdata)
[snip]
> .meram_update = sh_mobile_meram_update,
> + .meram_clk_off = sh_mobile_meram_clk_off,
> + .meram_clk_on = sh_mobile_meram_clk_on,
> };
>
Seems like the _clk_off/on functions ought to be static, too.
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2011-05-24 7:37 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2011-05-24 7:16 [PATCH 1/3 v2] sh_mobile_meram: Add clock enable/disble hooks via runtime PM Damian Hobson-Garcia
2011-05-24 7:37 ` Paul Mundt
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.