[U-Boot] [PATCH 1/2] ARM: imx6: DHCOM i.MX6 PDK: use Kconfig for inclusion of DDR calibration

Marek Vasut marex at denx.de
Fri Apr 12 13:26:18 UTC 2019


On 4/12/19 1:29 PM, Ludwig Zenz wrote:
> The four x16 DDR3 are wired in T-topology. From NXP AN4467:
> 'Although not required, T-Topologies may also benefit from performing
> Write Leveling as there are package delays on both the processor and DDR
> devices that can be de-skewed by performing Write Leveling. Therefore,
> Freescale recommends determining Write Leveling calibration parameters
> for all boards, regardless of topology used.'
> That is why write level calibration is also done.
> 
> Signed-off-by: Ludwig Zenz <lzenz at dh-electronics.com>

Reviewed-by: Marek Vasut <marex at denx.de>

> ---
>  board/dhelectronics/dh_imx6/dh_imx6_spl.c | 32 +++++++++++++++++++++++++------
>  1 file changed, 26 insertions(+), 6 deletions(-)
> 
> diff --git a/board/dhelectronics/dh_imx6/dh_imx6_spl.c b/board/dhelectronics/dh_imx6/dh_imx6_spl.c
> index 04e9eab272a..bbd2dc26828 100644
> --- a/board/dhelectronics/dh_imx6/dh_imx6_spl.c
> +++ b/board/dhelectronics/dh_imx6/dh_imx6_spl.c
> @@ -482,6 +482,29 @@ static void setup_iomux_usb(void)
>  	SETUP_IOMUX_PADS(usb_pads);
>  }
>  
> +/* Perform DDR DRAM calibration */
> +static int spl_dram_perform_cal(struct mx6_ddr_sysinfo const *sysinfo)
> +{
> +	int ret = 0;
> +
> +#ifdef CONFIG_MX6_DDRCAL
> +	udelay(100);
> +	ret = mmdc_do_write_level_calibration(sysinfo);
> +	if (ret) {
> +		printf("DDR3: Write level calibration error [%d]\n", ret);
> +		return ret;
> +	}
> +
> +	ret = mmdc_do_dqs_calibration(sysinfo);
> +	if (ret) {
> +		printf("DDR3: DQS calibration error [%d]\n", ret);
> +		return ret;
> +	}
> +#endif /* CONFIG_MX6_DDRCAL */
> +
> +	return ret;
> +}
> +
>  
>  /* DRAM */
>  static void dhcom_spl_dram_init(void)
> @@ -509,8 +532,7 @@ static void dhcom_spl_dram_init(void)
>  		}
>  
>  		/* Perform DDR DRAM calibration */
> -		udelay(100);
> -		mmdc_do_dqs_calibration(&dhcom_ddr_64bit);
> +		spl_dram_perform_cal(&dhcom_ddr_64bit);
>  
>  	} else if (is_cpu_type(MXC_CPU_MX6DL)) {
>  		mx6sdl_dram_iocfg(64, &dhcom6sdl_ddr_ioregs,
> @@ -528,8 +550,7 @@ static void dhcom_spl_dram_init(void)
>  		}
>  
>  		/* Perform DDR DRAM calibration */
> -		udelay(100);
> -		mmdc_do_dqs_calibration(&dhcom_ddr_64bit);
> +		spl_dram_perform_cal(&dhcom_ddr_64bit);
>  
>  	} else if (is_cpu_type(MXC_CPU_MX6SOLO)) {
>  		mx6sdl_dram_iocfg(32, &dhcom6sdl_ddr_ioregs,
> @@ -552,8 +573,7 @@ static void dhcom_spl_dram_init(void)
>  		}
>  
>  		/* Perform DDR DRAM calibration */
> -		udelay(100);
> -		mmdc_do_dqs_calibration(&dhcom_ddr_32bit);
> +		spl_dram_perform_cal(&dhcom_ddr_32bit);
>  	}
>  }
>  
> 


-- 
Best regards,
Marek Vasut


More information about the U-Boot mailing list