clocksource: sh_cmt: Allocate channels dynamically
authorLaurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>
Mon, 27 Jan 2014 21:04:17 +0000 (22:04 +0100)
committerSimon Horman <horms@verge.net.au>
Fri, 5 Dec 2014 00:22:48 +0000 (09:22 +0900)
This prepares the driver for multi-channel support.

Signed-off-by: Laurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>
(cherry picked from commit f5ec9b194a93c05e2ccdb3e90d9061cfedc806d9)
Signed-off-by: Simon Horman <horms+renesas@verge.net.au>
drivers/clocksource/sh_cmt.c

index 0779bf1..f94db32 100644 (file)
@@ -62,7 +62,8 @@ struct sh_cmt_device {
        void __iomem *mapbase;
        struct clk *clk;
 
-       struct sh_cmt_channel channel;
+       struct sh_cmt_channel *channels;
+       unsigned int num_channels;
 
        unsigned long width; /* 16 or 32 bit version of hardware block */
        unsigned long overflow_bit;
@@ -822,7 +823,15 @@ static int sh_cmt_setup(struct sh_cmt_device *cmt, struct platform_device *pdev)
                cmt->clear_bits = ~0xc000;
        }
 
-       ret = sh_cmt_setup_channel(&cmt->channel, cfg->timer_bit, cmt);
+       cmt->channels = kzalloc(sizeof(*cmt->channels), GFP_KERNEL);
+       if (cmt->channels == NULL) {
+               ret = -ENOMEM;
+               goto err4;
+       }
+
+       cmt->num_channels = 1;
+
+       ret = sh_cmt_setup_channel(&cmt->channels[0], cfg->timer_bit, cmt);
        if (ret < 0)
                goto err4;
 
@@ -830,6 +839,7 @@ static int sh_cmt_setup(struct sh_cmt_device *cmt, struct platform_device *pdev)
 
        return 0;
 err4:
+       kfree(cmt->channels);
        clk_unprepare(cmt->clk);
 err3:
        clk_put(cmt->clk);