]> Pileus Git - ~andy/linux/commit
mmc: core: Prevent violation of specs while initializing cards
authorUlf Hansson <ulf.hansson@linaro.org>
Mon, 16 Sep 2013 09:28:42 +0000 (11:28 +0200)
committerChris Ball <cjb@laptop.org>
Thu, 31 Oct 2013 00:26:30 +0000 (20:26 -0400)
commitce69d37b7d8fa692c45d71d94aa0c921859b82ce
treeaef1e93b62424f07b72ddd322a64e6435b27d932
parent6904115095ad60ced638eb1e36e0e4e5e7de00b0
mmc: core: Prevent violation of specs while initializing cards

According to eMMC/SD/SDIO specs, the VDD (VCC) voltage level must be
maintained during the initialization sequence. If we want/need to tune
the voltage level, a complete power cycle of the card must be executed.

Most host drivers conforms to the specifications by only allowing to
change VDD voltage level at the MMC_POWER_UP state, but some also cares
about MMC_POWER_ON state, which they should'nt. This patch will not
break those drivers, but they could clean up code to better reflect
what is expected from the protocol layer.

A big re-work of the mmc_select_voltage function is done to only change
VDD voltage level if the host supports MMC_CAP2_FULL_PWR_CYCLE.
Otherwise only validation of the host and card ocr mask will be done.

A very nice side-effect of this patch is that we now don't need to
reset the negotiated ocr mask at the mmc_power_off function, since now
it will actually reflect the present voltage level, which safely can be
used at the next power up and re-initialization. Moreover, we then only
need to execute mmc_select_voltage from the attach sequence.

Signed-off-by: Ulf Hansson <ulf.hansson@linaro.org>
Signed-off-by: Chris Ball <cjb@laptop.org>
drivers/mmc/core/core.c
drivers/mmc/core/mmc.c
drivers/mmc/core/sd.c
drivers/mmc/core/sdio.c