Skip to content

Commit

Permalink
mmc: bcm2835-sdhost: Support underclocking
Browse files Browse the repository at this point in the history
Support underclocking of the SD bus in two ways:
1. using the max-frequency DT property (which currently has no DT
   parameter), and
2. using the exiting sd_overclock parameter.

The two methods differ slightly - in the former the MMC subsystem is
aware of the underclocking, while in the latter it isn't - but the
end results should be the same.

See: #2350

Signed-off-by: Phil Elwell <phil@raspberrypi.org>
  • Loading branch information
Phil Elwell committed Jan 22, 2018
1 parent 5b29147 commit 22da14e
Showing 1 changed file with 3 additions and 3 deletions.
6 changes: 3 additions & 3 deletions drivers/mmc/host/bcm2835-sdhost.c
Expand Up @@ -1519,8 +1519,7 @@ void bcm2835_sdhost_set_clock(struct bcm2835_host *host, unsigned int clock)
if (host->debug)
pr_info("%s: set_clock(%d)\n", mmc_hostname(host->mmc), clock);

if ((host->overclock_50 > 50) &&
(clock == 50*MHZ))
if (host->overclock_50 && (clock == 50*MHZ))
clock = host->overclock_50 * MHZ + (MHZ - 1);

/* The SDCDIV register has 11 bits, and holds (div - 2).
Expand Down Expand Up @@ -1894,7 +1893,8 @@ int bcm2835_sdhost_add_host(struct bcm2835_host *host)

mmc = host->mmc;

mmc->f_max = host->max_clk;
if (!mmc->f_max || mmc->f_max > host->max_clk)
mmc->f_max = host->max_clk;
mmc->f_min = host->max_clk / SDCDIV_MAX_CDIV;

mmc->max_busy_timeout = (~(unsigned int)0)/(mmc->f_max/1000);
Expand Down

0 comments on commit 22da14e

Please sign in to comment.