u-boot.lists.denx.de archive mirror
 help / color / mirror / Atom feed
* [PATCH v1 0/2] board: toradex: enable dynamic DDR calibration for iMX6 boards
@ 2021-08-31  9:46 Francesco Dolcini
  2021-08-31  9:46 ` [PATCH v1 1/2] colibri-imx6: use dynamic DDR calibration Francesco Dolcini
  2021-08-31  9:46 ` [PATCH v1 2/2] apalis-imx6: " Francesco Dolcini
  0 siblings, 2 replies; 5+ messages in thread
From: Francesco Dolcini @ 2021-08-31  9:46 UTC (permalink / raw)
  To: u-boot
  Cc: Francesco Dolcini, Harald Seiler, Heiko Schocher,
	Max Krummenacher, Ming Liu, Oleksandr Suvorov, Patrick Delaunay,
	Simon Glass


Enable dynamic DDR calibration to have a reliable behavior on edge
temperatures conditions for Toradex Apalis and Colibri iMX6 boards.


Francesco Dolcini (2):
  colibri-imx6: use dynamic DDR calibration
  apalis-imx6: use dynamic DDR calibration

 board/toradex/apalis_imx6/apalis_imx6.c   | 19 +++++++++++++++++++
 board/toradex/colibri_imx6/colibri_imx6.c | 22 ++++++++++++++++++++++
 configs/apalis_imx6_defconfig             |  1 +
 configs/colibri_imx6_defconfig            |  1 +
 4 files changed, 43 insertions(+)

-- 
2.25.1


^ permalink raw reply	[flat|nested] 5+ messages in thread

* [PATCH v1 1/2] colibri-imx6: use dynamic DDR calibration
  2021-08-31  9:46 [PATCH v1 0/2] board: toradex: enable dynamic DDR calibration for iMX6 boards Francesco Dolcini
