linux-arm-kernel.lists.infradead.org archive mirror
 help / color / mirror / Atom feed
* [GIT PULL 0/2 v2] Renesas ARM based SoC clocksource updates for v3.12
@ 2013-08-05  1:56 Simon Horman
  2013-08-05  1:56 ` [PATCH 1/2] clocksource: sh_cmt: 32-bit control register support Simon Horman
                   ` (2 more replies)
  0 siblings, 3 replies; 5+ messages in thread
From: Simon Horman @ 2013-08-05  1:56 UTC (permalink / raw)
  To: linux-arm-kernel

Hi Daniel,

please consider the following Renesas ARM based SoC clocksource updates
for v3.12.


The following changes since commit ad81f0545ef01ea651886dddac4bef6cec930092:

  Linux 3.11-rc1 (2013-07-14 15:18:27 -0700)

are available in the git repository at:

  git://git.kernel.org/pub/scm/linux/kernel/git/horms/renesas.git tags/renesas-clocksource-for-v3.12

for you to fetch changes up to 172705f8a40b6e72c53f8cceda079504ed71c4e0:

  clocksource: em_sti: Convert to devm_* managed helpers (2013-08-05 10:47:10 +0900)

----------------------------------------------------------------
Renesas ARM based SoC clocksource updates for v3.12

* Add support for CMT hardware with 32-bit control and counter registers
* em_sti: Convert to devm_* managed helpers

----------------------------------------------------------------
Laurent Pinchart (1):
      clocksource: em_sti: Convert to devm_* managed helpers

Magnus Damm (1):
      clocksource: sh_cmt: 32-bit control register support

 drivers/clocksource/em_sti.c | 49 +++++++++++++------------------------------
 drivers/clocksource/sh_cmt.c | 50 +++++++++++++++++++++++++++++++-------------
 2 files changed, 50 insertions(+), 49 deletions(-)

^ permalink raw reply	[flat|nested] 5+ messages in thread

* [PATCH 1/2] clocksource: sh_cmt: 32-bit control register support
  2013-08-05  1:56 [GIT PULL 0/2 v2] Renesas ARM based SoC clocksource updates for v3.12 Simon Horman
