Commit 681b9e85 authored by Laurent Pinchart's avatar Laurent Pinchart

clocksource: sh_tmu: Drop support for legacy platform data

Now that all platforms have switched to the new-style platform data,
drop support for the legacy version.
Signed-off-by: default avatarLaurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>
Tested-by: default avatarSimon Horman <horms+renesas@verge.net.au>
parent de599c88
...@@ -32,7 +32,6 @@ ...@@ -32,7 +32,6 @@
#include <linux/spinlock.h> #include <linux/spinlock.h>
enum sh_tmu_model { enum sh_tmu_model {
SH_TMU_LEGACY,
SH_TMU, SH_TMU,
SH_TMU_SH3, SH_TMU_SH3,
}; };
...@@ -91,8 +90,6 @@ static inline unsigned long sh_tmu_read(struct sh_tmu_channel *ch, int reg_nr) ...@@ -91,8 +90,6 @@ static inline unsigned long sh_tmu_read(struct sh_tmu_channel *ch, int reg_nr)
if (reg_nr == TSTR) { if (reg_nr == TSTR) {
switch (ch->tmu->model) { switch (ch->tmu->model) {
case SH_TMU_LEGACY:
return ioread8(ch->tmu->mapbase);
case SH_TMU_SH3: case SH_TMU_SH3:
return ioread8(ch->tmu->mapbase + 2); return ioread8(ch->tmu->mapbase + 2);
case SH_TMU: case SH_TMU:
...@@ -115,8 +112,6 @@ static inline void sh_tmu_write(struct sh_tmu_channel *ch, int reg_nr, ...@@ -115,8 +112,6 @@ static inline void sh_tmu_write(struct sh_tmu_channel *ch, int reg_nr,
if (reg_nr == TSTR) { if (reg_nr == TSTR) {
switch (ch->tmu->model) { switch (ch->tmu->model) {
case SH_TMU_LEGACY:
return iowrite8(value, ch->tmu->mapbase);
case SH_TMU_SH3: case SH_TMU_SH3:
return iowrite8(value, ch->tmu->mapbase + 2); return iowrite8(value, ch->tmu->mapbase + 2);
case SH_TMU: case SH_TMU:
...@@ -476,27 +471,12 @@ static int sh_tmu_channel_setup(struct sh_tmu_channel *ch, unsigned int index, ...@@ -476,27 +471,12 @@ static int sh_tmu_channel_setup(struct sh_tmu_channel *ch, unsigned int index,
return 0; return 0;
ch->tmu = tmu; ch->tmu = tmu;
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; ch->index = index;
if (tmu->model == SH_TMU_SH3) if (tmu->model == SH_TMU_SH3)
ch->base = tmu->mapbase + 4 + ch->index * 12; ch->base = tmu->mapbase + 4 + ch->index * 12;
else else
ch->base = tmu->mapbase + 8 + ch->index * 12; ch->base = tmu->mapbase + 8 + ch->index * 12;
}
ch->irq = platform_get_irq(tmu->pdev, index); ch->irq = platform_get_irq(tmu->pdev, index);
if (ch->irq < 0) { if (ch->irq < 0) {
...@@ -526,28 +506,9 @@ static int sh_tmu_map_memory(struct sh_tmu_device *tmu) ...@@ -526,28 +506,9 @@ static int sh_tmu_map_memory(struct sh_tmu_device *tmu)
if (tmu->mapbase == NULL) if (tmu->mapbase == NULL)
return -ENXIO; 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; 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) static int sh_tmu_setup(struct sh_tmu_device *tmu, struct platform_device *pdev)
{ {
struct sh_timer_config *cfg = pdev->dev.platform_data; 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) ...@@ -564,8 +525,7 @@ static int sh_tmu_setup(struct sh_tmu_device *tmu, struct platform_device *pdev)
tmu->model = id->driver_data; tmu->model = id->driver_data;
/* Get hold of clock. */ /* Get hold of clock. */
tmu->clk = clk_get(&tmu->pdev->dev, tmu->clk = clk_get(&tmu->pdev->dev, "fck");
tmu->model == SH_TMU_LEGACY ? "tmu_fck" : "fck");
if (IS_ERR(tmu->clk)) { if (IS_ERR(tmu->clk)) {
dev_err(&tmu->pdev->dev, "cannot get clock\n"); dev_err(&tmu->pdev->dev, "cannot get clock\n");
return PTR_ERR(tmu->clk); return PTR_ERR(tmu->clk);
...@@ -583,9 +543,6 @@ static int sh_tmu_setup(struct sh_tmu_device *tmu, struct platform_device *pdev) ...@@ -583,9 +543,6 @@ static int sh_tmu_setup(struct sh_tmu_device *tmu, struct platform_device *pdev)
} }
/* Allocate and setup the channels. */ /* 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, tmu->channels = kzalloc(sizeof(*tmu->channels) * tmu->num_channels,
...@@ -595,16 +552,9 @@ static int sh_tmu_setup(struct sh_tmu_device *tmu, struct platform_device *pdev) ...@@ -595,16 +552,9 @@ static int sh_tmu_setup(struct sh_tmu_device *tmu, struct platform_device *pdev)
goto err_unmap; 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);
if (ret < 0)
goto err_unmap;
} else {
/* /*
* Use the first channel as a clock event device and the second * Use the first channel as a clock event device and the second channel
* channel as a clock source. * as a clock source.
*/ */
for (i = 0; i < tmu->num_channels; ++i) { for (i = 0; i < tmu->num_channels; ++i) {
ret = sh_tmu_channel_setup(&tmu->channels[i], i, ret = sh_tmu_channel_setup(&tmu->channels[i], i,
...@@ -612,7 +562,6 @@ static int sh_tmu_setup(struct sh_tmu_device *tmu, struct platform_device *pdev) ...@@ -612,7 +562,6 @@ static int sh_tmu_setup(struct sh_tmu_device *tmu, struct platform_device *pdev)
if (ret < 0) if (ret < 0)
goto err_unmap; goto err_unmap;
} }
}
platform_set_drvdata(pdev, tmu); platform_set_drvdata(pdev, tmu);
...@@ -620,7 +569,7 @@ static int sh_tmu_setup(struct sh_tmu_device *tmu, struct platform_device *pdev) ...@@ -620,7 +569,7 @@ static int sh_tmu_setup(struct sh_tmu_device *tmu, struct platform_device *pdev)
err_unmap: err_unmap:
kfree(tmu->channels); kfree(tmu->channels);
sh_tmu_unmap_memory(tmu); iounmap(tmu->mapbase);
err_clk_unprepare: err_clk_unprepare:
clk_unprepare(tmu->clk); clk_unprepare(tmu->clk);
err_clk_put: err_clk_put:
...@@ -671,7 +620,6 @@ static int sh_tmu_remove(struct platform_device *pdev) ...@@ -671,7 +620,6 @@ static int sh_tmu_remove(struct platform_device *pdev)
} }
static const struct platform_device_id sh_tmu_id_table[] = { static const struct platform_device_id sh_tmu_id_table[] = {
{ "sh_tmu", SH_TMU_LEGACY },
{ "sh-tmu", SH_TMU }, { "sh-tmu", SH_TMU },
{ "sh-tmu-sh3", SH_TMU_SH3 }, { "sh-tmu-sh3", SH_TMU_SH3 },
{ } { }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment