[U-Boot] [PATCH 2/4] ARM: mx6: ddr: Factor out SDQS configuration code
Eric Nelson
ericnelsonaz at gmail.com
Tue Nov 26 16:26:16 UTC 2019
Hi Marek,
On 11/26/19 1:34 AM, Marek Vasut wrote:
> Pull out the code turning SDQS pullups on and off into a separate
> function, since it is replicated in two places in the code and it
> is the single place in the entire function which is SoC dependent.
>
> Signed-off-by: Marek Vasut <marex at denx.de>
> Cc: Eric Nelson <eric at nelint.com>
> Cc: Fabio Estevam <fabio.estevam at nxp.com>
> Cc: Stefano Babic <sbabic at denx.de>
> ---
> arch/arm/mach-imx/mx6/ddr.c | 46 ++++++++++++++++++++++---------------
> 1 file changed, 28 insertions(+), 18 deletions(-)
>
> diff --git a/arch/arm/mach-imx/mx6/ddr.c b/arch/arm/mach-imx/mx6/ddr.c
> index e6f69e904f..e917b04f3d 100644
> --- a/arch/arm/mach-imx/mx6/ddr.c
> +++ b/arch/arm/mach-imx/mx6/ddr.c
> @@ -245,12 +245,36 @@ int mmdc_do_write_level_calibration(struct mx6_ddr_sysinfo const *sysinfo)
> return errors;
> }
>
> +static void mmdc_set_sdqs(bool set)
> +{
> + struct mx6dq_iomux_ddr_regs *mx6_ddr_iomux =
> + (struct mx6dq_iomux_ddr_regs *)MX6DQ_IOM_DDR_BASE;
> +
> + if (set) {
> + setbits_le32(&mx6_ddr_iomux->dram_sdqs0, 0x7000);
> + setbits_le32(&mx6_ddr_iomux->dram_sdqs1, 0x7000);
> + setbits_le32(&mx6_ddr_iomux->dram_sdqs2, 0x7000);
> + setbits_le32(&mx6_ddr_iomux->dram_sdqs3, 0x7000);
> + setbits_le32(&mx6_ddr_iomux->dram_sdqs4, 0x7000);
> + setbits_le32(&mx6_ddr_iomux->dram_sdqs5, 0x7000);
> + setbits_le32(&mx6_ddr_iomux->dram_sdqs6, 0x7000);
> + setbits_le32(&mx6_ddr_iomux->dram_sdqs7, 0x7000);
> + } else {
> + clrbits_le32(&mx6_ddr_iomux->dram_sdqs0, 0x7000);
> + clrbits_le32(&mx6_ddr_iomux->dram_sdqs1, 0x7000);
> + clrbits_le32(&mx6_ddr_iomux->dram_sdqs2, 0x7000);
> + clrbits_le32(&mx6_ddr_iomux->dram_sdqs3, 0x7000);
> + clrbits_le32(&mx6_ddr_iomux->dram_sdqs4, 0x7000);
> + clrbits_le32(&mx6_ddr_iomux->dram_sdqs5, 0x7000);
> + clrbits_le32(&mx6_ddr_iomux->dram_sdqs6, 0x7000);
> + clrbits_le32(&mx6_ddr_iomux->dram_sdqs7, 0x7000);
> + }
> +}
> +
> int mmdc_do_dqs_calibration(struct mx6_ddr_sysinfo const *sysinfo)
> {
> struct mmdc_p_regs *mmdc0 = (struct mmdc_p_regs *)MMDC_P0_BASE_ADDR;
> struct mmdc_p_regs *mmdc1 = (struct mmdc_p_regs *)MMDC_P1_BASE_ADDR;
> - struct mx6dq_iomux_ddr_regs *mx6_ddr_iomux =
> - (struct mx6dq_iomux_ddr_regs *)MX6DQ_IOM_DDR_BASE;
> bool cs0_enable;
> bool cs1_enable;
> bool cs0_enable_initial;
> @@ -272,14 +296,7 @@ int mmdc_do_dqs_calibration(struct mx6_ddr_sysinfo const *sysinfo)
> setbits_le32(&mmdc0->mapsr, 0x1);
>
> /* set DQS pull ups */
> - setbits_le32(&mx6_ddr_iomux->dram_sdqs0, 0x7000);
> - setbits_le32(&mx6_ddr_iomux->dram_sdqs1, 0x7000);
> - setbits_le32(&mx6_ddr_iomux->dram_sdqs2, 0x7000);
> - setbits_le32(&mx6_ddr_iomux->dram_sdqs3, 0x7000);
> - setbits_le32(&mx6_ddr_iomux->dram_sdqs4, 0x7000);
> - setbits_le32(&mx6_ddr_iomux->dram_sdqs5, 0x7000);
> - setbits_le32(&mx6_ddr_iomux->dram_sdqs6, 0x7000);
> - setbits_le32(&mx6_ddr_iomux->dram_sdqs7, 0x7000);
> + mmdc_set_sdqs(true);
>
> /* Save old RALAT and WALAT values */
> esdmisc_val = readl(&mmdc0->mdmisc);
> @@ -524,14 +541,7 @@ int mmdc_do_dqs_calibration(struct mx6_ddr_sysinfo const *sysinfo)
> writel(esdmisc_val, &mmdc0->mdmisc);
>
> /* Clear DQS pull ups */
> - clrbits_le32(&mx6_ddr_iomux->dram_sdqs0, 0x7000);
> - clrbits_le32(&mx6_ddr_iomux->dram_sdqs1, 0x7000);
> - clrbits_le32(&mx6_ddr_iomux->dram_sdqs2, 0x7000);
> - clrbits_le32(&mx6_ddr_iomux->dram_sdqs3, 0x7000);
> - clrbits_le32(&mx6_ddr_iomux->dram_sdqs4, 0x7000);
> - clrbits_le32(&mx6_ddr_iomux->dram_sdqs5, 0x7000);
> - clrbits_le32(&mx6_ddr_iomux->dram_sdqs6, 0x7000);
> - clrbits_le32(&mx6_ddr_iomux->dram_sdqs7, 0x7000);
> + mmdc_set_sdqs(false);
>
> /* Re-enable SDE (chip selects) if they were set initially */
> if (cs1_enable_initial)
>
Reviewed-by: Eric Nelson <eric at nelint.com>
More information about the U-Boot
mailing list