@ 2021-08-31  9:46 ` Francesco Dolcini
  2021-10-20 12:20   ` sbabic
  2021-08-31  9:46 ` [PATCH v1 2/2] apalis-imx6: " Francesco Dolcini
  1 sibling, 1 reply; 5+ messages in thread
From: Francesco Dolcini @ 2021-08-31  9:46 UTC (permalink / raw)
  To: u-boot
  Cc: Francesco Dolcini, Max Krummenacher, Harald Seiler,
	Heiko Schocher, Ming Liu, Oleksandr Suvorov, Patrick Delaunay,
	Simon Glass

Enable dynamic DDR calibration to have a reliable behavior on edge
temperatures conditions.

Signed-off-by: Max Krummenacher <max.krummenacher@toradex.com>
Signed-off-by: Francesco Dolcini <francesco.dolcini@toradex.com>
---

 board/toradex/colibri_imx6/colibri_imx6.c | 22 ++++++++++++++++++++++
 configs/colibri_imx6_defconfig            |  1 +
 2 files changed, 23 insertions(+)

diff --git a/board/toradex/colibri_imx6/colibri_imx6.c b/board/toradex/colibri_imx6/colibri_imx6.c
index 587d92a8e9..0fdeec51c4 100644
--- a/board/toradex/colibri_imx6/colibri_imx6.c
+++ b/board/toradex/colibri_imx6/colibri_imx6.c
@@ -998,9 +998,28 @@ static void ddr_init(int *table, int size)
 		writel(table[2 * i + 1], table[2 * i]);
 }
 
+/* Perform DDR DRAM calibration */
+static void spl_dram_perform_cal(u8 dsize)
+{
+#ifdef CONFIG_MX6_DDRCAL
+	int err;
+	struct mx6_ddr_sysinfo ddr_sysinfo = {
+		.dsize = dsize,
+	};
+
+	err = mmdc_do_write_level_calibration(&ddr_sysinfo);
+	if (err)
+		printf("error %d from write level calibration\n", err);
+	err = mmdc_do_dqs_calibration(&ddr_sysinfo);
+	if (err)
+		printf("error %d from dqs calibration\n", err);
+#endif
+}
+
 static void spl_dram_init(void)
 {
 	int minc, maxc;
+	u8 dsize = 2;
 
 	switch (get_cpu_temp_grade(&minc, &maxc)) {
 	case TEMP_COMMERCIAL:
@@ -1010,6 +1029,7 @@ static void spl_dram_init(void)
 			ddr_init(mx6dl_dcd_table, ARRAY_SIZE(mx6dl_dcd_table));
 		} else {
 			puts("Commercial temperature grade DDR3 timings, 32bit bus width.\n");
+			dsize = 1;
 			ddr_init(mx6s_dcd_table, ARRAY_SIZE(mx6s_dcd_table));
 		}
 		break;
@@ -1021,11 +1041,13 @@ static void spl_dram_init(void)
 			ddr_init(mx6dl_dcd_table, ARRAY_SIZE(mx6dl_dcd_table));
 		} else {
 			puts("Industrial temperature grade DDR3 timings, 32bit bus width.\n");
+			dsize = 1;
 			ddr_init(mx6s_dcd_table, ARRAY_SIZE(mx6s_dcd_table));
 		}
 		break;
 	};
 	udelay(100);
+	spl_dram_perform_cal(dsize);
 }
 
 static iomux_v3_cfg_t const gpio_reset_pad[] = {
diff --git a/configs/colibri_imx6_defconfig b/configs/colibri_imx6_defconfig
index 47b1cfb191..5a4f901fa7 100644
--- a/configs/colibri_imx6_defconfig
+++ b/configs/colibri_imx6_defconfig
@@ -10,6 +10,7 @@ CONFIG_SYS_MEMTEST_END=0x10010000
 CONFIG_ENV_SIZE=0x2000
 CONFIG_ENV_OFFSET=0xFFFFDE00
 CONFIG_MX6DL=y
+CONFIG_MX6_DDRCAL=y
 CONFIG_TARGET_COLIBRI_IMX6=y
 CONFIG_DM_GPIO=y
 CONFIG_DEFAULT_DEVICE_TREE="imx6-colibri"
-- 
2.25.1


^ permalink raw reply related	[flat|nested] 5+ messages in thread

* [PATCH v1 2/2] apalis-imx6: use dynamic DDR calibration
  2021-08-31  9:46 [PATCH v1 0/2] board: toradex: enable dynamic DDR calibration for iMX6 boards Francesco Dolcini
  2021-08-31  9:46 ` [PATCH v1 1/2] colibri-imx6: use dynamic DDR calibration Francesco Dolcini
@ 2021-08-31  9:46 ` Francesco Dolcini
  2021-10-20 12:21   ` sbabic
  1 sibling, 1 reply; 5+ messages in thread
From: Francesco Dolcini @ 2021-08-31  9:46 UTC (permalink / raw)
  To: u-boot
  Cc: Francesco Dolcini, Max Krummenacher, Harald Seiler,
	Heiko Schocher, Patrick Delaunay, Simon Glass

Enable dynamic DDR calibration to have a reliable behavior on edge
temperatures conditions.

Signed-off-by: Max Krummenacher <max.krummenacher@toradex.com>
Signed-off-by: Francesco Dolcini <francesco.dolcini@toradex.com>

---

 board/toradex/apalis_imx6/apalis_imx6.c | 19 +++++++++++++++++++
 configs/apalis_imx6_defconfig           |  1 +
 2 files changed, 20 insertions(+)

diff --git a/board/toradex/apalis_imx6/apalis_imx6.c b/board/toradex/apalis_imx6/apalis_imx6.c
index 74060daadd..ce64ace0d4 100644
--- a/board/toradex/apalis_imx6/apalis_imx6.c
+++ b/board/toradex/apalis_imx6/apalis_imx6.c
@@ -1077,6 +1077,24 @@ static void ddr_init(int *table, int size)
 		writel(table[2 * i + 1], table[2 * i]);
 }
 
