Commit 91a0b089 authored by kishore kadiyala's avatar kishore kadiyala Committed by Tony Lindgren

omap4 hsmmc: Register offset handling

In OMAP4, as per new PM programming model, the legacy registers
which were there in OMAP3 are all shifted by 0x100 while new one's
are added from offset 0 to 0x10.
For OMAP4, the register offset appending of 0x100 done in devices.c
currently, is moved to driver file.This change fits in for current
implementation as well as once the driver undergoes hwmod adaptation.

Cc: Andrew Morton <akpm@linux-foundation.org>
Cc: Madhusudhan Chikkature <madhu.cr@ti.com>
Cc: Adrian Hunter <adrian.hunter@nokia.com>
Cc: Benoit Cousson <b-cousson@ti.com>
Signed-off-by: default avatarKishore Kadiyala <kishore.kadiyala@ti.com>
Signed-off-by: default avatarTony Lindgren <tony@atomide.com>
parent 531c21ba
...@@ -817,13 +817,13 @@ void __init omap2_init_mmc(struct omap_mmc_platform_data **mmc_data, ...@@ -817,13 +817,13 @@ void __init omap2_init_mmc(struct omap_mmc_platform_data **mmc_data,
case 3: case 3:
if (!cpu_is_omap44xx()) if (!cpu_is_omap44xx())
return; return;
base = OMAP4_MMC4_BASE + OMAP4_MMC_REG_OFFSET; base = OMAP4_MMC4_BASE;
irq = OMAP44XX_IRQ_MMC4; irq = OMAP44XX_IRQ_MMC4;
break; break;
case 4: case 4:
if (!cpu_is_omap44xx()) if (!cpu_is_omap44xx())
return; return;
base = OMAP4_MMC5_BASE + OMAP4_MMC_REG_OFFSET; base = OMAP4_MMC5_BASE;
irq = OMAP44XX_IRQ_MMC5; irq = OMAP44XX_IRQ_MMC5;
break; break;
default: default:
...@@ -834,10 +834,8 @@ void __init omap2_init_mmc(struct omap_mmc_platform_data **mmc_data, ...@@ -834,10 +834,8 @@ void __init omap2_init_mmc(struct omap_mmc_platform_data **mmc_data,
size = OMAP2420_MMC_SIZE; size = OMAP2420_MMC_SIZE;
name = "mmci-omap"; name = "mmci-omap";
} else if (cpu_is_omap44xx()) { } else if (cpu_is_omap44xx()) {
if (i < 3) { if (i < 3)
base += OMAP4_MMC_REG_OFFSET;
irq += OMAP44XX_IRQ_GIC_START; irq += OMAP44XX_IRQ_GIC_START;
}
size = OMAP4_HSMMC_SIZE; size = OMAP4_HSMMC_SIZE;
name = "mmci-omap-hs"; name = "mmci-omap-hs";
} else { } else {
......
...@@ -266,6 +266,10 @@ void __init omap2_hsmmc_init(struct omap2_hsmmc_info *controllers) ...@@ -266,6 +266,10 @@ void __init omap2_hsmmc_init(struct omap2_hsmmc_info *controllers)
mmc->slots[0].caps = c->caps; mmc->slots[0].caps = c->caps;
mmc->slots[0].internal_clock = !c->ext_clock; mmc->slots[0].internal_clock = !c->ext_clock;
mmc->dma_mask = 0xffffffff; mmc->dma_mask = 0xffffffff;
if (cpu_is_omap44xx())
mmc->reg_offset = OMAP4_MMC_REG_OFFSET;
else
mmc->reg_offset = 0;
mmc->get_context_loss_count = hsmmc_get_context_loss; mmc->get_context_loss_count = hsmmc_get_context_loss;
......
...@@ -71,6 +71,9 @@ struct omap_mmc_platform_data { ...@@ -71,6 +71,9 @@ struct omap_mmc_platform_data {
u64 dma_mask; u64 dma_mask;
/* Register offset deviation */
u16 reg_offset;
struct omap_mmc_slot_data { struct omap_mmc_slot_data {
/* 4/8 wires and any additional host capabilities /* 4/8 wires and any additional host capabilities
......
...@@ -2014,6 +2014,8 @@ static int __init omap_hsmmc_probe(struct platform_device *pdev) ...@@ -2014,6 +2014,8 @@ static int __init omap_hsmmc_probe(struct platform_device *pdev)
if (res == NULL || irq < 0) if (res == NULL || irq < 0)
return -ENXIO; return -ENXIO;
res->start += pdata->reg_offset;
res->end += pdata->reg_offset;
res = request_mem_region(res->start, res->end - res->start + 1, res = request_mem_region(res->start, res->end - res->start + 1,
pdev->name); pdev->name);
if (res == NULL) if (res == NULL)
......
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