* [PATCH] ARM: imx: esdctl: fix LPDDR4 size calculation
@ 2022-05-13 14:16 Lucas Stach
  2022-05-16  8:10 ` Sascha Hauer
  2022-05-20 14:16 ` Teresa Remmet
  0 siblings, 2 replies; 5+ messages in thread
From: Lucas Stach @ 2022-05-13 14:16 UTC (permalink / raw)
  To: barebox
The DDRC only uses the DEVICE_CONFIG field for memory types other than
LPDDR4. While LPDDR4 always has a bus width of x32, the script aid
generates the value for a x16 bus, as this was apparently used for the
controller validation. This resulted in the calculated DRAM size to be
halved on boards with LPDDR4 memory.
Fixes: d8d5778ee8c2 ("ARM: imx: Correct mem size calculation for 4/8/16/32 bit bus width")
Signed-off-by: Lucas Stach <l.stach@pengutronix.de>
---
 arch/arm/mach-imx/esdctl.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/arch/arm/mach-imx/esdctl.c b/arch/arm/mach-imx/esdctl.c
index d3dbfff423da..4c8765c193d0 100644
--- a/arch/arm/mach-imx/esdctl.c
+++ b/arch/arm/mach-imx/esdctl.c
@@ -392,7 +392,7 @@ imx_ddrc_sdram_size(void __iomem *ddrc, const u32 addrmap[],
 	}
 
 	/* Bus width in bytes, 0 means half byte or 4-bit mode */
-	if (is_imx8)
+	if (is_imx8 && !(mstr & DDRC_MSTR_LPDDR4))
 		width = (1 << FIELD_GET(DDRC_MSTR_DEVICE_CONFIG, mstr)) >> 1;
 	else
 		width = 4;
