arch/risc-v/src/mpfs: Add configuration option to enable DDR manual addcmd training
Also switch to automatic one by default, as it saves a lot of flash. The manual training code is left in for now to be able to use it as an option if there are problems with automatic one Signed-off-by: Jukka Laitinen <jukkax@ssrc.tii.ae>
This commit is contained in:
parent
26dda05cdf
commit
8766865e09
@ -157,6 +157,12 @@ config MPFS_DDR_TYPE
|
|||||||
default 3 if MPFS_DDR_TYPE_LPDDR3
|
default 3 if MPFS_DDR_TYPE_LPDDR3
|
||||||
default 4 if MPFS_DDR_TYPE_LPDDR4
|
default 4 if MPFS_DDR_TYPE_LPDDR4
|
||||||
|
|
||||||
|
config MPFS_DDR_MANUAL_ADDCMD_TRAINING
|
||||||
|
bool "Use manual addcmd training"
|
||||||
|
default n
|
||||||
|
---help---
|
||||||
|
This adds code for manual addcmd training. To use it also enable bit 1 in TIP_CFG_PARAMS to skip the automatic one
|
||||||
|
|
||||||
config MPFS_ENABLE_CACHE
|
config MPFS_ENABLE_CACHE
|
||||||
bool "Enable L2 cache"
|
bool "Enable L2 cache"
|
||||||
depends on MPFS_BOOTLOADER
|
depends on MPFS_BOOTLOADER
|
||||||
|
@ -254,6 +254,8 @@ static struct mpfs_ddr_priv_s g_mpfs_ddr_priv =
|
|||||||
.bclk_answer = 0,
|
.bclk_answer = 0,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#ifdef CONFIG_MPFS_DDR_MANUAL_ADDCMD_TRAINING
|
||||||
|
|
||||||
static const uint8_t refclk_offsets[][5] =
|
static const uint8_t refclk_offsets[][5] =
|
||||||
{
|
{
|
||||||
{LIBERO_SETTING_REFCLK_DDR3_1333_NUM_OFFSETS,
|
{LIBERO_SETTING_REFCLK_DDR3_1333_NUM_OFFSETS,
|
||||||
@ -309,6 +311,8 @@ static const uint8_t refclk_offsets[][5] =
|
|||||||
LIBERO_SETTING_REFCLK_LPDDR4_1333_OFFSET_3},
|
LIBERO_SETTING_REFCLK_LPDDR4_1333_OFFSET_3},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Private Functions
|
* Private Functions
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
@ -1560,6 +1564,8 @@ static void mpfs_init_ddrc(void)
|
|||||||
MPFS_DDR_CSR_APB_PHY_HALF_CLK_DLY_ENABLE);
|
MPFS_DDR_CSR_APB_PHY_HALF_CLK_DLY_ENABLE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef CONFIG_MPFS_DDR_MANUAL_ADDCMD_TRAINING
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: mpfs_ddr_manual_addcmd_refclk_offset
|
* Name: mpfs_ddr_manual_addcmd_refclk_offset
|
||||||
*
|
*
|
||||||
@ -1610,6 +1616,8 @@ static uint8_t mpfs_ddr_manual_addcmd_refclk_offset(
|
|||||||
return refclk_offset;
|
return refclk_offset;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: mpfs_get_num_lanes
|
* Name: mpfs_get_num_lanes
|
||||||
*
|
*
|
||||||
@ -2447,6 +2455,8 @@ static uint32_t mpfs_ddr_read_write_fn(struct mpfs_ddr_priv_s *priv,
|
|||||||
return error_cnt;
|
return error_cnt;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef CONFIG_MPFS_DDR_MANUAL_ADDCMD_TRAINING
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: mpfs_ddr_manual_addcmd_training
|
* Name: mpfs_ddr_manual_addcmd_training
|
||||||
*
|
*
|
||||||
@ -2468,6 +2478,13 @@ static void mpfs_ddr_manual_addcmd_training(struct mpfs_ddr_priv_s *priv)
|
|||||||
uint32_t j;
|
uint32_t j;
|
||||||
uint32_t i;
|
uint32_t i;
|
||||||
|
|
||||||
|
/* If automatic training is enabled, skip this */
|
||||||
|
|
||||||
|
if ((LIBERO_SETTING_TRAINING_SKIP_SETTING & ADDCMD_BIT) == 0)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
/* Apply offset & load the phase */
|
/* Apply offset & load the phase */
|
||||||
|
|
||||||
bclk_phase = ((priv->bclk_answer + SW_TRAINING_BCLK_SCLK_OFFSET) &
|
bclk_phase = ((priv->bclk_answer + SW_TRAINING_BCLK_SCLK_OFFSET) &
|
||||||
@ -2975,6 +2992,8 @@ static void mpfs_ddr_manual_addcmd_training(struct mpfs_ddr_priv_s *priv)
|
|||||||
putreg32(ca_drv, MPFS_CFG_DDR_SGMII_PHY_RPC1_DRV);
|
putreg32(ca_drv, MPFS_CFG_DDR_SGMII_PHY_RPC1_DRV);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: mpfs_ddr_sm_init
|
* Name: mpfs_ddr_sm_init
|
||||||
*
|
*
|
||||||
@ -3895,7 +3914,10 @@ static int mpfs_ddr_setup(struct mpfs_ddr_priv_s *priv)
|
|||||||
|
|
||||||
/* DDR_MANUAL_ADDCMD_TRAINING_SW */
|
/* DDR_MANUAL_ADDCMD_TRAINING_SW */
|
||||||
|
|
||||||
|
#ifdef CONFIG_MPFS_DDR_MANUAL_ADDCMD_TRAINING
|
||||||
mpfs_ddr_manual_addcmd_training(priv);
|
mpfs_ddr_manual_addcmd_training(priv);
|
||||||
|
#endif
|
||||||
|
|
||||||
mpfs_training_start(priv);
|
mpfs_training_start(priv);
|
||||||
|
|
||||||
/* DDR_TRAINING_IP_SM_START_CHECK */
|
/* DDR_TRAINING_IP_SM_START_CHECK */
|
||||||
|
Loading…
Reference in New Issue
Block a user