mmc: sd: limit SD card power limit according to cards capabilities
authorRussell King <rmk+kernel@arm.linux.org.uk>
Sat, 2 Jan 2016 10:06:29 +0000 (10:06 +0000)
committerUlf Hansson <ulf.hansson@linaro.org>
Wed, 13 Jan 2016 09:56:27 +0000 (10:56 +0100)
commitd9812780a020bcec44565b5950b2a8b31afb5545
tree8ce1c87d3d0025ee731dde4dcccbfe5edff9ed8e
parent67990608c8b95d2b8ccc29932376ae73d5818727
mmc: sd: limit SD card power limit according to cards capabilities

The SD card specification allows cards to error out a SWITCH command
where the requested function in a group is not supported.  The spec
provides for a set of capabilities which indicate which functions are
supported.

In the case of the power limit, requesting an unsupported power level
via the SWITCH command fails, resulting in the power level remaining at
the power-on default of 0.72W, even though the host and card may support
higher powers levels.

This has been seen with SanDisk 8GB cards, which support the default
0.72W and 1.44W (200mA and 400mA) in combination with an iMX6 host,
supporting up to 2.88W (800mA).  This currently causes us to try to set
a power limit function value of '3' (2.88W) which the card errors out
on, and thereby causes the power level to remain at 0.72W rather than
the desired 1.44W.

Arrange to limit the selected current limit by the capabilities reported
by the card to avoid the SWITCH command failing.  Select the highest
current limit that the host and card combination support.

Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
Fixes: a39ca6ae0a08 ("mmc: core: Simplify and fix for SD switch processing")
Signed-off-by: Ulf Hansson <ulf.hansson@linaro.org>
drivers/mmc/core/sd.c