diff options
Diffstat (limited to 'drivers/mmc/core/mmc.c')
| -rw-r--r-- | drivers/mmc/core/mmc.c | 16 | 
1 files changed, 15 insertions, 1 deletions
| diff --git a/drivers/mmc/core/mmc.c b/drivers/mmc/core/mmc.c index 4466f5de54d4..bc1bd2c25613 100644 --- a/drivers/mmc/core/mmc.c +++ b/drivers/mmc/core/mmc.c @@ -1169,6 +1169,10 @@ static int mmc_select_hs400(struct mmc_card *card)  	/* Set host controller to HS timing */  	mmc_set_timing(card->host, MMC_TIMING_MMC_HS); +	/* Prepare host to downgrade to HS timing */ +	if (host->ops->hs400_downgrade) +		host->ops->hs400_downgrade(host); +  	/* Reduce frequency to HS frequency */  	max_dtr = card->ext_csd.hs_max_dtr;  	mmc_set_clock(host, max_dtr); @@ -1209,6 +1213,9 @@ static int mmc_select_hs400(struct mmc_card *card)  	if (err)  		goto out_err; +	if (host->ops->hs400_complete) +		host->ops->hs400_complete(host); +  	return 0;  out_err: @@ -1256,6 +1263,9 @@ int mmc_hs400_to_hs200(struct mmc_card *card)  	mmc_set_timing(host, MMC_TIMING_MMC_HS); +	if (host->ops->hs400_downgrade) +		host->ops->hs400_downgrade(host); +  	err = mmc_switch_status(card);  	if (err)  		goto out_err; @@ -1338,8 +1348,12 @@ static int mmc_select_hs400es(struct mmc_card *card)  		goto out_err;  	err = mmc_select_bus_width(card); -	if (err < 0) +	if (err != MMC_BUS_WIDTH_8) { +		pr_err("%s: switch to 8bit bus width failed, err:%d\n", +			mmc_hostname(host), err); +		err = err < 0 ? err : -ENOTSUPP;  		goto out_err; +	}  	/* Switch card to HS mode */  	err = __mmc_switch(card, EXT_CSD_CMD_SET_NORMAL, |