Skip to content

Commit

Permalink
ARM: 7280/1: mmc: mmci: Cache MMCICLOCK and MMCIPOWER register
Browse files Browse the repository at this point in the history
Instead of reading a register value everytime we need to
apply a new value for it, maintain a cached copy for it.
This also means we are able to skip writes that are not
needed.

Tested-by: Linus Walleij <linus.walleij@linaro.org>
Signed-off-by: Ulf Hansson <ulf.hansson@stericsson.com>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
  • Loading branch information
Ulf Hansson authored and Russell King committed Feb 2, 2012
1 parent 393e5e2 commit 7437cfa
Show file tree
Hide file tree
Showing 2 changed files with 31 additions and 13 deletions.
41 changes: 29 additions & 12 deletions drivers/mmc/host/mmci.c
Original file line number Diff line number Diff line change
Expand Up @@ -118,6 +118,28 @@ static struct variant_data variant_ux500v2 = {
.signal_direction = true,
};

/*
* This must be called with host->lock held
*/
static void mmci_write_clkreg(struct mmci_host *host, u32 clk)
{
if (host->clk_reg != clk) {
host->clk_reg = clk;
writel(clk, host->base + MMCICLOCK);
}
}

/*
* This must be called with host->lock held
*/
static void mmci_write_pwrreg(struct mmci_host *host, u32 pwr)
{
if (host->pwr_reg != pwr) {
host->pwr_reg = pwr;
writel(pwr, host->base + MMCIPOWER);
}
}

/*
* This must be called with host->lock held
*/
Expand Down Expand Up @@ -165,7 +187,7 @@ static void mmci_set_clkreg(struct mmci_host *host, unsigned int desired)
if (host->mmc->ios.bus_width == MMC_BUS_WIDTH_8)
clk |= MCI_ST_8BIT_BUS;

writel(clk, host->base + MMCICLOCK);
mmci_write_clkreg(host, clk);
}

static void
Expand Down Expand Up @@ -846,14 +868,13 @@ static int mmci_pio_write(struct mmci_host *host, char *buffer, unsigned int rem
*/
if (variant->sdio &&
mmc_card_sdio(host->mmc->card)) {
u32 clk;
if (count < 8)
writel(readl(host->base + MMCICLOCK) &
~variant->clkreg_enable,
host->base + MMCICLOCK);
clk = host->clk_reg & ~variant->clkreg_enable;
else
writel(readl(host->base + MMCICLOCK) |
variant->clkreg_enable,
host->base + MMCICLOCK);
clk = host->clk_reg | variant->clkreg_enable;

mmci_write_clkreg(host, clk);
}

/*
Expand Down Expand Up @@ -1114,11 +1135,7 @@ static void mmci_set_ios(struct mmc_host *mmc, struct mmc_ios *ios)
spin_lock_irqsave(&host->lock, flags);

mmci_set_clkreg(host, ios->clock);

if (host->pwr != pwr) {
host->pwr = pwr;
writel(pwr, host->base + MMCIPOWER);
}
mmci_write_pwrreg(host, pwr);

spin_unlock_irqrestore(&host->lock, flags);

Expand Down
3 changes: 2 additions & 1 deletion drivers/mmc/host/mmci.h
Original file line number Diff line number Diff line change
Expand Up @@ -179,7 +179,8 @@ struct mmci_host {

unsigned int mclk;
unsigned int cclk;
u32 pwr;
u32 pwr_reg;
u32 clk_reg;
struct mmci_platform_data *plat;
struct variant_data *variant;

Expand Down

0 comments on commit 7437cfa

Please sign in to comment.