-- 
2.35.3
_______________________________________________
barebox mailing list
barebox@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/barebox
^ permalink raw reply	[flat|nested] 5+ messages in thread* Re: [PATCH] ARM: imx: esdctl: fix LPDDR4 size calculation 2022-05-13 14:16 [PATCH] ARM: imx: esdctl: fix LPDDR4 size calculation Lucas Stach @ 2022-05-16 8:10 ` Sascha Hauer 2022-05-20 14:16 ` Teresa Remmet 1 sibling, 0 replies; 5+ messages in thread From: Sascha Hauer @ 2022-05-16 8:10 UTC (permalink / raw) To: Lucas Stach; +Cc: barebox On Fri, May 13, 2022 at 04:16:25PM +0200, Lucas Stach wrote: > The DDRC only uses the DEVICE_CONFIG field for memory types other than > LPDDR4. While LPDDR4 always has a bus width of x32, the script aid > generates the value for a x16 bus, as this was apparently used for the > controller validation. This resulted in the calculated DRAM size to be > halved on boards with LPDDR4 memory. > > Fixes: d8d5778ee8c2 ("ARM: imx: Correct mem size calculation for 4/8/16/32 bit bus width") > Signed-off-by: Lucas Stach <l.stach@pengutronix.de> > --- > arch/arm/mach-imx/esdctl.c | 2 +- > 1 file changed, 1 insertion(+), 1 deletion(-) Applied, thanks Sascha > > diff --git a/arch/arm/mach-imx/esdctl.c b/arch/arm/mach-imx/esdctl.c > index d3dbfff423da..4c8765c193d0 100644 > --- a/arch/arm/mach-imx/esdctl.c > +++ b/arch/arm/mach-imx/esdctl.c > @@ -392,7 +392,7 @@ imx_ddrc_sdram_size(void __iomem *ddrc, const u32 addrmap[], > } > > /* Bus width in bytes, 0 means half byte or 4-bit mode */ > - if (is_imx8) > + if (is_imx8 && !(mstr & DDRC_MSTR_LPDDR4)) > width = (1 << FIELD_GET(DDRC_MSTR_DEVICE_CONFIG, mstr)) >> 1; > else > width = 4; > -- > 2.35.3 > > > _______________________________________________ > barebox mailing list > barebox@lists.infradead.org > http://lists.infradead.org/mailman/listinfo/barebox > -- Pengutronix e.K. | | Steuerwalder Str. 21 | http://www.pengutronix.de/ | 31137 Hildesheim, Germany | Phone: +49-5121-206917-0 | Amtsgericht Hildesheim, HRA 2686 | Fax: +49-5121-206917-5555 | _______________________________________________ barebox mailing list barebox@lists.infradead.org http://lists.infradead.org/mailman/listinfo/barebox ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH] ARM: imx: esdctl: fix LPDDR4 size calculation 2022-05-13 14:16 [PATCH] ARM: imx: esdctl: fix LPDDR4 size calculation Lucas Stach 2022-05-16 8:10 ` Sascha Hauer @ 2022-05-20 14:16 ` Teresa Remmet 2022-05-20 14:33 ` Lucas Stach 1 sibling, 1 reply; 5+ messages in thread From: Teresa Remmet @ 2022-05-20 14:16 UTC (permalink / raw) To: l.stach, barebox Hello Lucas, Am Freitag, dem 13.05.2022 um 16:16 +0200 schrieb Lucas Stach: > The DDRC only uses the DEVICE_CONFIG field for memory types other > than > LPDDR4. While LPDDR4 always has a bus width of x32, the script aid this is not true for i.MX8M Nano. This SoC has only x16. This is probably why reading the register worked for Joacim on imx8mn. So there is some more checking needed. Regards, Teresa > generates the value for a x16 bus, as this was apparently used for > the > controller validation. This resulted in the calculated DRAM size to > be > halved on boards with LPDDR4 memory. > > Fixes: d8d5778ee8c2 ("ARM: imx: Correct mem size calculation for > 4/8/16/32 bit bus width") > Signed-off-by: Lucas Stach <l.stach@pengutronix.de> > --- > arch/arm/mach-imx/esdctl.c | 2 +- > 1 file changed, 1 insertion(+), 1 deletion(-) > > diff --git a/arch/arm/mach-imx/esdctl.c b/arch/arm/mach-imx/esdctl.c > index d3dbfff423da..4c8765c193d0 100644 > --- a/arch/arm/mach-imx/esdctl.c > +++ b/arch/arm/mach-imx/esdctl.c > @@ -392,7 +392,7 @@ imx_ddrc_sdram_size(void __iomem *ddrc, const u32 > addrmap[], > } > > /* Bus width in bytes, 0 means half byte or 4-bit mode */ > - if (is_imx8) > + if (is_imx8 && !(mstr & DDRC_MSTR_LPDDR4)) > width = (1 << FIELD_GET(DDRC_MSTR_DEVICE_CONFIG, mstr)) > >> 1; > else > width = 4; -- PHYTEC Messtechnik GmbH | Robert-Koch-Str. 39 | 55129 Mainz, Germany Geschäftsführer: Dipl.-Ing. Michael Mitezki, Dipl.-Ing. Bodo Huber | Handelsregister Mainz HRB 4656 | Finanzamt Mainz | St.Nr. 266500608, DE 149059855 _______________________________________________ barebox mailing list barebox@lists.infradead.org http://lists.infradead.org/mailman/listinfo/barebox ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH] ARM: imx: esdctl: fix LPDDR4 size calculation 2022-05-20 14:16 ` Teresa Remmet @ 2022-05-20 14:33 ` Lucas Stach 2022-05-20 14:55 ` Teresa Remmet 0 siblings, 1 reply; 5+ messages in thread From: Lucas Stach @ 2022-05-20 14:33 UTC (permalink / raw) To: Teresa Remmet, barebox Hi Teresa, Am Freitag, dem 20.05.2022 um 14:16 +0000 schrieb Teresa Remmet: > Hello Lucas, > > Am Freitag, dem 13.05.2022 um 16:16 +0200 schrieb Lucas Stach: > > The DDRC only uses the DEVICE_CONFIG field for memory types other > > than > > LPDDR4. While LPDDR4 always has a bus width of x32, the script aid > > this is not true for i.MX8M Nano. This SoC has only x16. This is > probably why reading the register worked for Joacim on imx8mn. > So there is some more checking needed. > Does the 8MN really use the DEVICE_CONFIG to configure the LPDDR4 bus to 16bit width, or does it use the DATA_BUS_WIDTH control to limit the bus to 16bit? The register programming aid spreadsheet for the 8MN claims that DEVICE_CONFIG has no effect on LPDDR4 memory, same as for all other i.M8M* variants. But then the spreadsheet may have copy-and-paste issues. So maybe we do in fact need to know that native bus width of controller implementation on the specific SoC to get things right for LPDDR4? Regards, Lucas > Regards, > Teresa > > > generates the value for a x16 bus, as this was apparently used for > > the > > controller validation. This resulted in the calculated DRAM size to > > be > > halved on boards with LPDDR4 memory. > > > > Fixes: d8d5778ee8c2 ("ARM: imx: Correct mem size calculation for > > 4/8/16/32 bit bus width") > > Signed-off-by: Lucas Stach <l.stach@pengutronix.de> > > --- > > arch/arm/mach-imx/esdctl.c | 2 +- > > 1 file changed, 1 insertion(+), 1 deletion(-) > > > > diff --git a/arch/arm/mach-imx/esdctl.c b/arch/arm/mach-imx/esdctl.c > > index d3dbfff423da..4c8765c193d0 100644 > > --- a/arch/arm/mach-imx/esdctl.c > > +++ b/arch/arm/mach-imx/esdctl.c > > @@ -392,7 +392,7 @@ imx_ddrc_sdram_size(void __iomem *ddrc, const u32 > > addrmap[], > > } > > > > /* Bus width in bytes, 0 means half byte or 4-bit mode */ > > - if (is_imx8) > > + if (is_imx8 && !(mstr & DDRC_MSTR_LPDDR4)) > > width = (1 << FIELD_GET(DDRC_MSTR_DEVICE_CONFIG, mstr)) > > > > 1; > > else > > width = 4; > -- > PHYTEC Messtechnik GmbH | Robert-Koch-Str. 39 | 55129 Mainz, Germany > > Geschäftsführer: Dipl.-Ing. Michael Mitezki, Dipl.-Ing. Bodo Huber | > Handelsregister Mainz HRB 4656 | Finanzamt Mainz | St.Nr. 266500608, DE > 149059855 _______________________________________________ barebox mailing list barebox@lists.infradead.org http://lists.infradead.org/mailman/listinfo/barebox ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH] ARM: imx: esdctl: fix LPDDR4 size calculation 2022-05-20 14:33 ` Lucas Stach @ 2022-05-20 14:55 ` Teresa Remmet 0 siblings, 0 replies; 5+ messages in thread From: Teresa Remmet @ 2022-05-20 14:55 UTC (permalink / raw) To: l.stach, barebox Am Freitag, dem 20.05.2022 um 16:33 +0200 schrieb Lucas Stach: > Hi Teresa, > > Am Freitag, dem 20.05.2022 um 14:16 +0000 schrieb Teresa Remmet: > > Hello Lucas, > > > > Am Freitag, dem 13.05.2022 um 16:16 +0200 schrieb Lucas Stach: > > > The DDRC only uses the DEVICE_CONFIG field for memory types other > > > than > > > LPDDR4. While LPDDR4 always has a bus width of x32, the script > > > aid > > > > this is not true for i.MX8M Nano. This SoC has only x16. This is > > probably why reading the register worked for Joacim on imx8mn. > > So there is some more checking needed. > > > Does the 8MN really use the DEVICE_CONFIG to configure the LPDDR4 bus > to 16bit width, or does it use the DATA_BUS_WIDTH control to limit > the > bus to 16bit? > > The register programming aid spreadsheet for the 8MN claims that > DEVICE_CONFIG has no effect on LPDDR4 memory, same as for all other > i.M8M* variants. But then the spreadsheet may have copy-and-paste > issues. So maybe we do in fact need to know that native bus width of > controller implementation on the specific SoC to get things right for > LPDDR4? when looking behind the formulas of the DATA_BUS_WIDTH in the spreadsheet for i.MX8MN "Full DQ bus width" means always 16bit. For i.MX8MM + i.MX8MP always 32bit. So yes, I guess we need to check for the SoC we are running on to get it right. Regards, Teresa > > Regards, > Lucas > > > Regards, > > Teresa > > > > > generates the value for a x16 bus, as this was apparently used > > > for > > > the > > > controller validation. This resulted in the calculated DRAM size > > > to > > > be > > > halved on boards with LPDDR4 memory. > > > > > > Fixes: d8d5778ee8c2 ("ARM: imx: Correct mem size calculation for > > > 4/8/16/32 bit bus width") > > > Signed-off-by: Lucas Stach <l.stach@pengutronix.de> > > > --- > > > arch/arm/mach-imx/esdctl.c | 2 +- > > > 1 file changed, 1 insertion(+), 1 deletion(-) > > > > > > diff --git a/arch/arm/mach-imx/esdctl.c b/arch/arm/mach- > > > imx/esdctl.c > > > index d3dbfff423da..4c8765c193d0 100644 > > > --- a/arch/arm/mach-imx/esdctl.c > > > +++ b/arch/arm/mach-imx/esdctl.c > > > @@ -392,7 +392,7 @@ imx_ddrc_sdram_size(void __iomem *ddrc, const > > > u32 > > > addrmap[], > > > } > > > > > > /* Bus width in bytes, 0 means half byte or 4-bit mode */ > > > - if (is_imx8) > > > + if (is_imx8 && !(mstr & DDRC_MSTR_LPDDR4)) > > > width = (1 << FIELD_GET(DDRC_MSTR_DEVICE_CONFIG, mstr)) > > > > > 1; > > > else > > > width = 4; > > -- > > PHYTEC Messtechnik GmbH | Robert-Koch-Str. 39 | 55129 Mainz, > > Germany > > > > Geschäftsführer: Dipl.-Ing. Michael Mitezki, Dipl.-Ing. Bodo Huber > > | > > Handelsregister Mainz HRB 4656 | Finanzamt Mainz | St.Nr. > > 266500608, DE > > 149059855 > > -- PHYTEC Messtechnik GmbH | Robert-Koch-Str. 39 | 55129 Mainz, Germany Geschäftsführer: Dipl.-Ing. Michael Mitezki, Dipl.-Ing. Bodo Huber | Handelsregister Mainz HRB 4656 | Finanzamt Mainz | St.Nr. 266500608, DE 149059855 _______________________________________________ barebox mailing list barebox@lists.infradead.org http://lists.infradead.org/mailman/listinfo/barebox ^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2022-05-20 14:57 UTC | newest] Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed) -- links below jump to the message on this page -- 2022-05-13 14:16 [PATCH] ARM: imx: esdctl: fix LPDDR4 size calculation Lucas Stach 2022-05-16 8:10 ` Sascha Hauer 2022-05-20 14:16 ` Teresa Remmet 2022-05-20 14:33 ` Lucas Stach 2022-05-20 14:55 ` Teresa Remmet
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox