clocksource: sh_tmu: Drop support for legacy platform data
authorLaurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>
Tue, 28 Jan 2014 14:52:46 +0000 (15:52 +0100)
committerLaurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>
Wed, 2 Jul 2014 14:01:49 +0000 (16:01 +0200)
Now that all platforms have switched to the new-style platform data,
drop support for the legacy version.

Signed-off-by: Laurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>
Tested-by: Simon Horman <horms+renesas@verge.net.au>
drivers/clocksource/sh_tmu.c

index 6bd17a8f3dd417f5603e8ec52a2a4ca090d8d2e6..3eee5c8c26aa324de91161b175a25524e5541584 100644 (file)
@@ -32,7 +32,6 @@
 #include <linux/spinlock.h>
 
 enum sh_tmu_model {
-       SH_TMU_LEGACY,
        SH_TMU,
        SH_TMU_SH3,
 };
@@ -91,8 +90,6 @@ static inline unsigned long sh_tmu_read(struct sh_tmu_channel *ch, int reg_nr)
 
        if (reg_nr == TSTR) {
                switch (ch->tmu->model) {
-               case SH_TMU_LEGACY:
-                       return ioread8(ch->tmu->mapbase);
                case SH_TMU_SH3:
                        return ioread8(ch->tmu->mapbase + 2);
                case SH_TMU:
@@ -115,8 +112,6 @@ static inline void sh_tmu_write(struct sh_tmu_channel *ch, int reg_nr,
 
        if (reg_nr == TSTR) {
                switch (ch->tmu->model) {
-               case SH_TMU_LEGACY:
-                       return iowrite8(value, ch->tmu->mapbase);
                case SH_TMU_SH3:
                        return iowrite8(value, ch->tmu->mapbase + 2);
                case SH_TMU:
@@ -476,27 +471,12 @@ static int sh_tmu_channel_setup(struct sh_tmu_channel *ch, unsigned int index,
                return 0;
 
        ch->tmu = tmu;
+       ch->index = index;
 
-       if (tmu->model == SH_TMU_LEGACY) {
-               struct sh_timer_config *cfg = tmu->pdev->dev.platform_data;
-
-               /*
-                * The SH3 variant (SH770x, SH7705, SH7710 and SH7720) maps
-                * channel registers blocks at base + 2 + 12 * index, while all
-                * other variants map them at base + 4 + 12 * index. We can
-                * compute the index by just dividing by 12, the 2 bytes or 4
-                * bytes offset being hidden by the integer division.
-                */
-               ch->index = cfg->channel_offset / 12;
-               ch->base = tmu->mapbase + cfg->channel_offset;
-       } else {
-               ch->index = index;
-
-               if (tmu->model == SH_TMU_SH3)
-                       ch->base = tmu->mapbase + 4 + ch->index * 12;
-               else
-                       ch->base = tmu->mapbase + 8 + ch->index * 12;
-       }
+       if (tmu->model == SH_TMU_SH3)
+               ch->base = tmu->mapbase + 4 + ch->index * 12;
+       else
+               ch->base = tmu->mapbase + 8 + ch->index * 12;
 
        ch->irq = platform_get_irq(tmu->pdev, index);
        if (ch->irq < 0) {
@@ -526,28 +506,9 @@ static int sh_tmu_map_memory(struct sh_tmu_device *tmu)
        if (tmu->mapbase == NULL)
                return -ENXIO;
 
-       /*
-        * In legacy platform device configuration (with one device per channel)
-        * the resource points to the channel base address.
-        */
-       if (tmu->model == SH_TMU_LEGACY) {
-               struct sh_timer_config *cfg = tmu->pdev->dev.platform_data;
-               tmu->mapbase -= cfg->channel_offset;
-       }
-
        return 0;
 }
 
-static void sh_tmu_unmap_memory(struct sh_tmu_device *tmu)
-{
-       if (tmu->model == SH_TMU_LEGACY) {
-               struct sh_timer_config *cfg = tmu->pdev->dev.platform_data;
-               tmu->mapbase += cfg->channel_offset;
-       }
-
-       iounmap(tmu->mapbase);
-}
-
 static int sh_tmu_setup(struct sh_tmu_device *tmu, struct platform_device *pdev)
 {
        struct sh_timer_config *cfg = pdev->dev.platform_data;
@@ -564,8 +525,7 @@ static int sh_tmu_setup(struct sh_tmu_device *tmu, struct platform_device *pdev)
        tmu->model = id->driver_data;
 
        /* Get hold of clock. */
-       tmu->clk = clk_get(&tmu->pdev->dev,
-                          tmu->model == SH_TMU_LEGACY ? "tmu_fck" : "fck");
+       tmu->clk = clk_get(&tmu->pdev->dev, "fck");
        if (IS_ERR(tmu->clk)) {
                dev_err(&tmu->pdev->dev, "cannot get clock\n");
                return PTR_ERR(tmu->clk);
@@ -583,10 +543,7 @@ static int sh_tmu_setup(struct sh_tmu_device *tmu, struct platform_device *pdev)
        }
 
        /* Allocate and setup the channels. */
-       if (tmu->model == SH_TMU_LEGACY)
-               tmu->num_channels = 1;
-       else
-               tmu->num_channels = hweight8(cfg->channels_mask);
+       tmu->num_channels = hweight8(cfg->channels_mask);
 
        tmu->channels = kzalloc(sizeof(*tmu->channels) * tmu->num_channels,
                                GFP_KERNEL);
@@ -595,23 +552,15 @@ static int sh_tmu_setup(struct sh_tmu_device *tmu, struct platform_device *pdev)
                goto err_unmap;
        }
 
-       if (tmu->model == SH_TMU_LEGACY) {
-               ret = sh_tmu_channel_setup(&tmu->channels[0], 0,
-                                          cfg->clockevent_rating != 0,
-                                          cfg->clocksource_rating != 0, tmu);
+       /*
+        * Use the first channel as a clock event device and the second channel
+        * as a clock source.
+        */
+       for (i = 0; i < tmu->num_channels; ++i) {
+               ret = sh_tmu_channel_setup(&tmu->channels[i], i,
+                                          i == 0, i == 1, tmu);
                if (ret < 0)
                        goto err_unmap;
-       } else {
-               /*
-                * Use the first channel as a clock event device and the second
-                * channel as a clock source.
-                */
-               for (i = 0; i < tmu->num_channels; ++i) {
-                       ret = sh_tmu_channel_setup(&tmu->channels[i], i,
-                                                  i == 0, i == 1, tmu);
-                       if (ret < 0)
-                               goto err_unmap;
-               }
        }
 
        platform_set_drvdata(pdev, tmu);
@@ -620,7 +569,7 @@ static int sh_tmu_setup(struct sh_tmu_device *tmu, struct platform_device *pdev)
 
 err_unmap:
        kfree(tmu->channels);
-       sh_tmu_unmap_memory(tmu);
+       iounmap(tmu->mapbase);
 err_clk_unprepare:
        clk_unprepare(tmu->clk);
 err_clk_put:
@@ -671,7 +620,6 @@ static int sh_tmu_remove(struct platform_device *pdev)
 }
 
 static const struct platform_device_id sh_tmu_id_table[] = {
-       { "sh_tmu", SH_TMU_LEGACY },
        { "sh-tmu", SH_TMU },
        { "sh-tmu-sh3", SH_TMU_SH3 },
        { }