Commit fa56ac97 authored by Veerabhadrarao Badiganti's avatar Veerabhadrarao Badiganti Committed by Ulf Hansson

mmc: sdhci-msm: Correct the offset and value for DDR_CONFIG register

The DDR_CONFIG register offset got updated after a specific
minor version of sdcc V4. This offset change has not been properly
taken care of while updating register changes for sdcc V5.

Correcting proper offset for this register.
Also updating this register value to reflect the recommended RCLK
delay.
Signed-off-by: default avatarVeerabhadrarao Badiganti <vbadigan@codeaurora.org>
Link: https://lore.kernel.org/r/0101016ea738ec72-fa0f852d-20f8-474a-80b2-4b0ef63b132c-000000@us-west-2.amazonses.com
Fixes: f1535888 ("mmc: sdhci-msm: Define new Register address map")
Cc: stable@vger.kernel.org
Signed-off-by: default avatarUlf Hansson <ulf.hansson@linaro.org>
parent 07bcc411
...@@ -99,7 +99,7 @@ ...@@ -99,7 +99,7 @@
#define CORE_PWRSAVE_DLL BIT(3) #define CORE_PWRSAVE_DLL BIT(3)
#define DDR_CONFIG_POR_VAL 0x80040853 #define DDR_CONFIG_POR_VAL 0x80040873
#define INVALID_TUNING_PHASE -1 #define INVALID_TUNING_PHASE -1
...@@ -148,8 +148,9 @@ struct sdhci_msm_offset { ...@@ -148,8 +148,9 @@ struct sdhci_msm_offset {
u32 core_ddr_200_cfg; u32 core_ddr_200_cfg;
u32 core_vendor_spec3; u32 core_vendor_spec3;
u32 core_dll_config_2; u32 core_dll_config_2;
u32 core_dll_config_3;
u32 core_ddr_config_old; /* Applicable to sdcc minor ver < 0x49 */
u32 core_ddr_config; u32 core_ddr_config;
u32 core_ddr_config_2;
}; };
static const struct sdhci_msm_offset sdhci_msm_v5_offset = { static const struct sdhci_msm_offset sdhci_msm_v5_offset = {
...@@ -177,8 +178,8 @@ static const struct sdhci_msm_offset sdhci_msm_v5_offset = { ...@@ -177,8 +178,8 @@ static const struct sdhci_msm_offset sdhci_msm_v5_offset = {
.core_ddr_200_cfg = 0x224, .core_ddr_200_cfg = 0x224,
.core_vendor_spec3 = 0x250, .core_vendor_spec3 = 0x250,
.core_dll_config_2 = 0x254, .core_dll_config_2 = 0x254,
.core_ddr_config = 0x258, .core_dll_config_3 = 0x258,
.core_ddr_config_2 = 0x25c, .core_ddr_config = 0x25c,
}; };
static const struct sdhci_msm_offset sdhci_msm_mci_offset = { static const struct sdhci_msm_offset sdhci_msm_mci_offset = {
...@@ -207,8 +208,8 @@ static const struct sdhci_msm_offset sdhci_msm_mci_offset = { ...@@ -207,8 +208,8 @@ static const struct sdhci_msm_offset sdhci_msm_mci_offset = {
.core_ddr_200_cfg = 0x184, .core_ddr_200_cfg = 0x184,
.core_vendor_spec3 = 0x1b0, .core_vendor_spec3 = 0x1b0,
.core_dll_config_2 = 0x1b4, .core_dll_config_2 = 0x1b4,
.core_ddr_config = 0x1b8, .core_ddr_config_old = 0x1b8,
.core_ddr_config_2 = 0x1bc, .core_ddr_config = 0x1bc,
}; };
struct sdhci_msm_variant_ops { struct sdhci_msm_variant_ops {
...@@ -253,6 +254,7 @@ struct sdhci_msm_host { ...@@ -253,6 +254,7 @@ struct sdhci_msm_host {
const struct sdhci_msm_offset *offset; const struct sdhci_msm_offset *offset;
bool use_cdr; bool use_cdr;
u32 transfer_mode; u32 transfer_mode;
bool updated_ddr_cfg;
}; };
static const struct sdhci_msm_offset *sdhci_priv_msm_offset(struct sdhci_host *host) static const struct sdhci_msm_offset *sdhci_priv_msm_offset(struct sdhci_host *host)
...@@ -924,8 +926,10 @@ static int sdhci_msm_cdclp533_calibration(struct sdhci_host *host) ...@@ -924,8 +926,10 @@ static int sdhci_msm_cdclp533_calibration(struct sdhci_host *host)
static int sdhci_msm_cm_dll_sdc4_calibration(struct sdhci_host *host) static int sdhci_msm_cm_dll_sdc4_calibration(struct sdhci_host *host)
{ {
struct mmc_host *mmc = host->mmc; struct mmc_host *mmc = host->mmc;
u32 dll_status, config; u32 dll_status, config, ddr_cfg_offset;
int ret; int ret;
struct sdhci_pltfm_host *pltfm_host = sdhci_priv(host);
struct sdhci_msm_host *msm_host = sdhci_pltfm_priv(pltfm_host);
const struct sdhci_msm_offset *msm_offset = const struct sdhci_msm_offset *msm_offset =
sdhci_priv_msm_offset(host); sdhci_priv_msm_offset(host);
...@@ -938,8 +942,11 @@ static int sdhci_msm_cm_dll_sdc4_calibration(struct sdhci_host *host) ...@@ -938,8 +942,11 @@ static int sdhci_msm_cm_dll_sdc4_calibration(struct sdhci_host *host)
* bootloaders. In the future, if this changes, then the desired * bootloaders. In the future, if this changes, then the desired
* values will need to be programmed appropriately. * values will need to be programmed appropriately.
*/ */
writel_relaxed(DDR_CONFIG_POR_VAL, host->ioaddr + if (msm_host->updated_ddr_cfg)
msm_offset->core_ddr_config); ddr_cfg_offset = msm_offset->core_ddr_config;
else
ddr_cfg_offset = msm_offset->core_ddr_config_old;
writel_relaxed(DDR_CONFIG_POR_VAL, host->ioaddr + ddr_cfg_offset);
if (mmc->ios.enhanced_strobe) { if (mmc->ios.enhanced_strobe) {
config = readl_relaxed(host->ioaddr + config = readl_relaxed(host->ioaddr +
...@@ -1899,6 +1906,9 @@ static int sdhci_msm_probe(struct platform_device *pdev) ...@@ -1899,6 +1906,9 @@ static int sdhci_msm_probe(struct platform_device *pdev)
msm_offset->core_vendor_spec_capabilities0); msm_offset->core_vendor_spec_capabilities0);
} }
if (core_major == 1 && core_minor >= 0x49)
msm_host->updated_ddr_cfg = true;
/* /*
* Power on reset state may trigger power irq if previous status of * Power on reset state may trigger power irq if previous status of
* PWRCTL was either BUS_ON or IO_HIGH_V. So before enabling pwr irq * PWRCTL was either BUS_ON or IO_HIGH_V. So before enabling pwr irq
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment