diff options
Diffstat (limited to 'drivers/mmc')
| -rw-r--r-- | drivers/mmc/host/sdhci-esdhc-imx.c | 22 | ||||
| -rw-r--r-- | drivers/mmc/host/sunxi-mmc.c | 8 | 
2 files changed, 20 insertions, 10 deletions
diff --git a/drivers/mmc/host/sdhci-esdhc-imx.c b/drivers/mmc/host/sdhci-esdhc-imx.c index 89ef0c80ac37..9e73c34b6401 100644 --- a/drivers/mmc/host/sdhci-esdhc-imx.c +++ b/drivers/mmc/host/sdhci-esdhc-imx.c @@ -107,6 +107,7 @@  #define ESDHC_TUNING_START_TAP_DEFAULT	0x1  #define ESDHC_TUNING_START_TAP_MASK	0x7f  #define ESDHC_TUNING_CMD_CRC_CHECK_DISABLE	(1 << 7) +#define ESDHC_TUNING_STEP_DEFAULT	0x1  #define ESDHC_TUNING_STEP_MASK		0x00070000  #define ESDHC_TUNING_STEP_SHIFT		16 @@ -1368,7 +1369,7 @@ static void sdhci_esdhc_imx_hwinit(struct sdhci_host *host)  	struct sdhci_pltfm_host *pltfm_host = sdhci_priv(host);  	struct pltfm_imx_data *imx_data = sdhci_pltfm_priv(pltfm_host);  	struct cqhci_host *cq_host = host->mmc->cqe_private; -	int tmp; +	u32 tmp;  	if (esdhc_is_usdhc(imx_data)) {  		/* @@ -1423,17 +1424,24 @@ static void sdhci_esdhc_imx_hwinit(struct sdhci_host *host)  		if (imx_data->socdata->flags & ESDHC_FLAG_STD_TUNING) {  			tmp = readl(host->ioaddr + ESDHC_TUNING_CTRL); -			tmp |= ESDHC_STD_TUNING_EN | -				ESDHC_TUNING_START_TAP_DEFAULT; -			if (imx_data->boarddata.tuning_start_tap) { -				tmp &= ~ESDHC_TUNING_START_TAP_MASK; +			tmp |= ESDHC_STD_TUNING_EN; + +			/* +			 * ROM code or bootloader may config the start tap +			 * and step, unmask them first. +			 */ +			tmp &= ~(ESDHC_TUNING_START_TAP_MASK | ESDHC_TUNING_STEP_MASK); +			if (imx_data->boarddata.tuning_start_tap)  				tmp |= imx_data->boarddata.tuning_start_tap; -			} +			else +				tmp |= ESDHC_TUNING_START_TAP_DEFAULT;  			if (imx_data->boarddata.tuning_step) { -				tmp &= ~ESDHC_TUNING_STEP_MASK;  				tmp |= imx_data->boarddata.tuning_step  					<< ESDHC_TUNING_STEP_SHIFT; +			} else { +				tmp |= ESDHC_TUNING_STEP_DEFAULT +					<< ESDHC_TUNING_STEP_SHIFT;  			}  			/* Disable the CMD CRC check for tuning, if not, need to diff --git a/drivers/mmc/host/sunxi-mmc.c b/drivers/mmc/host/sunxi-mmc.c index b16e12e62e72..3db9f32d6a7b 100644 --- a/drivers/mmc/host/sunxi-mmc.c +++ b/drivers/mmc/host/sunxi-mmc.c @@ -1492,9 +1492,11 @@ static int sunxi_mmc_remove(struct platform_device *pdev)  	struct sunxi_mmc_host *host = mmc_priv(mmc);  	mmc_remove_host(mmc); -	pm_runtime_force_suspend(&pdev->dev); -	disable_irq(host->irq); -	sunxi_mmc_disable(host); +	pm_runtime_disable(&pdev->dev); +	if (!pm_runtime_status_suspended(&pdev->dev)) { +		disable_irq(host->irq); +		sunxi_mmc_disable(host); +	}  	dma_free_coherent(&pdev->dev, PAGE_SIZE, host->sg_cpu, host->sg_dma);  	mmc_free_host(mmc);  | 
