[PATCH 2/3] stm32mp1: ram: remove the support of calibration result
Patrice CHOTARD
patrice.chotard at foss.st.com
Mon Nov 22 08:49:54 CET 2021
Hi Patrick
On 11/15/21 3:32 PM, Patrick Delaunay wrote:
> The support of a predefined DDR PHY tuning result is removed for
> STM32MP1 driver because it is not needed at the supported frequency
> when built-in calibration is executed.
>
> The calibration parameters were provided in the device tree by the
> optional node "st,phy-cal", activated in ddr helper file by the
> compilation flag DDR_PHY_CAL_SKIP and filled with values generated
> by the CubeMX DDR utilities.
>
> This patch
> - updates the binding file to remove "st,phy-cal" support
> - updates the device trees and remove the associated defines
> - simplifies the STM32MP1 DDR driver and remove the support of
> the optional parameter "st,phy-cal"
>
> After this patch, the built-in calibration is always executed
> and the calibration registers are moved in the phy dynamic part;
> that allows manual tests.
>
> Signed-off-by: Patrick Delaunay <patrick.delaunay at foss.st.com>
> ---
>
> arch/arm/dts/stm32mp15-ddr.dtsi | 30 ---------
> .../dts/stm32mp15-ddr3-1x4Gb-1066-binG.dtsi | 12 ----
> .../dts/stm32mp15-ddr3-2x4Gb-1066-binG.dtsi | 12 ----
> .../stm32mp15-ddr3-dhsom-2x1Gb-1066-binG.dtsi | 12 ----
> .../stm32mp15-ddr3-dhsom-2x2Gb-1066-binG.dtsi | 12 ----
> .../stm32mp15-ddr3-dhsom-2x4Gb-1066-binG.dtsi | 12 ----
> .../stm32mp15-ddr3-icore-1x4Gb-1066-binG.dtsi | 12 ----
> .../memory-controllers/st,stm32mp1-ddr.txt | 32 ---------
> drivers/ram/stm32mp1/stm32mp1_ddr.c | 65 +++++++------------
> drivers/ram/stm32mp1/stm32mp1_ddr.h | 17 -----
> drivers/ram/stm32mp1/stm32mp1_interactive.c | 15 +----
> drivers/ram/stm32mp1/stm32mp1_ram.c | 22 +------
> 12 files changed, 27 insertions(+), 226 deletions(-)
>
> diff --git a/arch/arm/dts/stm32mp15-ddr.dtsi b/arch/arm/dts/stm32mp15-ddr.dtsi
> index 2a139c54e9..0aac9131a6 100644
> --- a/arch/arm/dts/stm32mp15-ddr.dtsi
> +++ b/arch/arm/dts/stm32mp15-ddr.dtsi
> @@ -116,24 +116,6 @@
> DDR_MR3
> >;
>
> -#ifdef DDR_PHY_CAL_SKIP
> - st,phy-cal = <
> - DDR_DX0DLLCR
> - DDR_DX0DQTR
> - DDR_DX0DQSTR
> - DDR_DX1DLLCR
> - DDR_DX1DQTR
> - DDR_DX1DQSTR
> - DDR_DX2DLLCR
> - DDR_DX2DQTR
> - DDR_DX2DQSTR
> - DDR_DX3DLLCR
> - DDR_DX3DQTR
> - DDR_DX3DQSTR
> - >;
> -
> -#endif
> -
> status = "okay";
> };
> };
> @@ -224,18 +206,6 @@
> #undef DDR_ODTCR
> #undef DDR_ZQ0CR1
> #undef DDR_DX0GCR
> -#undef DDR_DX0DLLCR
> -#undef DDR_DX0DQTR
> -#undef DDR_DX0DQSTR
> #undef DDR_DX1GCR
> -#undef DDR_DX1DLLCR
> -#undef DDR_DX1DQTR
> -#undef DDR_DX1DQSTR
> #undef DDR_DX2GCR
> -#undef DDR_DX2DLLCR
> -#undef DDR_DX2DQTR
> -#undef DDR_DX2DQSTR
> #undef DDR_DX3GCR
> -#undef DDR_DX3DLLCR
> -#undef DDR_DX3DQTR
> -#undef DDR_DX3DQSTR
> diff --git a/arch/arm/dts/stm32mp15-ddr3-1x4Gb-1066-binG.dtsi b/arch/arm/dts/stm32mp15-ddr3-1x4Gb-1066-binG.dtsi
> index 978331b279..e60d0ae606 100644
> --- a/arch/arm/dts/stm32mp15-ddr3-1x4Gb-1066-binG.dtsi
> +++ b/arch/arm/dts/stm32mp15-ddr3-1x4Gb-1066-binG.dtsi
> @@ -100,20 +100,8 @@
> #define DDR_ODTCR 0x00010000
> #define DDR_ZQ0CR1 0x00000038
> #define DDR_DX0GCR 0x0000CE81
> -#define DDR_DX0DLLCR 0x40000000
> -#define DDR_DX0DQTR 0xFFFFFFFF
> -#define DDR_DX0DQSTR 0x3DB02000
> #define DDR_DX1GCR 0x0000CE81
> -#define DDR_DX1DLLCR 0x40000000
> -#define DDR_DX1DQTR 0xFFFFFFFF
> -#define DDR_DX1DQSTR 0x3DB02000
> #define DDR_DX2GCR 0x0000CE80
> -#define DDR_DX2DLLCR 0x40000000
> -#define DDR_DX2DQTR 0xFFFFFFFF
> -#define DDR_DX2DQSTR 0x3DB02000
> #define DDR_DX3GCR 0x0000CE80
> -#define DDR_DX3DLLCR 0x40000000
> -#define DDR_DX3DQTR 0xFFFFFFFF
> -#define DDR_DX3DQSTR 0x3DB02000
>
> #include "stm32mp15-ddr.dtsi"
> diff --git a/arch/arm/dts/stm32mp15-ddr3-2x4Gb-1066-binG.dtsi b/arch/arm/dts/stm32mp15-ddr3-2x4Gb-1066-binG.dtsi
> index 426be21f42..1a6fa80edf 100644
> --- a/arch/arm/dts/stm32mp15-ddr3-2x4Gb-1066-binG.dtsi
> +++ b/arch/arm/dts/stm32mp15-ddr3-2x4Gb-1066-binG.dtsi
> @@ -100,20 +100,8 @@
> #define DDR_ODTCR 0x00010000
> #define DDR_ZQ0CR1 0x00000038
> #define DDR_DX0GCR 0x0000CE81
> -#define DDR_DX0DLLCR 0x40000000
> -#define DDR_DX0DQTR 0xFFFFFFFF
> -#define DDR_DX0DQSTR 0x3DB02000
> #define DDR_DX1GCR 0x0000CE81
> -#define DDR_DX1DLLCR 0x40000000
> -#define DDR_DX1DQTR 0xFFFFFFFF
> -#define DDR_DX1DQSTR 0x3DB02000
> #define DDR_DX2GCR 0x0000CE81
> -#define DDR_DX2DLLCR 0x40000000
> -#define DDR_DX2DQTR 0xFFFFFFFF
> -#define DDR_DX2DQSTR 0x3DB02000
> #define DDR_DX3GCR 0x0000CE81
> -#define DDR_DX3DLLCR 0x40000000
> -#define DDR_DX3DQTR 0xFFFFFFFF
> -#define DDR_DX3DQSTR 0x3DB02000
>
> #include "stm32mp15-ddr.dtsi"
> diff --git a/arch/arm/dts/stm32mp15-ddr3-dhsom-2x1Gb-1066-binG.dtsi b/arch/arm/dts/stm32mp15-ddr3-dhsom-2x1Gb-1066-binG.dtsi
> index b3eb280f96..0a277cd675 100644
> --- a/arch/arm/dts/stm32mp15-ddr3-dhsom-2x1Gb-1066-binG.dtsi
> +++ b/arch/arm/dts/stm32mp15-ddr3-dhsom-2x1Gb-1066-binG.dtsi
> @@ -101,20 +101,8 @@
> #define DDR_ODTCR 0x00010000
> #define DDR_ZQ0CR1 0x00000038
> #define DDR_DX0GCR 0x0000CE81
> -#define DDR_DX0DLLCR 0x40000000
> -#define DDR_DX0DQTR 0xFFFFFFFF
> -#define DDR_DX0DQSTR 0x3DB02000
> #define DDR_DX1GCR 0x0000CE81
> -#define DDR_DX1DLLCR 0x40000000
> -#define DDR_DX1DQTR 0xFFFFFFFF
> -#define DDR_DX1DQSTR 0x3DB02000
> #define DDR_DX2GCR 0x0000CE81
> -#define DDR_DX2DLLCR 0x40000000
> -#define DDR_DX2DQTR 0xFFFFFFFF
> -#define DDR_DX2DQSTR 0x3DB02000
> #define DDR_DX3GCR 0x0000CE81
> -#define DDR_DX3DLLCR 0x40000000
> -#define DDR_DX3DQTR 0xFFFFFFFF
> -#define DDR_DX3DQSTR 0x3DB02000
>
> #include "stm32mp15-ddr.dtsi"
> diff --git a/arch/arm/dts/stm32mp15-ddr3-dhsom-2x2Gb-1066-binG.dtsi b/arch/arm/dts/stm32mp15-ddr3-dhsom-2x2Gb-1066-binG.dtsi
> index ed3a5248f8..92774fffb9 100644
> --- a/arch/arm/dts/stm32mp15-ddr3-dhsom-2x2Gb-1066-binG.dtsi
> +++ b/arch/arm/dts/stm32mp15-ddr3-dhsom-2x2Gb-1066-binG.dtsi
> @@ -101,20 +101,8 @@
> #define DDR_ODTCR 0x00010000
> #define DDR_ZQ0CR1 0x00000038
> #define DDR_DX0GCR 0x0000CE81
> -#define DDR_DX0DLLCR 0x40000000
> -#define DDR_DX0DQTR 0xFFFFFFFF
> -#define DDR_DX0DQSTR 0x3DB02000
> #define DDR_DX1GCR 0x0000CE81
> -#define DDR_DX1DLLCR 0x40000000
> -#define DDR_DX1DQTR 0xFFFFFFFF
> -#define DDR_DX1DQSTR 0x3DB02000
> #define DDR_DX2GCR 0x0000CE81
> -#define DDR_DX2DLLCR 0x40000000
> -#define DDR_DX2DQTR 0xFFFFFFFF
> -#define DDR_DX2DQSTR 0x3DB02000
> #define DDR_DX3GCR 0x0000CE81
> -#define DDR_DX3DLLCR 0x40000000
> -#define DDR_DX3DQTR 0xFFFFFFFF
> -#define DDR_DX3DQSTR 0x3DB02000
>
> #include "stm32mp15-ddr.dtsi"
> diff --git a/arch/arm/dts/stm32mp15-ddr3-dhsom-2x4Gb-1066-binG.dtsi b/arch/arm/dts/stm32mp15-ddr3-dhsom-2x4Gb-1066-binG.dtsi
> index d5813d64b0..e53ab18a69 100644
> --- a/arch/arm/dts/stm32mp15-ddr3-dhsom-2x4Gb-1066-binG.dtsi
> +++ b/arch/arm/dts/stm32mp15-ddr3-dhsom-2x4Gb-1066-binG.dtsi
> @@ -101,20 +101,8 @@
> #define DDR_ODTCR 0x00010000
> #define DDR_ZQ0CR1 0x00000038
> #define DDR_DX0GCR 0x0000CE81
> -#define DDR_DX0DLLCR 0x40000000
> -#define DDR_DX0DQTR 0xFFFFFFFF
> -#define DDR_DX0DQSTR 0x3DB02000
> #define DDR_DX1GCR 0x0000CE81
> -#define DDR_DX1DLLCR 0x40000000
> -#define DDR_DX1DQTR 0xFFFFFFFF
> -#define DDR_DX1DQSTR 0x3DB02000
> #define DDR_DX2GCR 0x0000CE81
> -#define DDR_DX2DLLCR 0x40000000
> -#define DDR_DX2DQTR 0xFFFFFFFF
> -#define DDR_DX2DQSTR 0x3DB02000
> #define DDR_DX3GCR 0x0000CE81
> -#define DDR_DX3DLLCR 0x40000000
> -#define DDR_DX3DQTR 0xFFFFFFFF
> -#define DDR_DX3DQSTR 0x3DB02000
>
> #include "stm32mp15-ddr.dtsi"
> diff --git a/arch/arm/dts/stm32mp15-ddr3-icore-1x4Gb-1066-binG.dtsi b/arch/arm/dts/stm32mp15-ddr3-icore-1x4Gb-1066-binG.dtsi
> index 24c81269b0..ff582ac6af 100644
> --- a/arch/arm/dts/stm32mp15-ddr3-icore-1x4Gb-1066-binG.dtsi
> +++ b/arch/arm/dts/stm32mp15-ddr3-icore-1x4Gb-1066-binG.dtsi
> @@ -100,20 +100,8 @@
> #define DDR_ODTCR 0x00010000
> #define DDR_ZQ0CR1 0x00000038
> #define DDR_DX0GCR 0x0000CE81
> -#define DDR_DX0DLLCR 0x40000000
> -#define DDR_DX0DQTR 0xFFFFFFFF
> -#define DDR_DX0DQSTR 0x3DB02000
> #define DDR_DX1GCR 0x0000CE81
> -#define DDR_DX1DLLCR 0x40000000
> -#define DDR_DX1DQTR 0xFFFFFFFF
> -#define DDR_DX1DQSTR 0x3DB02000
> #define DDR_DX2GCR 0x0000CE81
> -#define DDR_DX2DLLCR 0x40000000
> -#define DDR_DX2DQTR 0xFFFFFFFF
> -#define DDR_DX2DQSTR 0x3DB02000
> #define DDR_DX3GCR 0x0000CE81
> -#define DDR_DX3DLLCR 0x40000000
> -#define DDR_DX3DQTR 0xFFFFFFFF
> -#define DDR_DX3DQSTR 0x3DB02000
>
> #include "stm32mp15-ddr.dtsi"
> diff --git a/doc/device-tree-bindings/memory-controllers/st,stm32mp1-ddr.txt b/doc/device-tree-bindings/memory-controllers/st,stm32mp1-ddr.txt
> index ac6a7df432..926e3e83b3 100644
> --- a/doc/device-tree-bindings/memory-controllers/st,stm32mp1-ddr.txt
> +++ b/doc/device-tree-bindings/memory-controllers/st,stm32mp1-ddr.txt
> @@ -128,23 +128,6 @@ phyc attributes:
> MR2
> MR3
>
> -- st,phy-cal : phy cal depending of calibration or tuning of DDR
> - This parameter is optional; when it is absent the built-in PHY
> - calibration is done.
> - for STM32MP15x: 12 values are requested in this order
> - DX0DLLCR
> - DX0DQTR
> - DX0DQSTR
> - DX1DLLCR
> - DX1DQTR
> - DX1DQSTR
> - DX2DLLCR
> - DX2DQTR
> - DX2DQSTR
> - DX3DLLCR
> - DX3DQTR
> - DX3DQSTR
> -
> Example:
>
> / {
> @@ -280,21 +263,6 @@ Example:
> 0x00000000 /*MR3*/
> >;
>
> - st,phy-cal = <
> - 0x40000000 /*DX0DLLCR*/
> - 0xFFFFFFFF /*DX0DQTR*/
> - 0x3DB02000 /*DX0DQSTR*/
> - 0x40000000 /*DX1DLLCR*/
> - 0xFFFFFFFF /*DX1DQTR*/
> - 0x3DB02000 /*DX1DQSTR*/
> - 0x40000000 /*DX2DLLCR*/
> - 0xFFFFFFFF /*DX2DQTR*/
> - 0x3DB02000 /*DX2DQSTR*/
> - 0x40000000 /*DX3DLLCR*/
> - 0xFFFFFFFF /*DX3DQTR*/
> - 0x3DB02000 /*DX3DQSTR*/
> - >;
> -
> status = "okay";
> };
> };
> diff --git a/drivers/ram/stm32mp1/stm32mp1_ddr.c b/drivers/ram/stm32mp1/stm32mp1_ddr.c
> index 1f8422518b..9d086601a4 100644
> --- a/drivers/ram/stm32mp1/stm32mp1_ddr.c
> +++ b/drivers/ram/stm32mp1/stm32mp1_ddr.c
> @@ -68,7 +68,6 @@ struct reg_desc {
>
> #define DDRPHY_REG_REG_SIZE 11 /* st,phy-reg */
> #define DDRPHY_REG_TIMING_SIZE 10 /* st,phy-timing */
> -#define DDRPHY_REG_CAL_SIZE 12 /* st,phy-cal */
>
> #define DDRCTL_REG_REG(x) DDRCTL_REG(x, stm32mp1_ddrctrl_reg)
> static const struct reg_desc ddr_reg[DDRCTL_REG_REG_SIZE] = {
> @@ -178,22 +177,6 @@ static const struct reg_desc ddrphy_timing[DDRPHY_REG_TIMING_SIZE] = {
> DDRPHY_REG_TIMING(mr3),
> };
>
> -#define DDRPHY_REG_CAL(x) DDRPHY_REG(x, stm32mp1_ddrphy_cal)
> -static const struct reg_desc ddrphy_cal[DDRPHY_REG_CAL_SIZE] = {
> - DDRPHY_REG_CAL(dx0dllcr),
> - DDRPHY_REG_CAL(dx0dqtr),
> - DDRPHY_REG_CAL(dx0dqstr),
> - DDRPHY_REG_CAL(dx1dllcr),
> - DDRPHY_REG_CAL(dx1dqtr),
> - DDRPHY_REG_CAL(dx1dqstr),
> - DDRPHY_REG_CAL(dx2dllcr),
> - DDRPHY_REG_CAL(dx2dqtr),
> - DDRPHY_REG_CAL(dx2dqstr),
> - DDRPHY_REG_CAL(dx3dllcr),
> - DDRPHY_REG_CAL(dx3dqtr),
> - DDRPHY_REG_CAL(dx3dqstr),
> -};
> -
> /**************************************************************
> * DYNAMIC REGISTERS: only used for debug purpose (read/modify)
> **************************************************************/
> @@ -218,12 +201,24 @@ static const struct reg_desc ddrphy_dyn[] = {
> DDRPHY_REG_DYN(zq0sr1),
> DDRPHY_REG_DYN(dx0gsr0),
> DDRPHY_REG_DYN(dx0gsr1),
> + DDRPHY_REG_DYN(dx0dllcr),
> + DDRPHY_REG_DYN(dx0dqtr),
> + DDRPHY_REG_DYN(dx0dqstr),
> DDRPHY_REG_DYN(dx1gsr0),
> DDRPHY_REG_DYN(dx1gsr1),
> + DDRPHY_REG_DYN(dx1dllcr),
> + DDRPHY_REG_DYN(dx1dqtr),
> + DDRPHY_REG_DYN(dx1dqstr),
> DDRPHY_REG_DYN(dx2gsr0),
> DDRPHY_REG_DYN(dx2gsr1),
> + DDRPHY_REG_DYN(dx2dllcr),
> + DDRPHY_REG_DYN(dx2dqtr),
> + DDRPHY_REG_DYN(dx2dqstr),
> DDRPHY_REG_DYN(dx3gsr0),
> DDRPHY_REG_DYN(dx3gsr1),
> + DDRPHY_REG_DYN(dx3dllcr),
> + DDRPHY_REG_DYN(dx3dqtr),
> + DDRPHY_REG_DYN(dx3dqstr),
> };
>
> #define DDRPHY_REG_DYN_SIZE ARRAY_SIZE(ddrphy_dyn)
> @@ -240,7 +235,6 @@ enum reg_type {
> REG_MAP,
> REGPHY_REG,
> REGPHY_TIMING,
> - REGPHY_CAL,
> #ifdef CONFIG_STM32MP1_DDR_INTERACTIVE
> /* dynamic registers => managed in driver or not changed,
> * can be dumped in interactive mode
> @@ -264,8 +258,6 @@ struct ddr_reg_info {
> enum base_type base;
> };
>
> -#define DDRPHY_REG_CAL(x) DDRPHY_REG(x, stm32mp1_ddrphy_cal)
> -
> const struct ddr_reg_info ddr_registers[REG_TYPE_NB] = {
> [REG_REG] = {
> "static", ddr_reg, DDRCTL_REG_REG_SIZE, DDR_BASE},
> @@ -279,8 +271,6 @@ const struct ddr_reg_info ddr_registers[REG_TYPE_NB] = {
> "static", ddrphy_reg, DDRPHY_REG_REG_SIZE, DDRPHY_BASE},
> [REGPHY_TIMING] = {
> "timing", ddrphy_timing, DDRPHY_REG_TIMING_SIZE, DDRPHY_BASE},
> -[REGPHY_CAL] = {
> - "cal", ddrphy_cal, DDRPHY_REG_CAL_SIZE, DDRPHY_BASE},
> #ifdef CONFIG_STM32MP1_DDR_INTERACTIVE
> [REG_DYN] = {
> "dyn", ddr_dyn, DDR_REG_DYN_SIZE, DDR_BASE},
> @@ -456,9 +446,6 @@ static u32 get_par_addr(const struct stm32mp1_ddr_config *config,
> case REGPHY_TIMING:
> par_addr = (u32)&config->p_timing;
> break;
> - case REGPHY_CAL:
> - par_addr = (u32)&config->p_cal;
> - break;
> case REG_DYN:
> case REGPHY_DYN:
> case REG_TYPE_NB:
> @@ -774,8 +761,6 @@ start:
> */
> set_reg(priv, REGPHY_REG, &config->p_reg);
> set_reg(priv, REGPHY_TIMING, &config->p_timing);
> - if (config->p_cal_present)
> - set_reg(priv, REGPHY_CAL, &config->p_cal);
>
> if (INTERACTIVE(STEP_PHY_INIT))
> goto start;
> @@ -810,36 +795,32 @@ start:
>
> wait_operating_mode(priv, DDRCTRL_STAT_OPERATING_MODE_NORMAL);
>
> - if (config->p_cal_present) {
> - log_debug("DDR DQS training skipped.\n");
> - } else {
> - log_debug("DDR DQS training : ");
> + log_debug("DDR DQS training : ");
> /* 8. Disable Auto refresh and power down by setting
> * - RFSHCTL3.dis_au_refresh = 1
> * - PWRCTL.powerdown_en = 0
> * - DFIMISC.dfiinit_complete_en = 0
> */
> - stm32mp1_refresh_disable(priv->ctl);
> + stm32mp1_refresh_disable(priv->ctl);
>
> /* 9. Program PUBL PGCR to enable refresh during training and rank to train
> * not done => keep the programed value in PGCR
> */
>
> /* 10. configure PUBL PIR register to specify which training step to run */
> - /* RVTRN is excuted only on LPDDR2/LPDDR3 */
> - if (config->c_reg.mstr & DDRCTRL_MSTR_DDR3)
> - pir = DDRPHYC_PIR_QSTRN;
> - else
> - pir = DDRPHYC_PIR_QSTRN | DDRPHYC_PIR_RVTRN;
> - stm32mp1_ddrphy_init(priv->phy, pir);
> + /* RVTRN is excuted only on LPDDR2/LPDDR3 */
> + if (config->c_reg.mstr & DDRCTRL_MSTR_DDR3)
> + pir = DDRPHYC_PIR_QSTRN;
> + else
> + pir = DDRPHYC_PIR_QSTRN | DDRPHYC_PIR_RVTRN;
> + stm32mp1_ddrphy_init(priv->phy, pir);
>
> /* 11. monitor PUB PGSR.IDONE to poll cpmpletion of training sequence */
> - ddrphy_idone_wait(priv->phy);
> + ddrphy_idone_wait(priv->phy);
>
> /* 12. set back registers in step 8 to the orginal values if desidered */
> - stm32mp1_refresh_restore(priv->ctl, config->c_reg.rfshctl3,
> - config->c_reg.pwrctl);
> - } /* if (config->p_cal_present) */
> + stm32mp1_refresh_restore(priv->ctl, config->c_reg.rfshctl3,
> + config->c_reg.pwrctl);
>
> /* enable uMCTL2 AXI port 0 and 1 */
> setbits_le32(&priv->ctl->pctrl_0, DDRCTRL_PCTRL_N_PORT_EN);
> diff --git a/drivers/ram/stm32mp1/stm32mp1_ddr.h b/drivers/ram/stm32mp1/stm32mp1_ddr.h
> index 4998f04439..3bfcb85a8f 100644
> --- a/drivers/ram/stm32mp1/stm32mp1_ddr.h
> +++ b/drivers/ram/stm32mp1/stm32mp1_ddr.h
> @@ -140,21 +140,6 @@ struct stm32mp1_ddrphy_timing {
> u32 mr3;
> };
>
> -struct stm32mp1_ddrphy_cal {
> - u32 dx0dllcr;
> - u32 dx0dqtr;
> - u32 dx0dqstr;
> - u32 dx1dllcr;
> - u32 dx1dqtr;
> - u32 dx1dqstr;
> - u32 dx2dllcr;
> - u32 dx2dqtr;
> - u32 dx2dqstr;
> - u32 dx3dllcr;
> - u32 dx3dqtr;
> - u32 dx3dqstr;
> -};
> -
> struct stm32mp1_ddr_info {
> const char *name;
> u32 speed; /* in kHZ */
> @@ -169,8 +154,6 @@ struct stm32mp1_ddr_config {
> struct stm32mp1_ddrctrl_perf c_perf;
> struct stm32mp1_ddrphy_reg p_reg;
> struct stm32mp1_ddrphy_timing p_timing;
> - struct stm32mp1_ddrphy_cal p_cal;
> - bool p_cal_present;
> };
>
> int stm32mp1_ddr_clk_enable(struct ddr_info *priv, u32 mem_speed);
> diff --git a/drivers/ram/stm32mp1/stm32mp1_interactive.c b/drivers/ram/stm32mp1/stm32mp1_interactive.c
> index 8c2310ac90..a667d49cff 100644
> --- a/drivers/ram/stm32mp1/stm32mp1_interactive.c
> +++ b/drivers/ram/stm32mp1/stm32mp1_interactive.c
> @@ -111,7 +111,7 @@ static void stm32mp1_do_usage(void)
> "help displays help\n"
> "info displays DDR information\n"
> "info <param> <val> changes DDR information\n"
> - " with <param> = step, name, size, speed or cal\n"
> + " with <param> = step, name, size or speed\n"
> "freq displays the DDR PHY frequency in kHz\n"
> "freq <freq> changes the DDR PHY frequency\n"
> "param [type|reg] prints input parameters\n"
> @@ -132,7 +132,7 @@ static void stm32mp1_do_usage(void)
> "\nwith for [type|reg]:\n"
> " all registers if absent\n"
> " <type> = ctl, phy\n"
> - " or one category (static, timing, map, perf, cal, dyn)\n"
> + " or one category (static, timing, map, perf, dyn)\n"
> " <reg> = name of the register\n"
> };
>
> @@ -165,7 +165,6 @@ static void stm32mp1_do_info(struct ddr_info *priv,
> printf("name = %s\n", config->info.name);
> printf("size = 0x%x\n", config->info.size);
> printf("speed = %d kHz\n", config->info.speed);
> - printf("cal = %d\n", config->p_cal_present);
> return;
> }
>
> @@ -214,16 +213,6 @@ static void stm32mp1_do_info(struct ddr_info *priv,
> }
> return;
> }
> - if (!strcmp(argv[1], "cal")) {
> - if (strict_strtoul(argv[2], 10, &value) < 0 ||
> - (value != 0 && value != 1)) {
> - printf("invalid value %s\n", argv[2]);
> - } else {
> - config->p_cal_present = value;
> - printf("cal = %d\n", config->p_cal_present);
> - }
> - return;
> - }
> printf("argument %s invalid\n", argv[1]);
> }
>
> diff --git a/drivers/ram/stm32mp1/stm32mp1_ram.c b/drivers/ram/stm32mp1/stm32mp1_ram.c
> index 98fa1f4f11..3b65269b98 100644
> --- a/drivers/ram/stm32mp1/stm32mp1_ram.c
> +++ b/drivers/ram/stm32mp1/stm32mp1_ram.c
> @@ -95,26 +95,22 @@ static __maybe_unused int stm32mp1_ddr_setup(struct udevice *dev)
> { .name = x, \
> .offset = offsetof(struct stm32mp1_ddr_config, y), \
> .size = sizeof(config.y) / sizeof(u32), \
> - .present = z, \
> }
>
> #define CTL_PARAM(x) PARAM("st,ctl-"#x, c_##x, NULL)
> #define PHY_PARAM(x) PARAM("st,phy-"#x, p_##x, NULL)
> -#define PHY_PARAM_OPT(x) PARAM("st,phy-"#x, p_##x, &config.p_##x##_present)
>
> const struct {
> const char *name; /* name in DT */
> const u32 offset; /* offset in config struct */
> const u32 size; /* size of parameters */
> - bool * const present; /* presence indication for opt */
> } param[] = {
> CTL_PARAM(reg),
> CTL_PARAM(timing),
> CTL_PARAM(map),
> CTL_PARAM(perf),
> PHY_PARAM(reg),
> - PHY_PARAM(timing),
> - PHY_PARAM_OPT(cal)
> + PHY_PARAM(timing)
> };
>
> config.info.speed = ofnode_read_u32_default(node, "st,mem-speed", 0);
> @@ -133,25 +129,11 @@ static __maybe_unused int stm32mp1_ddr_setup(struct udevice *dev)
> param[idx].size);
> dev_dbg(dev, "%s: %s[0x%x] = %d\n", __func__,
> param[idx].name, param[idx].size, ret);
> - if (ret &&
> - (ret != -FDT_ERR_NOTFOUND || !param[idx].present)) {
> + if (ret) {
> dev_err(dev, "Cannot read %s, error=%d\n",
> param[idx].name, ret);
> return -EINVAL;
> }
> - if (param[idx].present) {
> - /* save presence of optional parameters */
> - *param[idx].present = true;
> - if (ret == -FDT_ERR_NOTFOUND) {
> - *param[idx].present = false;
> -#ifdef CONFIG_STM32MP1_DDR_INTERACTIVE
> - /* reset values if used later */
> - memset((void *)((u32)&config +
> - param[idx].offset),
> - 0, param[idx].size * sizeof(u32));
> -#endif
> - }
> - }
> }
>
> ret = clk_get_by_name(dev, "axidcg", &axidcg);
>
Reviewed-by: Patrice Chotard <patrice.chotard at foss.st.com>
Thanks
Patrice
More information about the U-Boot
mailing list