@ 2013-08-05  1:56 ` Simon Horman
  2013-08-05  1:56 ` [PATCH 2/2] clocksource: em_sti: Convert to devm_* managed helpers Simon Horman
  2013-08-05 10:44 ` [GIT PULL 0/2 v2] Renesas ARM based SoC clocksource updates for v3.12 Daniel Lezcano
  2 siblings, 0 replies; 5+ messages in thread
From: Simon Horman @ 2013-08-05  1:56 UTC (permalink / raw)
  To: linux-arm-kernel

From: Magnus Damm <damm@opensource.se>

Add support for CMT hardware with 32-bit control and counter
registers, as found on r8a73a4 and r8a7790. To use the CMT
with 32-bit hardware a second I/O memory resource needs to
point out the CMSTR register and it needs to be 32 bit wide.

Signed-off-by: Magnus Damm <damm@opensource.se>
Reviewed-by: Daniel Lezcano <daniel.lezcano@linaro.org>
Signed-off-by: Simon Horman <horms+renesas@verge.net.au>
---
 drivers/clocksource/sh_cmt.c | 50 +++++++++++++++++++++++++++++++-------------
 1 file changed, 36 insertions(+), 14 deletions(-)

diff --git a/drivers/clocksource/sh_cmt.c b/drivers/clocksource/sh_cmt.c
index 08d0c41..0965e98 100644
--- a/drivers/clocksource/sh_cmt.c
+++ b/drivers/clocksource/sh_cmt.c
@@ -37,6 +37,7 @@
 
 struct sh_cmt_priv {
 	void __iomem *mapbase;
+	void __iomem *mapbase_str;
 	struct clk *clk;
 	unsigned long width; /* 16 or 32 bit version of hardware block */
 	unsigned long overflow_bit;
@@ -79,6 +80,12 @@ struct sh_cmt_priv {
  * CMCSR 0xffca0060 16-bit
  * CMCNT 0xffca0064 32-bit
  * CMCOR 0xffca0068 32-bit
+ *
+ * "32-bit counter and 32-bit control" as found on r8a73a4 and r8a7790:
+ * CMSTR 0xffca0500 32-bit
+ * CMCSR 0xffca0510 32-bit
+ * CMCNT 0xffca0514 32-bit
+ * CMCOR 0xffca0518 32-bit
  */
 
 static unsigned long sh_cmt_read16(void __iomem *base, unsigned long offs)
@@ -109,9 +116,7 @@ static void sh_cmt_write32(void __iomem *base, unsigned long offs,
 
 static inline unsigned long sh_cmt_read_cmstr(struct sh_cmt_priv *p)
 {
-	struct sh_timer_config *cfg = p->pdev->dev.platform_data;
-
-	return p->read_control(p->mapbase - cfg->channel_offset, 0);
+	return p->read_control(p->mapbase_str, 0);
 }
 
 static inline unsigned long sh_cmt_read_cmcsr(struct sh_cmt_priv *p)
@@ -127,9 +132,7 @@ static inline unsigned long sh_cmt_read_cmcnt(struct sh_cmt_priv *p)
 static inline void sh_cmt_write_cmstr(struct sh_cmt_priv *p,
 				      unsigned long value)
 {
-	struct sh_timer_config *cfg = p->pdev->dev.platform_data;
-
-	p->write_control(p->mapbase - cfg->channel_offset, 0, value);
+	p->write_control(p->mapbase_str, 0, value);
 }
 
 static inline void sh_cmt_write_cmcsr(struct sh_cmt_priv *p,
@@ -676,7 +679,7 @@ static int sh_cmt_register(struct sh_cmt_priv *p, char *name,
 static int sh_cmt_setup(struct sh_cmt_priv *p, struct platform_device *pdev)
 {
 	struct sh_timer_config *cfg = pdev->dev.platform_data;
-	struct resource *res;
+	struct resource *res, *res2;
 	int irq, ret;
 	ret = -ENXIO;
 
@@ -694,6 +697,9 @@ static int sh_cmt_setup(struct sh_cmt_priv *p, struct platform_device *pdev)
 		goto err0;
 	}
 
+	/* optional resource for the shared timer start/stop register */
+	res2 = platform_get_resource(p->pdev, IORESOURCE_MEM, 1);
+
 	irq = platform_get_irq(p->pdev, 0);
 	if (irq < 0) {
 		dev_err(&p->pdev->dev, "failed to get irq\n");
@@ -707,6 +713,15 @@ static int sh_cmt_setup(struct sh_cmt_priv *p, struct platform_device *pdev)
 		goto err0;
 	}
 
+	/* map second resource for CMSTR */
+	p->mapbase_str = ioremap_nocache(res2 ? res2->start :
+					 res->start - cfg->channel_offset,
+					 res2 ? resource_size(res2) : 2);
+	if (p->mapbase_str == NULL) {
+		dev_err(&p->pdev->dev, "failed to remap I/O second memory\n");
+		goto err1;
+	}
+
 	/* request irq using setup_irq() (too early for request_irq()) */
 	p->irqaction.name = dev_name(&p->pdev->dev);
 	p->irqaction.handler = sh_cmt_interrupt;
@@ -719,11 +734,17 @@ static int sh_cmt_setup(struct sh_cmt_priv *p, struct platform_device *pdev)
 	if (IS_ERR(p->clk)) {
 		dev_err(&p->pdev->dev, "cannot get clock\n");
 		ret = PTR_ERR(p->clk);
-		goto err1;
+		goto err2;
 	}
 
-	p->read_control = sh_cmt_read16;
-	p->write_control = sh_cmt_write16;
+	if (res2 && (resource_size(res2) == 4)) {
+		/* assume both CMSTR and CMCSR to be 32-bit */
+		p->read_control = sh_cmt_read32;
+		p->write_control = sh_cmt_write32;
+	} else {
+		p->read_control = sh_cmt_read16;
+		p->write_control = sh_cmt_write16;
+	}
 
 	if (resource_size(res) == 6) {
 		p->width = 16;
@@ -752,22 +773,23 @@ static int sh_cmt_setup(struct sh_cmt_priv *p, struct platform_device *pdev)
 			      cfg->clocksource_rating);
 	if (ret) {
 		dev_err(&p->pdev->dev, "registration failed\n");
-		goto err2;
+		goto err3;
 	}
 	p->cs_enabled = false;
 
 	ret = setup_irq(irq, &p->irqaction);
 	if (ret) {
 		dev_err(&p->pdev->dev, "failed to request irq %d\n", irq);
-		goto err2;
+		goto err3;
 	}
 
 	platform_set_drvdata(pdev, p);
 
 	return 0;
-err2:
+err3:
 	clk_put(p->clk);
-
+err2:
+	iounmap(p->mapbase_str);
 err1:
 	iounmap(p->mapbase);
 err0:
-- 
1.8.3.2

^ permalink raw reply related	[flat|nested] 5+ messages in thread

* [PATCH 2/2] clocksource: em_sti: Convert to devm_* managed helpers
  2013-08-05  1:56 [GIT PULL 0/2 v2] Renesas ARM based SoC clocksource updates for v3.12 Simon Horman
  2013-08-05  1:56 ` [PATCH 1/2] clocksource: sh_cmt: 32-bit control register support Simon Horman