+/* Perform DDR DRAM calibration */
+static void spl_dram_perform_cal(void)
+{
+#ifdef CONFIG_MX6_DDRCAL
+	int err;
+	struct mx6_ddr_sysinfo ddr_sysinfo = {
+		.dsize = 2,
+	};
+
+	err = mmdc_do_write_level_calibration(&ddr_sysinfo);
+	if (err)
+		printf("error %d from write level calibration\n", err);
+	err = mmdc_do_dqs_calibration(&ddr_sysinfo);
+	if (err)
+		printf("error %d from dqs calibration\n", err);
+#endif
+}
+
 static void spl_dram_init(void)
 {
 	int minc, maxc;
@@ -1095,6 +1113,7 @@ static void spl_dram_init(void)
 		break;
 	};
 	udelay(100);
+	spl_dram_perform_cal();
 }
 
 void board_init_f(ulong dummy)
diff --git a/configs/apalis_imx6_defconfig b/configs/apalis_imx6_defconfig
index a0e85ba23a..0e06e75818 100644
--- a/configs/apalis_imx6_defconfig
+++ b/configs/apalis_imx6_defconfig
@@ -10,6 +10,7 @@ CONFIG_SYS_MEMTEST_END=0x10010000
 CONFIG_ENV_SIZE=0x2000
 CONFIG_ENV_OFFSET=0xFFFFDE00
 CONFIG_MX6Q=y
+CONFIG_MX6_DDRCAL=y
 CONFIG_TARGET_APALIS_IMX6=y
 CONFIG_DM_GPIO=y
 CONFIG_DEFAULT_DEVICE_TREE="imx6-apalis"
-- 
2.25.1


^ permalink raw reply related	[flat|nested] 5+ messages in thread

* [PATCH v1 1/2] colibri-imx6: use dynamic DDR calibration
  2021-08-31  9:46 ` [PATCH v1 1/2] colibri-imx6: use dynamic DDR calibration Francesco Dolcini
@ 2021-10-20 12:20   ` sbabic
  0 siblings, 0 replies; 5+ messages in thread
From: sbabic @ 2021-10-20 12:20 UTC (permalink / raw)
  To: Francesco Dolcini, u-boot

> Enable dynamic DDR calibration to have a reliable behavior on edge
> temperatures conditions.
> Signed-off-by: Max Krummenacher <max.krummenacher@toradex.com>
> Signed-off-by: Francesco Dolcini <francesco.dolcini@toradex.com>
Applied to u-boot-imx, master, thanks !

Best regards,
Stefano Babic

-- 
=====================================================================
DENX Software Engineering GmbH,      Managing Director: Wolfgang Denk
HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany
Phone: +49-8142-66989-53 Fax: +49-8142-66989-80 Email: sbabic@denx.de
=====================================================================

^ permalink raw reply	[flat|nested] 5+ messages in thread

* [PATCH v1 2/2] apalis-imx6: use dynamic DDR calibration
  2021-08-31  9:46 ` [PATCH v1 2/2] apalis-imx6: " Francesco Dolcini
@ 2021-10-20 12:21   ` sbabic
  0 siblings, 0 replies; 5+ messages in thread
From: sbabic @ 2021-10-20 12:21 UTC (permalink / raw)
  To: Francesco Dolcini, u-boot

> Enable dynamic DDR calibration to have a reliable behavior on edge
> temperatures conditions.
> Signed-off-by: Max Krummenacher <max.krummenacher@toradex.com>
> Signed-off-by: Francesco Dolcini <francesco.dolcini@toradex.com>
Applied to u-boot-imx, master, thanks !

Best regards,
Stefano Babic

-- 
=====================================================================
DENX Software Engineering GmbH,      Managing Director: Wolfgang Denk
HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany
Phone: +49-8142-66989-53 Fax: +49-8142-66989-80 Email: sbabic@denx.de
=====================================================================

^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2021-10-20 12:22 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2021-08-31  9:46 [PATCH v1 0/2] board: toradex: enable dynamic DDR calibration for iMX6 boards Francesco Dolcini
2021-08-31  9:46 ` [PATCH v1 1/2] colibri-imx6: use dynamic DDR calibration Francesco Dolcini
2021-10-20 12:20   ` sbabic
2021-08-31  9:46 ` [PATCH v1 2/2] apalis-imx6: " Francesco Dolcini
2021-10-20 12:21   ` sbabic

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).