@ 2013-08-05  1:56 ` Simon Horman
  2013-08-05 10:44 ` [GIT PULL 0/2 v2] Renesas ARM based SoC clocksource updates for v3.12 Daniel Lezcano
  2 siblings, 0 replies; 5+ messages in thread
From: Simon Horman @ 2013-08-05  1:56 UTC (permalink / raw)
  To: linux-arm-kernel

From: Laurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>

Replace kzalloc, clk_get, ioremap and request_irq by their managed
counterparts to simplify error paths.

Signed-off-by: Laurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>
Reviewed-by: Daniel Lezcano <daniel.lezcano@linaro.org>
---
 drivers/clocksource/em_sti.c | 49 +++++++++++++-------------------------------
 1 file changed, 14 insertions(+), 35 deletions(-)

diff --git a/drivers/clocksource/em_sti.c b/drivers/clocksource/em_sti.c
index 4329a29..b9c81b7 100644
--- a/drivers/clocksource/em_sti.c
+++ b/drivers/clocksource/em_sti.c
@@ -315,68 +315,47 @@ static int em_sti_probe(struct platform_device *pdev)
 {
 	struct em_sti_priv *p;
 	struct resource *res;
-	int irq, ret;
+	int irq;
 
-	p = kzalloc(sizeof(*p), GFP_KERNEL);
+	p = devm_kzalloc(&pdev->dev, sizeof(*p), GFP_KERNEL);
 	if (p == NULL) {
 		dev_err(&pdev->dev, "failed to allocate driver data\n");
-		ret = -ENOMEM;
-		goto err0;
+		return -ENOMEM;
 	}
 
 	p->pdev = pdev;
 	platform_set_drvdata(pdev, p);
 
-	res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
-	if (!res) {
-		dev_err(&pdev->dev, "failed to get I/O memory\n");
-		ret = -EINVAL;
-		goto err0;
-	}
-
 	irq = platform_get_irq(pdev, 0);
 	if (irq < 0) {
 		dev_err(&pdev->dev, "failed to get irq\n");
-		ret = -EINVAL;
-		goto err0;
+		return -EINVAL;
 	}
 
 	/* map memory, let base point to the STI instance */
-	p->base = ioremap_nocache(res->start, resource_size(res));
-	if (p->base == NULL) {
-		dev_err(&pdev->dev, "failed to remap I/O memory\n");
-		ret = -ENXIO;
-		goto err0;
-	}
+	res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
+	p->base = devm_ioremap_resource(&pdev->dev, res);
+	if (IS_ERR(p->base))
+		return PTR_ERR(p->base);
 
 	/* get hold of clock */
-	p->clk = clk_get(&pdev->dev, "sclk");
+	p->clk = devm_clk_get(&pdev->dev, "sclk");
 	if (IS_ERR(p->clk)) {
 		dev_err(&pdev->dev, "cannot get clock\n");
-		ret = PTR_ERR(p->clk);
-		goto err1;
+		return PTR_ERR(p->clk);
 	}
 
-	if (request_irq(irq, em_sti_interrupt,
-			IRQF_TIMER | IRQF_IRQPOLL | IRQF_NOBALANCING,
-			dev_name(&pdev->dev), p)) {
+	if (devm_request_irq(&pdev->dev, irq, em_sti_interrupt,
+			     IRQF_TIMER | IRQF_IRQPOLL | IRQF_NOBALANCING,
+			     dev_name(&pdev->dev), p)) {
 		dev_err(&pdev->dev, "failed to request low IRQ\n");
-		ret = -ENOENT;
-		goto err2;
+		return -ENOENT;
 	}
 
 	raw_spin_lock_init(&p->lock);
 	em_sti_register_clockevent(p);
 	em_sti_register_clocksource(p);
 	return 0;
-
-err2:
-	clk_put(p->clk);
-err1:
-	iounmap(p->base);
-err0:
-	kfree(p);
-	return ret;
 }
 
 static int em_sti_remove(struct platform_device *pdev)
-- 
1.8.3.2

^ permalink raw reply related	[flat|nested] 5+ messages in thread

* [GIT PULL 0/2 v2] Renesas ARM based SoC clocksource updates for v3.12
  2013-08-05  1:56 [GIT PULL 0/2 v2] Renesas ARM based SoC clocksource updates for v3.12 Simon Horman
  2013-08-05  1:56 ` [PATCH 1/2] clocksource: sh_cmt: 32-bit control register support Simon Horman
  2013-08-05  1:56 ` [PATCH 2/2] clocksource: em_sti: Convert to devm_* managed helpers Simon Horman
@ 2013-08-05 10:44 ` Daniel Lezcano
  2013-08-06  1:32   ` Simon Horman
  2 siblings, 1 reply; 5+ messages in thread
From: Daniel Lezcano @ 2013-08-05 10:44 UTC (permalink / raw)
  To: linux-arm-kernel

On 08/05/2013 03:56 AM, Simon Horman wrote:
> Hi Daniel,
> 
> please consider the following Renesas ARM based SoC clocksource updates
> for v3.12.
> 
> 
> The following changes since commit ad81f0545ef01ea651886dddac4bef6cec930092:
> 
>   Linux 3.11-rc1 (2013-07-14 15:18:27 -0700)
> 
> are available in the git repository at:
> 
>   git://git.kernel.org/pub/scm/linux/kernel/git/horms/renesas.git tags/renesas-clocksource-for-v3.12
> 
> for you to fetch changes up to 172705f8a40b6e72c53f8cceda079504ed71c4e0:
> 
>   clocksource: em_sti: Convert to devm_* managed helpers (2013-08-05 10:47:10 +0900)

Shall I pull your tree or applying the patches to my branch is ok also ?

Thanks
  -- Daniel

> 
> ----------------------------------------------------------------
> Renesas ARM based SoC clocksource updates for v3.12
> 
> * Add support for CMT hardware with 32-bit control and counter registers
> * em_sti: Convert to devm_* managed helpers
> 
> ----------------------------------------------------------------
> Laurent Pinchart (1):
>       clocksource: em_sti: Convert to devm_* managed helpers
> 
> Magnus Damm (1):
>       clocksource: sh_cmt: 32-bit control register support
> 
>  drivers/clocksource/em_sti.c | 49 +++++++++++++------------------------------
>  drivers/clocksource/sh_cmt.c | 50 +++++++++++++++++++++++++++++++-------------
>  2 files changed, 50 insertions(+), 49 deletions(-)
> 


-- 
 <http://www.linaro.org/> Linaro.org ? Open source software for ARM SoCs

Follow Linaro:  <http://www.facebook.com/pages/Linaro> Facebook |
<http://twitter.com/#!/linaroorg> Twitter |
<http://www.linaro.org/linaro-blog/> Blog

^ permalink raw reply	[flat|nested] 5+ messages in thread

* [GIT PULL 0/2 v2] Renesas ARM based SoC clocksource updates for v3.12
  2013-08-05 10:44 ` [GIT PULL 0/2 v2] Renesas ARM based SoC clocksource updates for v3.12 Daniel Lezcano
@ 2013-08-06  1:32   ` Simon Horman
  0 siblings, 0 replies; 5+ messages in thread
From: Simon Horman @ 2013-08-06  1:32 UTC (permalink / raw)
  To: linux-arm-kernel

On Mon, Aug 05, 2013 at 12:44:34PM +0200, Daniel Lezcano wrote:
> On 08/05/2013 03:56 AM, Simon Horman wrote:
> > Hi Daniel,
> > 
> > please consider the following Renesas ARM based SoC clocksource updates
> > for v3.12.
> > 
> > 
> > The following changes since commit ad81f0545ef01ea651886dddac4bef6cec930092:
> > 
> >   Linux 3.11-rc1 (2013-07-14 15:18:27 -0700)
> > 
> > are available in the git repository at:
> > 
> >   git://git.kernel.org/pub/scm/linux/kernel/git/horms/renesas.git tags/renesas-clocksource-for-v3.12
> > 
> > for you to fetch changes up to 172705f8a40b6e72c53f8cceda079504ed71c4e0:
> > 
> >   clocksource: em_sti: Convert to devm_* managed helpers (2013-08-05 10:47:10 +0900)
> 
> Shall I pull your tree or applying the patches to my branch is ok also ?

I have a slight preference for you to pull the
renesas-clocksource-for-v3.12 tag of my tree.
But I am happy for you to apply the patches if you prefer.

> 
> Thanks
>   -- Daniel
> 
> > 
> > ----------------------------------------------------------------
> > Renesas ARM based SoC clocksource updates for v3.12
> > 
> > * Add support for CMT hardware with 32-bit control and counter registers
> > * em_sti: Convert to devm_* managed helpers
> > 
> > ----------------------------------------------------------------
> > Laurent Pinchart (1):
> >       clocksource: em_sti: Convert to devm_* managed helpers
> > 
> > Magnus Damm (1):
> >       clocksource: sh_cmt: 32-bit control register support
> > 
> >  drivers/clocksource/em_sti.c | 49 +++++++++++++------------------------------
> >  drivers/clocksource/sh_cmt.c | 50 +++++++++++++++++++++++++++++++-------------
> >  2 files changed, 50 insertions(+), 49 deletions(-)
> > 
> 
> 
> -- 
>  <http://www.linaro.org/> Linaro.org ? Open source software for ARM SoCs
> 
> Follow Linaro:  <http://www.facebook.com/pages/Linaro> Facebook |
> <http://twitter.com/#!/linaroorg> Twitter |
> <http://www.linaro.org/linaro-blog/> Blog
> 
> --
> To unsubscribe from this list: send the line "unsubscribe linux-sh" in
> the body of a message to majordomo at vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
> 

^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2013-08-06  1:32 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2013-08-05  1:56 [GIT PULL 0/2 v2] Renesas ARM based SoC clocksource updates for v3.12 Simon Horman
2013-08-05  1:56 ` [PATCH 1/2] clocksource: sh_cmt: 32-bit control register support Simon Horman
2013-08-05  1:56 ` [PATCH 2/2] clocksource: em_sti: Convert to devm_* managed helpers Simon Horman
2013-08-05 10:44 ` [GIT PULL 0/2 v2] Renesas ARM based SoC clocksource updates for v3.12 Daniel Lezcano
2013-08-06  1:32   ` Simon Horman

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).